From 58e344a0c14692fce547d64ea9295f866754fe63 Mon Sep 17 00:00:00 2001
From: luofl <1442745593@qq.com>
Date: 星期四, 03 四月 2025 18:19:26 +0800
Subject: [PATCH] 1

---
 cloud-server-other/src/main/java/com/dsh/other/controller/StoreController.java |  292 +++++++++++++++++++++++++++++++++++++---------------------
 1 files changed, 187 insertions(+), 105 deletions(-)

diff --git a/cloud-server-other/src/main/java/com/dsh/other/controller/StoreController.java b/cloud-server-other/src/main/java/com/dsh/other/controller/StoreController.java
index a699e6d..24c18f3 100644
--- a/cloud-server-other/src/main/java/com/dsh/other/controller/StoreController.java
+++ b/cloud-server-other/src/main/java/com/dsh/other/controller/StoreController.java
@@ -3,22 +3,26 @@
 
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
-import com.dsh.other.entity.Store;
-import com.dsh.other.entity.TBackRecord;
-import com.dsh.other.entity.TStoreOther;
-import com.dsh.other.entity.TStoreOtherConfigTrue;
+import com.dsh.other.entity.*;
 import com.dsh.other.feignclient.model.*;
 import com.dsh.other.model.*;
+import com.dsh.other.model.dto.siteDto.StoreInfoDto;
 import com.dsh.other.service.*;
 import com.dsh.other.util.GDMapGeocodingUtil;
+import com.dsh.other.util.GeodesyUtil;
 import com.dsh.other.util.ResultUtil;
 import com.dsh.other.util.ToolUtil;
+import com.sun.javafx.binding.StringFormatter;
 import io.swagger.annotations.ApiImplicitParam;
 import io.swagger.annotations.ApiImplicitParams;
 import io.swagger.annotations.ApiOperation;
+import org.springframework.beans.BeanUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.*;
 
+import java.math.BigDecimal;
+import java.math.RoundingMode;
+import java.text.DecimalFormat;
 import java.util.*;
 import java.util.stream.Collectors;
 
@@ -29,7 +33,6 @@
     @Autowired
     private StoreService storeService;
 
-
     @Autowired
     private GDMapGeocodingUtil gdMapGeocodingUtil;
 
@@ -39,19 +42,36 @@
     @Autowired
     private TBackRecordService backRecordService;
 
+    @Autowired
+    private TStoreOtherConfigTrueService tStoreOtherConfigTrueService;
+
+
+
+
+
+
+    /**
+     * 获取根据门店id 获取店长信息
+     */
+    @RequestMapping(value = "/getStoreInfo")
+    public StoreInfoDto getStoreInfo(@RequestBody Integer id) {
+
+        return storeService.getStoreInfo(id);
+    }
 
     /**
      * 根据城市管理员id获取门店
      */
     @RequestMapping("base/site/getStoreByCityManagerId")
