jiangping
2023-08-10 e3523883aadf423cb78647c38f0648c2143d2a89
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
package doumeemes.api.common;
 
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import doumeemes.api.BaseController;
import doumeemes.core.annotation.trace.Trace;
import doumeemes.core.model.ApiResponse;
import doumeemes.core.model.LoginUserInfo;
import doumeemes.core.utils.Constants;
import doumeemes.core.utils.dingding.DingCallbackCrypto;
import doumeemes.core.utils.dingding.DingDingUtil;
import doumeemes.core.utils.redis.RedisUtil;
import doumeemes.dao.ext.CompanyUserExtMapper;
import doumeemes.dao.ext.vo.CompanyExtListVO;
import doumeemes.service.business.BackorderService;
import doumeemes.service.ext.CompanyExtService;
import doumeemes.service.ext.CompanyUserExtService;
import doumeemes.service.ext.DepartmentExtService;
import doumeemes.service.system.SystemLoginService;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.web.bind.annotation.*;
 
import javax.servlet.http.HttpServletRequest;
import java.util.Map;
 
/**
 * 钉钉相关接口
 */
@Api(tags = "钉钉相关接口")
@Trace(exclude = true)
@RestController
@RequestMapping("/dingding")
public class DingdingController extends BaseController {
 
    @Autowired
    private RedisTemplate<String, Object> redisTemplate;
    @Autowired
    private CompanyExtService companyExtService;
    @Autowired
    private CompanyUserExtService companyUserExtService;
    @Autowired
    private BackorderService backorderService;
    @Autowired
    private DepartmentExtService departmentExtService;
    @Autowired
    private SystemLoginService systemLoginService;
    @ApiOperation(value = "获取钉钉jsapi_ticket",httpMethod = "POST" )
    @PostMapping("/jsapiTicket")
    public ApiResponse<String> jsapiTicket(HttpServletRequest request) {
//      int time = request.getSession().getServletContext().getSessionTimeout();
//      int time1 = request.getSession().getMaxInactiveInterval();
//      System.out.println(time1+"====================="+time);
        LoginUserInfo user = this.getLoginUser();
        if(user!=null&& user.getCompany()!=null){
            return ApiResponse.success(companyExtService.getDingdingTicekt(user.getCompany().getId()));
        }else {
            return ApiResponse.failed("无效获取");
        }
    }
 
