@kya-os/contracts 1.7.26 → 1.7.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 (44) hide show
  1. package/dist/agent-deployment-utils.d.ts +20 -0
  2. package/dist/agent-deployment-utils.js +37 -0
  3. package/dist/agent-deployment.d.ts +19 -19
  4. package/dist/agent-deployment.js +2 -1
  5. package/dist/agentshield-api/admin-schemas.d.ts +2 -2
  6. package/dist/agentshield-api/schemas.d.ts +462 -462
  7. package/dist/audit/index.d.ts +24 -24
  8. package/dist/cli.d.ts +44 -44
  9. package/dist/compute-binding.d.ts +6 -6
  10. package/dist/compute.d.ts +27 -8
  11. package/dist/compute.js +6 -0
  12. package/dist/config/identity.d.ts +98 -98
  13. package/dist/consent/schemas.d.ts +72 -72
  14. package/dist/dashboard-config/schemas.d.ts +2191 -2191
  15. package/dist/delegation/constraints.d.ts +32 -32
  16. package/dist/delegation/schemas.d.ts +610 -610
  17. package/dist/deploy/schemas.d.ts +84 -84
  18. package/dist/gateway/index.d.ts +579 -0
  19. package/dist/gateway/index.js +103 -0
  20. package/dist/handshake.d.ts +42 -42
  21. package/dist/index.d.ts +1 -0
  22. package/dist/index.js +2 -0
  23. package/dist/molti/admin-ws.d.ts +116 -116
  24. package/dist/molti/schemas.d.ts +98 -98
  25. package/dist/openclaw/index.d.ts +20 -0
  26. package/dist/openclaw/index.js +28 -0
  27. package/dist/openclaw/types.d.ts +714 -0
  28. package/dist/openclaw/types.js +122 -0
  29. package/dist/pairing/index.d.ts +44 -0
  30. package/dist/pairing/index.js +11 -0
  31. package/dist/policy/schemas.d.ts +553 -553
  32. package/dist/proof/proof-record.d.ts +48 -48
  33. package/dist/proof/signing-spec.d.ts +8 -8
  34. package/dist/proof.d.ts +68 -68
  35. package/dist/registry.d.ts +24 -24
  36. package/dist/reputation/api.d.ts +156 -156
  37. package/dist/reputation/credentials.d.ts +48 -48
  38. package/dist/reputation/schemas.d.ts +48 -48
  39. package/dist/test.d.ts +22 -22
  40. package/dist/tlkrc/rotation.d.ts +12 -12
  41. package/dist/tool-protection/index.d.ts +22 -22
  42. package/dist/verifier.d.ts +17 -17
  43. package/dist/well-known/index.d.ts +72 -72
  44. package/package.json +10 -2
