wuxw лет назад: 2
Родитель
Сommit
5df540fb08
1 измененных файлов с 102 добавлено и 0 удалено
  1. 102 0
      service-job/src/main/java/com/java110/job/cmd/mall/GetMallTokenCmd.java

+ 102 - 0
service-job/src/main/java/com/java110/job/cmd/mall/GetMallTokenCmd.java

@@ -0,0 +1,102 @@
+package com.java110.job.cmd.mall;
+
+import com.alibaba.fastjson.JSONObject;
+import com.java110.core.annotation.Java110Cmd;
+import com.java110.core.context.CmdContextUtils;
+import com.java110.core.context.ICmdDataFlowContext;
+import com.java110.core.event.cmd.Cmd;
+import com.java110.core.event.cmd.CmdEvent;
+import com.java110.dto.store.StoreDto;
+import com.java110.dto.store.StoreUserDto;
+import com.java110.dto.user.UserDto;
+import com.java110.intf.store.IStoreUserV1InnerServiceSMO;
+import com.java110.intf.store.IStoreV1InnerServiceSMO;
+import com.java110.intf.user.IUserV1InnerServiceSMO;
+import com.java110.job.adapt.hcIot.IotConstant;
+import com.java110.job.mall.ISendMall;
+import com.java110.utils.cache.MappingCache;
+import com.java110.utils.exception.CmdException;
+import com.java110.utils.util.Assert;
+import com.java110.vo.ResultVo;
+import org.springframework.beans.factory.annotation.Autowired;
+
+import java.text.ParseException;
+import java.util.List;
+
+@Java110Cmd(serviceCode = "mall.getMallToken")
+public class GetMallTokenCmd extends Cmd {
+
+    @Autowired
+    private IUserV1InnerServiceSMO userV1InnerServiceSMOImpl;
+
+    @Autowired
+    private IStoreUserV1InnerServiceSMO storeUserV1InnerServiceSMOImpl;
+
+    @Autowired
+    private IStoreV1InnerServiceSMO storeV1InnerServiceSMOImpl;
+
+    public static final String URL_DOMAIN = "URL_DOMAIN"; // 物联网域
+
+
+    public static final String MALL_URL = "MALL_URL"; // 物联网域
+
+
+    @Autowired
+    private ISendMall sendMallImpl;
+
+    @Override
+    public void validate(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException, ParseException {
+        Assert.hasKeyAndValue(reqJson, "targetUrl", "未包含targetUrl");
+        Assert.hasKeyAndValue(reqJson, "communityId", "未包含communityId");
+
+        String mallSwitch = MappingCache.getValue("MALL", "MALL_SWITCH");
+        if (!"ON".equals(mallSwitch)) {
+            throw new CmdException("商城系统未部署");
+        }
+    }
+
+    @Override
+    public void doCmd(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException, ParseException {
+
+        String userId = CmdContextUtils.getUserId(context);
+
+        UserDto userDto = new UserDto();
+        userDto.setUserId(userId);
+        List<UserDto> userDtos = userV1InnerServiceSMOImpl.queryUsers(userDto);
+
+        Assert.listOnlyOne(userDtos, "用户未登录");
+
+        StoreUserDto storeUserDto = new StoreUserDto();
+        storeUserDto.setUserId(userId);
+        List<StoreUserDto> storeUserDtos = storeUserV1InnerServiceSMOImpl.queryStoreUsers(storeUserDto);
+
+        Assert.listOnlyOne(storeUserDtos, "未包含商户");
+
+
+        StoreDto storeDto = new StoreDto();
+        storeDto.setStoreId(storeUserDtos.get(0).getStoreId());
+        List<StoreDto> storeDtos = storeV1InnerServiceSMOImpl.queryStores(storeDto);
+
+        Assert.listOnlyOne(storeDtos, "商户不存在");
+
+        JSONObject staff = new JSONObject();
+        staff.put("tel", userDtos.get(0).getTel());
+        staff.put("storeName", storeDtos.get(0).getName());
+        staff.put("storeId", storeDtos.get(0).getStoreId());
+
+
+        ResultVo resultVo = sendMallImpl.post("/mall/api/token.getSsoToken", staff);
+
+        if (resultVo.getCode() != ResultVo.CODE_OK) {
+            throw new CmdException(resultVo.getMsg());
+        }
+
+        JSONObject paramOut = (JSONObject) resultVo.getData();
+
+        String mallUrl = MappingCache.getValue(URL_DOMAIN, MALL_URL);
+        String targetUrl = mallUrl + reqJson.getString("targetUrl");
+        String url = mallUrl + paramOut.getString("url") + "&targetUrl=" + targetUrl;
+        paramOut.put("url", url);
+        context.setResponseEntity(ResultVo.createResponseEntity(paramOut));
+    }
+}