From 985358a07ef4c262042df2c586be39a2d178fa36 Mon Sep 17 00:00:00 2001 From: jiangping <jp@doumee.com> Date: 星期日, 29 九月 2024 09:44:45 +0800 Subject: [PATCH] 最新版本 --- server/visits/dmvisit_service/src/main/java/com/doumee/core/haikang/service/HKService.java | 370 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 369 insertions(+), 1 deletions(-) diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/core/haikang/service/HKService.java b/server/visits/dmvisit_service/src/main/java/com/doumee/core/haikang/service/HKService.java index bdbe7c6..63508a0 100644 --- a/server/visits/dmvisit_service/src/main/java/com/doumee/core/haikang/service/HKService.java +++ b/server/visits/dmvisit_service/src/main/java/com/doumee/core/haikang/service/HKService.java @@ -1,5 +1,6 @@ package com.doumee.core.haikang.service; +import cn.hutool.core.bean.BeanUtil; import com.alibaba.fastjson.JSONObject; import com.alibaba.fastjson.TypeReference; import com.doumee.core.haikang.model.HKConstants; @@ -9,13 +10,21 @@ import com.doumee.core.haikang.model.param.BaseResponse; import com.doumee.core.haikang.model.param.request.*; import com.doumee.core.haikang.model.param.respose.*; +import com.doumee.core.utils.Constants; import lombok.extern.slf4j.Slf4j; +import org.apache.commons.lang3.ObjectUtils; import org.apache.commons.lang3.StringUtils; import org.slf4j.Logger; import org.slf4j.LoggerFactory; +import org.springframework.beans.BeanUtils; +import oshi.hardware.Sensors; +import sun.management.Sensor; import java.io.InputStream; +import java.lang.reflect.Field; +import java.util.HashMap; import java.util.List; +import java.util.Map; @Slf4j public class HKService { @@ -378,7 +387,7 @@ public static BaseResponse parkReservationDeletion(ParkReservationDelRequest param){ log.info("銆愭捣搴疯溅浣嶅彇娑堥绾︺��================寮�濮�===="+JSONObject.toJSONString(param)); try { - String res = HKTools.carChargeDeletion(JSONObject.toJSONString(param)); + String res = HKTools.parkDeletion(JSONObject.toJSONString(param)); TypeReference typeReference = new TypeReference< BaseResponse>(){}; BaseResponse result = JSONObject.parseObject(res, typeReference.getType()); @@ -400,6 +409,24 @@ TypeReference typeReference = new TypeReference< BaseResponse<VisitAppointmentResponse>>(){}; BaseResponse<VisitAppointmentResponse> result = JSONObject.parseObject(res, typeReference.getType()); + logResult(result,"娴峰悍璁垮棰勭害"); + return result; + }catch (Exception e){ + log.error("銆愭捣搴疯瀹㈤绾︺��================澶辫触====锛歕n"+ e.getMessage()); + } + return null; + } + /** + *璁垮棰勭害 + * @return + */ + public static BaseResponse<IccmAppointmentResponse> iccmAppointment(IccmAppointmentRequest param){ + log.info("銆愭捣搴疯瀹㈤绾︺��================寮�濮�===="+JSONObject.toJSONString(param)); + try { + String res = HKTools.iccmAppointment(JSONObject.toJSONString(param)); + TypeReference typeReference = + new TypeReference< BaseResponse<IccmAppointmentResponse>>(){}; + BaseResponse<IccmAppointmentResponse> result = JSONObject.parseObject(res, typeReference.getType()); logResult(result,"娴峰悍璁垮棰勭害"); return result; }catch (Exception e){ @@ -458,6 +485,24 @@ return result; }catch (Exception e){ log.error("銆愭捣搴疯瀹㈠厤鐧昏棰勭害銆�================澶辫触====锛歕n"+ e.getMessage()); + } + return null; + } + /** + *璁垮鍏嶇櫥璁伴绾� + * @return + */ + public static BaseResponse<IccmAppointmentMDJResponse> iccmAppiontmentMDJ(IccmAppointmentMDJRequest param){ + log.info("銆愭捣搴疯瀹㈠厤鐧昏棰勭害銆�================iccm寮�濮�===="+JSONObject.toJSONString(param)); + try { + String res = HKTools.iccmAppointmentMDJ(JSONObject.toJSONString(param)); + TypeReference typeReference = + new TypeReference< BaseResponse<IccmAppointmentMDJResponse> >(){}; + BaseResponse<IccmAppointmentMDJResponse> result = JSONObject.parseObject(res, typeReference.getType()); + logResult(result,"娴峰悍璁垮鍏嶇櫥璁伴绾�"); + return result; + }catch (Exception e){ + log.error("銆愭捣搴疯瀹㈠厤鐧昏棰勭害銆�================iccm澶辫触====锛歕n"+ e.getMessage()); } return null; } @@ -820,6 +865,170 @@ return null; } /** + *鏌ヨ璁垮棰勭害璁板綍锛堝垎椤碉級 + * @return + */ + public static BaseResponse<BaseListPageResponse<IccmAppointmentListResponse>> iccmAppointmentRecords(IccmAppointmentListRequest param){ + log.info("銆愭捣搴疯瀹㈤绾﹁褰曟煡璇€��================寮�濮�===="+JSONObject.toJSONString(param)); + try { + String res = HKTools.iccmAppointmentRecords(JSONObject.toJSONString(param)); + TypeReference typeReference = + new TypeReference<BaseResponse<BaseListPageResponse<IccmAppointmentListResponse>>>(){}; + BaseResponse<BaseListPageResponse<IccmAppointmentListResponse>> result = JSONObject.parseObject(res, typeReference.getType()); + logResult(result,"娴峰悍璁垮棰勭害璁板綍鏌ヨ"); + return result; + }catch (Exception e){ + log.error("銆愭捣搴疯瀹㈤绾﹁褰曟煡璇€��================澶辫触====锛歕n"+ e.getMessage()); + } + return null; + } + /** + *1.9.1鏍规嵁寰俊鍏紬鍙蜂俊鎭幏鍙朅ccessToken锛堝垎椤碉級 + * @return + */ + public static BaseResponse<String> wxAccessToken(String configId,String tagId){ + log.info("銆愭捣搴锋牴鎹井淇″叕浼楀彿淇℃伅鑾峰彇AccessToken銆�================寮�濮�====configId:"+configId+" && tagId:"+tagId); + try { + String res = HKTools.wxAccessToken(configId,tagId); + TypeReference typeReference = + new TypeReference<BaseResponse<String>>(){}; + BaseResponse<String> result = JSONObject.parseObject(res, typeReference.getType()); + logResult(result,"娴峰悍鏍规嵁寰俊鍏紬鍙蜂俊鎭幏鍙朅ccessToken"); + return result; + }catch (Exception e){ + log.error("銆愭捣搴锋牴鎹井淇″叕浼楀彿淇℃伅鑾峰彇AccessToken銆�================澶辫触====锛歕n"+ e.getMessage()); + } + return null; + } + /** + *鏍规嵁閰嶇疆寰俊鍏紬鍙风紪鍙锋煡璇㈠井淇″叕浼楀彿淇℃伅 + * @return + */ + public static BaseResponse<BaseListPageResponse<WxConfigInfoResponse>> getWxConfig(WxConfigInfoRequest param){ + log.info("銆愭捣搴锋牴鎹厤缃井淇″叕浼楀彿缂栧彿鏌ヨ寰俊鍏紬鍙蜂俊鎭��================寮�濮�===="+JSONObject.toJSONString(param)); + try { + String res = HKTools.getWxConfig(toMap(param)); + TypeReference typeReference = + new TypeReference<BaseResponse<BaseListPageResponse<WxConfigInfoResponse>>>(){}; + BaseResponse<BaseListPageResponse<WxConfigInfoResponse>> result = JSONObject.parseObject(res, typeReference.getType()); + logResult(result,"娴峰悍鏍规嵁閰嶇疆寰俊鍏紬鍙风紪鍙锋煡璇㈠井淇″叕浼楀彿淇℃伅"); + return result; + }catch (Exception e){ + log.error("銆愭捣搴锋牴鎹厤缃井淇″叕浼楀彿缂栧彿鏌ヨ寰俊鍏紬鍙蜂俊鎭��================澶辫触====锛歕n"+ e.getMessage()); + } + return null; + } + + /** + *鍒嗛〉鏌ヨ娑堥槻璁惧閮ㄤ欢鐘舵�� + * @return + */ + public static BaseResponse<BaseListPageResponse<FireDeviceStatusListResponse>> fireDeviceStatusSearch(FireDeviceStatuslListRequest param){ + log.info("銆愭捣搴锋煡璇㈡秷闃茶澶囬儴浠剁姸鎬併��================寮�濮�===="+JSONObject.toJSONString(param)); + try { + String res = HKTools.fireDeviceStatusSearch(JSONObject.toJSONString(param)); + TypeReference typeReference = + new TypeReference<BaseResponse<BaseListPageResponse<FireDeviceStatusListResponse>>>(){}; + BaseResponse<BaseListPageResponse<FireDeviceStatusListResponse>> result = JSONObject.parseObject(res, typeReference.getType()); + logResult(result,"娴峰悍鍒嗛〉鏌ヨ娑堥槻浼犳劅鍣ㄩ儴浠剁姸鎬�"); + return result; + }catch (Exception e){ + log.error("銆愭捣搴锋煡璇㈡秷闃茶澶囬儴浠剁姸鎬併��================澶辫触====锛歕n"+ e.getMessage()); + } + return null; + } + /** + *鍒嗛〉鏌ヨ娑堥槻浼犳劅鍣ㄩ儴浠剁姸鎬� + * @return + */ + public static BaseResponse<BaseListPageResponse<SensorStatusListResponse>> sensorStatusSearch(SensorStatusListRequest param){ + log.info("銆愭捣搴峰垎椤垫煡璇㈡秷闃蹭紶鎰熷櫒閮ㄤ欢鐘舵�併��================寮�濮�===="+JSONObject.toJSONString(param)); + try { + String res = HKTools.sensorStatusSearch(JSONObject.toJSONString(param)); + TypeReference typeReference = + new TypeReference<BaseResponse<BaseListPageResponse<SensorStatusListResponse>>>(){}; + BaseResponse<BaseListPageResponse<SensorStatusListResponse>> result = JSONObject.parseObject(res, typeReference.getType()); + logResult(result,"娴峰悍鍒嗛〉鏌ヨ娑堥槻浼犳劅鍣ㄩ儴浠剁姸鎬�"); + return result; + }catch (Exception e){ + log.error("銆愭捣搴峰垎椤垫煡璇㈡秷闃蹭紶鎰熷櫒閮ㄤ欢鐘舵�併��================澶辫触====锛歕n"+ e.getMessage()); + } + return null; + } + + /** + *鏌ヨ娑堥槻浼犳劅鍣ㄥ垪琛� + * @return + */ + public static BaseResponse<BaseListPageResponse<FireChannelListResponse>> fireChannelSearch(FireChannelListRequest param){ + log.info("銆愭捣搴锋煡璇㈡秷闃蹭紶鎰熷櫒鍒楄〃銆�================寮�濮�===="+JSONObject.toJSONString(param)); + try { + String res = HKTools.fireChannelSearch(JSONObject.toJSONString(param)); + TypeReference typeReference = + new TypeReference<BaseResponse<BaseListPageResponse<FireChannelListResponse>>>(){}; + BaseResponse<BaseListPageResponse<FireChannelListResponse>> result = JSONObject.parseObject(res, typeReference.getType()); + logResult(result,"娴峰悍鏌ヨ娑堥槻浼犳劅鍣ㄥ垪琛�"); + return result; + }catch (Exception e){ + log.error("銆愭捣搴锋煡璇㈡秷闃蹭紶鎰熷櫒鍒楄〃銆�================澶辫触====锛歕n"+ e.getMessage()); + } + return null; + } + /** + *鍒嗛〉鏌ヨ璁惧涓嬬殑鎵�鏈夋姤璀﹁褰� + * @return + */ + public static BaseResponse<BaseListPageResponse<FindDeviceAlarmListResponse>> findDeviceAlarmPage(FindDeviceAlarmListRequest param){ + log.info("銆愭捣搴峰垎椤垫煡璇㈣澶囦笅鐨勬墍鏈夋姤璀﹁褰曘��================寮�濮�===="+JSONObject.toJSONString(param)); + try { + String res = HKTools.findDeviceAlarmPage(JSONObject.toJSONString(param)); + TypeReference typeReference = + new TypeReference<BaseResponse<BaseListPageResponse<FindDeviceAlarmListResponse>>>(){}; + BaseResponse<BaseListPageResponse<FindDeviceAlarmListResponse>> result = JSONObject.parseObject(res, typeReference.getType()); + logResult(result,"娴峰悍鍒嗛〉鏌ヨ璁惧涓嬬殑鎵�鏈夋姤璀﹁褰�"); + return result; + }catch (Exception e){ + log.error("銆愭捣搴峰垎椤垫煡璇㈣澶囦笅鐨勬墍鏈夋姤璀﹁褰曘��================澶辫触====锛歕n"+ e.getMessage()); + } + return null; + } + /** + *璇㈡秷闃茶澶囧垪琛� + * @return + */ + public static BaseResponse<BaseListPageResponse<FireDeviceListResponse>> fireDeviceSearch(FireDeviceListRequest param){ + log.info("銆愭捣搴疯娑堥槻璁惧鍒楄〃銆�================寮�濮�===="+JSONObject.toJSONString(param)); + try { + String res = HKTools.fireDeviceSearch(JSONObject.toJSONString(param)); + TypeReference typeReference = + new TypeReference<BaseResponse<BaseListPageResponse<FireDeviceListResponse>>>(){}; + BaseResponse<BaseListPageResponse<FireDeviceListResponse>> result = JSONObject.parseObject(res, typeReference.getType()); + logResult(result,"娴峰悍璇㈡秷闃茶澶囧垪琛�"); + return result; + }catch (Exception e){ + log.error("銆愭捣搴疯娑堥槻璁惧鍒楄〃銆�================澶辫触====锛歕n"+ e.getMessage()); + } + return null; + } + /** + *鍒嗛〉鑾峰彇鍛婅浜嬩欢 + * @return + */ + public static BaseResponse<BaseListPageResponse<NhEventPageListResponse>> nhEventPageList(NhEventPageListRequest param){ + log.info("銆愭捣搴峰垎椤佃幏鍙栧憡璀︿簨浠躲��================寮�濮�===="+JSONObject.toJSONString(param)); + try { + String res = HKTools.nhEventPageList(toMap(param)); + TypeReference typeReference = + new TypeReference<BaseResponse<BaseListPageResponse<NhEventPageListResponse>>>(){}; + BaseResponse<BaseListPageResponse<NhEventPageListResponse>> result = JSONObject.parseObject(res, typeReference.getType()); + logResult(result,"娴峰悍鍒嗛〉鑾峰彇鍛婅浜嬩欢"); + return result; + }catch (Exception e){ + log.error("銆愭捣搴峰垎椤佃幏鍙栧憡璀︿簨浠躲��================澶辫触====锛歕n"+ e.getMessage()); + } + return null; + } + /** *鏌ヨ璁垮鏉ヨ璁板綍锛堝凡鐧昏锛夛紙鍒嗛〉锛� * @return */ @@ -852,6 +1061,28 @@ return result; }catch (Exception e){ log.error("銆愭捣搴峰叏閲忕粍缁囨煡璇€��================澶辫触====锛歕n"+ e.getMessage()); + } + return null; + } + /** + *鑾峰彇宸ヤ綔鍙拌彍鍗曞厤瀵嗙櫥闄嗚皟鏁村湴鍧� + * @return + */ + public static String getMenuUrl(Integer type,String token){ + String menuId = HKConstants.MenuPageId.zhaf; + if(Constants.equalsInteger(type,Constants.ONE)){ + menuId = HKConstants.MenuPageId.wyhq; + }else if(Constants.equalsInteger(type,Constants.TWO)){ + menuId = HKConstants.MenuPageId.xzbg; + }else if(Constants.equalsInteger(type,Constants.THREE)){ + menuId = HKConstants.MenuPageId.yyzx; + } + log.info("銆愭捣搴疯幏鍙栧伐浣滃彴鑿滃崟鍏嶅瘑鐧婚檰璋冩暣鍦板潃銆�================寮�濮�====menuId:"+menuId+"==token:"+token); + try { + String res = HKTools.getMenuUrl(menuId,token); + return res; + }catch (Exception e){ + log.error("銆愭捣搴疯幏鍙栧伐浣滃彴鑿滃崟鍏嶅瘑鐧婚檰璋冩暣鍦板潃銆�================澶辫触====锛歕n"+ e.getMessage()); } return null; } @@ -1018,6 +1249,143 @@ return null; } /** + *鍒嗛〉鑾峰彇骞挎挱鐐癸紙鍒嗛〉锛� + * @return + */ + public static BaseResponse<BaseListPageResponse<FetchAudioChannelInfoResponse>> fetchAudioChannel(FetchAudioChannelRequest param){ + log.info("銆愭捣搴疯幏鍙栧垎椤佃幏鍙栧箍鎾偣銆�================寮�濮�===="+JSONObject.toJSONString(param)); + try { + String res = HKTools.fetchAudioChannel(JSONObject.toJSONString(param)); + TypeReference typeReference = + new TypeReference< BaseResponse<BaseListPageResponse<FetchAudioChannelInfoResponse>> >(){}; + BaseResponse<BaseListPageResponse<FetchAudioChannelInfoResponse>> result = JSONObject.parseObject(res, typeReference.getType()); + logResult(result,"娴峰悍鑾峰彇鍒嗛〉鑾峰彇骞挎挱鐐�"); + return result; + }catch (Exception e){ + log.error("銆愭捣搴疯幏鍙栧垎椤佃幏鍙栧箍鎾偣銆�================澶辫触====锛歕n"+ e.getMessage()); + } + return null; + } + /** + *鍒嗛〉鑾峰彇骞挎挱鐐癸紙鍒嗛〉锛� + * @return + */ + public static BaseResponse<BaseListPageResponse<FetchAudioChannelInfoResponse>> fetchAudioDevice(FetchAudioChannelRequest param){ + log.info("銆愭捣搴疯幏鍙栧垎椤佃幏鍙栧箍鎾偣銆�================寮�濮�===="+JSONObject.toJSONString(param)); + try { + String res = HKTools.fetchAudioDevice(JSONObject.toJSONString(param)); + TypeReference typeReference = + new TypeReference< BaseResponse<BaseListPageResponse<FetchAudioChannelInfoResponse>> >(){}; + BaseResponse<BaseListPageResponse<FetchAudioChannelInfoResponse>> result = JSONObject.parseObject(res, typeReference.getType()); + logResult(result,"娴峰悍鑾峰彇鍒嗛〉鑾峰彇骞挎挱鐐�"); + return result; + }catch (Exception e){ + log.error("銆愭捣搴疯幏鍙栧垎椤佃幏鍙栧箍鎾偣銆�================澶辫触====锛歕n"+ e.getMessage()); + } + return null; + } + /** + *鑾峰彇鍏ㄩ儴鏈堝彴淇℃伅 + * @return + */ + public static BaseResponse<BaseListPageResponse<PlatformListInfoResponse>> platformsList(PlatformsListRequest param){ + log.info("銆愭捣搴疯幏鍙栧叏閮ㄦ湀鍙颁俊鎭��================寮�濮�===="+JSONObject.toJSONString(param)); + try { + String res = HKTools.platformsList(JSONObject.toJSONString(param)); + TypeReference typeReference = + new TypeReference< BaseResponse<BaseListPageResponse<PlatformListInfoResponse>> >(){}; + BaseResponse<BaseListPageResponse<PlatformListInfoResponse>> result = JSONObject.parseObject(res, typeReference.getType()); + logResult(result,"娴峰悍鑾峰彇鍏ㄩ儴鏈堝彴淇℃伅"); + return result; + }catch (Exception e){ + log.error("銆愭捣搴疯幏鍙栧叏閮ㄦ湀鍙颁俊鎭��================澶辫触====锛歕n"+ e.getMessage()); + } + return null; + } + /** + *鑾峰彇鏈堝彴缁勪欢閰嶇疆鐨凩ED璁惧娓呭崟 + * @return + */ + public static BaseResponse<BaseListPageResponse<LedRecordsInfoResponse>> ledRecords(LedRecordsRequest param){ + log.info("銆愭捣搴疯幏鍙栨湀鍙扮粍浠堕厤缃殑LED璁惧娓呭崟銆�================寮�濮�===="+JSONObject.toJSONString(param)); + try { + String res = HKTools.ledRecords(JSONObject.toJSONString(param)); + TypeReference typeReference = + new TypeReference< BaseResponse<BaseListPageResponse<LedRecordsInfoResponse>> >(){}; + BaseResponse<BaseListPageResponse<LedRecordsInfoResponse>> result = JSONObject.parseObject(res, typeReference.getType()); + logResult(result,"娴峰悍鑾峰彇鏈堝彴缁勪欢閰嶇疆鐨凩ED璁惧娓呭崟"); + return result; + }catch (Exception e){ + log.error("銆愭捣搴疯幏鍙栨湀鍙扮粍浠堕厤缃殑LED璁惧娓呭崟銆�================澶辫触====锛歕n"+ e.getMessage()); + } + return null; + } + /** + *鐢ㄤ簬璁剧疆骞挎挱鐨勮嚜瀹氭挱鏀惧拰鍋滄 + * @return + */ + public static BaseResponse customBroadcast(CustomBroadcastRequest param){ + log.info("銆愭捣搴风敤浜庤缃箍鎾殑鑷畾鎾斁鍜屽仠姝€��================寮�濮�===="+JSONObject.toJSONString(param)); + try { + String res = HKTools.customBroadcast(JSONObject.toJSONString(param)); + TypeReference typeReference = + new TypeReference< BaseResponse>(){}; + BaseResponse result = JSONObject.parseObject(res, typeReference.getType()); + logResult(result,"娴峰悍鐢ㄤ簬璁剧疆骞挎挱鐨勮嚜瀹氭挱鏀惧拰鍋滄"); + return result; + }catch (Exception e){ + log.error("銆愭捣搴风敤浜庤缃箍鎾殑鑷畾鎾斁鍜屽仠姝€��================澶辫触====锛歕n"+ e.getMessage()); + } + return null; + } + /** + *鑾峰彇鍏ㄩ儴鏈堝彴淇℃伅 + * @return + */ + public static BaseResponse<BaseListPageResponse<PlatformStatusInfoResponse>> platformStatus(PlatformStatusRequest param) { + log.info("銆愭捣搴疯幏鍙栧叏閮ㄦ湀鍙颁俊鎭��================寮�濮�====" + JSONObject.toJSONString(param)); + try { + String res = HKTools.platformStatus(param.getPlatformIds()); + TypeReference typeReference = + new TypeReference<BaseResponse<BaseListPageResponse<PlatformStatusInfoResponse>>>() { + }; + BaseResponse<BaseListPageResponse<PlatformStatusInfoResponse>> result = JSONObject.parseObject(res, typeReference.getType()); + logResult(result, "娴峰悍鑾峰彇鍏ㄩ儴鏈堝彴淇℃伅"); + return result; + } catch (Exception e) { + log.error("銆愭捣搴疯幏鍙栧叏閮ㄦ湀鍙颁俊鎭��================澶辫触====锛歕n" + e.getMessage()); + } + return null; + } + /** + *鍙戦�佹秷鎭粰LED + * @return + */ + public static BaseResponse transparentchannel(TransparentChannelHeadRequest head,TransparentChannelBodyRequest param){ + log.info("銆愭捣搴峰彂閫佹秷鎭粰LED銆�================寮�濮�===="+JSONObject.toJSONString(param)); + try { + Map<String,String> header = toMap(head); + String res = HKTools.transparentchannel(header,JSONObject.toJSONString(param)); + TypeReference typeReference = + new TypeReference<BaseResponse>(){}; + BaseResponse result = JSONObject.parseObject(res, typeReference.getType()); + logResult(result,"娴峰悍鍙戦�佹秷鎭粰LED"); + return result; + }catch (Exception e){ + log.error("銆愭捣搴峰彂閫佹秷鎭粰LED銆�================澶辫触====锛歕n"+ e.getMessage()); + } + return null; + } + public static Map<String, String> toMap(Object obj) throws IllegalAccessException { + Map<String, String> map = new HashMap<>(); + Class<?> clazz = obj.getClass(); + for (Field field : clazz.getDeclaredFields()) { + field.setAccessible(true); // 浣垮緱绉佹湁瀛楁涔熷彲浠ヨ闂� + map.put(field.getName(), (String) field.get(obj)); + } + return map; + } + /** *鏌ヨ鍦哄唴杞﹀仠杞︿俊鎭紙鍒嗛〉锛� * @return */ -- Gitblit v1.9.3