plugin-agent-orchestrator 1.0.28 → 1.0.32

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 (108) hide show
  1. package/README.md +9 -7
  2. package/dist/client/index.js +1 -1
  3. package/dist/client-v2/{214.723affb37c13bf7a.js → 214.79650a549273f163.js} +1 -1
  4. package/dist/client-v2/264.718a107e43fc163c.js +10 -0
  5. package/dist/client-v2/373.f5d5292e53c4e832.js +10 -0
  6. package/dist/client-v2/{41.1805b2edfaa4afe2.js → 41.ba6e080cc0488143.js} +1 -1
  7. package/dist/client-v2/418.29e713f79131eece.js +10 -0
  8. package/dist/client-v2/619.bd3c5698b40705c3.js +10 -0
  9. package/dist/client-v2/677.a991ce0250ff5c77.js +10 -0
  10. package/dist/client-v2/{70.a15d7fcec7c41768.js → 70.bda9518881c05360.js} +1 -1
  11. package/dist/client-v2/925.f5370de8f6632d65.js +10 -0
  12. package/dist/client-v2/index.js +1 -1
  13. package/dist/externalVersion.js +7 -10
  14. package/dist/locale/en-US.json +94 -25
  15. package/dist/locale/vi-VN.json +94 -25
  16. package/dist/locale/zh-CN.json +94 -25
  17. package/dist/server/collections/agent-execution-spans.js +37 -0
  18. package/dist/server/collections/agent-harness-profiles.js +2 -2
  19. package/dist/server/collections/agent-memory-contexts.js +125 -0
  20. package/dist/server/collections/orchestrator-logs.js +2 -2
  21. package/dist/server/migrations/20260425000000-add-interaction-schema.js +3 -1
  22. package/dist/server/migrations/20260427000000-change-packages-to-text.js +3 -1
  23. package/dist/server/migrations/20260427000001-change-other-json-to-text.js +6 -2
  24. package/dist/server/migrations/20260524001000-add-plan-approval-and-harness-profiles.js +21 -19
  25. package/dist/server/migrations/20260621000000-native-policy-profile-defaults.js +193 -0
  26. package/dist/server/plugin.js +128 -74
  27. package/dist/server/resources/agent-monitor.js +454 -0
  28. package/dist/server/services/AgentHarness.js +24 -499
  29. package/dist/server/services/AgentMemoryContextService.js +216 -0
  30. package/dist/server/services/ExecutionSpanService.js +2 -2
  31. package/dist/server/services/NativeSubAgentObserver.js +413 -0
  32. package/dist/server/skill-hub/plugin.js +81 -5
  33. package/dist/server/skill-hub/tasks/SkillExecutionTask.js +9 -3
  34. package/dist/server/tools/delegate-task.js +11 -589
  35. package/dist/server/utils/skill-settings.js +18 -1
  36. package/package.json +47 -49
  37. package/src/client/AIEmployeesContext.tsx +5 -18
  38. package/src/client/AgentRunsTab.tsx +2 -771
  39. package/src/client/HarnessProfilesTab.tsx +2 -257
  40. package/src/client/OrchestratorSettings.tsx +97 -106
  41. package/src/client/RulesTab.tsx +2 -788
  42. package/src/client/plugin.tsx +0 -2
  43. package/src/client/skill-hub/components/ExecutionHistory.tsx +200 -202
  44. package/src/client/skill-hub/components/ExecutionProgress.tsx +51 -55
  45. package/src/client/skill-hub/components/LoopSettings.tsx +331 -331
  46. package/src/client/skill-hub/components/SkillEditor.tsx +43 -39
  47. package/src/client/skill-hub/components/SkillManager.tsx +194 -181
  48. package/src/client/skill-hub/components/SkillTestPanel.tsx +141 -145
  49. package/src/client/skill-hub/locale.ts +16 -16
  50. package/src/client/skill-hub/tools/SkillHubCard.tsx +104 -109
  51. package/src/client/skill-hub/tools/loopTemplates.ts +52 -52
  52. package/src/client/skill-hub/utils/jsonFields.ts +7 -3
  53. package/src/client-v2/components/AIEmployeesContext.tsx +3 -16
  54. package/src/client-v2/components/AgentRunsTab.tsx +182 -455
  55. package/src/client-v2/components/HarnessProfilesTab.tsx +34 -31
  56. package/src/client-v2/components/RulesTab.tsx +2 -782
  57. package/src/client-v2/components/TracingTab.tsx +1 -1
  58. package/src/client-v2/hooks/useApiRequest.ts +8 -1
  59. package/src/client-v2/pages/RulesPage.tsx +2 -2
  60. package/src/client-v2/plugin.tsx +3 -3
  61. package/src/locale/en-US.json +94 -25
  62. package/src/locale/vi-VN.json +94 -25
  63. package/src/locale/zh-CN.json +94 -25
  64. package/src/server/__tests__/native-sub-agent-observer.test.ts +246 -0
  65. package/src/server/__tests__/skill-settings.test.ts +6 -6
  66. package/src/server/__tests__/smoke.test.ts +1 -0
  67. package/src/server/collections/agent-execution-spans.ts +37 -0
  68. package/src/server/collections/agent-harness-profiles.ts +59 -59
  69. package/src/server/collections/agent-loop-events.ts +71 -71
  70. package/src/server/collections/agent-loop-steps.ts +144 -144
  71. package/src/server/collections/agent-memory-contexts.ts +95 -0
  72. package/src/server/collections/orchestrator-logs.ts +4 -4
  73. package/src/server/collections/skill-definitions.ts +111 -111
  74. package/src/server/collections/skill-executions.ts +106 -106
  75. package/src/server/collections/skill-loop-configs.ts +65 -65
  76. package/src/server/migrations/20260423000000-add-progress-fields.ts +14 -14
  77. package/src/server/migrations/20260425000000-add-interaction-schema.ts +3 -1
  78. package/src/server/migrations/20260427000000-change-packages-to-text.ts +4 -2
  79. package/src/server/migrations/20260427000001-change-other-json-to-text.ts +9 -5
  80. package/src/server/migrations/20260524000000-add-agent-loop-fields-to-skill-executions.ts +30 -30
  81. package/src/server/migrations/20260524001000-add-plan-approval-and-harness-profiles.ts +145 -142
  82. package/src/server/migrations/20260615000000-normalize-ai-employee-tool-bindings.ts +2 -2
  83. package/src/server/migrations/20260621000000-native-policy-profile-defaults.ts +193 -0
  84. package/src/server/plugin.ts +151 -94
  85. package/src/server/resources/agent-monitor.ts +482 -0
  86. package/src/server/services/AgentHarness.ts +38 -623
  87. package/src/server/services/AgentMemoryContextService.ts +256 -0
  88. package/src/server/services/AgentPlanValidator.ts +73 -73
  89. package/src/server/services/ExecutionSpanService.ts +6 -2
  90. package/src/server/services/FileManager.ts +144 -144
  91. package/src/server/services/NativeSubAgentObserver.ts +507 -0
  92. package/src/server/services/SkillManager.ts +583 -583
  93. package/src/server/services/SkillRepositoryService.ts +5 -7
  94. package/src/server/services/TokenTracker.ts +3 -3
  95. package/src/server/services/WorkerEnvManager.ts +1 -2
  96. package/src/server/skill-hub/actions/git-import.ts +5 -7
  97. package/src/server/skill-hub/plugin.ts +89 -6
  98. package/src/server/skill-hub/tasks/SkillExecutionTask.ts +470 -460
  99. package/src/server/skill-hub/utils/json-fields.ts +1 -1
  100. package/src/server/tools/delegate-task.ts +13 -847
  101. package/src/server/utils/skill-settings.ts +24 -6
  102. package/dist/client-v2/264.0533912e6c5ea2d7.js +0 -10
  103. package/dist/client-v2/418.5ae055abf141820e.js +0 -10
  104. package/dist/client-v2/619.d99d3c9e61c99064.js +0 -10
  105. package/dist/client-v2/892.72db4161511c8a16.js +0 -10
  106. package/dist/client-v2/926.87f660b670d85bcc.js +0 -10
  107. package/src/client/tools/PlanApprovalCard.tsx +0 -176
  108. package/src/client/tools/registerOrchestratorCards.ts +0 -17
