@huo15/dingtalk-connector-pro 1.0.0

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.
Files changed (62) hide show
  1. package/CHANGELOG.md +485 -0
  2. package/LICENSE +21 -0
  3. package/README.en.md +479 -0
  4. package/README.md +209 -0
  5. package/docs/AGENT_ROUTING.md +335 -0
  6. package/docs/DEAP_AGENT_GUIDE.en.md +115 -0
  7. package/docs/DEAP_AGENT_GUIDE.md +115 -0
  8. package/docs/images/dingtalk.svg +1 -0
  9. package/docs/images/image-1.png +0 -0
  10. package/docs/images/image-2.png +0 -0
  11. package/docs/images/image-3.png +0 -0
  12. package/docs/images/image-4.png +0 -0
  13. package/docs/images/image-5.png +0 -0
  14. package/docs/images/image-6.png +0 -0
  15. package/docs/images/image-7.png +0 -0
  16. package/index.ts +28 -0
  17. package/install-beta.sh +438 -0
  18. package/install-npm.sh +167 -0
  19. package/openclaw.plugin.json +498 -0
  20. package/package.json +80 -0
  21. package/src/channel.ts +463 -0
  22. package/src/config/accounts.ts +242 -0
  23. package/src/config/schema.ts +148 -0
  24. package/src/core/connection.ts +722 -0
  25. package/src/core/message-handler.ts +1700 -0
  26. package/src/core/provider.ts +111 -0
  27. package/src/core/state.ts +54 -0
  28. package/src/directory.ts +95 -0
  29. package/src/docs.ts +293 -0
  30. package/src/gateway-methods.ts +404 -0
  31. package/src/onboarding.ts +413 -0
  32. package/src/policy.ts +32 -0
  33. package/src/probe.ts +212 -0
  34. package/src/reply-dispatcher.ts +630 -0
  35. package/src/runtime.ts +32 -0
  36. package/src/sdk/helpers.ts +322 -0
  37. package/src/sdk/types.ts +513 -0
  38. package/src/secret-input.ts +19 -0
  39. package/src/services/media/audio.ts +54 -0
  40. package/src/services/media/chunk-upload.ts +296 -0
  41. package/src/services/media/common.ts +155 -0
  42. package/src/services/media/file.ts +70 -0
  43. package/src/services/media/image.ts +81 -0
  44. package/src/services/media/index.ts +10 -0
  45. package/src/services/media/video.ts +162 -0
  46. package/src/services/media.ts +1136 -0
  47. package/src/services/messaging/card.ts +342 -0
  48. package/src/services/messaging/index.ts +17 -0
  49. package/src/services/messaging/send.ts +141 -0
  50. package/src/services/messaging.ts +1013 -0
  51. package/src/targets.ts +45 -0
  52. package/src/types/index.ts +59 -0
  53. package/src/utils/agent.ts +63 -0
  54. package/src/utils/async.ts +51 -0
  55. package/src/utils/constants.ts +27 -0
  56. package/src/utils/http-client.ts +37 -0
  57. package/src/utils/index.ts +8 -0
  58. package/src/utils/logger.ts +78 -0
  59. package/src/utils/session.ts +147 -0
  60. package/src/utils/token.ts +93 -0
  61. package/src/utils/utils-legacy.ts +454 -0
  62. package/tsconfig.json +20 -0
