@objectstack/platform-objects 4.0.5 → 4.1.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.
- package/dist/apps/index.d.mts +16 -48
- package/dist/apps/index.d.ts +16 -48
- package/dist/apps/index.js +139 -217
- package/dist/apps/index.js.map +1 -1
- package/dist/apps/index.mjs +140 -212
- package/dist/apps/index.mjs.map +1 -1
- package/dist/audit/index.d.mts +38990 -51
- package/dist/audit/index.d.ts +38990 -51
- package/dist/audit/index.js +1428 -0
- package/dist/audit/index.js.map +1 -1
- package/dist/audit/index.mjs +1417 -1
- package/dist/audit/index.mjs.map +1 -1
- package/dist/identity/index.d.mts +14869 -2802
- package/dist/identity/index.d.ts +14869 -2802
- package/dist/identity/index.js +1090 -6
- package/dist/identity/index.js.map +1 -1
- package/dist/identity/index.mjs +1089 -7
- package/dist/identity/index.mjs.map +1 -1
- package/dist/index.d.mts +8 -7
- package/dist/index.d.ts +8 -7
- package/dist/index.js +3652 -1482
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +3633 -1465
- package/dist/index.mjs.map +1 -1
- package/dist/integration/index.d.mts +2905 -0
- package/dist/integration/index.d.ts +2905 -0
- package/dist/integration/index.js +140 -0
- package/dist/integration/index.js.map +1 -0
- package/dist/integration/index.mjs +138 -0
- package/dist/integration/index.mjs.map +1 -0
- package/dist/metadata/index.d.mts +577 -21181
- package/dist/metadata/index.d.ts +577 -21181
- package/dist/metadata/index.js +29 -619
- package/dist/metadata/index.js.map +1 -1
- package/dist/metadata/index.mjs +30 -615
- package/dist/metadata/index.mjs.map +1 -1
- package/dist/security/index.d.mts +7278 -46
- package/dist/security/index.d.ts +7278 -46
- package/dist/security/index.js +540 -0
- package/dist/security/index.js.map +1 -1
- package/dist/security/index.mjs +539 -1
- package/dist/security/index.mjs.map +1 -1
- package/dist/system/index.d.mts +8409 -0
- package/dist/system/index.d.ts +8409 -0
- package/dist/system/index.js +395 -0
- package/dist/system/index.js.map +1 -0
- package/dist/system/index.mjs +391 -0
- package/dist/system/index.mjs.map +1 -0
- package/package.json +13 -8
- package/dist/tenant/index.d.mts +0 -18464
- package/dist/tenant/index.d.ts +0 -18464
- package/dist/tenant/index.js +0 -741
- package/dist/tenant/index.js.map +0 -1
- package/dist/tenant/index.mjs +0 -733
- package/dist/tenant/index.mjs.map +0 -1
- /package/dist/{state-machine.zod-BFg-VE0M.d-Ek3_yo9P.d.mts → state-machine.zod-BNanU03M.d-Ek3_yo9P.d.mts} +0 -0
- /package/dist/{state-machine.zod-BFg-VE0M.d-Ek3_yo9P.d.ts → state-machine.zod-BNanU03M.d-Ek3_yo9P.d.ts} +0 -0
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var data = require('@objectstack/spec/data');
|
|
4
|
+
|
|
5
|
+
// src/integration/sys-webhook.object.ts
|
|
6
|
+
var SysWebhook = data.ObjectSchema.create({
|
|
7
|
+
name: "sys_webhook",
|
|
8
|
+
label: "Webhook",
|
|
9
|
+
pluralLabel: "Webhooks",
|
|
10
|
+
icon: "webhook",
|
|
11
|
+
isSystem: true,
|
|
12
|
+
managedBy: "config",
|
|
13
|
+
// Authoring a webhook from the UI requires a structured form for the
|
|
14
|
+
// headers / auth / retry / payload blocks — the generic JSON textarea
|
|
15
|
+
// is acceptable as a v1 until a dedicated builder lands. Re-enable
|
|
16
|
+
// create/edit/delete so admins can at least toggle `active` and edit
|
|
17
|
+
// simple URL/method fields without round-tripping through code.
|
|
18
|
+
userActions: { create: true, edit: true, delete: true, import: false },
|
|
19
|
+
description: "Outbound HTTP webhook subscription. Authored via defineWebhook() in code or the Studio editor; executed by the HTTP connector plugin.",
|
|
20
|
+
displayNameField: "name",
|
|
21
|
+
titleFormat: "{label}",
|
|
22
|
+
compactLayout: ["name", "object_name", "url", "active", "updated_at"],
|
|
23
|
+
listViews: {
|
|
24
|
+
active: {
|
|
25
|
+
type: "grid",
|
|
26
|
+
name: "active",
|
|
27
|
+
label: "Active",
|
|
28
|
+
data: { provider: "object", object: "sys_webhook" },
|
|
29
|
+
columns: ["label", "object_name", "url", "method", "active", "updated_at"],
|
|
30
|
+
filter: [{ field: "active", operator: "equals", value: true }],
|
|
31
|
+
sort: [{ field: "label", order: "asc" }],
|
|
32
|
+
pagination: { pageSize: 50 }
|
|
33
|
+
},
|
|
34
|
+
inactive: {
|
|
35
|
+
type: "grid",
|
|
36
|
+
name: "inactive",
|
|
37
|
+
label: "Inactive",
|
|
38
|
+
data: { provider: "object", object: "sys_webhook" },
|
|
39
|
+
columns: ["label", "object_name", "url", "method", "active", "updated_at"],
|
|
40
|
+
filter: [{ field: "active", operator: "equals", value: false }],
|
|
41
|
+
sort: [{ field: "label", order: "asc" }],
|
|
42
|
+
pagination: { pageSize: 50 }
|
|
43
|
+
},
|
|
44
|
+
by_object: {
|
|
45
|
+
type: "grid",
|
|
46
|
+
name: "by_object",
|
|
47
|
+
label: "By Object",
|
|
48
|
+
data: { provider: "object", object: "sys_webhook" },
|
|
49
|
+
columns: ["object_name", "label", "url", "active", "updated_at"],
|
|
50
|
+
sort: [{ field: "object_name", order: "asc" }, { field: "label", order: "asc" }],
|
|
51
|
+
grouping: { fields: [{ field: "object_name", order: "asc", collapsed: false }] },
|
|
52
|
+
pagination: { pageSize: 100 }
|
|
53
|
+
},
|
|
54
|
+
all_webhooks: {
|
|
55
|
+
type: "grid",
|
|
56
|
+
name: "all_webhooks",
|
|
57
|
+
label: "All",
|
|
58
|
+
data: { provider: "object", object: "sys_webhook" },
|
|
59
|
+
columns: ["label", "object_name", "url", "method", "active", "updated_at"],
|
|
60
|
+
sort: [{ field: "label", order: "asc" }],
|
|
61
|
+
pagination: { pageSize: 50 }
|
|
62
|
+
}
|
|
63
|
+
},
|
|
64
|
+
fields: {
|
|
65
|
+
id: data.Field.text({ label: "Webhook ID", required: true, readonly: true, group: "System" }),
|
|
66
|
+
name: data.Field.text({
|
|
67
|
+
label: "Name",
|
|
68
|
+
required: true,
|
|
69
|
+
maxLength: 100,
|
|
70
|
+
description: "Unique snake_case name \u2014 referenced in logs and audit",
|
|
71
|
+
group: "Definition"
|
|
72
|
+
}),
|
|
73
|
+
label: data.Field.text({
|
|
74
|
+
label: "Display Label",
|
|
75
|
+
required: false,
|
|
76
|
+
maxLength: 200,
|
|
77
|
+
group: "Definition"
|
|
78
|
+
}),
|
|
79
|
+
object_name: data.Field.text({
|
|
80
|
+
label: "Object",
|
|
81
|
+
required: false,
|
|
82
|
+
maxLength: 100,
|
|
83
|
+
description: "Short object name whose events fire this webhook (blank = manual / API-triggered)",
|
|
84
|
+
group: "Definition"
|
|
85
|
+
}),
|
|
86
|
+
triggers: data.Field.text({
|
|
87
|
+
label: "Triggers",
|
|
88
|
+
required: false,
|
|
89
|
+
maxLength: 200,
|
|
90
|
+
description: "Comma-separated event list: create,update,delete,undelete,api",
|
|
91
|
+
group: "Definition"
|
|
92
|
+
}),
|
|
93
|
+
url: data.Field.text({
|
|
94
|
+
label: "Target URL",
|
|
95
|
+
required: true,
|
|
96
|
+
maxLength: 2048,
|
|
97
|
+
description: "External endpoint that receives the POST",
|
|
98
|
+
group: "Definition"
|
|
99
|
+
}),
|
|
100
|
+
method: data.Field.text({
|
|
101
|
+
label: "HTTP Method",
|
|
102
|
+
required: true,
|
|
103
|
+
defaultValue: "POST",
|
|
104
|
+
maxLength: 10,
|
|
105
|
+
description: "GET / POST / PUT / PATCH / DELETE",
|
|
106
|
+
group: "Definition"
|
|
107
|
+
}),
|
|
108
|
+
description: data.Field.textarea({ label: "Description", required: false, group: "Definition" }),
|
|
109
|
+
active: data.Field.boolean({
|
|
110
|
+
label: "Active",
|
|
111
|
+
required: true,
|
|
112
|
+
defaultValue: true,
|
|
113
|
+
description: "Inactive webhooks are skipped by the dispatcher",
|
|
114
|
+
group: "Definition"
|
|
115
|
+
}),
|
|
116
|
+
definition_json: data.Field.textarea({
|
|
117
|
+
label: "Definition",
|
|
118
|
+
required: true,
|
|
119
|
+
description: "Serialised Webhook JSON (see @objectstack/spec/automation/webhook) \u2014 full headers/auth/retry/payload config",
|
|
120
|
+
group: "Definition"
|
|
121
|
+
}),
|
|
122
|
+
created_at: data.Field.datetime({
|
|
123
|
+
label: "Created At",
|
|
124
|
+
required: true,
|
|
125
|
+
defaultValue: "NOW()",
|
|
126
|
+
readonly: true,
|
|
127
|
+
group: "System"
|
|
128
|
+
}),
|
|
129
|
+
updated_at: data.Field.datetime({ label: "Updated At", required: false, group: "System" })
|
|
130
|
+
},
|
|
131
|
+
indexes: [
|
|
132
|
+
{ fields: ["name"], unique: true },
|
|
133
|
+
{ fields: ["object_name"] },
|
|
134
|
+
{ fields: ["active", "object_name"] }
|
|
135
|
+
]
|
|
136
|
+
});
|
|
137
|
+
|
|
138
|
+
exports.SysWebhook = SysWebhook;
|
|
139
|
+
//# sourceMappingURL=index.js.map
|
|
140
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/integration/sys-webhook.object.ts"],"names":["ObjectSchema","Field"],"mappings":"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","file":"index.js","sourcesContent":["// Copyright (c) 2025 ObjectStack. Licensed under the Apache-2.0 license.\n\nimport { ObjectSchema, Field } from '@objectstack/spec/data';\n\n/**\n * sys_webhook — Outbound HTTP integration configuration (runtime).\n *\n * Persists a single {@link Webhook} envelope per row so administrators\n * can author, enable/disable, and edit webhook subscriptions from the\n * Studio UI without code changes. The canonical Zod schema for the\n * `definition_json` envelope lives at `@objectstack/spec/automation/webhook`.\n *\n * One row per `name`. The HTTP connector plugin\n * (`@objectstack/service-automation/plugins/http-connector-plugin`) loads\n * active rows on boot + on `sys_webhook:changed` events, registers\n * `afterInsert` / `afterUpdate` / `afterDelete` listeners for the\n * targeted object, and dispatches outbound HTTP calls when matching\n * record events fire.\n *\n * Platform-wide on purpose: every project (standalone, single-tenant,\n * cloud) can integrate with external systems (Slack, Stripe, internal\n * services) the same way. The control-plane-only `sys_project*`\n * objects live in @objectstack/service-tenant; webhooks are\n * orthogonal and ship with every kernel.\n *\n * @namespace sys\n */\nexport const SysWebhook = ObjectSchema.create({\n name: 'sys_webhook',\n label: 'Webhook',\n pluralLabel: 'Webhooks',\n icon: 'webhook',\n isSystem: true,\n managedBy: 'config',\n // Authoring a webhook from the UI requires a structured form for the\n // headers / auth / retry / payload blocks — the generic JSON textarea\n // is acceptable as a v1 until a dedicated builder lands. Re-enable\n // create/edit/delete so admins can at least toggle `active` and edit\n // simple URL/method fields without round-tripping through code.\n userActions: { create: true, edit: true, delete: true, import: false },\n description: 'Outbound HTTP webhook subscription. Authored via defineWebhook() in code or the Studio editor; executed by the HTTP connector plugin.',\n displayNameField: 'name',\n titleFormat: '{label}',\n compactLayout: ['name', 'object_name', 'url', 'active', 'updated_at'],\n\n listViews: {\n active: {\n type: 'grid',\n name: 'active',\n label: 'Active',\n data: { provider: 'object', object: 'sys_webhook' },\n columns: ['label', 'object_name', 'url', 'method', 'active', 'updated_at'],\n filter: [{ field: 'active', operator: 'equals', value: true }],\n sort: [{ field: 'label', order: 'asc' }],\n pagination: { pageSize: 50 },\n },\n inactive: {\n type: 'grid',\n name: 'inactive',\n label: 'Inactive',\n data: { provider: 'object', object: 'sys_webhook' },\n columns: ['label', 'object_name', 'url', 'method', 'active', 'updated_at'],\n filter: [{ field: 'active', operator: 'equals', value: false }],\n sort: [{ field: 'label', order: 'asc' }],\n pagination: { pageSize: 50 },\n },\n by_object: {\n type: 'grid',\n name: 'by_object',\n label: 'By Object',\n data: { provider: 'object', object: 'sys_webhook' },\n columns: ['object_name', 'label', 'url', 'active', 'updated_at'],\n sort: [{ field: 'object_name', order: 'asc' }, { field: 'label', order: 'asc' }],\n grouping: { fields: [{ field: 'object_name', order: 'asc', collapsed: false }] },\n pagination: { pageSize: 100 },\n },\n all_webhooks: {\n type: 'grid',\n name: 'all_webhooks',\n label: 'All',\n data: { provider: 'object', object: 'sys_webhook' },\n columns: ['label', 'object_name', 'url', 'method', 'active', 'updated_at'],\n sort: [{ field: 'label', order: 'asc' }],\n pagination: { pageSize: 50 },\n },\n },\n\n fields: {\n id: Field.text({ label: 'Webhook ID', required: true, readonly: true, group: 'System' }),\n\n name: Field.text({\n label: 'Name',\n required: true,\n maxLength: 100,\n description: 'Unique snake_case name — referenced in logs and audit',\n group: 'Definition',\n }),\n\n label: Field.text({\n label: 'Display Label',\n required: false,\n maxLength: 200,\n group: 'Definition',\n }),\n\n object_name: Field.text({\n label: 'Object',\n required: false,\n maxLength: 100,\n description: 'Short object name whose events fire this webhook (blank = manual / API-triggered)',\n group: 'Definition',\n }),\n\n triggers: Field.text({\n label: 'Triggers',\n required: false,\n maxLength: 200,\n description: 'Comma-separated event list: create,update,delete,undelete,api',\n group: 'Definition',\n }),\n\n url: Field.text({\n label: 'Target URL',\n required: true,\n maxLength: 2048,\n description: 'External endpoint that receives the POST',\n group: 'Definition',\n }),\n\n method: Field.text({\n label: 'HTTP Method',\n required: true,\n defaultValue: 'POST',\n maxLength: 10,\n description: 'GET / POST / PUT / PATCH / DELETE',\n group: 'Definition',\n }),\n\n description: Field.textarea({ label: 'Description', required: false, group: 'Definition' }),\n\n active: Field.boolean({\n label: 'Active',\n required: true,\n defaultValue: true,\n description: 'Inactive webhooks are skipped by the dispatcher',\n group: 'Definition',\n }),\n\n definition_json: Field.textarea({\n label: 'Definition',\n required: true,\n description: 'Serialised Webhook JSON (see @objectstack/spec/automation/webhook) — full headers/auth/retry/payload config',\n group: 'Definition',\n }),\n\n created_at: Field.datetime({\n label: 'Created At',\n required: true,\n defaultValue: 'NOW()',\n readonly: true,\n group: 'System',\n }),\n\n updated_at: Field.datetime({ label: 'Updated At', required: false, group: 'System' }),\n },\n\n indexes: [\n { fields: ['name'], unique: true },\n { fields: ['object_name'] },\n { fields: ['active', 'object_name'] },\n ],\n});\n"]}
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
import { ObjectSchema, Field } from '@objectstack/spec/data';
|
|
2
|
+
|
|
3
|
+
// src/integration/sys-webhook.object.ts
|
|
4
|
+
var SysWebhook = ObjectSchema.create({
|
|
5
|
+
name: "sys_webhook",
|
|
6
|
+
label: "Webhook",
|
|
7
|
+
pluralLabel: "Webhooks",
|
|
8
|
+
icon: "webhook",
|
|
9
|
+
isSystem: true,
|
|
10
|
+
managedBy: "config",
|
|
11
|
+
// Authoring a webhook from the UI requires a structured form for the
|
|
12
|
+
// headers / auth / retry / payload blocks — the generic JSON textarea
|
|
13
|
+
// is acceptable as a v1 until a dedicated builder lands. Re-enable
|
|
14
|
+
// create/edit/delete so admins can at least toggle `active` and edit
|
|
15
|
+
// simple URL/method fields without round-tripping through code.
|
|
16
|
+
userActions: { create: true, edit: true, delete: true, import: false },
|
|
17
|
+
description: "Outbound HTTP webhook subscription. Authored via defineWebhook() in code or the Studio editor; executed by the HTTP connector plugin.",
|
|
18
|
+
displayNameField: "name",
|
|
19
|
+
titleFormat: "{label}",
|
|
20
|
+
compactLayout: ["name", "object_name", "url", "active", "updated_at"],
|
|
21
|
+
listViews: {
|
|
22
|
+
active: {
|
|
23
|
+
type: "grid",
|
|
24
|
+
name: "active",
|
|
25
|
+
label: "Active",
|
|
26
|
+
data: { provider: "object", object: "sys_webhook" },
|
|
27
|
+
columns: ["label", "object_name", "url", "method", "active", "updated_at"],
|
|
28
|
+
filter: [{ field: "active", operator: "equals", value: true }],
|
|
29
|
+
sort: [{ field: "label", order: "asc" }],
|
|
30
|
+
pagination: { pageSize: 50 }
|
|
31
|
+
},
|
|
32
|
+
inactive: {
|
|
33
|
+
type: "grid",
|
|
34
|
+
name: "inactive",
|
|
35
|
+
label: "Inactive",
|
|
36
|
+
data: { provider: "object", object: "sys_webhook" },
|
|
37
|
+
columns: ["label", "object_name", "url", "method", "active", "updated_at"],
|
|
38
|
+
filter: [{ field: "active", operator: "equals", value: false }],
|
|
39
|
+
sort: [{ field: "label", order: "asc" }],
|
|
40
|
+
pagination: { pageSize: 50 }
|
|
41
|
+
},
|
|
42
|
+
by_object: {
|
|
43
|
+
type: "grid",
|
|
44
|
+
name: "by_object",
|
|
45
|
+
label: "By Object",
|
|
46
|
+
data: { provider: "object", object: "sys_webhook" },
|
|
47
|
+
columns: ["object_name", "label", "url", "active", "updated_at"],
|
|
48
|
+
sort: [{ field: "object_name", order: "asc" }, { field: "label", order: "asc" }],
|
|
49
|
+
grouping: { fields: [{ field: "object_name", order: "asc", collapsed: false }] },
|
|
50
|
+
pagination: { pageSize: 100 }
|
|
51
|
+
},
|
|
52
|
+
all_webhooks: {
|
|
53
|
+
type: "grid",
|
|
54
|
+
name: "all_webhooks",
|
|
55
|
+
label: "All",
|
|
56
|
+
data: { provider: "object", object: "sys_webhook" },
|
|
57
|
+
columns: ["label", "object_name", "url", "method", "active", "updated_at"],
|
|
58
|
+
sort: [{ field: "label", order: "asc" }],
|
|
59
|
+
pagination: { pageSize: 50 }
|
|
60
|
+
}
|
|
61
|
+
},
|
|
62
|
+
fields: {
|
|
63
|
+
id: Field.text({ label: "Webhook ID", required: true, readonly: true, group: "System" }),
|
|
64
|
+
name: Field.text({
|
|
65
|
+
label: "Name",
|
|
66
|
+
required: true,
|
|
67
|
+
maxLength: 100,
|
|
68
|
+
description: "Unique snake_case name \u2014 referenced in logs and audit",
|
|
69
|
+
group: "Definition"
|
|
70
|
+
}),
|
|
71
|
+
label: Field.text({
|
|
72
|
+
label: "Display Label",
|
|
73
|
+
required: false,
|
|
74
|
+
maxLength: 200,
|
|
75
|
+
group: "Definition"
|
|
76
|
+
}),
|
|
77
|
+
object_name: Field.text({
|
|
78
|
+
label: "Object",
|
|
79
|
+
required: false,
|
|
80
|
+
maxLength: 100,
|
|
81
|
+
description: "Short object name whose events fire this webhook (blank = manual / API-triggered)",
|
|
82
|
+
group: "Definition"
|
|
83
|
+
}),
|
|
84
|
+
triggers: Field.text({
|
|
85
|
+
label: "Triggers",
|
|
86
|
+
required: false,
|
|
87
|
+
maxLength: 200,
|
|
88
|
+
description: "Comma-separated event list: create,update,delete,undelete,api",
|
|
89
|
+
group: "Definition"
|
|
90
|
+
}),
|
|
91
|
+
url: Field.text({
|
|
92
|
+
label: "Target URL",
|
|
93
|
+
required: true,
|
|
94
|
+
maxLength: 2048,
|
|
95
|
+
description: "External endpoint that receives the POST",
|
|
96
|
+
group: "Definition"
|
|
97
|
+
}),
|
|
98
|
+
method: Field.text({
|
|
99
|
+
label: "HTTP Method",
|
|
100
|
+
required: true,
|
|
101
|
+
defaultValue: "POST",
|
|
102
|
+
maxLength: 10,
|
|
103
|
+
description: "GET / POST / PUT / PATCH / DELETE",
|
|
104
|
+
group: "Definition"
|
|
105
|
+
}),
|
|
106
|
+
description: Field.textarea({ label: "Description", required: false, group: "Definition" }),
|
|
107
|
+
active: Field.boolean({
|
|
108
|
+
label: "Active",
|
|
109
|
+
required: true,
|
|
110
|
+
defaultValue: true,
|
|
111
|
+
description: "Inactive webhooks are skipped by the dispatcher",
|
|
112
|
+
group: "Definition"
|
|
113
|
+
}),
|
|
114
|
+
definition_json: Field.textarea({
|
|
115
|
+
label: "Definition",
|
|
116
|
+
required: true,
|
|
117
|
+
description: "Serialised Webhook JSON (see @objectstack/spec/automation/webhook) \u2014 full headers/auth/retry/payload config",
|
|
118
|
+
group: "Definition"
|
|
119
|
+
}),
|
|
120
|
+
created_at: Field.datetime({
|
|
121
|
+
label: "Created At",
|
|
122
|
+
required: true,
|
|
123
|
+
defaultValue: "NOW()",
|
|
124
|
+
readonly: true,
|
|
125
|
+
group: "System"
|
|
126
|
+
}),
|
|
127
|
+
updated_at: Field.datetime({ label: "Updated At", required: false, group: "System" })
|
|
128
|
+
},
|
|
129
|
+
indexes: [
|
|
130
|
+
{ fields: ["name"], unique: true },
|
|
131
|
+
{ fields: ["object_name"] },
|
|
132
|
+
{ fields: ["active", "object_name"] }
|
|
133
|
+
]
|
|
134
|
+
});
|
|
135
|
+
|
|
136
|
+
export { SysWebhook };
|
|
137
|
+
//# sourceMappingURL=index.mjs.map
|
|
138
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/integration/sys-webhook.object.ts"],"names":[],"mappings":"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","file":"index.mjs","sourcesContent":["// Copyright (c) 2025 ObjectStack. Licensed under the Apache-2.0 license.\n\nimport { ObjectSchema, Field } from '@objectstack/spec/data';\n\n/**\n * sys_webhook — Outbound HTTP integration configuration (runtime).\n *\n * Persists a single {@link Webhook} envelope per row so administrators\n * can author, enable/disable, and edit webhook subscriptions from the\n * Studio UI without code changes. The canonical Zod schema for the\n * `definition_json` envelope lives at `@objectstack/spec/automation/webhook`.\n *\n * One row per `name`. The HTTP connector plugin\n * (`@objectstack/service-automation/plugins/http-connector-plugin`) loads\n * active rows on boot + on `sys_webhook:changed` events, registers\n * `afterInsert` / `afterUpdate` / `afterDelete` listeners for the\n * targeted object, and dispatches outbound HTTP calls when matching\n * record events fire.\n *\n * Platform-wide on purpose: every project (standalone, single-tenant,\n * cloud) can integrate with external systems (Slack, Stripe, internal\n * services) the same way. The control-plane-only `sys_project*`\n * objects live in @objectstack/service-tenant; webhooks are\n * orthogonal and ship with every kernel.\n *\n * @namespace sys\n */\nexport const SysWebhook = ObjectSchema.create({\n name: 'sys_webhook',\n label: 'Webhook',\n pluralLabel: 'Webhooks',\n icon: 'webhook',\n isSystem: true,\n managedBy: 'config',\n // Authoring a webhook from the UI requires a structured form for the\n // headers / auth / retry / payload blocks — the generic JSON textarea\n // is acceptable as a v1 until a dedicated builder lands. Re-enable\n // create/edit/delete so admins can at least toggle `active` and edit\n // simple URL/method fields without round-tripping through code.\n userActions: { create: true, edit: true, delete: true, import: false },\n description: 'Outbound HTTP webhook subscription. Authored via defineWebhook() in code or the Studio editor; executed by the HTTP connector plugin.',\n displayNameField: 'name',\n titleFormat: '{label}',\n compactLayout: ['name', 'object_name', 'url', 'active', 'updated_at'],\n\n listViews: {\n active: {\n type: 'grid',\n name: 'active',\n label: 'Active',\n data: { provider: 'object', object: 'sys_webhook' },\n columns: ['label', 'object_name', 'url', 'method', 'active', 'updated_at'],\n filter: [{ field: 'active', operator: 'equals', value: true }],\n sort: [{ field: 'label', order: 'asc' }],\n pagination: { pageSize: 50 },\n },\n inactive: {\n type: 'grid',\n name: 'inactive',\n label: 'Inactive',\n data: { provider: 'object', object: 'sys_webhook' },\n columns: ['label', 'object_name', 'url', 'method', 'active', 'updated_at'],\n filter: [{ field: 'active', operator: 'equals', value: false }],\n sort: [{ field: 'label', order: 'asc' }],\n pagination: { pageSize: 50 },\n },\n by_object: {\n type: 'grid',\n name: 'by_object',\n label: 'By Object',\n data: { provider: 'object', object: 'sys_webhook' },\n columns: ['object_name', 'label', 'url', 'active', 'updated_at'],\n sort: [{ field: 'object_name', order: 'asc' }, { field: 'label', order: 'asc' }],\n grouping: { fields: [{ field: 'object_name', order: 'asc', collapsed: false }] },\n pagination: { pageSize: 100 },\n },\n all_webhooks: {\n type: 'grid',\n name: 'all_webhooks',\n label: 'All',\n data: { provider: 'object', object: 'sys_webhook' },\n columns: ['label', 'object_name', 'url', 'method', 'active', 'updated_at'],\n sort: [{ field: 'label', order: 'asc' }],\n pagination: { pageSize: 50 },\n },\n },\n\n fields: {\n id: Field.text({ label: 'Webhook ID', required: true, readonly: true, group: 'System' }),\n\n name: Field.text({\n label: 'Name',\n required: true,\n maxLength: 100,\n description: 'Unique snake_case name — referenced in logs and audit',\n group: 'Definition',\n }),\n\n label: Field.text({\n label: 'Display Label',\n required: false,\n maxLength: 200,\n group: 'Definition',\n }),\n\n object_name: Field.text({\n label: 'Object',\n required: false,\n maxLength: 100,\n description: 'Short object name whose events fire this webhook (blank = manual / API-triggered)',\n group: 'Definition',\n }),\n\n triggers: Field.text({\n label: 'Triggers',\n required: false,\n maxLength: 200,\n description: 'Comma-separated event list: create,update,delete,undelete,api',\n group: 'Definition',\n }),\n\n url: Field.text({\n label: 'Target URL',\n required: true,\n maxLength: 2048,\n description: 'External endpoint that receives the POST',\n group: 'Definition',\n }),\n\n method: Field.text({\n label: 'HTTP Method',\n required: true,\n defaultValue: 'POST',\n maxLength: 10,\n description: 'GET / POST / PUT / PATCH / DELETE',\n group: 'Definition',\n }),\n\n description: Field.textarea({ label: 'Description', required: false, group: 'Definition' }),\n\n active: Field.boolean({\n label: 'Active',\n required: true,\n defaultValue: true,\n description: 'Inactive webhooks are skipped by the dispatcher',\n group: 'Definition',\n }),\n\n definition_json: Field.textarea({\n label: 'Definition',\n required: true,\n description: 'Serialised Webhook JSON (see @objectstack/spec/automation/webhook) — full headers/auth/retry/payload config',\n group: 'Definition',\n }),\n\n created_at: Field.datetime({\n label: 'Created At',\n required: true,\n defaultValue: 'NOW()',\n readonly: true,\n group: 'System',\n }),\n\n updated_at: Field.datetime({ label: 'Updated At', required: false, group: 'System' }),\n },\n\n indexes: [\n { fields: ['name'], unique: true },\n { fields: ['object_name'] },\n { fields: ['active', 'object_name'] },\n ],\n});\n"]}
|