-    public Object getStoreByCityManagerId(@RequestBody Integer id){
+    public Object getStoreByCityManagerId(@RequestBody Integer id) {
         return storeService.getStoreByCityManagerId(id);
     }
+
     /**
      * 根据员工id获取门店
      */
     @RequestMapping("base/site/getStoreByStoreStaffId")
-    public Object getStoreByStoreStaffId(@RequestBody Integer id){
+    public Object getStoreByStoreStaffId(@RequestBody Integer id) {
         return storeService.getStoreByStoreStaffId(id);
     }
 
@@ -59,34 +79,35 @@
      * 根据门店id获取门店信息
      */
     @RequestMapping("base/site/getStoreById")
-    public Store getStoreById(@RequestBody Integer id){
-        return storeService.getOne(new QueryWrapper<Store>().eq("id",id));
+    public Store getStoreById(@RequestBody Integer id) {
+        return storeService.getOne(new QueryWrapper<Store>().eq("id", id));
     }
+
     /**
      * 选择市区 展示全部门店
      */
     @RequestMapping("base/store/getStore")
-    public List<Store> getStore(@RequestBody String city){
-        return storeService.list(new QueryWrapper<Store>().eq("city",city));
+    public List<Store> getStore(@RequestBody String city) {
+        return storeService.list(new QueryWrapper<Store>().eq("city", city));
     }
 
     /**
      * 根据所选门店 查询经营时间
+     *
      * @param oneId
      * @return
      */
     @RequestMapping("base/store/getTime")
-    public Store getTime(@RequestBody String oneId){
-        return storeService.getOne(new QueryWrapper<Store>().eq("name",oneId));
+    public Store getTime(@RequestBody String oneId) {
+        return storeService.getOne(new QueryWrapper<Store>().eq("name", oneId));
     }
 
 
-
     @PostMapping("/base/protocol/storeDetail/courseOfSto")
-    public StoreDetailOfCourse getCourseOfStore(@RequestBody Integer storeId){
+    public StoreDetailOfCourse getCourseOfStore(@RequestBody Integer storeId) {
         StoreDetailOfCourse ofCourse = new StoreDetailOfCourse();
         Store store = storeService.getById(storeId);
-        if (null != store){
+        if (null != store) {
             ofCourse.setStoreName(store.getName());
             ofCourse.setStoreAddr(store.getAddress());
         }
@@ -94,97 +115,126 @@
     }
 
     @PostMapping("/base/protocol/storeDetail/nearbyStore")
-    public List<StoreInfo> getAllNearbyStoreList(@RequestBody GetAllNearbyStoreList list ){
+    public List<StoreInfo> getAllNearbyStoreList(@RequestBody GetAllNearbyStoreList list) {
         List<StoreInfo> storeInfos = new ArrayList<>();
-        if (ToolUtil.isEmpty(list.getLongitude()) && ToolUtil.isEmpty(list.getLatitude())){
+        if (ToolUtil.isEmpty(list.getLongitude()) && ToolUtil.isEmpty(list.getLatitude())) {
             return storeInfos;
         }
-        String current = list.getLongitude()+","+list.getLatitude();
+        String current = list.getLongitude() + "," + list.getLatitude();
         String cityCode = "";
         try {
             Map<String, String> geocode = gdMapGeocodingUtil.geocode(list.getLongitude(), list.getLatitude());
             cityCode = geocode.get("cityCode");
-        }catch (Exception e){
+        } catch (Exception e) {
             e.printStackTrace();
         }
         List<Store> storeList = storeService.list(new QueryWrapper<Store>()
                 .eq("state", 1)
-                .eq("cityCode",cityCode));
-        if (storeList.size() > 0){
+                .eq("cityCode", cityCode));
+        if (storeList.size() > 0) {
             for (Store store : storeList) {
                 String storeLon = store.getLon();
                 String storeLat = store.getLat();
-                String result = storeLon+","+storeLat;
-                String distanceTOKilometer = gdMapGeocodingUtil.getDistanceTOKilometer(current, result);
+//                String result = storeLon + "," + storeLat;
+//                String distanceTOKilometer = gdMapGeocodingUtil.getDistanceTOKilometer(current, result);
                 long l = 0;
-                try {
-                    l = Long.parseLong(distanceTOKilometer);
-                }catch (Exception e){
-                    l = 0;
-                }
+//                try {
+//                    l = Long.parseLong(distanceTOKilometer);
+//                }catch (Exception e){
+//                    l = 0;
+//                }
                 StoreInfo info = new StoreInfo();
                 info.setStoreId(store.getId());
                 info.setStoreName(store.getName());
-                info.setStoreImg(store.getRealPicture());
-                info.setDistance(l);
-                info.setStoreAddr(store.getAddress());
+                info.setStoreImg(store.getCoverDrawing());
+//                info.setDistance( Double.parseDouble(distanceTOKilometer));
+
+                Map<String, Double> distance = GeodesyUtil.getDistance(list.getLongitude() + "," + list.getLatitude(), storeLon + "," + storeLat);
+                double wgs84 = new BigDecimal(distance.get("WGS84")).divide(new BigDecimal(1000)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
+                info.setDistance(wgs84);
+
+
+                String str = store.getAddress();
+                str = str.substring(str.indexOf("省") + 1);
+
+                // 去掉第一个“市”及之前的字符串
+                str = str.substring(str.indexOf("市") + 1);
+
+                // 去掉第一个“区”及之前的字符串
+                str = str.substring(str.indexOf("区") + 1);
+
+                info.setStoreAddr(str);
                 info.setLatitude(storeLat);
                 info.setLongitude(storeLon);
+
                 storeInfos.add(info);
             }
-            Comparator<StoreInfo> distanceComparator = new Comparator<StoreInfo>() {
-                @Override
-                public int compare(StoreInfo store1, StoreInfo store2) {
-                    return Long.compare(store1.getDistance(), store2.getDistance());
-                }
-            };
-            Collections.sort(storeInfos, distanceComparator);
+//            Comparator<StoreInfo> distanceComparator = new Comparator<StoreInfo>() {
+//                @Override
+//                public int compare(StoreInfo store1, StoreInfo store2) {
+//                    return Long.compare(store1.getDistance(), store2.getDistance());
+//                }
+//            };
+//            Collections.sort(storeInfos, distanceComparator);
+            storeInfos = storeInfos.stream().sorted(Comparator.comparing(StoreInfo::getDistance)).collect(Collectors.toList());
         }
         return storeInfos;
     }
 
     /**
      * 根据门店坐标与传入坐标,计算距离
+     *
      * @param distanceVo
      * @return
      */
     @PostMapping("/base/protocol/storeDetail/distanceCal")
-    public String calculateDistance(@RequestBody GetDistanceVo distanceVo){
-        String current = distanceVo.getLongitude()+","+distanceVo.getLatitude();
+    public String calculateDistance(@RequestBody GetDistanceVo distanceVo) {
+        String current = distanceVo.getLongitude() + "," + distanceVo.getLatitude();
         Store store = storeService.getById(distanceVo.getStoreId());
-        String result = store.getLon()+","+store.getLat();
-        return gdMapGeocodingUtil.getDistanceTOKilometer(current, result);
+        String result = store.getLon() + "," + store.getLat();
+
+
+        if (ToolUtil.isNotEmpty(distanceVo.getLongitude()) && ToolUtil.isNotEmpty(distanceVo.getLatitude())) {
+            Map<String, Double> distance = GeodesyUtil.getDistance(distanceVo.getLongitude() + "," + distanceVo.getLatitude(), store.getLon() + "," + store.getLat());
+            double wgs84 = new BigDecimal(distance.get("WGS84")).divide(new BigDecimal(1000)).setScale(2, RoundingMode.HALF_EVEN).doubleValue();
+//            packageResponse.setDistance(wgs84);
+            return wgs84 + "";
+        }
+        return "";
+
+//        return gdMapGeocodingUtil.getDistanceTOKilometer(current, result);
     }
 
 
     @PostMapping("/base/protocol/storeDetail/citycodeLoLa")
-    public List<StoreDetailList> getQueryStoreList(@RequestBody StoreOfCitycodeResp citycodeResp){
+    public List<StoreDetailList> getQueryStoreList(@RequestBody StoreOfCitycodeResp citycodeResp) throws Exception {
         List<StoreDetailList> detailLists = new ArrayList<>();
-        List<Store> list = storeService.list(new QueryWrapper<Store>()
-                .eq("state",1 )
-                .eq("cityCode",citycodeResp.getCityCode()));
-        if (list.size() > 0 ){
-            if (ToolUtil.isEmpty(citycodeResp.getLongitude()) && ToolUtil.isEmpty(citycodeResp.getLatitude())){
-                return detailLists;
+
+        if (citycodeResp.getCityCode() == null) {
+            Map<String, String> geocode = gdMapGeocodingUtil.geocode(citycodeResp.getLongitude(), citycodeResp.getLatitude());
+            if(null != geocode){
+                String cityCode = geocode.get("cityCode");
+                citycodeResp.setCityCode(cityCode);
             }
+        }
+
+        List<Store> list = storeService.list(new QueryWrapper<Store>()
+                .eq("state", 1)
+                .eq("cityCode", citycodeResp.getCityCode()));
+        if (list.size() > 0) {
             for (Store store : list) {
-                String current = citycodeResp.getLongitude() +","+citycodeResp.getLatitude();
-                String result = store.getLon()+","+store.getLat();
-                String distanceTOKilometer = gdMapGeocodingUtil.getDistanceTOKilometer(current, result);
-                long l = Long.parseLong(distanceTOKilometer);
-//                取5公里范围内的门店
-                if ( l > 5){
-                    continue;
-                }
+                String current = citycodeResp.getLongitude() + "," + citycodeResp.getLatitude();
+                String result = store.getLon() + "," + store.getLat();
+                Map<String, Double> distance = GeodesyUtil.getDistance(current, result);
                 StoreDetailList detailList = new StoreDetailList();
                 detailList.setStoreId(store.getId());
                 detailList.setStoreImg(store.getCoverDrawing());
                 detailList.setStoreName(store.getName());
                 detailList.setStoreAddress(store.getAddress());
                 detailList.setStorePhone(store.getPhone());
-                detailList.setStoreDistance(l);
                 detailList.setStoreTime(store.getStartTime() + "-" + store.getEndTime());
                 detailList.setStoreInfo(store.getIntroduce());
+                detailList.setStoreDistance(null != distance ? Double.valueOf(String.format("%.2f", distance.get("WGS84") / 1000)) : 0D);
                 detailLists.add(detailList);
             }
         }
@@ -192,20 +242,17 @@
     }
 
 
-
-
-
-
     /**
      * 获取门店列表
+     *
      * @return
      */
     @ResponseBody
     @PostMapping("/store/queryStoreList")
-    public List<Store> queryStoreList(QueryStoreList queryStoreList){
+    public List<Store> queryStoreList(QueryStoreList queryStoreList) {
         try {
             return storeService.queryStorsList(queryStoreList.getProvinceCode(), queryStoreList.getCityCode());
-        }catch (Exception e){
+        } catch (Exception e) {
             e.printStackTrace();
             return new ArrayList<>();
         }
@@ -214,24 +261,25 @@
 
     /**
      * 获取门店列表
+     *
      * @return
      */
     @ResponseBody
     @PostMapping("/store/queryStoreByIds")
-    public List<Store> queryStoreByIds(@RequestBody List<Integer> ids){
+    public List<Store> queryStoreByIds(@RequestBody List<Integer> ids) {
         try {
             List<Store> list = storeService.list(new LambdaQueryWrapper<Store>()
                     .in(Store::getId, ids));
             for (Store store : list) {
                 Integer operatorId = store.getOperatorId();
-                if(operatorId == null){
-                    operatorId=-1;
+                if (operatorId == null) {
+                    operatorId = -1;
                 }
                 String name = storeService.getOName(operatorId);
                 store.setOName(name);
             }
             return list;
-        }catch (Exception e){
+        } catch (Exception e) {
             e.printStackTrace();
             return new ArrayList<>();
         }
@@ -239,16 +287,23 @@
 
     @ResponseBody
     @PostMapping("/store/queryStoreIdByCityCode")
-    List<Integer> queryStoreIdByCityCode(@RequestBody List<String> collect){
+    List<Integer> queryStoreIdByCityCode(@RequestBody List<String> collect) {
         try {
             return storeService.list(new LambdaQueryWrapper<Store>()
-                    .in(Store::getCityCode,collect)).stream().map(Store::getId).collect(Collectors.toList());
-        }catch (Exception e){
+                    .in(Store::getCityCode, collect)).stream().map(Store::getId).collect(Collectors.toList());
+        } catch (Exception e) {
             e.printStackTrace();
             return new ArrayList<>();
         }
     }
 
+    @ResponseBody
+    @PostMapping("/store/querySiteIdById")
+    public List<Integer> querySiteIdById(@RequestBody List<Integer> storeIds) {
+        List<Site> list = siteService.list(new LambdaQueryWrapper<Site>().in(Site::getStoreId, storeIds));
+        List<Integer> collect = list.stream().map(Site::getId).collect(Collectors.toList());
+        return collect;
+    }
 
 
     @ResponseBody
@@ -259,11 +314,11 @@
             @ApiImplicitParam(value = "纬度", name = "lat", dataType = "string", required = false),
             @ApiImplicitParam(value = "cityCode", name = "cityCode", dataType = "string", required = false),
     })
-    public ResultUtil<List<BaseVo>> queryStoreLists(String lon, String lat,String cityCode){
+    public ResultUtil<List<BaseVo>> queryStoreLists(String lon, String lat, String cityCode) {
         try {
-            List<BaseVo> baseVos = storeService.queryStoreLists(lon, lat,cityCode);
+            List<BaseVo> baseVos = storeService.queryStoreLists(lon, lat, cityCode);
             return ResultUtil.success(baseVos);
-        }catch (Exception e){
+        } catch (Exception e) {
             e.printStackTrace();
             return ResultUtil.runErr();
         }
@@ -272,16 +327,17 @@
 
     /**
      * 根据门店模糊搜索店铺
+     *
      * @param name
      * @return
      */
     @ResponseBody
     @PostMapping("/store/queryStoreListByName")
-    public List<Store> queryStoreListByName(@RequestBody String name){
+    public List<Store> queryStoreListByName(@RequestBody String name) {
         try {
             List<Store> stores = storeService.list(new QueryWrapper<Store>().eq("state", 1).like("name", name));
             return stores;
-        }catch (Exception e){
+        } catch (Exception e) {
             e.printStackTrace();
             return new ArrayList<>();
         }
@@ -290,23 +346,47 @@
 
     /**
      * 根据门店
+     *
      * @param id
      * @return
      */
     @ResponseBody
     @PostMapping("/store/queryStoreById")
-    public Store queryStoreById(@RequestBody Integer id){
+    public Store queryStoreById(@RequestBody Integer id) {
         try {
             return storeService.getById(id);
-        }catch (Exception e){
+        } catch (Exception e) {
+            e.printStackTrace();
+            return null;
+        }
+    }
+
+    @ResponseBody
+    @PostMapping("/store/queryByStoreId")
+    public OperatorUser queryByStoreId(@RequestBody Integer id) {
+        try {
+            return storeService.queryByStoreId(id);
+        } catch (Exception e) {
             e.printStackTrace();
             return null;
         }
     }
 
 
+    @Autowired
+    private ISiteService siteService;
+
+    @ResponseBody
+    @PostMapping("/store/querySiteId")
+    public List<Integer> querySiteId(@RequestBody Integer storeId) {
+        List<Site> list = siteService.list(new LambdaQueryWrapper<Site>().eq(Site::getStoreId, storeId).eq(Site::getSign, 1));
+        List<Integer> collect = list.stream().map(Site::getId).collect(Collectors.toList());
+        return collect;
+    }
+
+
     @PostMapping("/store/addBackRecord")
-    public void addBackRecord(@RequestBody String s){
+    public void addBackRecord(@RequestBody String s) {
         TBackRecord tBackRecord = new TBackRecord();
         String[] split = s.split("_");
         tBackRecord.setMoney(Double.valueOf(split[0]));
@@ -316,52 +396,57 @@
     }
 
 
-
-
     @ResponseBody
     @PostMapping("/base/store/queryStoreFreeBenefit")
     @ApiOperation(value = "获取门店免费福利", tags = {"APP-免费福利"})
     @ApiImplicitParams({
             @ApiImplicitParam(value = "门店id", name = "id", dataType = "int", required = true),
     })
-    public ResultUtil<StoreFreeBenefitVo> queryStoreFreeBenefit(Integer id){
+    public ResultUtil<StoreFreeBenefitVo> queryStoreFreeBenefit(Integer id) {
         try {
             Store store = storeService.getById(id);
             StoreFreeBenefitVo storeFreeBenefitVo = new StoreFreeBenefitVo();
             storeFreeBenefitVo.setPhone(store.getPhone());
             storeFreeBenefitVo.setImg(store.getWelfarePicture());
             return ResultUtil.success(storeFreeBenefitVo);
-        }catch (Exception e){
+        } catch (Exception e) {
             e.printStackTrace();
             return ResultUtil.runErr();
         }
     }
 
-    @Autowired
-    private TStoreOtherConfigTrueService tStoreOtherConfigTrueService;
+
+
+
+
     @ResponseBody
     @PostMapping("/base/store/queryIndexSet")
-    @ApiOperation(value = "获取门店首页设置 2.0", tags = {"APP-免费福利"})
+    @ApiOperation(value = "获取门店首页设置", tags = {"APP-免费福利"})
     @ApiImplicitParams({
             @ApiImplicitParam(value = "门店id", name = "id", dataType = "int", required = true),
     })
-    public ResultUtil<List<TStoreOtherConfigTrue>> queryIndexSet(Integer id){
+    public ResultUtil<List<TStoreOtherConfigTrue>> queryIndexSet(Integer id) {
         try {
             List<TStoreOtherConfigTrue> tStoreOtherConfigTrues = new ArrayList<>();
 
-            List<TStoreOther> list = tStoreOtherService.list(new LambdaQueryWrapper<TStoreOther>().eq(TStoreOther::getStoreId, id).eq(TStoreOther::getState,1));
-            if(list.size()>0){
-                tStoreOtherConfigTrues= tStoreOtherConfigTrueService.list(new LambdaQueryWrapper<TStoreOtherConfigTrue>().in(TStoreOtherConfigTrue::getPid, list.stream().map(TStoreOther::getId).collect(Collectors.toList())).eq(TStoreOtherConfigTrue::getState,1));
+            List<TStoreOther> list = tStoreOtherService.list(new LambdaQueryWrapper<TStoreOther>().eq(TStoreOther::getStoreId, id).eq(TStoreOther::getState, 1));
+            if (list.size() > 0) {
+                tStoreOtherConfigTrues = tStoreOtherConfigTrueService.list(new LambdaQueryWrapper<TStoreOtherConfigTrue>().in(TStoreOtherConfigTrue::getPid, list.stream().map(TStoreOther::getId).collect(Collectors.toList())).eq(TStoreOtherConfigTrue::getState, 1));
+            }
+            for (TStoreOtherConfigTrue tStoreOtherConfigTrue : tStoreOtherConfigTrues) {
+                for (TStoreOther tStoreOther : list) {
+                    if (tStoreOtherConfigTrue.getPid() == tStoreOther.getId()) {
+                        tStoreOtherConfigTrue.setSort(tStoreOther.getSort());
+                    }
+                }
+                tStoreOtherConfigTrue.setDisplayType(2);
             }
             return ResultUtil.success(tStoreOtherConfigTrues);
-        }catch (Exception e){
+        } catch (Exception e) {
             e.printStackTrace();
             return ResultUtil.runErr();
         }
     }
-
-
-
 
 
     @ResponseBody
@@ -370,17 +455,15 @@
     @ApiImplicitParams({
             @ApiImplicitParam(value = "省编号", name = "pcode", dataType = "string", required = false),
     })
-    public ResultUtil<List<ProvinceAndCityVo>> queryProvinceAndCity(String pcode){
+    public ResultUtil<List<ProvinceAndCityVo>> queryProvinceAndCity(String pcode) {
         try {
             List<ProvinceAndCityVo> provinceAndCityVos = storeService.queryProvinceAndCity(pcode);
             return ResultUtil.success(provinceAndCityVos);
-        }catch (Exception e){
+        } catch (Exception e) {
             e.printStackTrace();
             return ResultUtil.runErr();
         }
     }
-
-
 
 
     @ResponseBody
@@ -388,16 +471,15 @@
     @ApiOperation(value = "获取所有开通城市", tags = {"APP-赛事活动列表", "用户—预约场地"})
     @ApiImplicitParams({
     })
-    public ResultUtil<List<ProvinceAndCityVo>> queryAllCity(){
+    public ResultUtil<List<ProvinceAndCityVo>> queryAllCity() {
         try {
             List<ProvinceAndCityVo> provinceAndCityVos = storeService.queryAllCity();
             return ResultUtil.success(provinceAndCityVos);
-        }catch (Exception e){
+        } catch (Exception e) {
             e.printStackTrace();
             return ResultUtil.runErr();
         }
     }
-
 
 
     @ResponseBody
@@ -406,11 +488,11 @@
     @ApiImplicitParams({
             @ApiImplicitParam(value = "城市code", name = "cityCode", dataType = "string", required = true),
     })
-    public ResultUtil<List<BaseVo>> queryStoreByCityCode(String cityCode){
+    public ResultUtil<List<BaseVo>> queryStoreByCityCode(String provinceCode, String cityCode) {
         try {
-            List<BaseVo> list = storeService.queryStoreByCityCode(cityCode);
+            List<BaseVo> list = storeService.queryStoreByCityCode(provinceCode, cityCode);
             return ResultUtil.success(list);
-        }catch (Exception e){
+        } catch (Exception e) {
             e.printStackTrace();
             return ResultUtil.runErr();
         }

--
Gitblit v1.7.1