From 3555e2dd2926ac2cd4b168b273699221d9eeb31f Mon Sep 17 00:00:00 2001
From: jiangping <jp@doumee.com>
Date: 星期五, 07 三月 2025 17:32:11 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 server/visits/dmvisit_service/src/main/java/com/doumee/core/haikang/model/HKTools.java |  426 +++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 397 insertions(+), 29 deletions(-)

diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/core/haikang/model/HKTools.java b/server/visits/dmvisit_service/src/main/java/com/doumee/core/haikang/model/HKTools.java
index b230c6a..faaa2e5 100644
--- a/server/visits/dmvisit_service/src/main/java/com/doumee/core/haikang/model/HKTools.java
+++ b/server/visits/dmvisit_service/src/main/java/com/doumee/core/haikang/model/HKTools.java
@@ -1,10 +1,9 @@
 package com.doumee.core.haikang.model;
 
 import com.alibaba.fastjson.JSONObject;
-import com.doumee.config.SpringContextUtil;
 import com.doumee.core.haikang.model.param.request.CarPictureRequest;
+import com.doumee.core.haikang.model.param.request.FacePictureCheckRequest;
 import com.doumee.core.haikang.service.HKService;
-import com.doumee.core.utils.Constants;
 import com.doumee.dao.business.model.InterfaceLog;
 import com.doumee.service.business.InterfaceLogService;
 import com.hikvision.artemis.sdk.ArtemisHttpUtil;
@@ -13,18 +12,14 @@
 import org.apache.commons.lang3.StringUtils;
 import org.apache.http.HttpEntity;
 import org.apache.http.HttpResponse;
-import org.apache.tomcat.util.bcel.Const;
-import org.yaml.snakeyaml.scanner.Constant;
 
-import java.io.*;
-import java.net.HttpURLConnection;
-import java.net.InetSocketAddress;
-import java.net.Proxy;
-import java.net.URL;
-import java.text.DateFormat;
-import java.text.ParseException;
-import java.text.SimpleDateFormat;
-import java.util.*;
+import java.io.File;
+import java.io.FileOutputStream;
+import java.io.InputStream;
+import java.util.Date;
+import java.util.HashMap;
+import java.util.Map;
+import java.util.UUID;
 
 
 @Slf4j
@@ -34,11 +29,12 @@
 
 
 	public static void main(String[] args) throws Exception {
-		ArtemisConfig.host = "10.50.60.253";
-		ArtemisConfig.appKey = "27786546";
-		ArtemisConfig.appSecret = "kC5dohxU7CvEqgGhVt4R";
+		ArtemisConfig.host = "10.50.250.253:1443";
+
+		ArtemisConfig.appKey = "23154099";
+		ArtemisConfig.appSecret = "88wFsg3xfn7o8QMsWEO2";
 		HKConstants.https = "https://";
-		CarPictureRequest param = new CarPictureRequest();
+	/*	CarPictureRequest param = new CarPictureRequest();
 		param.setPicUri( "HKIMG=/pic?0dd400=4c40ip-feo831-933*9o4=3=2109*2l0001893117*0t7=6*2ps==014b*=787d*069d70361-95754d-9*l108od0b192=001");
 		param.setAswSyscode("3fa3e5e3-db3e-41ba-97fc-39c948778dfe");
 		InputStream is = HKService.getCarPicture(param);
@@ -57,7 +53,11 @@
 			outStream.close(); //鍐欏叆鏁版嵁
 		} catch ( Exception e) {
 			throw new RuntimeException(e);
-		}
+		}*/
+
+		FacePictureCheckRequest param = new FacePictureCheckRequest();
+		param.setFacePicUrl("http://10.50.250.253:8088/file/member/20241016/d0cded86-a55d-43be-bc01-4f628a1400cf.jpg");
+		System.out.println(facePictureCheck(JSONObject.toJSONString(param)));
 
 	}
 	public static InterfaceLogService interfaceLogService = null;
