ssh-mcp-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.
- package/AGENTS.md +127 -0
- package/ARCHITECTURE.md +145 -0
- package/LICENSE +21 -0
- package/LICENSES/MIT.txt +21 -0
- package/MIGRATION.md +14 -0
- package/README.md +175 -0
- package/REGISTRY_SUBMISSION.md +38 -0
- package/SECURITY.md +40 -0
- package/SECURITY_DECISIONS.md +59 -0
- package/dist/agent-bin.d.ts +3 -0
- package/dist/agent-bin.d.ts.map +1 -0
- package/dist/agent-bin.js +8 -0
- package/dist/agent-bin.js.map +1 -0
- package/dist/audit.d.ts +25 -0
- package/dist/audit.d.ts.map +1 -0
- package/dist/audit.js +50 -0
- package/dist/audit.js.map +1 -0
- package/dist/auth.d.ts +4 -0
- package/dist/auth.d.ts.map +1 -0
- package/dist/auth.js +33 -0
- package/dist/auth.js.map +1 -0
- package/dist/cli.d.ts +16 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +99 -0
- package/dist/cli.js.map +1 -0
- package/dist/config.d.ts +103 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +490 -0
- package/dist/config.js.map +1 -0
- package/dist/connector-credentials.d.ts +8 -0
- package/dist/connector-credentials.d.ts.map +1 -0
- package/dist/connector-credentials.js +132 -0
- package/dist/connector-credentials.js.map +1 -0
- package/dist/connector-profile.d.ts +17 -0
- package/dist/connector-profile.d.ts.map +1 -0
- package/dist/connector-profile.js +81 -0
- package/dist/connector-profile.js.map +1 -0
- package/dist/container.d.ts +18 -0
- package/dist/container.d.ts.map +1 -0
- package/dist/container.js +52 -0
- package/dist/container.js.map +1 -0
- package/dist/detect.d.ts +7 -0
- package/dist/detect.d.ts.map +1 -0
- package/dist/detect.js +271 -0
- package/dist/detect.js.map +1 -0
- package/dist/ensure.d.ts +17 -0
- package/dist/ensure.d.ts.map +1 -0
- package/dist/ensure.js +531 -0
- package/dist/ensure.js.map +1 -0
- package/dist/errors.d.ts +54 -0
- package/dist/errors.d.ts.map +1 -0
- package/dist/errors.js +84 -0
- package/dist/errors.js.map +1 -0
- package/dist/fs-tools.d.ts +26 -0
- package/dist/fs-tools.d.ts.map +1 -0
- package/dist/fs-tools.js +599 -0
- package/dist/fs-tools.js.map +1 -0
- package/dist/http-rate-limit.d.ts +9 -0
- package/dist/http-rate-limit.d.ts.map +1 -0
- package/dist/http-rate-limit.js +41 -0
- package/dist/http-rate-limit.js.map +1 -0
- package/dist/http-security.d.ts +22 -0
- package/dist/http-security.d.ts.map +1 -0
- package/dist/http-security.js +88 -0
- package/dist/http-security.js.map +1 -0
- package/dist/index.d.ts +10 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +201 -0
- package/dist/index.js.map +1 -0
- package/dist/logging.d.ts +52 -0
- package/dist/logging.d.ts.map +1 -0
- package/dist/logging.js +180 -0
- package/dist/logging.js.map +1 -0
- package/dist/mcp.d.ts +16 -0
- package/dist/mcp.d.ts.map +1 -0
- package/dist/mcp.js +159 -0
- package/dist/mcp.js.map +1 -0
- package/dist/metrics.d.ts +95 -0
- package/dist/metrics.d.ts.map +1 -0
- package/dist/metrics.js +204 -0
- package/dist/metrics.js.map +1 -0
- package/dist/oauth.d.ts +14 -0
- package/dist/oauth.d.ts.map +1 -0
- package/dist/oauth.js +105 -0
- package/dist/oauth.js.map +1 -0
- package/dist/policy.d.ts +64 -0
- package/dist/policy.d.ts.map +1 -0
- package/dist/policy.js +368 -0
- package/dist/policy.js.map +1 -0
- package/dist/process.d.ts +24 -0
- package/dist/process.d.ts.map +1 -0
- package/dist/process.js +212 -0
- package/dist/process.js.map +1 -0
- package/dist/prompts.d.ts +49 -0
- package/dist/prompts.d.ts.map +1 -0
- package/dist/prompts.js +191 -0
- package/dist/prompts.js.map +1 -0
- package/dist/rate-limiter.d.ts +57 -0
- package/dist/rate-limiter.d.ts.map +1 -0
- package/dist/rate-limiter.js +141 -0
- package/dist/rate-limiter.js.map +1 -0
- package/dist/remote/agent-cli.d.ts +2 -0
- package/dist/remote/agent-cli.d.ts.map +1 -0
- package/dist/remote/agent-cli.js +270 -0
- package/dist/remote/agent-cli.js.map +1 -0
- package/dist/remote/agent-executor.d.ts +26 -0
- package/dist/remote/agent-executor.d.ts.map +1 -0
- package/dist/remote/agent-executor.js +400 -0
- package/dist/remote/agent-executor.js.map +1 -0
- package/dist/remote/config.d.ts +3 -0
- package/dist/remote/config.d.ts.map +1 -0
- package/dist/remote/config.js +52 -0
- package/dist/remote/config.js.map +1 -0
- package/dist/remote/control-plane.d.ts +57 -0
- package/dist/remote/control-plane.d.ts.map +1 -0
- package/dist/remote/control-plane.js +1248 -0
- package/dist/remote/control-plane.js.map +1 -0
- package/dist/remote/crypto.d.ts +38 -0
- package/dist/remote/crypto.d.ts.map +1 -0
- package/dist/remote/crypto.js +143 -0
- package/dist/remote/crypto.js.map +1 -0
- package/dist/remote/mcp-tools.d.ts +10 -0
- package/dist/remote/mcp-tools.d.ts.map +1 -0
- package/dist/remote/mcp-tools.js +201 -0
- package/dist/remote/mcp-tools.js.map +1 -0
- package/dist/remote/policy.d.ts +11 -0
- package/dist/remote/policy.d.ts.map +1 -0
- package/dist/remote/policy.js +94 -0
- package/dist/remote/policy.js.map +1 -0
- package/dist/remote/schemas.d.ts +298 -0
- package/dist/remote/schemas.d.ts.map +1 -0
- package/dist/remote/schemas.js +111 -0
- package/dist/remote/schemas.js.map +1 -0
- package/dist/remote/scopes.d.ts +6 -0
- package/dist/remote/scopes.d.ts.map +1 -0
- package/dist/remote/scopes.js +24 -0
- package/dist/remote/scopes.js.map +1 -0
- package/dist/remote/store.d.ts +45 -0
- package/dist/remote/store.d.ts.map +1 -0
- package/dist/remote/store.js +355 -0
- package/dist/remote/store.js.map +1 -0
- package/dist/remote/types.d.ts +183 -0
- package/dist/remote/types.d.ts.map +1 -0
- package/dist/remote/types.js +103 -0
- package/dist/remote/types.js.map +1 -0
- package/dist/remote/util.d.ts +6 -0
- package/dist/remote/util.d.ts.map +1 -0
- package/dist/remote/util.js +45 -0
- package/dist/remote/util.js.map +1 -0
- package/dist/remote/websocket.d.ts +26 -0
- package/dist/remote/websocket.d.ts.map +1 -0
- package/dist/remote/websocket.js +167 -0
- package/dist/remote/websocket.js.map +1 -0
- package/dist/render-http.d.ts +2 -0
- package/dist/render-http.d.ts.map +1 -0
- package/dist/render-http.js +14 -0
- package/dist/render-http.js.map +1 -0
- package/dist/resources.d.ts +19 -0
- package/dist/resources.d.ts.map +1 -0
- package/dist/resources.js +96 -0
- package/dist/resources.js.map +1 -0
- package/dist/retry.d.ts +45 -0
- package/dist/retry.d.ts.map +1 -0
- package/dist/retry.js +120 -0
- package/dist/retry.js.map +1 -0
- package/dist/safety.d.ts +31 -0
- package/dist/safety.d.ts.map +1 -0
- package/dist/safety.js +174 -0
- package/dist/safety.js.map +1 -0
- package/dist/server-http.d.ts +2 -0
- package/dist/server-http.d.ts.map +1 -0
- package/dist/server-http.js +432 -0
- package/dist/server-http.js.map +1 -0
- package/dist/session.d.ts +116 -0
- package/dist/session.d.ts.map +1 -0
- package/dist/session.js +666 -0
- package/dist/session.js.map +1 -0
- package/dist/shell.d.ts +10 -0
- package/dist/shell.d.ts.map +1 -0
- package/dist/shell.js +83 -0
- package/dist/shell.js.map +1 -0
- package/dist/ssh-config.d.ts +94 -0
- package/dist/ssh-config.d.ts.map +1 -0
- package/dist/ssh-config.js +234 -0
- package/dist/ssh-config.js.map +1 -0
- package/dist/streaming.d.ts +36 -0
- package/dist/streaming.d.ts.map +1 -0
- package/dist/streaming.js +140 -0
- package/dist/streaming.js.map +1 -0
- package/dist/telemetry.d.ts +17 -0
- package/dist/telemetry.d.ts.map +1 -0
- package/dist/telemetry.js +101 -0
- package/dist/telemetry.js.map +1 -0
- package/dist/tools/connector.provider.d.ts +28 -0
- package/dist/tools/connector.provider.d.ts.map +1 -0
- package/dist/tools/connector.provider.js +360 -0
- package/dist/tools/connector.provider.js.map +1 -0
- package/dist/tools/ensure.provider.d.ts +18 -0
- package/dist/tools/ensure.provider.d.ts.map +1 -0
- package/dist/tools/ensure.provider.js +173 -0
- package/dist/tools/ensure.provider.js.map +1 -0
- package/dist/tools/fs.provider.d.ts +21 -0
- package/dist/tools/fs.provider.d.ts.map +1 -0
- package/dist/tools/fs.provider.js +259 -0
- package/dist/tools/fs.provider.js.map +1 -0
- package/dist/tools/index.d.ts +4 -0
- package/dist/tools/index.d.ts.map +1 -0
- package/dist/tools/index.js +68 -0
- package/dist/tools/index.js.map +1 -0
- package/dist/tools/metadata.d.ts +11 -0
- package/dist/tools/metadata.d.ts.map +1 -0
- package/dist/tools/metadata.js +10 -0
- package/dist/tools/metadata.js.map +1 -0
- package/dist/tools/output-schemas.d.ts +217 -0
- package/dist/tools/output-schemas.d.ts.map +1 -0
- package/dist/tools/output-schemas.js +300 -0
- package/dist/tools/output-schemas.js.map +1 -0
- package/dist/tools/process.provider.d.ts +22 -0
- package/dist/tools/process.provider.d.ts.map +1 -0
- package/dist/tools/process.provider.js +146 -0
- package/dist/tools/process.provider.js.map +1 -0
- package/dist/tools/registry.d.ts +12 -0
- package/dist/tools/registry.d.ts.map +1 -0
- package/dist/tools/registry.js +163 -0
- package/dist/tools/registry.js.map +1 -0
- package/dist/tools/results.d.ts +4 -0
- package/dist/tools/results.d.ts.map +1 -0
- package/dist/tools/results.js +5 -0
- package/dist/tools/results.js.map +1 -0
- package/dist/tools/session.provider.d.ts +23 -0
- package/dist/tools/session.provider.d.ts.map +1 -0
- package/dist/tools/session.provider.js +299 -0
- package/dist/tools/session.provider.js.map +1 -0
- package/dist/tools/system.provider.d.ts +18 -0
- package/dist/tools/system.provider.d.ts.map +1 -0
- package/dist/tools/system.provider.js +81 -0
- package/dist/tools/system.provider.js.map +1 -0
- package/dist/tools/transfer.provider.d.ts +16 -0
- package/dist/tools/transfer.provider.d.ts.map +1 -0
- package/dist/tools/transfer.provider.js +85 -0
- package/dist/tools/transfer.provider.js.map +1 -0
- package/dist/tools/tunnel.provider.d.ts +18 -0
- package/dist/tools/tunnel.provider.d.ts.map +1 -0
- package/dist/tools/tunnel.provider.js +142 -0
- package/dist/tools/tunnel.provider.js.map +1 -0
- package/dist/tools/types.d.ts +16 -0
- package/dist/tools/types.d.ts.map +1 -0
- package/dist/tools/types.js +2 -0
- package/dist/tools/types.js.map +1 -0
- package/dist/transfer.d.ts +40 -0
- package/dist/transfer.d.ts.map +1 -0
- package/dist/transfer.js +363 -0
- package/dist/transfer.js.map +1 -0
- package/dist/tunnel.d.ts +37 -0
- package/dist/tunnel.d.ts.map +1 -0
- package/dist/tunnel.js +234 -0
- package/dist/tunnel.js.map +1 -0
- package/dist/types.d.ts +341 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +184 -0
- package/dist/types.js.map +1 -0
- package/docs/docker.md +22 -0
- package/examples/README.md +77 -0
- package/mcp.json +21 -0
- package/package.json +147 -0
- package/registry/ssh-mcp-pro/mcp.json +21 -0
- package/server.json +76 -0
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import path from "node:path";
|
|
2
|
+
import { REMOTE_CAPABILITIES, } from "./types.js";
|
|
3
|
+
function allCapabilities(value) {
|
|
4
|
+
return Object.fromEntries(REMOTE_CAPABILITIES.map((capability) => [capability, value]));
|
|
5
|
+
}
|
|
6
|
+
export function createAgentPolicy(profile = "read-only") {
|
|
7
|
+
const base = allCapabilities(false);
|
|
8
|
+
let allowServices = [];
|
|
9
|
+
let allowContainers = [];
|
|
10
|
+
if (profile === "read-only") {
|
|
11
|
+
base["hosts.read"] = true;
|
|
12
|
+
base["agents.read"] = true;
|
|
13
|
+
base["system.read"] = true;
|
|
14
|
+
base["logs.read"] = true;
|
|
15
|
+
base["audit.read"] = true;
|
|
16
|
+
}
|
|
17
|
+
if (profile === "operations") {
|
|
18
|
+
base["hosts.read"] = true;
|
|
19
|
+
base["agents.read"] = true;
|
|
20
|
+
base["system.read"] = true;
|
|
21
|
+
base["logs.read"] = true;
|
|
22
|
+
base["service.manage"] = true;
|
|
23
|
+
base["docker.manage"] = true;
|
|
24
|
+
base["files.read"] = true;
|
|
25
|
+
base["audit.read"] = true;
|
|
26
|
+
}
|
|
27
|
+
if (profile === "full-admin") {
|
|
28
|
+
for (const capability of REMOTE_CAPABILITIES) {
|
|
29
|
+
base[capability] = true;
|
|
30
|
+
}
|
|
31
|
+
allowServices = ["*"];
|
|
32
|
+
allowContainers = ["*"];
|
|
33
|
+
}
|
|
34
|
+
return {
|
|
35
|
+
profile,
|
|
36
|
+
capabilities: base,
|
|
37
|
+
allowPaths: ["/tmp", "/var/tmp"],
|
|
38
|
+
denyPaths: ["/", "/etc", "/boot", "/dev", "/proc", "/sys"],
|
|
39
|
+
allowServices,
|
|
40
|
+
allowContainers,
|
|
41
|
+
maxOutputBytes: 200_000,
|
|
42
|
+
maxActionTimeoutSeconds: 120,
|
|
43
|
+
version: 1,
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
export function mergeCustomPolicy(policy) {
|
|
47
|
+
const base = createAgentPolicy(policy.profile ?? "custom");
|
|
48
|
+
return {
|
|
49
|
+
...base,
|
|
50
|
+
...policy,
|
|
51
|
+
profile: policy.profile ?? "custom",
|
|
52
|
+
capabilities: {
|
|
53
|
+
...base.capabilities,
|
|
54
|
+
...(policy.capabilities ?? {}),
|
|
55
|
+
},
|
|
56
|
+
allowPaths: policy.allowPaths ?? base.allowPaths,
|
|
57
|
+
denyPaths: policy.denyPaths ?? base.denyPaths,
|
|
58
|
+
allowServices: policy.allowServices ?? base.allowServices,
|
|
59
|
+
allowContainers: policy.allowContainers ?? base.allowContainers,
|
|
60
|
+
maxOutputBytes: policy.maxOutputBytes ?? base.maxOutputBytes,
|
|
61
|
+
maxActionTimeoutSeconds: policy.maxActionTimeoutSeconds ?? base.maxActionTimeoutSeconds,
|
|
62
|
+
version: policy.version ?? base.version,
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
function normalizePolicyPath(value) {
|
|
66
|
+
const normalized = path.posix.normalize(value.replace(/\\/gu, "/"));
|
|
67
|
+
return normalized.replace(/\/$/u, "") || "/";
|
|
68
|
+
}
|
|
69
|
+
export function isPathAllowed(policy, filePath) {
|
|
70
|
+
const normalized = normalizePolicyPath(filePath);
|
|
71
|
+
const denied = policy.denyPaths.some((rawPrefix) => {
|
|
72
|
+
const prefix = normalizePolicyPath(rawPrefix);
|
|
73
|
+
if (prefix === "/") {
|
|
74
|
+
return normalized === "/";
|
|
75
|
+
}
|
|
76
|
+
return normalized === prefix || normalized.startsWith(`${prefix}/`);
|
|
77
|
+
});
|
|
78
|
+
if (denied) {
|
|
79
|
+
return false;
|
|
80
|
+
}
|
|
81
|
+
return policy.allowPaths.some((rawPrefix) => {
|
|
82
|
+
const prefix = normalizePolicyPath(rawPrefix);
|
|
83
|
+
return prefix === "/"
|
|
84
|
+
? normalized === "/"
|
|
85
|
+
: normalized === prefix || normalized.startsWith(`${prefix}/`);
|
|
86
|
+
});
|
|
87
|
+
}
|
|
88
|
+
export function isServiceAllowed(policy, service) {
|
|
89
|
+
return policy.allowServices.includes("*") || policy.allowServices.includes(service);
|
|
90
|
+
}
|
|
91
|
+
export function isContainerAllowed(policy, container) {
|
|
92
|
+
return policy.allowContainers.includes("*") || policy.allowContainers.includes(container);
|
|
93
|
+
}
|
|
94
|
+
//# sourceMappingURL=policy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"policy.js","sourceRoot":"","sources":["../../src/remote/policy.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,298 @@
|
|
|
1
|
+
import { z } from "zod";
|
|
2
|
+
import { type ActionRequestEnvelope, type ActionResultEnvelope, type AgentHelloEnvelope, type AgentHostMetadata, type AgentPolicy, type PolicyUpdateEnvelope } from "./types.js";
|
|
3
|
+
export declare const agentHostMetadataSchema: z.ZodObject<{
|
|
4
|
+
hostname: z.ZodString;
|
|
5
|
+
os: z.ZodString;
|
|
6
|
+
arch: z.ZodString;
|
|
7
|
+
platform: z.ZodString;
|
|
8
|
+
}, z.core.$strict>;
|
|
9
|
+
export declare const capabilityPolicySchema: z.ZodObject<{
|
|
10
|
+
"hosts.read": z.ZodBoolean;
|
|
11
|
+
"agents.read": z.ZodBoolean;
|
|
12
|
+
"agents.admin": z.ZodBoolean;
|
|
13
|
+
"system.read": z.ZodBoolean;
|
|
14
|
+
"logs.read": z.ZodBoolean;
|
|
15
|
+
"service.manage": z.ZodBoolean;
|
|
16
|
+
"docker.manage": z.ZodBoolean;
|
|
17
|
+
"files.read": z.ZodBoolean;
|
|
18
|
+
"files.write": z.ZodBoolean;
|
|
19
|
+
"shell.exec": z.ZodBoolean;
|
|
20
|
+
"sudo.exec": z.ZodBoolean;
|
|
21
|
+
"agent.admin": z.ZodBoolean;
|
|
22
|
+
"audit.read": z.ZodBoolean;
|
|
23
|
+
}, z.core.$strict>;
|
|
24
|
+
export declare const agentPolicySchema: z.ZodObject<{
|
|
25
|
+
profile: z.ZodEnum<{
|
|
26
|
+
"read-only": "read-only";
|
|
27
|
+
operations: "operations";
|
|
28
|
+
"full-admin": "full-admin";
|
|
29
|
+
custom: "custom";
|
|
30
|
+
}>;
|
|
31
|
+
capabilities: z.ZodObject<{
|
|
32
|
+
"hosts.read": z.ZodBoolean;
|
|
33
|
+
"agents.read": z.ZodBoolean;
|
|
34
|
+
"agents.admin": z.ZodBoolean;
|
|
35
|
+
"system.read": z.ZodBoolean;
|
|
36
|
+
"logs.read": z.ZodBoolean;
|
|
37
|
+
"service.manage": z.ZodBoolean;
|
|
38
|
+
"docker.manage": z.ZodBoolean;
|
|
39
|
+
"files.read": z.ZodBoolean;
|
|
40
|
+
"files.write": z.ZodBoolean;
|
|
41
|
+
"shell.exec": z.ZodBoolean;
|
|
42
|
+
"sudo.exec": z.ZodBoolean;
|
|
43
|
+
"agent.admin": z.ZodBoolean;
|
|
44
|
+
"audit.read": z.ZodBoolean;
|
|
45
|
+
}, z.core.$strict>;
|
|
46
|
+
allowPaths: z.ZodArray<z.ZodString>;
|
|
47
|
+
denyPaths: z.ZodArray<z.ZodString>;
|
|
48
|
+
allowServices: z.ZodArray<z.ZodString>;
|
|
49
|
+
allowContainers: z.ZodArray<z.ZodString>;
|
|
50
|
+
maxOutputBytes: z.ZodNumber;
|
|
51
|
+
maxActionTimeoutSeconds: z.ZodNumber;
|
|
52
|
+
version: z.ZodNumber;
|
|
53
|
+
}, z.core.$strict>;
|
|
54
|
+
export declare const agentHelloEnvelopeSchema: z.ZodObject<{
|
|
55
|
+
type: z.ZodLiteral<"agent.hello">;
|
|
56
|
+
agent_id: z.ZodString;
|
|
57
|
+
timestamp: z.ZodString;
|
|
58
|
+
nonce: z.ZodString;
|
|
59
|
+
capabilities: z.ZodArray<z.ZodEnum<{
|
|
60
|
+
"hosts.read": "hosts.read";
|
|
61
|
+
"agents.read": "agents.read";
|
|
62
|
+
"agents.admin": "agents.admin";
|
|
63
|
+
"system.read": "system.read";
|
|
64
|
+
"logs.read": "logs.read";
|
|
65
|
+
"service.manage": "service.manage";
|
|
66
|
+
"docker.manage": "docker.manage";
|
|
67
|
+
"files.read": "files.read";
|
|
68
|
+
"files.write": "files.write";
|
|
69
|
+
"shell.exec": "shell.exec";
|
|
70
|
+
"sudo.exec": "sudo.exec";
|
|
71
|
+
"agent.admin": "agent.admin";
|
|
72
|
+
"audit.read": "audit.read";
|
|
73
|
+
}>>;
|
|
74
|
+
agent_version: z.ZodString;
|
|
75
|
+
host: z.ZodObject<{
|
|
76
|
+
hostname: z.ZodString;
|
|
77
|
+
os: z.ZodString;
|
|
78
|
+
arch: z.ZodString;
|
|
79
|
+
platform: z.ZodString;
|
|
80
|
+
}, z.core.$strict>;
|
|
81
|
+
signature: z.ZodString;
|
|
82
|
+
}, z.core.$strict>;
|
|
83
|
+
export declare const actionRequestEnvelopeSchema: z.ZodObject<{
|
|
84
|
+
type: z.ZodLiteral<"action.request">;
|
|
85
|
+
action_id: z.ZodString;
|
|
86
|
+
agent_id: z.ZodString;
|
|
87
|
+
user_id: z.ZodString;
|
|
88
|
+
tool: z.ZodEnum<{
|
|
89
|
+
list_hosts: "list_hosts";
|
|
90
|
+
list_agents: "list_agents";
|
|
91
|
+
create_enrollment_token: "create_enrollment_token";
|
|
92
|
+
get_agent_install_command: "get_agent_install_command";
|
|
93
|
+
get_system_status: "get_system_status";
|
|
94
|
+
tail_logs: "tail_logs";
|
|
95
|
+
restart_service: "restart_service";
|
|
96
|
+
docker_ps: "docker_ps";
|
|
97
|
+
docker_logs: "docker_logs";
|
|
98
|
+
docker_restart: "docker_restart";
|
|
99
|
+
file_read: "file_read";
|
|
100
|
+
file_write: "file_write";
|
|
101
|
+
run_shell: "run_shell";
|
|
102
|
+
run_shell_as_root: "run_shell_as_root";
|
|
103
|
+
update_agent_policy: "update_agent_policy";
|
|
104
|
+
revoke_agent: "revoke_agent";
|
|
105
|
+
get_audit_events: "get_audit_events";
|
|
106
|
+
}>;
|
|
107
|
+
capability: z.ZodEnum<{
|
|
108
|
+
"hosts.read": "hosts.read";
|
|
109
|
+
"agents.read": "agents.read";
|
|
110
|
+
"agents.admin": "agents.admin";
|
|
111
|
+
"system.read": "system.read";
|
|
112
|
+
"logs.read": "logs.read";
|
|
113
|
+
"service.manage": "service.manage";
|
|
114
|
+
"docker.manage": "docker.manage";
|
|
115
|
+
"files.read": "files.read";
|
|
116
|
+
"files.write": "files.write";
|
|
117
|
+
"shell.exec": "shell.exec";
|
|
118
|
+
"sudo.exec": "sudo.exec";
|
|
119
|
+
"agent.admin": "agent.admin";
|
|
120
|
+
"audit.read": "audit.read";
|
|
121
|
+
}>;
|
|
122
|
+
args: z.ZodRecord<z.ZodString, z.ZodUnknown>;
|
|
123
|
+
policy_version: z.ZodNumber;
|
|
124
|
+
issued_at: z.ZodString;
|
|
125
|
+
deadline: z.ZodString;
|
|
126
|
+
nonce: z.ZodString;
|
|
127
|
+
signature: z.ZodString;
|
|
128
|
+
}, z.core.$strict>;
|
|
129
|
+
export declare const actionResultEnvelopeSchema: z.ZodObject<{
|
|
130
|
+
type: z.ZodLiteral<"action.result">;
|
|
131
|
+
action_id: z.ZodString;
|
|
132
|
+
agent_id: z.ZodString;
|
|
133
|
+
nonce: z.ZodString;
|
|
134
|
+
status: z.ZodEnum<{
|
|
135
|
+
error: "error";
|
|
136
|
+
ok: "ok";
|
|
137
|
+
}>;
|
|
138
|
+
exit_code: z.ZodOptional<z.ZodNumber>;
|
|
139
|
+
stdout: z.ZodOptional<z.ZodString>;
|
|
140
|
+
stderr: z.ZodOptional<z.ZodString>;
|
|
141
|
+
started_at: z.ZodString;
|
|
142
|
+
finished_at: z.ZodString;
|
|
143
|
+
truncated: z.ZodBoolean;
|
|
144
|
+
error_code: z.ZodOptional<z.ZodEnum<{
|
|
145
|
+
UNAUTHORIZED: "UNAUTHORIZED";
|
|
146
|
+
FORBIDDEN: "FORBIDDEN";
|
|
147
|
+
INVALID_TOKEN: "INVALID_TOKEN";
|
|
148
|
+
INVALID_SCOPE: "INVALID_SCOPE";
|
|
149
|
+
INVALID_CLIENT: "INVALID_CLIENT";
|
|
150
|
+
INVALID_REDIRECT_URI: "INVALID_REDIRECT_URI";
|
|
151
|
+
PKCE_VALIDATION_FAILED: "PKCE_VALIDATION_FAILED";
|
|
152
|
+
AGENT_NOT_FOUND: "AGENT_NOT_FOUND";
|
|
153
|
+
AGENT_OFFLINE: "AGENT_OFFLINE";
|
|
154
|
+
AGENT_REVOKED: "AGENT_REVOKED";
|
|
155
|
+
AGENT_TIMEOUT: "AGENT_TIMEOUT";
|
|
156
|
+
POLICY_DENIED: "POLICY_DENIED";
|
|
157
|
+
CAPABILITY_DENIED: "CAPABILITY_DENIED";
|
|
158
|
+
ACTION_EXPIRED: "ACTION_EXPIRED";
|
|
159
|
+
ACTION_REPLAY_DETECTED: "ACTION_REPLAY_DETECTED";
|
|
160
|
+
SIGNATURE_INVALID: "SIGNATURE_INVALID";
|
|
161
|
+
COMMAND_TIMEOUT: "COMMAND_TIMEOUT";
|
|
162
|
+
OUTPUT_TRUNCATED: "OUTPUT_TRUNCATED";
|
|
163
|
+
UNSUPPORTED_PLATFORM: "UNSUPPORTED_PLATFORM";
|
|
164
|
+
UNSUPPORTED_PLATFORM_OR_PRIVILEGE: "UNSUPPORTED_PLATFORM_OR_PRIVILEGE";
|
|
165
|
+
INTERNAL_ERROR: "INTERNAL_ERROR";
|
|
166
|
+
}>>;
|
|
167
|
+
message: z.ZodOptional<z.ZodString>;
|
|
168
|
+
signature: z.ZodString;
|
|
169
|
+
}, z.core.$strict>;
|
|
170
|
+
export declare const policyUpdateEnvelopeSchema: z.ZodObject<{
|
|
171
|
+
type: z.ZodLiteral<"policy.update">;
|
|
172
|
+
agent_id: z.ZodString;
|
|
173
|
+
policy: z.ZodObject<{
|
|
174
|
+
profile: z.ZodEnum<{
|
|
175
|
+
"read-only": "read-only";
|
|
176
|
+
operations: "operations";
|
|
177
|
+
"full-admin": "full-admin";
|
|
178
|
+
custom: "custom";
|
|
179
|
+
}>;
|
|
180
|
+
capabilities: z.ZodObject<{
|
|
181
|
+
"hosts.read": z.ZodBoolean;
|
|
182
|
+
"agents.read": z.ZodBoolean;
|
|
183
|
+
"agents.admin": z.ZodBoolean;
|
|
184
|
+
"system.read": z.ZodBoolean;
|
|
185
|
+
"logs.read": z.ZodBoolean;
|
|
186
|
+
"service.manage": z.ZodBoolean;
|
|
187
|
+
"docker.manage": z.ZodBoolean;
|
|
188
|
+
"files.read": z.ZodBoolean;
|
|
189
|
+
"files.write": z.ZodBoolean;
|
|
190
|
+
"shell.exec": z.ZodBoolean;
|
|
191
|
+
"sudo.exec": z.ZodBoolean;
|
|
192
|
+
"agent.admin": z.ZodBoolean;
|
|
193
|
+
"audit.read": z.ZodBoolean;
|
|
194
|
+
}, z.core.$strict>;
|
|
195
|
+
allowPaths: z.ZodArray<z.ZodString>;
|
|
196
|
+
denyPaths: z.ZodArray<z.ZodString>;
|
|
197
|
+
allowServices: z.ZodArray<z.ZodString>;
|
|
198
|
+
allowContainers: z.ZodArray<z.ZodString>;
|
|
199
|
+
maxOutputBytes: z.ZodNumber;
|
|
200
|
+
maxActionTimeoutSeconds: z.ZodNumber;
|
|
201
|
+
version: z.ZodNumber;
|
|
202
|
+
}, z.core.$strict>;
|
|
203
|
+
policy_version: z.ZodNumber;
|
|
204
|
+
issued_at: z.ZodString;
|
|
205
|
+
nonce: z.ZodString;
|
|
206
|
+
signature: z.ZodString;
|
|
207
|
+
}, z.core.$strict>;
|
|
208
|
+
export declare const controlPlaneEnvelopeSchema: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
209
|
+
type: z.ZodLiteral<"action.request">;
|
|
210
|
+
action_id: z.ZodString;
|
|
211
|
+
agent_id: z.ZodString;
|
|
212
|
+
user_id: z.ZodString;
|
|
213
|
+
tool: z.ZodEnum<{
|
|
214
|
+
list_hosts: "list_hosts";
|
|
215
|
+
list_agents: "list_agents";
|
|
216
|
+
create_enrollment_token: "create_enrollment_token";
|
|
217
|
+
get_agent_install_command: "get_agent_install_command";
|
|
218
|
+
get_system_status: "get_system_status";
|
|
219
|
+
tail_logs: "tail_logs";
|
|
220
|
+
restart_service: "restart_service";
|
|
221
|
+
docker_ps: "docker_ps";
|
|
222
|
+
docker_logs: "docker_logs";
|
|
223
|
+
docker_restart: "docker_restart";
|
|
224
|
+
file_read: "file_read";
|
|
225
|
+
file_write: "file_write";
|
|
226
|
+
run_shell: "run_shell";
|
|
227
|
+
run_shell_as_root: "run_shell_as_root";
|
|
228
|
+
update_agent_policy: "update_agent_policy";
|
|
229
|
+
revoke_agent: "revoke_agent";
|
|
230
|
+
get_audit_events: "get_audit_events";
|
|
231
|
+
}>;
|
|
232
|
+
capability: z.ZodEnum<{
|
|
233
|
+
"hosts.read": "hosts.read";
|
|
234
|
+
"agents.read": "agents.read";
|
|
235
|
+
"agents.admin": "agents.admin";
|
|
236
|
+
"system.read": "system.read";
|
|
237
|
+
"logs.read": "logs.read";
|
|
238
|
+
"service.manage": "service.manage";
|
|
239
|
+
"docker.manage": "docker.manage";
|
|
240
|
+
"files.read": "files.read";
|
|
241
|
+
"files.write": "files.write";
|
|
242
|
+
"shell.exec": "shell.exec";
|
|
243
|
+
"sudo.exec": "sudo.exec";
|
|
244
|
+
"agent.admin": "agent.admin";
|
|
245
|
+
"audit.read": "audit.read";
|
|
246
|
+
}>;
|
|
247
|
+
args: z.ZodRecord<z.ZodString, z.ZodUnknown>;
|
|
248
|
+
policy_version: z.ZodNumber;
|
|
249
|
+
issued_at: z.ZodString;
|
|
250
|
+
deadline: z.ZodString;
|
|
251
|
+
nonce: z.ZodString;
|
|
252
|
+
signature: z.ZodString;
|
|
253
|
+
}, z.core.$strict>, z.ZodObject<{
|
|
254
|
+
type: z.ZodLiteral<"policy.update">;
|
|
255
|
+
agent_id: z.ZodString;
|
|
256
|
+
policy: z.ZodObject<{
|
|
257
|
+
profile: z.ZodEnum<{
|
|
258
|
+
"read-only": "read-only";
|
|
259
|
+
operations: "operations";
|
|
260
|
+
"full-admin": "full-admin";
|
|
261
|
+
custom: "custom";
|
|
262
|
+
}>;
|
|
263
|
+
capabilities: z.ZodObject<{
|
|
264
|
+
"hosts.read": z.ZodBoolean;
|
|
265
|
+
"agents.read": z.ZodBoolean;
|
|
266
|
+
"agents.admin": z.ZodBoolean;
|
|
267
|
+
"system.read": z.ZodBoolean;
|
|
268
|
+
"logs.read": z.ZodBoolean;
|
|
269
|
+
"service.manage": z.ZodBoolean;
|
|
270
|
+
"docker.manage": z.ZodBoolean;
|
|
271
|
+
"files.read": z.ZodBoolean;
|
|
272
|
+
"files.write": z.ZodBoolean;
|
|
273
|
+
"shell.exec": z.ZodBoolean;
|
|
274
|
+
"sudo.exec": z.ZodBoolean;
|
|
275
|
+
"agent.admin": z.ZodBoolean;
|
|
276
|
+
"audit.read": z.ZodBoolean;
|
|
277
|
+
}, z.core.$strict>;
|
|
278
|
+
allowPaths: z.ZodArray<z.ZodString>;
|
|
279
|
+
denyPaths: z.ZodArray<z.ZodString>;
|
|
280
|
+
allowServices: z.ZodArray<z.ZodString>;
|
|
281
|
+
allowContainers: z.ZodArray<z.ZodString>;
|
|
282
|
+
maxOutputBytes: z.ZodNumber;
|
|
283
|
+
maxActionTimeoutSeconds: z.ZodNumber;
|
|
284
|
+
version: z.ZodNumber;
|
|
285
|
+
}, z.core.$strict>;
|
|
286
|
+
policy_version: z.ZodNumber;
|
|
287
|
+
issued_at: z.ZodString;
|
|
288
|
+
nonce: z.ZodString;
|
|
289
|
+
signature: z.ZodString;
|
|
290
|
+
}, z.core.$strict>], "type">;
|
|
291
|
+
export declare function parseAgentHostMetadata(value: unknown): AgentHostMetadata;
|
|
292
|
+
export declare function parseAgentPolicy(value: unknown): AgentPolicy;
|
|
293
|
+
export declare function parseAgentHelloEnvelope(value: unknown): AgentHelloEnvelope;
|
|
294
|
+
export declare function parseActionRequestEnvelope(value: unknown): ActionRequestEnvelope;
|
|
295
|
+
export declare function parseActionResultEnvelope(value: unknown): ActionResultEnvelope;
|
|
296
|
+
export declare function parsePolicyUpdateEnvelope(value: unknown): PolicyUpdateEnvelope;
|
|
297
|
+
export declare function parseControlPlaneEnvelope(value: unknown): ActionRequestEnvelope | PolicyUpdateEnvelope;
|
|
298
|
+
//# sourceMappingURL=schemas.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schemas.d.ts","sourceRoot":"","sources":["../../src/remote/schemas.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAIL,KAAK,qBAAqB,EAC1B,KAAK,oBAAoB,EACzB,KAAK,kBAAkB,EACvB,KAAK,iBAAiB,EACtB,KAAK,WAAW,EAChB,KAAK,oBAAoB,EAC1B,MAAM,YAAY,CAAC;AAMpB,eAAO,MAAM,uBAAuB;;;;;kBAOzB,CAAC;AAMZ,eAAO,MAAM,sBAAsB;;;;;;;;;;;;;;kBAA2C,CAAC;AAE/E,eAAO,MAAM,iBAAiB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBAYnB,CAAC;AAEZ,eAAO,MAAM,wBAAwB;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBAW1B,CAAC;AAEZ,eAAO,MAAM,2BAA2B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBAe7B,CAAC;AAEZ,eAAO,MAAM,0BAA0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBAiB5B,CAAC;AAEZ,eAAO,MAAM,0BAA0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBAU5B,CAAC;AAEZ,eAAO,MAAM,0BAA0B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4BAGrC,CAAC;AAEH,wBAAgB,sBAAsB,CAAC,KAAK,EAAE,OAAO,GAAG,iBAAiB,CAExE;AAED,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,OAAO,GAAG,WAAW,CAE5D;AAED,wBAAgB,uBAAuB,CAAC,KAAK,EAAE,OAAO,GAAG,kBAAkB,CAE1E;AAED,wBAAgB,0BAA0B,CAAC,KAAK,EAAE,OAAO,GAAG,qBAAqB,CAEhF;AAED,wBAAgB,yBAAyB,CAAC,KAAK,EAAE,OAAO,GAAG,oBAAoB,CAE9E;AAED,wBAAgB,yBAAyB,CAAC,KAAK,EAAE,OAAO,GAAG,oBAAoB,CAE9E;AAED,wBAAgB,yBAAyB,CACvC,KAAK,EAAE,OAAO,GACb,qBAAqB,GAAG,oBAAoB,CAE9C"}
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
import { z } from "zod";
|
|
2
|
+
import { REMOTE_CAPABILITIES, REMOTE_ERROR_CODES, REMOTE_TOOLS, } from "./types.js";
|
|
3
|
+
const capabilitySchema = z.enum(REMOTE_CAPABILITIES);
|
|
4
|
+
const toolSchema = z.enum(REMOTE_TOOLS);
|
|
5
|
+
const errorCodeSchema = z.enum(REMOTE_ERROR_CODES);
|
|
6
|
+
export const agentHostMetadataSchema = z
|
|
7
|
+
.object({
|
|
8
|
+
hostname: z.string().min(1).max(255),
|
|
9
|
+
os: z.string().min(1).max(128),
|
|
10
|
+
arch: z.string().min(1).max(64),
|
|
11
|
+
platform: z.string().min(1).max(128),
|
|
12
|
+
})
|
|
13
|
+
.strict();
|
|
14
|
+
const capabilityPolicyShape = Object.fromEntries(REMOTE_CAPABILITIES.map((capability) => [capability, z.boolean()]));
|
|
15
|
+
export const capabilityPolicySchema = z.object(capabilityPolicyShape).strict();
|
|
16
|
+
export const agentPolicySchema = z
|
|
17
|
+
.object({
|
|
18
|
+
profile: z.enum(["read-only", "operations", "full-admin", "custom"]),
|
|
19
|
+
capabilities: capabilityPolicySchema,
|
|
20
|
+
allowPaths: z.array(z.string()),
|
|
21
|
+
denyPaths: z.array(z.string()),
|
|
22
|
+
allowServices: z.array(z.string()),
|
|
23
|
+
allowContainers: z.array(z.string()),
|
|
24
|
+
maxOutputBytes: z.number().int().positive().max(10_000_000),
|
|
25
|
+
maxActionTimeoutSeconds: z.number().int().positive().max(3600),
|
|
26
|
+
version: z.number().int().positive(),
|
|
27
|
+
})
|
|
28
|
+
.strict();
|
|
29
|
+
export const agentHelloEnvelopeSchema = z
|
|
30
|
+
.object({
|
|
31
|
+
type: z.literal("agent.hello"),
|
|
32
|
+
agent_id: z.string().min(1),
|
|
33
|
+
timestamp: z.string().datetime(),
|
|
34
|
+
nonce: z.string().min(16),
|
|
35
|
+
capabilities: z.array(capabilitySchema),
|
|
36
|
+
agent_version: z.string().min(1).max(128),
|
|
37
|
+
host: agentHostMetadataSchema,
|
|
38
|
+
signature: z.string().min(1),
|
|
39
|
+
})
|
|
40
|
+
.strict();
|
|
41
|
+
export const actionRequestEnvelopeSchema = z
|
|
42
|
+
.object({
|
|
43
|
+
type: z.literal("action.request"),
|
|
44
|
+
action_id: z.string().min(1),
|
|
45
|
+
agent_id: z.string().min(1),
|
|
46
|
+
user_id: z.string().min(1),
|
|
47
|
+
tool: toolSchema,
|
|
48
|
+
capability: capabilitySchema,
|
|
49
|
+
args: z.record(z.string(), z.unknown()),
|
|
50
|
+
policy_version: z.number().int().positive(),
|
|
51
|
+
issued_at: z.string().datetime(),
|
|
52
|
+
deadline: z.string().datetime(),
|
|
53
|
+
nonce: z.string().min(16),
|
|
54
|
+
signature: z.string().min(1),
|
|
55
|
+
})
|
|
56
|
+
.strict();
|
|
57
|
+
export const actionResultEnvelopeSchema = z
|
|
58
|
+
.object({
|
|
59
|
+
type: z.literal("action.result"),
|
|
60
|
+
action_id: z.string().min(1),
|
|
61
|
+
agent_id: z.string().min(1),
|
|
62
|
+
nonce: z.string().min(16),
|
|
63
|
+
status: z.enum(["ok", "error"]),
|
|
64
|
+
exit_code: z.number().int().optional(),
|
|
65
|
+
stdout: z.string().optional(),
|
|
66
|
+
stderr: z.string().optional(),
|
|
67
|
+
started_at: z.string().datetime(),
|
|
68
|
+
finished_at: z.string().datetime(),
|
|
69
|
+
truncated: z.boolean(),
|
|
70
|
+
error_code: errorCodeSchema.optional(),
|
|
71
|
+
message: z.string().optional(),
|
|
72
|
+
signature: z.string().min(1),
|
|
73
|
+
})
|
|
74
|
+
.strict();
|
|
75
|
+
export const policyUpdateEnvelopeSchema = z
|
|
76
|
+
.object({
|
|
77
|
+
type: z.literal("policy.update"),
|
|
78
|
+
agent_id: z.string().min(1),
|
|
79
|
+
policy: agentPolicySchema,
|
|
80
|
+
policy_version: z.number().int().positive(),
|
|
81
|
+
issued_at: z.string().datetime(),
|
|
82
|
+
nonce: z.string().min(16),
|
|
83
|
+
signature: z.string().min(1),
|
|
84
|
+
})
|
|
85
|
+
.strict();
|
|
86
|
+
export const controlPlaneEnvelopeSchema = z.discriminatedUnion("type", [
|
|
87
|
+
actionRequestEnvelopeSchema,
|
|
88
|
+
policyUpdateEnvelopeSchema,
|
|
89
|
+
]);
|
|
90
|
+
export function parseAgentHostMetadata(value) {
|
|
91
|
+
return agentHostMetadataSchema.parse(value);
|
|
92
|
+
}
|
|
93
|
+
export function parseAgentPolicy(value) {
|
|
94
|
+
return agentPolicySchema.parse(value);
|
|
95
|
+
}
|
|
96
|
+
export function parseAgentHelloEnvelope(value) {
|
|
97
|
+
return agentHelloEnvelopeSchema.parse(value);
|
|
98
|
+
}
|
|
99
|
+
export function parseActionRequestEnvelope(value) {
|
|
100
|
+
return actionRequestEnvelopeSchema.parse(value);
|
|
101
|
+
}
|
|
102
|
+
export function parseActionResultEnvelope(value) {
|
|
103
|
+
return actionResultEnvelopeSchema.parse(value);
|
|
104
|
+
}
|
|
105
|
+
export function parsePolicyUpdateEnvelope(value) {
|
|
106
|
+
return policyUpdateEnvelopeSchema.parse(value);
|
|
107
|
+
}
|
|
108
|
+
export function parseControlPlaneEnvelope(value) {
|
|
109
|
+
return controlPlaneEnvelopeSchema.parse(value);
|
|
110
|
+
}
|
|
111
|
+
//# sourceMappingURL=schemas.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schemas.js","sourceRoot":"","sources":["../../src/remote/schemas.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EACL,mBAAmB,EACnB,kBAAkB,EAClB,YAAY,GAOb,MAAM,YAAY,CAAC;AAEpB,MAAM,gBAAgB,GAAG,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;AACrD,MAAM,UAAU,GAAG,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;AACxC,MAAM,eAAe,GAAG,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;AAEnD,MAAM,CAAC,MAAM,uBAAuB,GAAG,CAAC;KACrC,MAAM,CAAC;IACN,QAAQ,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC;IACpC,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC;IAC9B,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC;IAC/B,QAAQ,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC;CACrC,CAAC;KACD,MAAM,EAAE,CAAC;AAEZ,MAAM,qBAAqB,GAAG,MAAM,CAAC,WAAW,CAC9C,mBAAmB,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC,UAAU,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CACL,CAAC;AAEhE,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,CAAC,MAAM,CAAC,qBAAqB,CAAC,CAAC,MAAM,EAAE,CAAC;AAE/E,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC;KAC/B,MAAM,CAAC;IACN,OAAO,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,WAAW,EAAE,YAAY,EAAE,YAAY,EAAE,QAAQ,CAAC,CAAC;IACpE,YAAY,EAAE,sBAAsB;IACpC,UAAU,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;IAC/B,SAAS,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;IAC9B,aAAa,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;IAClC,eAAe,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC;IACpC,cAAc,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE,CAAC,GAAG,CAAC,UAAU,CAAC;IAC3D,uBAAuB,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC;IAC9D,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE;CACrC,CAAC;KACD,MAAM,EAAE,CAAC;AAEZ,MAAM,CAAC,MAAM,wBAAwB,GAAG,CAAC;KACtC,MAAM,CAAC;IACN,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC;IAC9B,QAAQ,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IAC3B,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAChC,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC;IACzB,YAAY,EAAE,CAAC,CAAC,KAAK,CAAC,gBAAgB,CAAC;IACvC,aAAa,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC;IACzC,IAAI,EAAE,uBAAuB;IAC7B,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;CAC7B,CAAC;KACD,MAAM,EAAE,CAAC;AAEZ,MAAM,CAAC,MAAM,2BAA2B,GAAG,CAAC;KACzC,MAAM,CAAC;IACN,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC;IACjC,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IAC5B,QAAQ,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IAC3B,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IAC1B,IAAI,EAAE,UAAU;IAChB,UAAU,EAAE,gBAAgB;IAC5B,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,OAAO,EAAE,CAAC;IACvC,cAAc,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE;IAC3C,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAChC,QAAQ,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC/B,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC;IACzB,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;CAC7B,CAAC;KACD,MAAM,EAAE,CAAC;AAEZ,MAAM,CAAC,MAAM,0BAA0B,GAAG,CAAC;KACxC,MAAM,CAAC;IACN,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,eAAe,CAAC;IAChC,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IAC5B,QAAQ,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IAC3B,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC;IACzB,MAAM,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;IAC/B,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE;IACtC,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC7B,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC7B,UAAU,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACjC,WAAW,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAClC,SAAS,EAAE,CAAC,CAAC,OAAO,EAAE;IACtB,UAAU,EAAE,eAAe,CAAC,QAAQ,EAAE;IACtC,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC9B,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;CAC7B,CAAC;KACD,MAAM,EAAE,CAAC;AAEZ,MAAM,CAAC,MAAM,0BAA0B,GAAG,CAAC;KACxC,MAAM,CAAC;IACN,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,eAAe,CAAC;IAChC,QAAQ,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IAC3B,MAAM,EAAE,iBAAiB;IACzB,cAAc,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE;IAC3C,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAChC,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC;IACzB,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;CAC7B,CAAC;KACD,MAAM,EAAE,CAAC;AAEZ,MAAM,CAAC,MAAM,0BAA0B,GAAG,CAAC,CAAC,kBAAkB,CAAC,MAAM,EAAE;IACrE,2BAA2B;IAC3B,0BAA0B;CAC3B,CAAC,CAAC;AAEH,MAAM,UAAU,sBAAsB,CAAC,KAAc;IACnD,OAAO,uBAAuB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;AAC9C,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,KAAc;IAC7C,OAAO,iBAAiB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;AACxC,CAAC;AAED,MAAM,UAAU,uBAAuB,CAAC,KAAc;IACpD,OAAO,wBAAwB,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;AAC/C,CAAC;AAED,MAAM,UAAU,0BAA0B,CAAC,KAAc;IACvD,OAAO,2BAA2B,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;AAClD,CAAC;AAED,MAAM,UAAU,yBAAyB,CAAC,KAAc;IACtD,OAAO,0BAA0B,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;AACjD,CAAC;AAED,MAAM,UAAU,yBAAyB,CAAC,KAAc;IACtD,OAAO,0BAA0B,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;AACjD,CAAC;AAED,MAAM,UAAU,yBAAyB,CACvC,KAAc;IAEd,OAAO,0BAA0B,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;AACjD,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { type RemoteCapability, type RemoteScope } from "./types.js";
|
|
2
|
+
export declare function parseScopes(scope: string | undefined): RemoteScope[];
|
|
3
|
+
export declare function capabilitiesFromScopes(scopes: RemoteScope[]): RemoteCapability[];
|
|
4
|
+
export declare function hasCapability(capabilities: readonly RemoteCapability[], capability: RemoteCapability): boolean;
|
|
5
|
+
export declare function allRemoteScopes(): RemoteScope[];
|
|
6
|
+
//# sourceMappingURL=scopes.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scopes.d.ts","sourceRoot":"","sources":["../../src/remote/scopes.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,KAAK,gBAAgB,EACrB,KAAK,WAAW,EACjB,MAAM,YAAY,CAAC;AAEpB,wBAAgB,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,GAAG,WAAW,EAAE,CAQpE;AAED,wBAAgB,sBAAsB,CAAC,MAAM,EAAE,WAAW,EAAE,GAAG,gBAAgB,EAAE,CAQhF;AAED,wBAAgB,aAAa,CAC3B,YAAY,EAAE,SAAS,gBAAgB,EAAE,EACzC,UAAU,EAAE,gBAAgB,GAC3B,OAAO,CAET;AAED,wBAAgB,eAAe,IAAI,WAAW,EAAE,CAE/C"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { REMOTE_SCOPES, SCOPE_CAPABILITY_MAP, } from "./types.js";
|
|
2
|
+
export function parseScopes(scope) {
|
|
3
|
+
if (!scope) {
|
|
4
|
+
return [];
|
|
5
|
+
}
|
|
6
|
+
const requested = scope.split(/\s+/u).filter(Boolean);
|
|
7
|
+
return requested.filter((item) => REMOTE_SCOPES.includes(item));
|
|
8
|
+
}
|
|
9
|
+
export function capabilitiesFromScopes(scopes) {
|
|
10
|
+
const capabilities = new Set();
|
|
11
|
+
for (const scope of scopes) {
|
|
12
|
+
for (const capability of SCOPE_CAPABILITY_MAP[scope]) {
|
|
13
|
+
capabilities.add(capability);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
return [...capabilities];
|
|
17
|
+
}
|
|
18
|
+
export function hasCapability(capabilities, capability) {
|
|
19
|
+
return capabilities.includes(capability);
|
|
20
|
+
}
|
|
21
|
+
export function allRemoteScopes() {
|
|
22
|
+
return [...REMOTE_SCOPES];
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=scopes.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scopes.js","sourceRoot":"","sources":["../../src/remote/scopes.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,aAAa,EACb,oBAAoB,GAGrB,MAAM,YAAY,CAAC;AAEpB,MAAM,UAAU,WAAW,CAAC,KAAyB;IACnD,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,OAAO,EAAE,CAAC;IACZ,CAAC;IACD,MAAM,SAAS,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IACtD,OAAO,SAAS,CAAC,MAAM,CAAC,CAAC,IAAI,EAAuB,EAAE,CACpD,aAAa,CAAC,QAAQ,CAAC,IAAmB,CAAC,CAC5C,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,sBAAsB,CAAC,MAAqB;IAC1D,MAAM,YAAY,GAAG,IAAI,GAAG,EAAoB,CAAC;IACjD,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;QAC3B,KAAK,MAAM,UAAU,IAAI,oBAAoB,CAAC,KAAK,CAAC,EAAE,CAAC;YACrD,YAAY,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QAC/B,CAAC;IACH,CAAC;IACD,OAAO,CAAC,GAAG,YAAY,CAAC,CAAC;AAC3B,CAAC;AAED,MAAM,UAAU,aAAa,CAC3B,YAAyC,EACzC,UAA4B;IAE5B,OAAO,YAAY,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;AAC3C,CAAC;AAED,MAAM,UAAU,eAAe;IAC7B,OAAO,CAAC,GAAG,aAAa,CAAC,CAAC;AAC5B,CAAC"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import type { ActionRecord, AgentEnrollmentTokenRecord, AuditEvent, GitHubUser, OAuthAuthorizationCode, OAuthClient, RemoteAgentRecord } from "./types.js";
|
|
2
|
+
type SqlValue = string | number | null;
|
|
3
|
+
type NodeSqliteModule = {
|
|
4
|
+
DatabaseSync: unknown;
|
|
5
|
+
};
|
|
6
|
+
type RemoteStoreOptions = {
|
|
7
|
+
loadSqlite?: () => NodeSqliteModule;
|
|
8
|
+
};
|
|
9
|
+
export declare class RemoteStore {
|
|
10
|
+
private readonly db;
|
|
11
|
+
constructor(databaseUrl: string, options?: RemoteStoreOptions);
|
|
12
|
+
close(): void;
|
|
13
|
+
private migrate;
|
|
14
|
+
upsertUser(user: GitHubUser & {
|
|
15
|
+
internalId: string;
|
|
16
|
+
now: string;
|
|
17
|
+
}): void;
|
|
18
|
+
getUserByGitHubId(githubId: string): {
|
|
19
|
+
id: string;
|
|
20
|
+
githubId: string;
|
|
21
|
+
githubLogin: string;
|
|
22
|
+
} | undefined;
|
|
23
|
+
insertClient(client: OAuthClient): void;
|
|
24
|
+
getClient(clientId: string): OAuthClient | undefined;
|
|
25
|
+
countOAuthClients(): number;
|
|
26
|
+
insertAuthorizationCode(code: OAuthAuthorizationCode): void;
|
|
27
|
+
getAuthorizationCodeByHash(codeHash: string): OAuthAuthorizationCode | undefined;
|
|
28
|
+
markAuthorizationCodeUsed(codeHash: string, usedAt: string): void;
|
|
29
|
+
insertAgent(agent: RemoteAgentRecord): void;
|
|
30
|
+
updateAgent(agent: RemoteAgentRecord): void;
|
|
31
|
+
getAgent(agentId: string): RemoteAgentRecord | undefined;
|
|
32
|
+
getAgentByAlias(userId: string, alias: string): RemoteAgentRecord | undefined;
|
|
33
|
+
listAgents(userId: string): RemoteAgentRecord[];
|
|
34
|
+
private agentFromRow;
|
|
35
|
+
insertEnrollmentToken(token: AgentEnrollmentTokenRecord): void;
|
|
36
|
+
getEnrollmentTokenByHash(tokenHash: string): AgentEnrollmentTokenRecord | undefined;
|
|
37
|
+
markEnrollmentTokenUsed(tokenHash: string, usedAt: string): void;
|
|
38
|
+
insertAction(action: ActionRecord): void;
|
|
39
|
+
updateAction(action: ActionRecord): void;
|
|
40
|
+
insertAudit(event: AuditEvent): void;
|
|
41
|
+
listAudit(userId: string, agentId: string | undefined, limit: number): AuditEvent[];
|
|
42
|
+
run(sql: string, ...params: SqlValue[]): void;
|
|
43
|
+
}
|
|
44
|
+
export {};
|
|
45
|
+
//# sourceMappingURL=store.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"store.d.ts","sourceRoot":"","sources":["../../src/remote/store.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,YAAY,EACZ,0BAA0B,EAC1B,UAAU,EACV,UAAU,EACV,sBAAsB,EACtB,WAAW,EACX,iBAAiB,EAClB,MAAM,YAAY,CAAC;AAEpB,KAAK,QAAQ,GAAG,MAAM,GAAG,MAAM,GAAG,IAAI,CAAC;AAEvC,KAAK,gBAAgB,GAAG;IAAE,YAAY,EAAE,OAAO,CAAA;CAAE,CAAC;AAElD,KAAK,kBAAkB,GAAG;IACxB,UAAU,CAAC,EAAE,MAAM,gBAAgB,CAAC;CACrC,CAAC;AAsDF,qBAAa,WAAW;IACtB,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAwC;gBAE/C,WAAW,EAAE,MAAM,EAAE,OAAO,GAAE,kBAAuB;IAWjE,KAAK,IAAI,IAAI;IAIb,OAAO,CAAC,OAAO;IA0Ff,UAAU,CAAC,IAAI,EAAE,UAAU,GAAG;QAAE,UAAU,EAAE,MAAM,CAAC;QAAC,GAAG,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI;IAUxE,iBAAiB,CACf,QAAQ,EAAE,MAAM,GACf;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAA;KAAE,GAAG,SAAS;IAcpE,YAAY,CAAC,MAAM,EAAE,WAAW,GAAG,IAAI;IAmBvC,SAAS,CAAC,QAAQ,EAAE,MAAM,GAAG,WAAW,GAAG,SAAS;IAmBpD,iBAAiB,IAAI,MAAM;IAO3B,uBAAuB,CAAC,IAAI,EAAE,sBAAsB,GAAG,IAAI;IAuB3D,0BAA0B,CAAC,QAAQ,EAAE,MAAM,GAAG,sBAAsB,GAAG,SAAS;IAuBhF,yBAAyB,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,IAAI;IAWjE,WAAW,CAAC,KAAK,EAAE,iBAAiB,GAAG,IAAI;IAuB3C,WAAW,CAAC,KAAK,EAAE,iBAAiB,GAAG,IAAI;IAsB3C,QAAQ,CAAC,OAAO,EAAE,MAAM,GAAG,iBAAiB,GAAG,SAAS;IAOxD,eAAe,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,iBAAiB,GAAG,SAAS;IAO7E,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,iBAAiB,EAAE;IAQ/C,OAAO,CAAC,YAAY;IAmBpB,qBAAqB,CAAC,KAAK,EAAE,0BAA0B,GAAG,IAAI;IAkB9D,wBAAwB,CAAC,SAAS,EAAE,MAAM,GAAG,0BAA0B,GAAG,SAAS;IAkBnF,uBAAuB,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,IAAI;IAWhE,YAAY,CAAC,MAAM,EAAE,YAAY,GAAG,IAAI;IAuBxC,YAAY,CAAC,MAAM,EAAE,YAAY,GAAG,IAAI;IAgBxC,WAAW,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;IAmBpC,SAAS,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,SAAS,EAAE,KAAK,EAAE,MAAM,GAAG,UAAU,EAAE;IAuBnF,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAI;CAG9C"}
|