n8n-nodes-wecom 0.1.21 → 0.1.23
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +56 -0
- package/dist/nodes/WeCom/resources/kf/addKfAccount.d.ts +2 -0
- package/dist/nodes/WeCom/resources/kf/addKfAccount.js +32 -0
- package/dist/nodes/WeCom/resources/kf/addKfAccount.js.map +1 -0
- package/dist/nodes/WeCom/resources/kf/addServicer.d.ts +2 -0
- package/dist/nodes/WeCom/resources/kf/addServicer.js +32 -0
- package/dist/nodes/WeCom/resources/kf/addServicer.js.map +1 -0
- package/dist/nodes/WeCom/resources/kf/delKfAccount.d.ts +2 -0
- package/dist/nodes/WeCom/resources/kf/delKfAccount.js +21 -0
- package/dist/nodes/WeCom/resources/kf/delKfAccount.js.map +1 -0
- package/dist/nodes/WeCom/resources/kf/delServicer.d.ts +2 -0
- package/dist/nodes/WeCom/resources/kf/delServicer.js +32 -0
- package/dist/nodes/WeCom/resources/kf/delServicer.js.map +1 -0
- package/dist/nodes/WeCom/resources/kf/execute.d.ts +2 -0
- package/dist/nodes/WeCom/resources/kf/execute.js +242 -0
- package/dist/nodes/WeCom/resources/kf/execute.js.map +1 -0
- package/dist/nodes/WeCom/resources/kf/getCorpStatistic.d.ts +2 -0
- package/dist/nodes/WeCom/resources/kf/getCorpStatistic.js +43 -0
- package/dist/nodes/WeCom/resources/kf/getCorpStatistic.js.map +1 -0
- package/dist/nodes/WeCom/resources/kf/getCustomerInfo.d.ts +2 -0
- package/dist/nodes/WeCom/resources/kf/getCustomerInfo.js +32 -0
- package/dist/nodes/WeCom/resources/kf/getCustomerInfo.js.map +1 -0
- package/dist/nodes/WeCom/resources/kf/getKfAccountLink.d.ts +2 -0
- package/dist/nodes/WeCom/resources/kf/getKfAccountLink.js +31 -0
- package/dist/nodes/WeCom/resources/kf/getKfAccountLink.js.map +1 -0
- package/dist/nodes/WeCom/resources/kf/getServicerStatistic.d.ts +2 -0
- package/dist/nodes/WeCom/resources/kf/getServicerStatistic.js +54 -0
- package/dist/nodes/WeCom/resources/kf/getServicerStatistic.js.map +1 -0
- package/dist/nodes/WeCom/resources/kf/index.d.ts +2 -0
- package/dist/nodes/WeCom/resources/kf/index.js +140 -0
- package/dist/nodes/WeCom/resources/kf/index.js.map +1 -0
- package/dist/nodes/WeCom/resources/kf/listKfAccount.d.ts +2 -0
- package/dist/nodes/WeCom/resources/kf/listKfAccount.js +34 -0
- package/dist/nodes/WeCom/resources/kf/listKfAccount.js.map +1 -0
- package/dist/nodes/WeCom/resources/kf/listServicer.d.ts +2 -0
- package/dist/nodes/WeCom/resources/kf/listServicer.js +21 -0
- package/dist/nodes/WeCom/resources/kf/listServicer.js.map +1 -0
- package/dist/nodes/WeCom/resources/kf/manageKnowledgeGroup.d.ts +2 -0
- package/dist/nodes/WeCom/resources/kf/manageKnowledgeGroup.js +49 -0
- package/dist/nodes/WeCom/resources/kf/manageKnowledgeGroup.js.map +1 -0
- package/dist/nodes/WeCom/resources/kf/manageKnowledgeIntent.d.ts +2 -0
- package/dist/nodes/WeCom/resources/kf/manageKnowledgeIntent.js +49 -0
- package/dist/nodes/WeCom/resources/kf/manageKnowledgeIntent.js.map +1 -0
- package/dist/nodes/WeCom/resources/kf/sendKfEventMsg.d.ts +2 -0
- package/dist/nodes/WeCom/resources/kf/sendKfEventMsg.js +53 -0
- package/dist/nodes/WeCom/resources/kf/sendKfEventMsg.js.map +1 -0
- package/dist/nodes/WeCom/resources/kf/sendKfMsg.d.ts +2 -0
- package/dist/nodes/WeCom/resources/kf/sendKfMsg.js +92 -0
- package/dist/nodes/WeCom/resources/kf/sendKfMsg.js.map +1 -0
- package/dist/nodes/WeCom/resources/kf/setUpgradeService.d.ts +2 -0
- package/dist/nodes/WeCom/resources/kf/setUpgradeService.js +32 -0
- package/dist/nodes/WeCom/resources/kf/setUpgradeService.js.map +1 -0
- package/dist/nodes/WeCom/resources/kf/transServiceState.d.ts +2 -0
- package/dist/nodes/WeCom/resources/kf/transServiceState.js +75 -0
- package/dist/nodes/WeCom/resources/kf/transServiceState.js.map +1 -0
- package/dist/nodes/WeCom/resources/kf/updateKfAccount.d.ts +2 -0
- package/dist/nodes/WeCom/resources/kf/updateKfAccount.js +41 -0
- package/dist/nodes/WeCom/resources/kf/updateKfAccount.js.map +1 -0
- package/dist/nodes/WeCom/shared/transport.js +11 -7
- package/dist/nodes/WeCom/shared/transport.js.map +1 -1
- package/dist/nodes/WeComWechat/WeComWechat.node.d.ts +5 -0
- package/dist/nodes/WeComWechat/WeComWechat.node.js +67 -0
- package/dist/nodes/WeComWechat/WeComWechat.node.js.map +1 -0
- package/dist/nodes/WeComWechat/WeComWechat.node.json +18 -0
- package/dist/package.json +4 -6
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +4 -6
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.transServiceStateDescription = void 0;
|
|
4
|
+
const showOnlyForTransServiceState = {
|
|
5
|
+
resource: ['kf'],
|
|
6
|
+
operation: ['transServiceState'],
|
|
7
|
+
};
|
|
8
|
+
exports.transServiceStateDescription = [
|
|
9
|
+
{
|
|
10
|
+
displayName: '客服账号ID',
|
|
11
|
+
name: 'open_kfid',
|
|
12
|
+
type: 'string',
|
|
13
|
+
required: true,
|
|
14
|
+
displayOptions: {
|
|
15
|
+
show: showOnlyForTransServiceState,
|
|
16
|
+
},
|
|
17
|
+
default: '',
|
|
18
|
+
hint: '客服账号ID',
|
|
19
|
+
},
|
|
20
|
+
{
|
|
21
|
+
displayName: '外部联系人ID',
|
|
22
|
+
name: 'external_userid',
|
|
23
|
+
type: 'string',
|
|
24
|
+
required: true,
|
|
25
|
+
displayOptions: {
|
|
26
|
+
show: showOnlyForTransServiceState,
|
|
27
|
+
},
|
|
28
|
+
default: '',
|
|
29
|
+
hint: '客户UserID',
|
|
30
|
+
},
|
|
31
|
+
{
|
|
32
|
+
displayName: '服务状态',
|
|
33
|
+
name: 'service_state',
|
|
34
|
+
type: 'options',
|
|
35
|
+
required: true,
|
|
36
|
+
displayOptions: {
|
|
37
|
+
show: showOnlyForTransServiceState,
|
|
38
|
+
},
|
|
39
|
+
options: [
|
|
40
|
+
{
|
|
41
|
+
name: '未处理',
|
|
42
|
+
value: 0,
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
name: '由智能助手接待',
|
|
46
|
+
value: 1,
|
|
47
|
+
},
|
|
48
|
+
{
|
|
49
|
+
name: '待Human接待',
|
|
50
|
+
value: 2,
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
name: '由Human接待',
|
|
54
|
+
value: 3,
|
|
55
|
+
},
|
|
56
|
+
{
|
|
57
|
+
name: '已结束',
|
|
58
|
+
value: 4,
|
|
59
|
+
},
|
|
60
|
+
],
|
|
61
|
+
default: 3,
|
|
62
|
+
hint: '变更的目标状态',
|
|
63
|
+
},
|
|
64
|
+
{
|
|
65
|
+
displayName: '接待人员UserID',
|
|
66
|
+
name: 'servicer_userid',
|
|
67
|
+
type: 'string',
|
|
68
|
+
displayOptions: {
|
|
69
|
+
show: showOnlyForTransServiceState,
|
|
70
|
+
},
|
|
71
|
+
default: '',
|
|
72
|
+
hint: '接待人员的userid(service_state=3时必填)',
|
|
73
|
+
},
|
|
74
|
+
];
|
|
75
|
+
//# sourceMappingURL=transServiceState.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"transServiceState.js","sourceRoot":"","sources":["../../../../../nodes/WeCom/resources/kf/transServiceState.ts"],"names":[],"mappings":";;;AAEA,MAAM,4BAA4B,GAAG;IACpC,QAAQ,EAAE,CAAC,IAAI,CAAC;IAChB,SAAS,EAAE,CAAC,mBAAmB,CAAC;CAChC,CAAC;AAEW,QAAA,4BAA4B,GAAsB;IAC9D;QACC,WAAW,EAAE,QAAQ;QACrB,IAAI,EAAE,WAAW;QACjB,IAAI,EAAE,QAAQ;QACd,QAAQ,EAAE,IAAI;QACd,cAAc,EAAE;YACf,IAAI,EAAE,4BAA4B;SAClC;QACD,OAAO,EAAE,EAAE;QACX,IAAI,EAAE,QAAQ;KACd;IACD;QACC,WAAW,EAAE,SAAS;QACtB,IAAI,EAAE,iBAAiB;QACvB,IAAI,EAAE,QAAQ;QACd,QAAQ,EAAE,IAAI;QACd,cAAc,EAAE;YACf,IAAI,EAAE,4BAA4B;SAClC;QACD,OAAO,EAAE,EAAE;QACX,IAAI,EAAE,UAAU;KAChB;IACD;QACC,WAAW,EAAE,MAAM;QACnB,IAAI,EAAE,eAAe;QACrB,IAAI,EAAE,SAAS;QACf,QAAQ,EAAE,IAAI;QACd,cAAc,EAAE;YACf,IAAI,EAAE,4BAA4B;SAClC;QACD,OAAO,EAAE;YACR;gBACC,IAAI,EAAE,KAAK;gBACX,KAAK,EAAE,CAAC;aACR;YACD;gBACC,IAAI,EAAE,SAAS;gBACf,KAAK,EAAE,CAAC;aACR;YACD;gBACC,IAAI,EAAE,UAAU;gBAChB,KAAK,EAAE,CAAC;aACR;YACD;gBACC,IAAI,EAAE,UAAU;gBAChB,KAAK,EAAE,CAAC;aACR;YACD;gBACC,IAAI,EAAE,KAAK;gBACX,KAAK,EAAE,CAAC;aACR;SACD;QACD,OAAO,EAAE,CAAC;QACV,IAAI,EAAE,SAAS;KACf;IACD;QACC,WAAW,EAAE,YAAY;QACzB,IAAI,EAAE,iBAAiB;QACvB,IAAI,EAAE,QAAQ;QACd,cAAc,EAAE;YACf,IAAI,EAAE,4BAA4B;SAClC;QACD,OAAO,EAAE,EAAE;QACX,IAAI,EAAE,iCAAiC;KACvC;CACD,CAAC"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.updateKfAccountDescription = void 0;
|
|
4
|
+
const showOnlyForUpdateKfAccount = {
|
|
5
|
+
resource: ['kf'],
|
|
6
|
+
operation: ['updateKfAccount'],
|
|
7
|
+
};
|
|
8
|
+
exports.updateKfAccountDescription = [
|
|
9
|
+
{
|
|
10
|
+
displayName: '客服账号ID',
|
|
11
|
+
name: 'open_kfid',
|
|
12
|
+
type: 'string',
|
|
13
|
+
required: true,
|
|
14
|
+
displayOptions: {
|
|
15
|
+
show: showOnlyForUpdateKfAccount,
|
|
16
|
+
},
|
|
17
|
+
default: '',
|
|
18
|
+
hint: '客服账号ID',
|
|
19
|
+
},
|
|
20
|
+
{
|
|
21
|
+
displayName: '客服名称',
|
|
22
|
+
name: 'name',
|
|
23
|
+
type: 'string',
|
|
24
|
+
displayOptions: {
|
|
25
|
+
show: showOnlyForUpdateKfAccount,
|
|
26
|
+
},
|
|
27
|
+
default: '',
|
|
28
|
+
hint: '客服名称,不多于16个字(可选)',
|
|
29
|
+
},
|
|
30
|
+
{
|
|
31
|
+
displayName: '客服头像',
|
|
32
|
+
name: 'media_id',
|
|
33
|
+
type: 'string',
|
|
34
|
+
displayOptions: {
|
|
35
|
+
show: showOnlyForUpdateKfAccount,
|
|
36
|
+
},
|
|
37
|
+
default: '',
|
|
38
|
+
hint: '客服头像临时素材(可选)',
|
|
39
|
+
},
|
|
40
|
+
];
|
|
41
|
+
//# sourceMappingURL=updateKfAccount.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"updateKfAccount.js","sourceRoot":"","sources":["../../../../../nodes/WeCom/resources/kf/updateKfAccount.ts"],"names":[],"mappings":";;;AAEA,MAAM,0BAA0B,GAAG;IAClC,QAAQ,EAAE,CAAC,IAAI,CAAC;IAChB,SAAS,EAAE,CAAC,iBAAiB,CAAC;CAC9B,CAAC;AAEW,QAAA,0BAA0B,GAAsB;IAC5D;QACC,WAAW,EAAE,QAAQ;QACrB,IAAI,EAAE,WAAW;QACjB,IAAI,EAAE,QAAQ;QACd,QAAQ,EAAE,IAAI;QACd,cAAc,EAAE;YACf,IAAI,EAAE,0BAA0B;SAChC;QACD,OAAO,EAAE,EAAE;QACX,IAAI,EAAE,QAAQ;KACd;IACD;QACC,WAAW,EAAE,MAAM;QACnB,IAAI,EAAE,MAAM;QACZ,IAAI,EAAE,QAAQ;QACd,cAAc,EAAE;YACf,IAAI,EAAE,0BAA0B;SAChC;QACD,OAAO,EAAE,EAAE;QACX,IAAI,EAAE,kBAAkB;KACxB;IACD;QACC,WAAW,EAAE,MAAM;QACnB,IAAI,EAAE,UAAU;QAChB,IAAI,EAAE,QAAQ;QACd,cAAc,EAAE;YACf,IAAI,EAAE,0BAA0B;SAChC;QACD,OAAO,EAAE,EAAE;QACX,IAAI,EAAE,cAAc;KACpB;CACD,CAAC"}
|
|
@@ -6,21 +6,23 @@ exports.weComApiRequest = weComApiRequest;
|
|
|
6
6
|
exports.uploadMedia = uploadMedia;
|
|
7
7
|
const n8n_workflow_1 = require("n8n-workflow");
|
|
8
8
|
const accessTokenCache = new Map();
|
|
9
|
-
const
|
|
10
|
-
|
|
9
|
+
const CACHE_CLEANUP_CONFIG = {
|
|
10
|
+
MAX_CACHE_AGE: 3 * 60 * 60 * 1000,
|
|
11
|
+
CLEANUP_THRESHOLD: 50,
|
|
12
|
+
};
|
|
11
13
|
function cleanupExpiredCache() {
|
|
12
|
-
if (accessTokenCache.size <= CLEANUP_THRESHOLD) {
|
|
14
|
+
if (accessTokenCache.size <= CACHE_CLEANUP_CONFIG.CLEANUP_THRESHOLD) {
|
|
13
15
|
return;
|
|
14
16
|
}
|
|
15
17
|
const now = Date.now();
|
|
16
18
|
for (const [key, cache] of accessTokenCache.entries()) {
|
|
17
|
-
if (cache.expiresAt < now || now - cache.lastAccess > MAX_CACHE_AGE) {
|
|
19
|
+
if (cache.expiresAt < now || now - cache.lastAccess > CACHE_CLEANUP_CONFIG.MAX_CACHE_AGE) {
|
|
18
20
|
accessTokenCache.delete(key);
|
|
19
21
|
}
|
|
20
22
|
}
|
|
21
23
|
}
|
|
22
24
|
function getCacheKey(credentials) {
|
|
23
|
-
return `${credentials.corpId}
|
|
25
|
+
return `${credentials.corpId}_${credentials.corpSecret}`;
|
|
24
26
|
}
|
|
25
27
|
function clearAccessTokenCache(credentials) {
|
|
26
28
|
const cacheKey = getCacheKey(credentials);
|
|
@@ -69,9 +71,10 @@ async function fetchAccessToken(credentials, cacheKey) {
|
|
|
69
71
|
throw new n8n_workflow_1.NodeOperationError(this.getNode(), `获取 Access Token 失败: ${response.errmsg} (错误码: ${response.errcode})`);
|
|
70
72
|
}
|
|
71
73
|
const expiresIn = response.expires_in || 7200;
|
|
74
|
+
const TOKEN_EXPIRE_BUFFER = 300;
|
|
72
75
|
accessTokenCache.set(cacheKey, {
|
|
73
76
|
token: response.access_token,
|
|
74
|
-
expiresAt: Date.now() + (expiresIn -
|
|
77
|
+
expiresAt: Date.now() + (expiresIn - TOKEN_EXPIRE_BUFFER) * 1000,
|
|
75
78
|
lastAccess: Date.now(),
|
|
76
79
|
});
|
|
77
80
|
return response.access_token;
|
|
@@ -100,7 +103,8 @@ async function weComApiRequest(method, resource, body = {}, qs = {}, headers = {
|
|
|
100
103
|
return response;
|
|
101
104
|
}
|
|
102
105
|
const jsonResponse = response;
|
|
103
|
-
|
|
106
|
+
const isTokenInvalid = jsonResponse.errcode === 40014 || jsonResponse.errcode === 42001;
|
|
107
|
+
if (isTokenInvalid && maxRetries > 0) {
|
|
104
108
|
const credentials = (await this.getCredentials('weComApi'));
|
|
105
109
|
clearAccessTokenCache(credentials);
|
|
106
110
|
return await weComApiRequest.call(this, method, resource, body, qs, headers, option, maxRetries - 1);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"transport.js","sourceRoot":"","sources":["../../../../nodes/WeCom/shared/transport.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"transport.js","sourceRoot":"","sources":["../../../../nodes/WeCom/shared/transport.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { IExecuteFunctions, INodeExecutionData, INodeType, INodeTypeDescription } from 'n8n-workflow';
|
|
2
|
+
export declare class WeComWechat implements INodeType {
|
|
3
|
+
description: INodeTypeDescription;
|
|
4
|
+
execute(this: IExecuteFunctions): Promise<INodeExecutionData[][]>;
|
|
5
|
+
}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.WeComWechat = void 0;
|
|
4
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
5
|
+
const kf_1 = require("../WeCom/resources/kf");
|
|
6
|
+
const execute_1 = require("../WeCom/resources/kf/execute");
|
|
7
|
+
class WeComWechat {
|
|
8
|
+
constructor() {
|
|
9
|
+
this.description = {
|
|
10
|
+
displayName: '企业微信-连接微信',
|
|
11
|
+
name: 'weComWechat',
|
|
12
|
+
icon: { light: 'file:../../icons/wecom.png', dark: 'file:../../icons/wecom.dark.png' },
|
|
13
|
+
group: ['transform'],
|
|
14
|
+
version: 1,
|
|
15
|
+
subtitle: '={{$parameter["operation"] + ": " + $parameter["resource"]}}',
|
|
16
|
+
description: '企业微信连接微信功能 - 微信客服',
|
|
17
|
+
defaults: {
|
|
18
|
+
name: '企业微信-连接微信',
|
|
19
|
+
},
|
|
20
|
+
inputs: [n8n_workflow_1.NodeConnectionTypes.Main],
|
|
21
|
+
outputs: [n8n_workflow_1.NodeConnectionTypes.Main],
|
|
22
|
+
credentials: [
|
|
23
|
+
{
|
|
24
|
+
name: 'weComApi',
|
|
25
|
+
required: true,
|
|
26
|
+
},
|
|
27
|
+
],
|
|
28
|
+
requestDefaults: {
|
|
29
|
+
baseURL: 'https://qyapi.weixin.qq.com',
|
|
30
|
+
headers: {
|
|
31
|
+
Accept: 'application/json',
|
|
32
|
+
'Content-Type': 'application/json',
|
|
33
|
+
},
|
|
34
|
+
},
|
|
35
|
+
properties: [
|
|
36
|
+
{
|
|
37
|
+
displayName: '资源',
|
|
38
|
+
name: 'resource',
|
|
39
|
+
type: 'options',
|
|
40
|
+
noDataExpression: true,
|
|
41
|
+
options: [
|
|
42
|
+
{
|
|
43
|
+
name: '微信客服',
|
|
44
|
+
value: 'kf',
|
|
45
|
+
description: '管理微信客服(客服账号、接待人员、消息收发等)',
|
|
46
|
+
},
|
|
47
|
+
],
|
|
48
|
+
default: 'kf',
|
|
49
|
+
},
|
|
50
|
+
...kf_1.kfDescription,
|
|
51
|
+
],
|
|
52
|
+
usableAsTool: true,
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
async execute() {
|
|
56
|
+
const items = this.getInputData();
|
|
57
|
+
const resource = this.getNodeParameter('resource', 0);
|
|
58
|
+
const operation = this.getNodeParameter('operation', 0);
|
|
59
|
+
let returnData = [];
|
|
60
|
+
if (resource === 'kf') {
|
|
61
|
+
returnData = await execute_1.executeKf.call(this, operation, items);
|
|
62
|
+
}
|
|
63
|
+
return [returnData];
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
exports.WeComWechat = WeComWechat;
|
|
67
|
+
//# sourceMappingURL=WeComWechat.node.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"WeComWechat.node.js","sourceRoot":"","sources":["../../../nodes/WeComWechat/WeComWechat.node.ts"],"names":[],"mappings":";;;AAMA,+CAAmD;AACnD,8CAAsD;AACtD,2DAA0D;AAE1D,MAAa,WAAW;IAAxB;QACC,gBAAW,GAAyB;YACnC,WAAW,EAAE,WAAW;YACxB,IAAI,EAAE,aAAa;YAEnB,IAAI,EAAE,EAAE,KAAK,EAAE,4BAA4B,EAAE,IAAI,EAAE,iCAAiC,EAAE;YACtF,KAAK,EAAE,CAAC,WAAW,CAAC;YACpB,OAAO,EAAE,CAAC;YACV,QAAQ,EAAE,8DAA8D;YACxE,WAAW,EAAE,mBAAmB;YAChC,QAAQ,EAAE;gBACT,IAAI,EAAE,WAAW;aACjB;YACD,MAAM,EAAE,CAAC,kCAAmB,CAAC,IAAI,CAAC;YAClC,OAAO,EAAE,CAAC,kCAAmB,CAAC,IAAI,CAAC;YACnC,WAAW,EAAE;gBACZ;oBACC,IAAI,EAAE,UAAU;oBAChB,QAAQ,EAAE,IAAI;iBACd;aACD;YACD,eAAe,EAAE;gBAChB,OAAO,EAAE,6BAA6B;gBACtC,OAAO,EAAE;oBACR,MAAM,EAAE,kBAAkB;oBAC1B,cAAc,EAAE,kBAAkB;iBAClC;aACD;YACD,UAAU,EAAE;gBACX;oBACC,WAAW,EAAE,IAAI;oBACjB,IAAI,EAAE,UAAU;oBAChB,IAAI,EAAE,SAAS;oBACf,gBAAgB,EAAE,IAAI;oBACtB,OAAO,EAAE;wBACR;4BACC,IAAI,EAAE,MAAM;4BACZ,KAAK,EAAE,IAAI;4BACX,WAAW,EAAE,yBAAyB;yBACtC;qBACD;oBACD,OAAO,EAAE,IAAI;iBACb;gBACD,GAAG,kBAAa;aAChB;YACD,YAAY,EAAE,IAAI;SAClB,CAAC;IAeH,CAAC;IAbA,KAAK,CAAC,OAAO;QACZ,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QAClC,MAAM,QAAQ,GAAG,IAAI,CAAC,gBAAgB,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC;QACtD,MAAM,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;QAExD,IAAI,UAAU,GAAyB,EAAE,CAAC;QAE1C,IAAI,QAAQ,KAAK,IAAI,EAAE,CAAC;YACvB,UAAU,GAAG,MAAM,mBAAS,CAAC,IAAI,CAAC,IAAI,EAAE,SAAmB,EAAE,KAAK,CAAC,CAAC;QACrE,CAAC;QAED,OAAO,CAAC,UAAU,CAAC,CAAC;IACrB,CAAC;CACD;AA7DD,kCA6DC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
{
|
|
2
|
+
"node": "n8n-nodes-base.weComWechat",
|
|
3
|
+
"nodeVersion": "1.0",
|
|
4
|
+
"codexVersion": "1.0",
|
|
5
|
+
"categories": ["Communication"],
|
|
6
|
+
"resources": {
|
|
7
|
+
"credentialDocumentation": [
|
|
8
|
+
{
|
|
9
|
+
"url": "https://developer.work.weixin.qq.com/document/path/94638"
|
|
10
|
+
}
|
|
11
|
+
],
|
|
12
|
+
"primaryDocumentation": [
|
|
13
|
+
{
|
|
14
|
+
"url": "https://developer.work.weixin.qq.com/document/path/94638"
|
|
15
|
+
}
|
|
16
|
+
]
|
|
17
|
+
}
|
|
18
|
+
}
|
package/dist/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "n8n-nodes-wecom",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.22",
|
|
4
4
|
"description": "n8n community node for WeCom (WeChat Work) integration. Send messages and manage contacts.",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"homepage": "https://github.com/funcodingdev/n8n-nodes-wecom",
|
|
@@ -25,10 +25,7 @@
|
|
|
25
25
|
"lint": "n8n-node lint",
|
|
26
26
|
"lint:fix": "n8n-node lint --fix",
|
|
27
27
|
"release": "n8n-node release",
|
|
28
|
-
"prepublishOnly": "n8n-node prerelease"
|
|
29
|
-
"install:local": "./scripts/dev-install.sh",
|
|
30
|
-
"uninstall:local": "./scripts/dev-uninstall.sh",
|
|
31
|
-
"start:local": "./scripts/dev-start.sh"
|
|
28
|
+
"prepublishOnly": "n8n-node prerelease"
|
|
32
29
|
},
|
|
33
30
|
"files": [
|
|
34
31
|
"dist"
|
|
@@ -44,7 +41,8 @@
|
|
|
44
41
|
"nodes": [
|
|
45
42
|
"dist/nodes/WeComBase/WeComBase.node.js",
|
|
46
43
|
"dist/nodes/WeComOffice/WeComOffice.node.js",
|
|
47
|
-
"dist/nodes/WeComTrigger/WeComTrigger.node.js"
|
|
44
|
+
"dist/nodes/WeComTrigger/WeComTrigger.node.js",
|
|
45
|
+
"dist/nodes/WeComWechat/WeComWechat.node.js"
|
|
48
46
|
]
|
|
49
47
|
},
|
|
50
48
|
"devDependencies": {
|