@@ -79,9 +79,9 @@
 	private static Map<String, String> getPath(String str) {
 		final String getCamsApi = HKConstants.ARTEMIS_PATH  + str;
 		Map<String, String> path = new HashMap<String, String>(2) {
-			{
-				put(HKConstants.https, getCamsApi);// 鏍规嵁鐜板満鐜閮ㄧ讲纭鏄痟ttp杩樻槸https
-			}
+		{
+			put(HKConstants.https, getCamsApi);// 鏍规嵁鐜板満鐜閮ㄧ讲纭鏄痟ttp杩樻槸https
+		}
 		};
 		return  path;
 	}
@@ -246,6 +246,7 @@
 			InputStream in = entity.getContent();
 			return  in;
 		}else{
+			log.error("浜鸿劯涓嬭浇鍑洪敊");
 			throw  new Exception("浜鸿劯涓嬭浇鍑洪敊");
 		}
 	}
@@ -303,6 +304,42 @@
 			throw  new Exception("鏌ヨ杞﹁締鎶撴媿鍥剧墖涓嬭浇鍑洪敊");
 		}
 	}
+	/**
+	 * 鍒嗛〉鑾峰彇寰呭姙鍒楄〃
+	 * @param body
+	 * @return
+	 */
+	public static String getTodoListPage(Map<String, String> body)  throws  Exception{
+		return startDoGetStringArtemis(HKConstants.InterfacePath.getTodoListPage,body);
+	}
+
+	/**
+	 *娑堥槻鐪嬫澘-4娓╂箍搴︽暟鎹�
+	 * @param body
+	 * @return
+	 */
+	public static String temperatureHumidityDataStatistic(String body) {
+		return startDoPostStringArtemisAdmin(HKConstants.InterfacePath.temperatureHumidityDataStatistic,body);
+	}
+
+	/**
+	 *娑堥槻鐪嬫澘-4鑾峰彇鍖哄煙鐢ㄩ噺鎺掑悕-鑳借�楃湅鏉�
+	 * @param body
+	 * @return
+	 */
+	public static String regionDataRanking(String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.regionDataRanking,body);
+	}
+
+	/**
+	 *娑堥槻鐪嬫澘-4鏍规嵁鏃堕棿鍜屾椂闂寸淮搴﹁幏鍙栧洯鍖鸿兘鑰楁暟鎹�
+	 * @param body
+	 * @return
+	 */
+	public static String energyTotal(String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.energyTotal,body);
+	}
+
 	/**
 	 *	鑾峰彇闂ㄧ鐐瑰垪琛�
 	 * @param body
@@ -369,6 +406,7 @@
 		return  startDoPostStringArtemis(HKConstants.InterfacePath.visitCancel,body);
 	}
 
+
 	public static String startDoPostStringArtemis(String[] pathStr,String body ){
 		Map<String, String> path = getPath(pathStr[0]);
 		Map<String, String> header = new HashMap<>();
@@ -376,7 +414,38 @@
 		String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", header);// post璇锋眰application/json绫诲瀷鍙傛暟
 		saveInterfaceLog(body,result,path,pathStr[1]);
 		return result;
+	}
 
+
+	public static String startDoPostStringArtemisAdmin(String[] pathStr,String body){
+		Map<String, String> path = getPath(pathStr[0]);
+		Map<String, String> header = new HashMap<>();
+		header.put("userId", "admin");
+		String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", header);// post璇锋眰application/json绫诲瀷鍙傛暟
+		saveInterfaceLog(body,result,path,pathStr[1]);
+		return result;
+	}
+
+	public static String startDoGetStringArtemis(String[] pathStr,Map<String,String> body ){
+		Map<String, String> path = getPath(pathStr[0]);
+		Map<String, String> header = new HashMap<>();
+		header.put("tagId", UUID.randomUUID().toString().replace("-", ""));
+		String result = ArtemisHttpUtil.doGetArtemis(path, body, null, null,  header);
+		saveInterfaceLog(JSONObject.toJSONString(body),result,path,pathStr[1]);
+		return result;
+	}
+	public static String startDoGetStringArtemis(String[] pathStr,Map<String,String> querys ,Map<String, String> header ){
+		Map<String, String> path = getPath(pathStr[0]);
+		String result = ArtemisHttpUtil.doGetArtemis(path, querys, null, null,  header);
+		saveInterfaceLog(JSONObject.toJSONString(querys),result,path,pathStr[1]);
+		return result;
+	}
+	public static String startDoGetStringArtemisJson(String[] pathStr,Map<String,String> body ){
+		Map<String, String> path = getPath(pathStr[0]);
+		Map<String, String> header = new HashMap<>();
+		String result = ArtemisHttpUtil.doGetArtemis(path, body, null, "application/json",  header);
+		saveInterfaceLog(JSONObject.toJSONString(body),result,path,pathStr[1]);
+		return result;
 	}
 	public static String startDoPostStringArtemis(String[] pathStr,String param,String body ){
 		Map<String, String> path = getPath(pathStr[0]+StringUtils.defaultString(param,""));
@@ -385,15 +454,15 @@
 		String result = ArtemisHttpUtil.doPostStringArtemis(path, body, null, null, "application/json", header);// post璇锋眰application/json绫诲瀷鍙傛暟
 		saveInterfaceLog(body,result,path,pathStr[1]);
 		return result;
-
 	}
+
+
 	public static String startDoPostStringArtemis(String[] pathStr,Map<String, String> querys,Map<String, String> header,String body){
 		Map<String, String> path = getPath(pathStr[0]);
 		header.put("tagId", UUID.randomUUID().toString().replace("-", ""));
 		String result = ArtemisHttpUtil.doPostStringArtemis(path, body, querys, null, "application/json", header);// post璇锋眰application/json绫诲瀷鍙傛暟
 		saveInterfaceLog(body,result,path,pathStr[1]);
 		return result;
-
 	}
 	/**
 	 *	绛剧璁垮棰勭害
@@ -402,6 +471,22 @@
 	 */
 	public static String visitOut(String body) {
 		return startDoPostStringArtemis(HKConstants.InterfacePath.visitOut,body);
+	}
+	/**
+	 *	iccm绛剧璁垮棰勭害
+	 * @param body
+	 * @return
+	 */
+	public static String iccmSignoff(String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.iccmSignoff,body);
+	}
+	/**
+	 *	iccm鍙栨秷璁垮棰勭害
+	 * @param body
+	 * @return
+	 */
+	public static String iccmCancelAppointment(String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.iccmCancelAppointment,body);
 	}
 	/**
 	 *	璁垮鏉冮檺缁�
@@ -557,10 +642,71 @@
 	 *	鏍规嵁寰俊鍏紬鍙蜂俊鎭幏鍙朅ccessToken
 	 * @return
 	 */