@@ -1,144 +1,144 @@
1
- import { defineCollection } from '@nocobase/database';
2
-
3
- export default defineCollection({
4
- name: 'agentLoopSteps',
5
- title: 'Agent Loop Steps',
6
- fields: [
7
- {
8
- name: 'id',
9
- type: 'bigInt',
10
- autoIncrement: true,
11
- primaryKey: true,
12
- },
13
- {
14
- name: 'run',
15
- type: 'belongsTo',
16
- target: 'agentLoopRuns',
17
- foreignKey: 'runId',
18
- },
19
- {
20
- name: 'parentStep',
21
- type: 'belongsTo',
22
- target: 'agentLoopSteps',
23
- foreignKey: 'parentStepId',
24
- },
25
- {
26
- name: 'planKey',
27
- type: 'string',
28
- length: 100,
29
- },
30
- {
31
- name: 'index',
32
- type: 'integer',
33
- defaultValue: 0,
34
- },
35
- {
36
- name: 'title',
37
- type: 'string',
38
- length: 500,
39
- },
40
- {
41
- name: 'description',
42
- type: 'text',
43
- },
44
- {
45
- name: 'type',
46
- type: 'string',
47
- length: 30,
48
- comment: 'reasoning, skill, tool, sub_agent, verification',
49
- },
50
- {
51
- name: 'target',
52
- type: 'string',
53
- length: 200,
54
- },
55
- {
56
- name: 'input',
57
- type: 'json',
58
- defaultValue: {},
59
- },
60
- {
61
- name: 'output',
62
- type: 'json',
63
- defaultValue: {},
64
- },
65
- {
66
- name: 'status',
67
- type: 'string',
68
- length: 30,
69
- defaultValue: 'pending',
70
- comment: 'pending, running, waiting_user, succeeded, failed, skipped',
71
- },
72
- {
73
- name: 'attempt',
74
- type: 'integer',
75
- defaultValue: 0,
76
- },
77
- {
78
- name: 'maxAttempts',
79
- type: 'integer',
80
- defaultValue: 2,
81
- },
82
- {
83
- name: 'dependsOn',
84
- type: 'json',
85
- defaultValue: [],
86
- },
87
- {
88
- name: 'dependencyPolicy',
89
- type: 'string',
90
- length: 30,
91
- defaultValue: 'require_success',
92
- comment: 'require_success or allow_skipped',
93
- },
94
- {
95
- name: 'approval',
96
- type: 'json',
97
- defaultValue: {},
98
- },
99
- {
100
- name: 'error',
101
- type: 'text',
102
- },
103
- {
104
- name: 'agentExecutionSpanId',
105
- type: 'bigInt',
106
- },
107
- {
108
- name: 'skillExecutionId',
109
- type: 'bigInt',
110
- },
111
- {
112
- name: 'metadata',
113
- type: 'json',
114
- defaultValue: {},
115
- },
116
- {
117
- name: 'startedAt',
118
- type: 'date',
119
- },
120
- {
121
- name: 'endedAt',
122
- type: 'date',
123
- },
124
- {
125
- name: 'createdAt',
126
- type: 'date',
127
- },
128
- {
129
- name: 'updatedAt',
130
- type: 'date',
131
- },
132
- ],
133
- indexes: [
134
- {
135
- fields: ['runId'],
136
- },
137
- {
138
- fields: ['status'],
139
- },
140
- {
141
- fields: ['planKey'],
142
- },
143
- ],
144
- });
1
+ import { defineCollection } from '@nocobase/database';
2
+
3
+ export default defineCollection({
4
+ name: 'agentLoopSteps',
5
+ title: 'Agent Loop Steps',
6
+ fields: [
7
+ {
8
+ name: 'id',
9
+ type: 'bigInt',
10
+ autoIncrement: true,
11
+ primaryKey: true,
12
+ },
13
+ {
14
+ name: 'run',
15
+ type: 'belongsTo',
16
+ target: 'agentLoopRuns',
17
+ foreignKey: 'runId',
18
+ },
19
+ {
20
+ name: 'parentStep',
21
+ type: 'belongsTo',
22
+ target: 'agentLoopSteps',
23
+ foreignKey: 'parentStepId',
24
+ },
25
+ {
26
+ name: 'planKey',
27
+ type: 'string',
28
+ length: 100,
29
+ },
30
+ {
31
+ name: 'index',
32
+ type: 'integer',
33
+ defaultValue: 0,
34
+ },
35
+ {
36
+ name: 'title',
37
+ type: 'string',
38
+ length: 500,
39
+ },
40
+ {
41
+ name: 'description',
42
+ type: 'text',
43
+ },
44
+ {
45
+ name: 'type',
46
+ type: 'string',
47
+ length: 30,
48
+ comment: 'reasoning, skill, tool, sub_agent, verification',
49
+ },
50
+ {
51
+ name: 'target',
52
+ type: 'string',
53
+ length: 200,
54
+ },
55
+ {
56
+ name: 'input',
57
+ type: 'json',
58
+ defaultValue: {},
59
+ },
60
+ {
61
+ name: 'output',
62
+ type: 'json',
63
+ defaultValue: {},
64
+ },
65
+ {
66
+ name: 'status',
67
+ type: 'string',
68
+ length: 30,
69
+ defaultValue: 'pending',
70
+ comment: 'pending, running, waiting_user, succeeded, failed, skipped',
71
+ },
72
+ {
73
+ name: 'attempt',
74
+ type: 'integer',
75
+ defaultValue: 0,
76
+ },
77
+ {
78
+ name: 'maxAttempts',
79
+ type: 'integer',
80
+ defaultValue: 2,
81
+ },
82
+ {
83
+ name: 'dependsOn',
84
+ type: 'json',
85
+ defaultValue: [],
86
+ },
87
+ {
88
+ name: 'dependencyPolicy',
89
+ type: 'string',
90
+ length: 30,
91
+ defaultValue: 'require_success',
92
+ comment: 'require_success or allow_skipped',
93
+ },
94
+ {
95
+ name: 'approval',
96
+ type: 'json',
97
+ defaultValue: {},
98
+ },
99
+ {
100
+ name: 'error',
101
+ type: 'text',
102
+ },
103
+ {
104
+ name: 'agentExecutionSpanId',
105
+ type: 'bigInt',
106
+ },
107
+ {
108
+ name: 'skillExecutionId',
109
+ type: 'bigInt',
110
+ },
111
+ {
112
+ name: 'metadata',
113
+ type: 'json',
114
+ defaultValue: {},
115
+ },
116
+ {
117
+ name: 'startedAt',
118
+ type: 'date',
119
+ },
120
+ {
121
+ name: 'endedAt',
122
+ type: 'date',
123
+ },
124
+ {
125
+ name: 'createdAt',
126
+ type: 'date',
127
+ },
128
+ {
129
+ name: 'updatedAt',
130
+ type: 'date',
131
+ },
132
+ ],
133
+ indexes: [
134
+ {
135
+ fields: ['runId'],
136
+ },
137
+ {
138
+ fields: ['status'],
139
+ },
140
+ {
141
+ fields: ['planKey'],
142
+ },
143
+ ],
144
+ });
@@ -0,0 +1,95 @@
1
+ import { defineCollection } from '@nocobase/database';
2
+
3
+ export default defineCollection({
4
+ name: 'agentMemoryContexts',
5
+ title: 'Agent Memory Contexts',
6
+ fields: [
7
+ {
8
+ name: 'id',
9
+ type: 'bigInt',
10
+ autoIncrement: true,
11
+ primaryKey: true,
12
+ },
13
+ {
14
+ name: 'scope',
15
+ type: 'string',
16
+ length: 30,
17
+ allowNull: false,
18
+ comment: 'public, user, or agent_user',
19
+ },
20
+ {
21
+ name: 'contextKey',
22
+ type: 'string',
23
+ length: 300,
24
+ allowNull: false,
25
+ comment: 'Normalized unique key: scope:userId:aiEmployeeUsername.',
26
+ },
27
+ {
28
+ name: 'userId',
29
+ type: 'bigInt',
30
+ comment: 'Null for public agent knowledge; required for user/private scopes.',
31
+ },
32
+ {
33
+ name: 'user',
34
+ type: 'belongsTo',
35
+ target: 'users',
36
+ targetKey: 'id',
37
+ foreignKey: 'userId',
38
+ },
39
+ {
40
+ name: 'aiEmployeeUsername',
41
+ type: 'string',
42
+ length: 100,
43
+ comment: 'Target AI employee username; null/empty means shared within the scope.',
44
+ },
45
+ {
46
+ name: 'contentMd',
47
+ type: 'text',
48
+ comment: 'Markdown facts, preferences, or operating notes for the agent context.',
49
+ },
50
+ {
51
+ name: 'graphMd',
52
+ type: 'text',
53
+ comment: 'Markdown graph or relationship notes for the agent context.',
54
+ },
55
+ {
56
+ name: 'enabled',
57
+ type: 'boolean',
58
+ defaultValue: true,
59
+ },
60
+ {
61
+ name: 'metadata',
62
+ type: 'json',
63
+ defaultValue: {},
64
+ },
65
+ {
66
+ name: 'createdAt',
67
+ type: 'date',
68
+ },
69
+ {
70
+ name: 'updatedAt',
71
+ type: 'date',
72
+ },
73
+ ],
74
+ indexes: [
75
+ {
76
+ unique: true,
77
+ fields: ['contextKey'],
78
+ },
79
+ {
80
+ fields: ['scope', 'userId', 'aiEmployeeUsername'],
81
+ },
82
+ {
83
+ fields: ['scope'],
84
+ },
85
+ {
86
+ fields: ['userId'],
87
+ },
88
+ {
89
+ fields: ['aiEmployeeUsername'],
90
+ },
91
+ {
92
+ fields: ['enabled'],
93
+ },
94
+ ],
95
+ });
@@ -3,8 +3,8 @@ import { defineCollection } from '@nocobase/database';
3
3
  /**
4
4
  * Stores delegation execution logs for Swarm Tracing (Phase 5).
5
5
  *
6
- * Since createReactAgent doesn't create aiConversation records,
7
- * we log delegation events to a dedicated table for observability.
6
+ * Legacy delegation events were logged to a dedicated table for observability.
7
+ * Native plugin-ai runs are now observed through agentExecutionSpans.
8
8
  */