@@ -0,0 +1,122 @@
1
+ "use strict";
2
+ /**
3
+ * OpenClaw Configuration & Gateway Protocol Types
4
+ *
5
+ * Single source of truth for:
6
+ * 1. openclaw.json config shape (Zod schemas + inferred types)
7
+ * 2. Gateway Protocol v3 WebSocket frame types (plain interfaces)
8
+ *
9
+ * Based on openclaw 2026.2.x config schema.
10
+ *
11
+ * @package @kya-os/contracts/openclaw
12
+ */
13
+ Object.defineProperty(exports, "__esModule", { value: true });
14
+ exports.OpenClawConfigSchema = exports.OpenClawModelProviderSchema = exports.OpenClawModelSchema = exports.OpenClawChannelsSchema = exports.OpenClawGatewaySchema = exports.OpenClawControlUiSchema = void 0;
15
+ const zod_1 = require("zod");
16
+ // ============================================================================
17
+ // OpenClaw Config Schemas (openclaw.json)
18
+ // ============================================================================
19
+ /**
20
+ * Gateway controlUi configuration.
21
+ * Controls WebSocket access, device auth, and origin allowlisting.
22
+ */
23
+ exports.OpenClawControlUiSchema = zod_1.z.object({
24
+ enabled: zod_1.z.boolean().optional(),
25
+ allowInsecureAuth: zod_1.z.boolean().optional(),
26
+ dangerouslyDisableDeviceAuth: zod_1.z.boolean().optional(),
27
+ /** Exact origin strings — no wildcard support */
28
+ allowedOrigins: zod_1.z.array(zod_1.z.string()).optional(),
29
+ });
30
+ /**
31
+ * Gateway configuration.
32
+ * Key differences from older versions:
33
+ * - bind is an enum ("lan"|"loopback"|"auto"|"custom"|"tailnet"), not an IP
34
+ */
35
+ exports.OpenClawGatewaySchema = zod_1.z.object({
36
+ mode: zod_1.z.enum(["local", "remote"]),
37
+ port: zod_1.z.number().int().positive(),
38
+ bind: zod_1.z.enum(["lan", "loopback", "auto", "custom", "tailnet"]),
39
+ auth: zod_1.z.object({
40
+ token: zod_1.z.string(),
41
+ }),
42
+ remote: zod_1.z
43
+ .object({
44
+ token: zod_1.z.string(),
45
+ })
46
+ .optional(),
47
+ trustedProxies: zod_1.z.array(zod_1.z.string()).optional(),
48
+ controlUi: exports.OpenClawControlUiSchema.optional(),
49
+ });
50
+ /**
51
+ * Channel configurations.
52
+ * - Telegram uses "botToken", Discord uses "token" (not "botToken")
53
+ * - Slack needs both botToken and appToken
54
+ */
55
+ exports.OpenClawChannelsSchema = zod_1.z.object({
56
+ telegram: zod_1.z
57
+ .object({
58
+ enabled: zod_1.z.boolean(),
59
+ botToken: zod_1.z.string(),
60
+ dmPolicy: zod_1.z.string().optional(),
61
+ })
62
+ .optional(),
63
+ discord: zod_1.z
64
+ .object({
65
+ enabled: zod_1.z.boolean(),
66
+ token: zod_1.z.string(),
67
+ dm: zod_1.z.object({ policy: zod_1.z.string() }).optional(),
68
+ })
69
+ .optional(),
70
+ slack: zod_1.z
71
+ .object({
72
+ enabled: zod_1.z.boolean(),
73
+ botToken: zod_1.z.string(),
74
+ appToken: zod_1.z.string(),
75
+ })
76
+ .optional(),
77
+ whatsapp: zod_1.z.record(zod_1.z.unknown()).optional(),
78
+ });
79
+ /**
80
+ * A single model definition within a provider.
81
+ */
82
+ exports.OpenClawModelSchema = zod_1.z.object({
83
+ id: zod_1.z.string(),
84
+ name: zod_1.z.string(),
85
+ contextWindow: zod_1.z.number().int().positive(),
86
+ maxTokens: zod_1.z.number().int().positive(),
87
+ });
88
+ /**
89
+ * AI model provider definition.
90
+ * Tells OpenClaw how to reach an AI provider (e.g. OpenAI, custom endpoint).
91
+ */
92
+ exports.OpenClawModelProviderSchema = zod_1.z.object({
93
+ baseUrl: zod_1.z.string(),
94
+ apiKey: zod_1.z.string().optional(),
95
+ api: zod_1.z.string(),
96
+ models: zod_1.z.array(exports.OpenClawModelSchema),
97
+ });
98
+ /**
99
+ * Full openclaw.json configuration.
100
+ *
101
+ * AI provider keys go in `env` (flat record), not a top-level "ai" key.
102
+ * The `agents.defaults.model.primary` field sets the default model.
103
+ */
104
+ exports.OpenClawConfigSchema = zod_1.z.object({
105
+ gateway: exports.OpenClawGatewaySchema,
106
+ env: zod_1.z.record(zod_1.z.string()).optional(),
107
+ channels: exports.OpenClawChannelsSchema.optional(),
108
+ agents: zod_1.z
109
+ .object({
110
+ defaults: zod_1.z
111
+ .object({
112
+ model: zod_1.z.object({ primary: zod_1.z.string() }).optional(),
113
+ })
114
+ .optional(),
115
+ })
116
+ .optional(),
117
+ models: zod_1.z
118
+ .object({
119
+ providers: zod_1.z.record(exports.OpenClawModelProviderSchema).optional(),
120
+ })
121
+ .optional(),
122
+ });
@@ -0,0 +1,44 @@
1
+ /**
2
+ * Pairing WebSocket event types
3
+ *
4
+ * Emitted by compute PairingWatcher via PairingEventBus.
5
+ * Consumed by Checkpoint UI via WS frames from the control server.
6
+ *
7
+ * These types are the canonical contract between compute and dashboard.
8
+ * Import via @kya-os/contracts or @kya-os/contracts/pairing.
9
+ */
10
+ /**
11
+ * WhatsApp login state machine (backend-owned).
12
+ *
13
+ * Transitions:
14
+ * disabled → enabling → qr_ready → scanned → linked
15
+ * → failed
16
+ */
17
+ export type WhatsAppLoginState = "disabled" | "enabling" | "qr_ready" | "scanned" | "linked" | "failed";
18
+ export type PairingRequestedEvent = {
19
+ event: "channel.pairing.requested";
20
+ payload: {
21
+ channel: string;
22
+ code: string;
23
+ userId: string;
24
+ createdAt: string;
25
+ meta?: Record<string, string>;
26
+ };
27
+ };
28
+ export type PairingApprovedEvent = {
29
+ event: "channel.pairing.approved";
30
+ payload: {
31
+ channel: string;
32
+ code: string;
33
+ userId: string;
34
+ };
35
+ };
36
+ export type LinkStateChangedEvent = {
37
+ event: "channel.link.stateChanged";
38
+ payload: {
39
+ channel: string;
40
+ state: WhatsAppLoginState | "waiting_user_start" | "code_issued" | "approved" | "configured";
41
+ previousState?: string;
42
+ };
43
+ };
44
+ export type PairingWsEvent = PairingRequestedEvent | PairingApprovedEvent | LinkStateChangedEvent;
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ /**
3
+ * Pairing WebSocket event types
4
+ *
5
+ * Emitted by compute PairingWatcher via PairingEventBus.
6
+ * Consumed by Checkpoint UI via WS frames from the control server.
7
+ *
8
+ * These types are the canonical contract between compute and dashboard.
9
+ * Import via @kya-os/contracts or @kya-os/contracts/pairing.
10
+ */
11
+ Object.defineProperty(exports, "__esModule", { value: true });