-	public static String wxAccessToken(String configId,String tagId) {
-		String[] wxAccessToken= HKConstants.InterfacePath.wxAccessToken;
-		wxAccessToken[0] = HKConstants.InterfacePath.wxAccessToken+"?tagId="+tagId+"&configId"+configId;
-		return startDoPostStringArtemis(wxAccessToken,"");
+	public static String wxAccessToken(HashMap<String,String> params ) {
+//		String[] wxAccessToken= new String[2];
+//		String url = HKConstants.InterfacePath.wxAccessToken[0]+"?tagId="+tagId+"&configId="+configId;
+//		String t = HKConstants.InterfacePath.wxAccessToken[1];
+//		wxAccessToken[0] = url;
+//		wxAccessToken[1] = t;
+		return startDoGetStringArtemisJson(HKConstants.InterfacePath.wxAccessToken,params);
+	}
+	/**
+	 *	鏍规嵁閰嶇疆寰俊鍏紬鍙风紪鍙锋煡璇㈠井淇″叕浼楀彿淇℃伅
+	 * @param body
+	 * @return
+	 */
+	public static String getWxConfig(Map<String,String>  body) {
+		return startDoGetStringArtemis(HKConstants.InterfacePath.getWxConfig,body);
+	}
+	/**
+	 *	鏍规嵁閰嶇疆寰俊鍏紬鍙风紪鍙锋煡璇㈠井淇″叕浼楀彿淇℃伅
+	 * @param body
+	 * @return
+	 */
+	public static String nhEventPageList(Map<String,String> body) {
+		return startDoGetStringArtemis(HKConstants.InterfacePath.nhEventPageList,body);
+	}
+
+	/**
+	 *	鏌ヨ娑堥槻璁惧閮ㄤ欢鐘舵��
+	 * @param body
+	 * @return
+	 */
+	public static String fireDeviceStatusSearch(String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.fireDeviceStatusSearch,body);
+	}
+	/**
+	 * 鍒嗛〉鏌ヨ娑堥槻浼犳劅鍣ㄩ儴浠剁姸鎬�
+	 * @param body
+	 * @return
+	 */
+	public static String sensorStatusSearch(String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.sensorStatusSearch,body);
+	}
+	/**
+	 * 鍒嗛〉鏌ヨ璁惧涓嬬殑鎵�鏈夋姤璀﹁褰�
+	 * @param body
+	 * @return
+	 */
+	public static String findDeviceAlarmPage(String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.findDeviceAlarmPage,body);
+	}
+	/**
+	 *	璇㈡秷闃茶澶囧垪琛�
+	 * @param body
+	 * @return
+	 */
+	public static String fireChannelSearch(String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.fireChannelSearch,body);
+	}
+
+	/**
+	 *	璇㈡秷闃茶澶囧垪琛�
+	 * @param body
+	 * @return
+	 */
+	public static String fireDeviceSearch(String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.fireDeviceSearch,body);
 	}
 	/**
 	 *	鑾峰彇鍏ㄩ噺鐢ㄦ埛鍒楄〃
@@ -668,6 +814,184 @@
 		return startDoPostStringArtemis(HKConstants.InterfacePath.platformsList,body);
 	}
 	/**
+	 * 鑾峰彇娑堥槻浼犳劅鍣ㄥ垪琛�
+	 * @param body
+	 * @return
+	 */
+	public static String pageFireChannel(String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.pageFireChannel,body);
+	}
+	/**
+	 * 鏌ヨ娑堥槻浼犳劅鍣ㄩ儴浠剁姸鎬乿2
+	 * @param body
+	 * @return
+	 */
+	public static String pageSensorStatus(String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.pageSensorStatus,body);
+	}
+	/**
+	 * 瀹夐槻鐪嬫澘-浠婃棩鍛婅浜嬩欢-鏍规嵁eventType瀛楁3
+	 * @param body
+	 * @return
+	 */
+	public static String ruleEventSearch(String body) {
+		Map<String,String> header = new HashMap<>();
+		header.put("User-Id","admin");
+		return startDoPostStringArtemis(HKConstants.InterfacePath.ruleEventSearch,null,header,body);
+	}
+	/**
+	 * 瀹夐槻鐪嬫澘-鍥尯瀹夐槻璁惧-鍚勭被鍨嬭澶囩姸鎬佹暟鎹垪琛�
+	 * @param body
+	 * @return
+	 */
+	public static String getSecureDevStatusList(String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.getSecureDevStatusList,body);
+	}
+	/**
+	 * 鑳借�楃湅鏉�-6鎸夋湀鏌ヨ杩�12涓湀鐨勭敤鐢垫�婚噺鏁版嵁
+	 * @param body
+	 * @return
+	 */
+	public static String energyTrend(String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.energyTrend,body);
+	}
+	/**
+	 * 娑堥槻缁翠繚缁熻
+	 * @param body
+	 * @return
+	 */
+	public static String fireStatistic(String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.fireStatistic,body);
+	}
+	/**
+	 * 娑堥槻缁翠繚姣忔湀鏂板缁熻
+	 * @param body
+	 * @return
+	 */
+	public static String fireStatisticMonth(String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.fireStatisticMonth,body);
+	}
+	/**
+	 * 娑堥槻鐪嬫澘-娑堥槻璁惧鍦ㄧ绾�1
+	 * @param body
+	 * @return
+	 */
+	public static String getFireDevStatusTotal(String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.getFireDevStatusTotal,body);
+	}
+	/**
+	 * 娑堥槻鐪嬫澘-鍚勭被鍨嬭澶囧湪绾跨巼2
+	 * @param body
+	 * @return
+	 */
+	public static String getFireDevStatusList(String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.getFireDevStatusList,body);
+	}
+
+	/**
+	 * 鍒嗛〉鏌ヨ璁惧鐨勪互鍙婁笅灞炰紶鎰熷櫒鏁版嵁鐨勭姸鎬佺粺璁�
+	 * @param body
+	 * @return
+	 */
+	public static String findDeviceStatistics(String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.findDeviceStatistics,body);
+	}
+	/**
+	 *娑堥槻鐪嬫澘-4鎶ヨ淇℃伅缁熻
+	 * @param body
+	 * @return
+	 */
+	public static String findAlarmBaseDataStatistic(String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.findAlarmBaseDataStatistic,body);
+	}
+
+	/**
+	 *瀹夐槻鐪嬫澘-- b
+	 * @param body
+	 * @return
+	 */
+	public static String findHomeAlarmInfoPage(String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.findHomeAlarmInfoPage,body);
+	}
+	/**
+	 *淇濆瓨鐢ㄦ埛鍙妎penId缁戝畾淇℃伅寰俊鍏紬鍙�
+	 * @param body
+	 * @return
+	 */
+	public static String userOpenidSave(String body) {
+		Map<String,String> header = new HashMap<>();
+		header.put("userId","admin");
+		return startDoPostStringArtemis(HKConstants.InterfacePath.userOpenidSave,null,header,body);
+	}
+	/**
+	 *閫氳繃openId鎴杣serName绛夊垹闄ょ粦瀹氫俊鎭�
+	 * @param param
+	 * @return
+	 */
+	public static String userOpenidDel(Map<String,String>  param) {
+		Map<String,String> header = new HashMap<>();
+		header.put("userId","admin");
+		return startDoGetStringArtemis(HKConstants.InterfacePath.userOpenidDel,param,header);
+	}
+	/**
+	 *鍒嗛〉鏌ヨ璁惧鐩戞祴鍘嗗彶鏁版嵁
+	 * @param body
+	 * @return
+	 */
+	public static String minitorDataSearch(String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.minitorDataSearchV1,body);
+	}
+	/**
+	 * 缁熻鍥尯鎬讳綋鐨勫畨闃茶澶囨暟閲忥紝鍦ㄧ嚎鏁般�佸湪绾跨巼銆佺绾挎暟銆佺绾跨巼
+	 * @param body
+	 * @return
+	 */
+	public static String getSecureDevStatusTotal(String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.getSecureDevStatusTotal,body);
+	}
+	/**
+	 * 缁熷畨闃茬湅鏉�--鍥尯瀹炴椂杞︽暟閲�4
+	 * @return
+	 */
+	public static String getParkingStatistics() {
+		return startDoGetStringArtemis(HKConstants.InterfacePath.getParkingStatistics,null);
+	}
+	/**
+	 * 鑳借�楃湅鏉�-1.鑾峰彇鏈湀鐢ㄨ兘鎬婚噺-鑷劧鏈�
+	 * @return
+	 */
+	public static String getCurrentMonthDataByMeterType(Map<String,String>   powerType) {
+		return startDoGetStringArtemis(HKConstants.InterfacePath.getCurrentMonthDataByMeterType,powerType);
+	}
+	/**
+	 * 鑳借�楃湅鏉�-2.鑾峰彇鍖哄煙鐢ㄨ兘鍓峃浣�
+	 * @return
+	 */
+	public static String regionTopPower(Map<String,String>   params) {
+		return startDoGetStringArtemis(HKConstants.InterfacePath.regionTopPower,params);
+	}
+	/**
+	 * 鑳借�楃湅鏉�-3.鑾峰彇鍚勫尯鍩熺敤鑳藉強鎬昏兘鑰�
+	 * @return
+	 */
+	public static String regionEnergyList(Map<String,String>   params) {
+		return startDoGetStringArtemis(HKConstants.InterfacePath.regionEnergyList,params);
+	}
+	/**
+	 * 鑳借�楃湅鏉�-4.鑾峰彇涓婃湀鐢ㄨ兘璐圭敤锛屼竴澶╁埛鏂帮紝鍑屾櫒鏌愪釜鐐瑰埛
+	 * @return
+	 */
+	public static String lastMonthFeeByMeterType(Map<String,String>   params) {
+		return startDoGetStringArtemis(HKConstants.InterfacePath.lastMonthFeeByMeterType,params);
+	}
+	/**
+	 * 鑳借�楃湅鏉�-5.鍥尯瀹炴椂璐熻嵎鏇茬嚎
+	 * @return
+	 */
+	public static String energyTodayLoadData( ) {
+		return startDoGetStringArtemis(HKConstants.InterfacePath.energyTodayLoadData,null);
+	}
+	/**
 	 * 鑾峰彇鏈堝彴鐘舵��
 	 * @return
 	 */