9
9
  export default defineCollection({
10
10
  name: 'orchestratorLogs',
@@ -31,7 +31,7 @@ export default defineCollection({
31
31
  {
32
32
  name: 'toolName',
33
33
  type: 'string',
34
- comment: 'The tool name used for delegation (e.g., delegate_pm_to_sql_expert)',
34
+ comment: 'Legacy delegation or native dispatch tool name',
35
35
  },
36
36
  {
37
37
  name: 'context',
@@ -79,7 +79,7 @@ export default defineCollection({
79
79
  name: 'messages',
80
80
  type: 'json',
81
81
  defaultValue: [],
82
- comment: 'Serialized LangChain messages from the sub-agent run',
82
+ comment: 'Serialized message snapshots from the sub-agent run',
83
83
  },
84
84
  {
85
85
  name: 'userId',
@@ -1,51 +1,51 @@
1
- import { CollectionOptions } from '@nocobase/database';
2
-
3
- export default {
4
- name: 'skillDefinitions',
5
- title: 'Skill Definitions',
6
- fields: [
7
- {
8
- name: 'id',
9
- type: 'bigInt',
10
- autoIncrement: true,
11
- primaryKey: true,
12
- },
13
- {
14
- name: 'name',
15
- type: 'string',
16
- length: 100,
17
- unique: true,
18
- },
19
- {
20
- name: 'title',
21
- type: 'string',
22
- length: 200,
23
- },
24
- {
25
- name: 'description',
26
- type: 'text',
27
- },
28
- {
29
- name: 'instructions',
30
- type: 'text',
31
- },
32
- {
33
- // 'node' | 'python'
34
- name: 'language',
35
- type: 'string',
36
- length: 20,
37
- },
38
- {
39
- // Code template with {{placeholder}} support
40
- name: 'codeTemplate',
41
- type: 'text',
42
- },
1
+ import { CollectionOptions } from '@nocobase/database';
2
+
3
+ export default {
4
+ name: 'skillDefinitions',
5
+ title: 'Skill Definitions',
6
+ fields: [
7
+ {
8
+ name: 'id',
9
+ type: 'bigInt',
10
+ autoIncrement: true,
11
+ primaryKey: true,
12
+ },
13
+ {
14
+ name: 'name',
15
+ type: 'string',
16
+ length: 100,
17
+ unique: true,
18
+ },
19
+ {
20
+ name: 'title',
21
+ type: 'string',
22
+ length: 200,
23
+ },
24
+ {
25
+ name: 'description',
26
+ type: 'text',
27
+ },
28
+ {
29
+ name: 'instructions',
30
+ type: 'text',
31
+ },
32
+ {
33
+ // 'node' | 'python'
34
+ name: 'language',
35
+ type: 'string',
36
+ length: 20,
37
+ },
38
+ {
39
+ // Code template with {{placeholder}} support
40
+ name: 'codeTemplate',
41
+ type: 'text',
42
+ },
43
43
  {
44
44
  // JSON Schema for input parameters (used by AI tool)
45
45
  name: 'inputSchema',
46
46
  type: 'text',
47
47
  },
48
- {
48
+ {
49
49
  // Optional UI schema for human-in-the-loop interaction.
50
50
  // Shape: { type: 'form'|'select'|'confirm', prompt: string,
51
51
  // options?: {label,value}[], fields?: Record<string, {type,title,required,enum}> }
@@ -58,71 +58,71 @@ export default {
58
58
  type: 'text',
59
59
  defaultValue: null,
60
60
  },
61
- {
62
- name: 'timeoutSeconds',
63
- type: 'integer',
64
- defaultValue: 60,
65
- },
66
- {
67
- name: 'maxOutputSizeMb',
68
- type: 'integer',
69
- defaultValue: 50,
70
- },
71
- {
72
- name: 'enabled',
73
- type: 'boolean',
74
- defaultValue: true,
75
- },
76
- {
77
- // 'CUSTOM' | 'GENERAL' | 'SPECIFIED'
78
- name: 'toolScope',
79
- type: 'string',
80
- length: 20,
81
- defaultValue: 'CUSTOM',
82
- },
83
- {
84
- name: 'autoCall',
85
- type: 'boolean',
86
- defaultValue: false,
87
- },
88
- {
89
- // Which plugin registered this skill. null = built-in / user-created.
90
- // Format: plugin package name, e.g. 'plugin-skill-pptx-advanced'
91
- name: 'pluginSource',
92
- type: 'string',
93
- length: 200,
94
- defaultValue: null,
95
- },
96
- {
97
- name: 'storageType',
98
- type: 'string',
99
- length: 20,
100
- defaultValue: 'database', // 'database', 'local', 's3', 'plugin'
101
- },
102
- {
103
- name: 'storageUrl',
104
- type: 'string',
105
- length: 1000,
106
- },
107
- {
108
- name: 'file',
109
- type: 'belongsTo',
110
- target: 'attachments',
111
- foreignKey: 'fileId',
112
- },
113
- {
114
- name: 'createdAt',
115
- type: 'date',
116
- },
117
- {
118
- name: 'updatedAt',
119
- type: 'date',
120
- },
121
- {
122
- name: 'createdBy',
123
- type: 'belongsTo',
124
- target: 'users',
125
- foreignKey: 'createdById',
126
- },
127
- ],
128
- } as CollectionOptions;
61
+ {
62
+ name: 'timeoutSeconds',
63
+ type: 'integer',
64
+ defaultValue: 60,
65
+ },
66
+ {
67
+ name: 'maxOutputSizeMb',
68
+ type: 'integer',
69
+ defaultValue: 50,
70
+ },
71
+ {
72
+ name: 'enabled',
73
+ type: 'boolean',
74
+ defaultValue: true,
75
+ },
76
+ {
77
+ // 'CUSTOM' | 'GENERAL' | 'SPECIFIED'
78
+ name: 'toolScope',
79
+ type: 'string',
80
+ length: 20,
81
+ defaultValue: 'CUSTOM',
82
+ },
83
+ {
84
+ name: 'autoCall',
85
+ type: 'boolean',
86
+ defaultValue: false,
87
+ },
88
+ {
89
+ // Which plugin registered this skill. null = built-in / user-created.
90
+ // Format: plugin package name, e.g. 'plugin-skill-pptx-advanced'
91
+ name: 'pluginSource',
92
+ type: 'string',
93
+ length: 200,
94
+ defaultValue: null,
95
+ },
96
+ {
97
+ name: 'storageType',
98
+ type: 'string',
99
+ length: 20,
100
+ defaultValue: 'database', // 'database', 'local', 's3', 'plugin'
101
+ },
102
+ {
103
+ name: 'storageUrl',
104
+ type: 'string',
105
+ length: 1000,
106
+ },
107
+ {
108
+ name: 'file',
109
+ type: 'belongsTo',
110
+ target: 'attachments',
111
+ foreignKey: 'fileId',
112
+ },
113
+ {
114
+ name: 'createdAt',
115
+ type: 'date',
116
+ },
117
+ {
118
+ name: 'updatedAt',
119
+ type: 'date',
120
+ },
121
+ {
122
+ name: 'createdBy',
123
+ type: 'belongsTo',
124
+ target: 'users',
125
+ foreignKey: 'createdById',
126
+ },
127
+ ],
128
+ } as CollectionOptions;