@@ -0,0 +1,148 @@
1
+ import { normalizeAccountId } from "../sdk/helpers.ts";
2
+ import { z } from "zod";
3
+ export { z };
4
+ import { buildSecretInputSchema, hasConfiguredSecretInput } from "../secret-input.ts";
5
+
6
+ const DmPolicySchema = z.enum(["open", "pairing", "allowlist"]);
7
+ const GroupPolicySchema = z.enum(["open", "allowlist", "disabled"]);
8
+
9
+ const ToolPolicySchema = z
10
+ .object({
11
+ allow: z.array(z.string()).optional(),
12
+ deny: z.array(z.string()).optional(),
13
+ })
14
+ .strict()
15
+ .optional();
16
+
17
+ /**
18
+ * Group session scope for routing DingTalk group messages.
19
+ * - "group" (default): one session per group chat
20
+ * - "group_sender": one session per (group + sender)
21
+ */
22
+ const GroupSessionScopeSchema = z
23
+ .enum(["group", "group_sender"])
24
+ .optional();
25
+
26
+ /**
27
+ * Dingtalk tools configuration.
28
+ * Controls which tool categories are enabled.
29
+ */
30
+ const DingtalkToolsConfigSchema = z
31
+ .object({
32
+ docs: z.boolean().optional(), // Document operations (default: true)
33
+ media: z.boolean().optional(), // Media upload operations (default: true)
34
+ })
35
+ .strict()
36
+ .optional();
37
+
38
+ export const DingtalkGroupSchema = z
39
+ .object({
40
+ requireMention: z.boolean().optional(),
41
+ tools: ToolPolicySchema,
42
+ enabled: z.boolean().optional(),
43
+ allowFrom: z.array(z.union([z.string(), z.number()])).optional(),
44
+ systemPrompt: z.string().optional(),
45
+ groupSessionScope: GroupSessionScopeSchema,
46
+ })
47
+ .strict();
48
+
49
+ const DingtalkSharedConfigShape = {
50
+ dmPolicy: DmPolicySchema.optional(),
51
+ allowFrom: z.array(z.union([z.string(), z.number()])).optional(),
52
+ groupPolicy: GroupPolicySchema.optional(),
53
+ groupAllowFrom: z.array(z.union([z.string(), z.number()])).optional(),
54
+ requireMention: z.boolean().optional(),
55
+ groups: z.record(z.string(), DingtalkGroupSchema.optional()).optional(),
56
+ historyLimit: z.number().int().min(0).optional(),
57
+ textChunkLimit: z.number().int().positive().optional(),
58
+ mediaMaxMb: z.number().positive().optional(),
59
+ tools: DingtalkToolsConfigSchema,
60
+ typingIndicator: z.boolean().optional(),
61
+ resolveSenderNames: z.boolean().optional(),
62
+ separateSessionByConversation: z.boolean().optional(),
63
+ sharedMemoryAcrossConversations: z.boolean().optional(),
64
+ groupSessionScope: GroupSessionScopeSchema,
65
+ asyncMode: z.boolean().optional(),
66
+ ackText: z.string().optional(),
67
+ endpoint: z.string().optional(), // DWClient gateway endpoint
68
+ debug: z.boolean().optional(), // DWClient debug mode
69
+ };
70
+
71
+ /**
72
+ * Per-account configuration.
73
+ * All fields are optional - missing fields inherit from top-level config.
74
+ */
75
+ export const DingtalkAccountConfigSchema = z
76
+ .object({
77
+ enabled: z.boolean().optional(),
78
+ name: z.string().optional(), // Display name for this account
79
+ clientId: z.union([z.string(), z.number()]).optional(),
80
+ clientSecret: buildSecretInputSchema().optional(),
81
+ ...DingtalkSharedConfigShape,
82
+ })
83
+ .strict();
84
+
85
+ /**
86
+ * Base schema (ZodObject) without superRefine, used for JSON Schema generation (Web UI).
87
+ * superRefine turns the schema into ZodEffects which is not compatible with buildChannelConfigSchema.
88
+ */
89
+ export const DingtalkConfigBaseSchema = z
90
+ .object({
91
+ enabled: z.boolean().optional(),
92
+ defaultAccount: z.string().optional(),
93
+ // Top-level credentials (backward compatible for single-account mode)
94
+ clientId: z.union([z.string(), z.number()]).optional(),
95
+ clientSecret: buildSecretInputSchema().optional(),
96
+ enableMediaUpload: z.boolean().optional(),
97
+ systemPrompt: z.string().optional(),
98
+ ...DingtalkSharedConfigShape,
99
+ dmPolicy: DmPolicySchema.optional().default("open"),
100
+ groupPolicy: GroupPolicySchema.optional().default("open"),
101
+ requireMention: z.boolean().optional().default(true),
102
+ separateSessionByConversation: z.boolean().optional().default(true),
103
+ sharedMemoryAcrossConversations: z.boolean().optional().default(false),
104
+ groupSessionScope: GroupSessionScopeSchema.optional().default("group"),
105
+ // Multi-account configuration
106
+ accounts: z.record(z.string(), DingtalkAccountConfigSchema.optional()).optional(),
107
+ })
108
+ .strict();
109
+
110
+ export const DingtalkConfigSchema = DingtalkConfigBaseSchema.superRefine((value, ctx) => {
111
+ const defaultAccount = value.defaultAccount?.trim();
112
+ if (defaultAccount && value.accounts && Object.keys(value.accounts).length > 0) {
113
+ const normalizedDefaultAccount = normalizeAccountId(defaultAccount);
114
+ if (!Object.prototype.hasOwnProperty.call(value.accounts, normalizedDefaultAccount)) {
115
+ ctx.addIssue({
116
+ code: z.ZodIssueCode.custom,
117
+ path: ["defaultAccount"],
118
+ message: `channels.dingtalk-connector.defaultAccount="${defaultAccount}" does not match a configured account key`,
119
+ });
120
+ }
121
+ }
122
+
123
+ // Validate dmPolicy and allowFrom consistency
124
+ if (value.dmPolicy === "allowlist") {
125
+ const allowFrom = value.allowFrom ?? [];
126
+ if (allowFrom.length === 0) {
127
+ ctx.addIssue({
128
+ code: z.ZodIssueCode.custom,
129
+ path: ["allowFrom"],
130
+ message:
131
+ 'channels.dingtalk-connector.dmPolicy="allowlist" requires channels.dingtalk-connector.allowFrom to contain at least one entry',
132
+ });
133
+ }
134
+ }
135
+
136
+ // Validate groupPolicy and groupAllowFrom consistency
137
+ if (value.groupPolicy === "allowlist") {
138
+ const groupAllowFrom = value.groupAllowFrom ?? [];
139
+ if (groupAllowFrom.length === 0) {
140
+ ctx.addIssue({
141
+ code: z.ZodIssueCode.custom,
142
+ path: ["groupAllowFrom"],
143
+ message:
144
+ 'channels.dingtalk-connector.groupPolicy="allowlist" requires channels.dingtalk-connector.groupAllowFrom to contain at least one entry',
145
+ });
146
+ }
147
+ }
148
+ });