This repository was archived by the owner on Apr 3, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathserver.js
More file actions
175 lines (161 loc) · 4.32 KB
/
server.js
File metadata and controls
175 lines (161 loc) · 4.32 KB
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
// 封装飞书相关api请求 & 数据库操作
const axios = require('axios');
const { store } = require('./config');
/**
* 处理请求中的错误信息
* @param {*} msg - 错误信息
*/
function errorHandle(msg) {
console.error(msg);
throw new Error(msg);
}
/**
* 创建 axios 实例
* @returns axios 实例
*/
function createService() {
const service = axios.create({
baseURL: 'https://open.feishu.cn',
timeout: 15000,
headers: { "Content-Type": "application/json" }
});
// 请求拦截添加token
service.interceptors.request.use(
async (config) => {
// 从数据库中获取token
if (config.url === '/open-apis/auth/v3/tenant_access_token/internal')
return config;
let token = await getToken();
if (token) config.headers.Authorization = `Bearer ${token}`;
return config;
},
(error) => Promise.reject(error)
)
// 响应拦截
service.interceptors.response.use(
(response) => {
const apiData = response.data;
const { code, msg } = apiData;
if (code) errorHandle(msg);
else return response;
},
(error) => {
let { response } = error;
if (!response) errorHandle(error.message);
else errorHandle(response?.data?.msg || response?.statusText || 'Error In Response');
}
)
return service;
}
const service = createService();
/**
* 获取访问凭证
*/
function getTenantToken() {
return service({
url: '/open-apis/auth/v3/tenant_access_token/internal',
method: 'POST',
data: {
app_id: store.feishu.appId,
app_secret: store.feishu.appSecret
}
})
}
/**
* 回复消息
* @param {String} message_id - 要回复的消息 id
* @param {String} msg_type - 消息类型
* @param {String} content - 消息内容
*/
function replyMessage(message_id, msg_type, content) {
console.log(content);
return service({
url: `/open-apis/im/v1/messages/${message_id}/reply`,
method: 'POST',
data: { msg_type, content }
})
}
/**
* 发送消息
* @param {String} receive_id - 消息接收者id
* @param {String} msg_type - 消息类型
* @param {String} content - 消息内容
*/
function sendMessage(receive_id, msg_type, content) {
return service({
url: '/open-apis/im/v1/messages?receive_id_type=open_id',
method: 'POST',
data: {
receive_id, msg_type, content
}
})
}
/**
* 获取用户信息
* @param {String} open_id - 用户 id
*/
function getUserInfo(open_id) {
return service({
url: `/open-apis/contact/v3/users/${open_id}?department_id_type=open_department_id&user_id_type=open_id`,
method: 'GET',
})
}
/**
* 获取所有用户
* @param {Number} page_size - 分页大小
* @param {String} page_token - 分页标记
* @returns
*/
function getAllValidUser(page_size = 50, page_token = '') {
return service({
url: `/open-apis/contact/v3/scopes?user_id_type=open_id&department_id_type=open_department_id&page_size=${page_size}&page_token=${page_token}`,
method: 'GET',
})
}
const aircode = require('aircode');
// 数据库实例
const runtimeLog = aircode.db.table('runtimeLog');
const token = aircode.db.table('token');
const userConfig = aircode.db.table('userConfig');
/**
* 获取 token 并保存到数据库
*/
async function fetchAndSaveToken() {
try {
let { data } = await getTenantToken();
let { tenant_access_token } = data;
await token
.where()
.set({ accessToken: tenant_access_token })
.upsert(true)
.save();
return tenant_access_token;
} catch {
return null;
}
}
/**
* 获取数据库中的token
* @returns accessToken - 访问凭证
*/
async function getToken() {
try {
let { accessToken } = await token.where().findOne() || {};
// 没找到就重新获取
if (!accessToken)
accessToken = await fetchAndSaveToken();
return accessToken;
} catch (err) {
return null;
}
}
module.exports = {
getTenantToken,
replyMessage,
sendMessage,
getUserInfo,
getAllValidUser,
fetchAndSaveToken,
userConfig,
runtimeLog
}