package com.artfess.third.controller; import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONObject; import com.artfess.base.annotation.ApiGroup; import com.artfess.base.conf.DingdingConfig; import com.artfess.base.constants.ApiGroupConsts; import com.artfess.base.dingding.utils.DingCallbackCrypto; import com.artfess.base.model.CommonResult; import com.artfess.third.service.DingdingService; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController; import java.util.HashMap; import java.util.Map; /** * 钉钉相关接口 * * @Author : min.wu * @Date: 2022/07/19 09:56 */ @RestController @Slf4j @Api(tags = "钉钉") @RequestMapping("/api/dingding/") @ApiGroup(group = {ApiGroupConsts.DEVICE_BIZ}) public class DingdingController { @Autowired private DingdingService dingdingService; @Autowired private DingdingConfig dingdingConfig; /** * 获取钉钉配置 * @return */ @ApiOperation(value = "获取钉钉配置(企业id)") @GetMapping("/config") public CommonResult getDingTalkConfig() { Map configMap = new HashMap<>(); configMap.put("corpId", dingdingConfig.getCorpId()); return CommonResult.success(configMap, "获取成功"); } @ApiOperation(value = "钉钉事件回调接口") @PostMapping("/callBack") public Map callBack( @RequestParam(value = "msg_signature", required = false) String msg_signature, @RequestParam(value = "timestamp", required = false) String timeStamp, @RequestParam(value = "nonce", required = false) String nonce, @RequestBody(required = false) JSONObject json) { try { log.info("------------------------"); // 1. 从http请求中获取加解密参数 // 2. 使用加解密类型 // Constant.OWNER_KEY 说明: // 1、开发者后台配置的订阅事件为应用级事件推送,此时OWNER_KEY为应用的APP_KEY。 // 2、调用订阅事件接口订阅的事件为企业级事件推送, // 此时OWNER_KEY为:企业的appkey(企业内部应用)或SUITE_KEY(三方应用) //参数分别填写Token、Aes_key和应用信息中的AppKey DingCallbackCrypto callbackCrypto = new DingCallbackCrypto(dingdingConfig.getToken(), dingdingConfig.getAeskey(), dingdingConfig.getAppKey()); String encryptMsg = json.getString("encrypt"); String decryptMsg = callbackCrypto.getDecryptMsg(msg_signature, timeStamp, nonce, encryptMsg); // 3. 反序列化回调事件json数据 JSONObject eventJson = JSON.parseObject(decryptMsg); log.info("回调事件响应数据:{}", eventJson); String eventType = eventJson.getString("EventType"); // 4. 根据EventType分类处理 if ("check_url".equals(eventType)) { // 测试回调url的正确性 log.info("测试回调url的正确性"); } else if ("user_add_org".equals(eventType)) { // 处理通讯录用户增加事件 log.info("发生了:" + eventType + "事件"); } else { // 添加其他已注册的 log.info("发生了:" + eventType + "事件"); } // 5. 返回success的加密数据 Map successMap = callbackCrypto.getEncryptedMap("success"); return successMap; } catch (DingCallbackCrypto.DingTalkEncryptException e) { e.printStackTrace(); } return null; } // /** // * 根据免登授权码, 获取登录用户身份 // * // * @param authCode 免登授权码 // * @return // */ // @GetMapping("/login") // public CommonResult login(@RequestParam(value = "authCode") String authCode) { // // return CommonResult.success(dingdingService.getUserInfo(authCode),"获取用户信息成功"); // // } // /** // * 创建用户 // * @param dingdingUser // * @return // * @throws ApiException // */ // @PostMapping("/createUser") // public OapiV2UserCreateResponse createDingdingUser(@RequestBody OapiV2UserCreateRequest dingdingUser) throws ApiException { // String accessToken = AccessTokenUtil.getAccessToken(dingdingConfig.getAppKey(), dingdingConfig.getAppSecret()); // DingTalkClient client = new DefaultDingTalkClient("https://oapi.dingtalk.com/topapi/v2/user/create"); // OapiV2UserCreateResponse rsp = client.execute(dingdingUser, accessToken); // log.info("创建用户结果:{}", JSON.toJSONString(rsp)); // return rsp; // } // // /** // * 更新用户 // * @param req // * @return // * @throws ApiException // */ // @PostMapping("/updateUser") // public OapiV2UserUpdateResponse updateUser(@RequestBody OapiV2UserUpdateRequest req) throws ApiException { // String accessToken = AccessTokenUtil.getAccessToken(dingdingConfig.getAppKey(), dingdingConfig.getAppSecret()); // DingTalkClient client = new DefaultDingTalkClient("https://oapi.dingtalk.com/topapi/v2/user/update"); // OapiV2UserUpdateResponse rsp = client.execute(req, accessToken); // log.info("更新用户结果:{}", JSON.toJSONString(rsp)); // return rsp; // // } // // // // /** // * 创建部门 // * @param req // * @return // * @throws ApiException // */ // @PostMapping("/createDept") // public OapiV2DepartmentCreateResponse createDept(@RequestBody OapiV2DepartmentCreateRequest req) throws ApiException { // String accessToken = AccessTokenUtil.getAccessToken(dingdingConfig.getAppKey(), dingdingConfig.getAppSecret()); // DingTalkClient client = new DefaultDingTalkClient("https://oapi.dingtalk.com/topapi/v2/department/create"); // OapiV2DepartmentCreateResponse rsp = client.execute(req, accessToken); // log.info("创建部门结果:{}", JSON.toJSONString(rsp)); // return rsp; // } // // /** // * 更新部门 // * @param req // * @return // * @throws ApiException // */ // @PostMapping("/updateDept") // public OapiV2DepartmentUpdateResponse createDingdingUser(@RequestBody OapiV2DepartmentUpdateRequest req) throws ApiException { // String accessToken = AccessTokenUtil.getAccessToken(dingdingConfig.getAppKey(), dingdingConfig.getAppSecret()); // DingTalkClient client = new DefaultDingTalkClient("https://oapi.dingtalk.com/topapi/v2/department/update"); // OapiV2DepartmentUpdateResponse rsp = client.execute(req, accessToken); // log.info("更新部门结果:{}", JSON.toJSONString(rsp)); // return rsp; // } // // /** // * 部门列表 // * @param req // * @return // * @throws ApiException // */ // @PostMapping("/deptList") // public OapiV2DepartmentListsubResponse deptList(@RequestBody OapiV2DepartmentListsubRequest req) throws ApiException { // String accessToken = AccessTokenUtil.getAccessToken(dingdingConfig.getAppKey(), dingdingConfig.getAppSecret()); // DingTalkClient client = new DefaultDingTalkClient("https://oapi.dingtalk.com/topapi/v2/department/listsub"); // OapiV2DepartmentListsubResponse rsp = client.execute(req, accessToken); // req.setDeptId(1L); // req.setLanguage("zh_CN"); // log.info("部门列表结果:{}", JSON.toJSONString(rsp)); // return rsp; // } }