    /**
     * @author Eva.Caesar Liu
     * @date 2022/04/18 18:12
     */
    @ApiOperation(value ="钉钉推送",httpMethod = "POST" )
    @RequestMapping("/push")
    public Map<String, String> callBack(
            @RequestParam(value = "msg_signature", required = false) String msg_signature,
            @RequestParam(value = "timestamp", required = false) String timeStamp,
            @RequestParam(value = "signature", required = false) String signature,
            @RequestParam(value = "nonce", required = false) String nonce,
            @RequestParam(value = "companyId", required = false) String companyId,
            @RequestBody(required = false) JSONObject json) throws Exception{
        try {
            // 1. 从http请求中获取加解密参数
            // 2. 使用加解密类型
            // Constant.OWNER_KEY 说明:
            // 1、开发者后台配置的订阅事件为应用级事件推送,此时OWNER_KEY为应用的APP_KEY。
            // 2、调用订阅事件接口订阅的事件为企业级事件推送,
            //    此时OWNER_KEY为:企业的appkey(企业内部应用)或SUITE_KEY(三方应用)
            CompanyExtListVO com = RedisUtil.getObject(redisTemplate, Constants.RedisKeys.COM_INFO_KEY+companyId,CompanyExtListVO.class);
            if(com!=null) {
                String ddinfo = com.getDingdingInfo();
                JSONObject j = JSONObject.parseObject(ddinfo);
                String aes_key = j .getString("aes_key");
                String aes_token = j .getString("aes_token");
                String app_key = j .getString("app_key");
                DingCallbackCrypto callbackCrypto = new DingCallbackCrypto(aes_token, aes_key, app_key);
                String encryptMsg = json.getString("encrypt");
                String decryptMsg = callbackCrypto.getDecryptMsg(msg_signature, timeStamp, nonce, encryptMsg);
                // 3. 反序列化回调事件json数据
                JSONObject eventJson = JSON.parseObject(decryptMsg);
                // -------------------测试开始-------------------
//                JSONObject eventJson = new JSONObject();
//                eventJson.put("EventType","bpms_instance_change");
//                eventJson.put("type","finish");
//                eventJson.put("processInstanceId","6keqDppjRme8fYyLjgtcmg06791659085082");
//                eventJson.put("result","agree");
                // -------------------测试结束-------------------
                String eventType = eventJson.getString("EventType");
                // 4. 根据EventType分类处理
                if ("check_url".equals(eventType)) {
                    // 测试回调url的正确性
 
                } else if ("user_add_org".equals(eventType)) {
                    // 审批实例开始,结束
                }else if ("bpms_instance_change".equals(eventType)) {
                    // 处理审批实例开始,结束 //实例ID
                    String processInstanceId = eventJson.getString("processInstanceId");
                    String type= eventJson.getString("type");
                    String result= eventJson.getString("result");
                    backorderService.dealProcessInstance(processInstanceId,type,result);
                }else if ("user_add_org".equals(eventType)) {
                    //加入企业后用户激活。。
                    JSONArray jsonArray = eventJson.getJSONArray("UserId");
                    for (int i = 0; i < jsonArray.size(); i++) {
                        String userId = jsonArray.getString(i);
                        companyUserExtService.syncCompanyUser(Long.valueOf(userId),Integer.valueOf(companyId),"add");
                    }
                }else if ("user_modify_org".equals(eventType)) {
                    //通讯录用户更改。
                    JSONArray jsonArray = eventJson.getJSONArray("UserId");
                    for (int i = 0; i < jsonArray.size(); i++) {
                        String userId = jsonArray.getString(i);
                        companyUserExtService.syncCompanyUser(Long.valueOf(userId),Integer.valueOf(companyId),"edit");
                    }
                }else if ("user_leave_org".equals(eventType)) {
                    //通讯录用户离职。
                    JSONArray jsonArray = eventJson.getJSONArray("UserId");
                    for (int i = 0; i < jsonArray.size(); i++) {
                        String userId = jsonArray.getString(i);
                        companyUserExtService.syncCompanyUser(Long.valueOf(userId),Integer.valueOf(companyId),"delete");
                    }
                }else if ("org_dept_create".equals(eventType)) {
                    //通讯录企业部门创建。
                    JSONArray jsonArray = eventJson.getJSONArray("DeptId");
                    for (int i = 0; i < jsonArray.size(); i++) {
                        String deptId = jsonArray.getString(i);
                        departmentExtService.syncDepartment(Long.valueOf(deptId),Integer.valueOf(companyId),"add");
                    }
                }else if ("org_dept_modify".equals(eventType)) {
                    //通讯录企业部门修改。
                    JSONArray jsonArray = eventJson.getJSONArray("DeptId");
                    for (int i = 0; i < jsonArray.size(); i++) {
                        String deptId = jsonArray.getString(i);
                        departmentExtService.syncDepartment(Long.valueOf(deptId),Integer.valueOf(companyId),"edit");
                    }
                }else if ("org_dept_remove".equals(eventType)) {
                    //通讯录企业部门删除。
                    JSONArray jsonArray = eventJson.getJSONArray("DeptId");
                    for (int i = 0; i < jsonArray.size(); i++) {
                        String deptId = jsonArray.getString(i);
                        departmentExtService.syncDelDepartment(Long.valueOf(deptId));
                    }
                } else {
                    // 添加其他已注册的
                }
                // 5. 返回success的加密数据
               Map<String, String> successMap = callbackCrypto.getEncryptedMap("success");
               return successMap;
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        return null;
    }
    /**
     * @author Eva.Caesar Liu
     * @date 2022/04/18 18:12
     */
    @ApiOperation(value = "钉钉免密登录",httpMethod = "POST" )
    @RequestMapping("/ddLogin")
    public ApiResponse<String> ddLogin(@RequestParam("companyId") Integer companyId , @RequestParam("code") String code , HttpServletRequest request) throws Exception{
        return ApiResponse.success(systemLoginService.loginByDingdingCode(companyId ,code, request));
    }
    @ApiOperation(value = "获取钉钉corpId",httpMethod = "POST" )
    @RequestMapping("/getDingdingCorpId")
    public ApiResponse<String> getDingdingCorpId(@RequestParam("companyId") Integer companyId ,   HttpServletRequest request) throws Exception{
        return ApiResponse.success(systemLoginService.getDingdingCorpId(companyId));
    }
}