@@ -678,6 +1002,50 @@
 			return startDoPostStringArtemis(HKConstants.InterfacePath.platformStatus,null);
 		}
 	}
+
+	/**
+	 * 鑾峰彇鑿滃崟
+	 * @param body
+	 * @return
+	 */
+	public static String getHkMenu(Map<String,String> body) {
+		return startDoGetStringArtemis(HKConstants.InterfacePath.getMenus,body);
+	}
+	/**
+	 * 鍒嗛〉鑾峰彇鍖哄煙鍒楄〃
+	 * @param body
+	 * @return
+	 */
+	public static String pageRegions(Map<String,String> header,String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.pageRegions,null,header,body);
+	}
+	/**
+	 * 鍒嗛〉鑾峰彇鐩戞帶鐐硅祫婧�
+	 * @param body
+	 * @return
+	 */
+	public static String pageCameras(Map<String,String> header,String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.pageCameras,null,header,body);
+	}
+	/**
+	 * 鑾峰彇鐩戞帶鐐归瑙堝彇娴乁RL
+	 * @param body
+	 * @return
+	 */
+	public static String cameraPreviewURLs(Map<String,String> header,String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.cameraPreviewURLs,null,header,body);
+	}
+
+
+	/**
+	 * 鍙戦�佺煭淇¢獙璇佺爜
+	 * @param body
+	 * @return
+	 */
+	public static String sendSms(String body) {
+		return startDoPostStringArtemis(HKConstants.InterfacePath.sendSms,body);
+	}
+
 	/**
 	 * 鑾峰彇鏈堝彴缁勪欢閰嶇疆鐨凩ED璁惧娓呭崟
 	 * @param body
@@ -729,9 +1097,9 @@
 		return startDoPostStringArtemis(HKConstants.InterfacePath.applyST,body);
 	}
 
-	public static String getMenuUrl(String menuId, String token) {
+	public static String getMenuUrl(String componentId,String menuId, String token) {
 		String url = HKConstants.InterfacePath.goMenuUrl[0];
-		url = url.replace("${menuId}", menuId).replace("${token}",token);
+		url = url.replace("${componentId}",componentId).replace("${menuId}", menuId).replace("${token}",token);
 		return  url;
 	}
 }

--
Gitblit v1.9.3