@lobu/cli 4.3.0 → 6.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/README.md +11 -26
- package/dist/__tests__/chat.integration.test.js +19 -19
- package/dist/__tests__/chat.integration.test.js.map +1 -1
- package/dist/__tests__/dev.test.d.ts +2 -0
- package/dist/__tests__/dev.test.d.ts.map +1 -0
- package/dist/__tests__/dev.test.js +25 -0
- package/dist/__tests__/dev.test.js.map +1 -0
- package/dist/__tests__/init-memory.test.js +1 -14
- package/dist/__tests__/init-memory.test.js.map +1 -1
- package/dist/__tests__/token.test.d.ts +2 -0
- package/dist/__tests__/token.test.d.ts.map +1 -0
- package/dist/__tests__/token.test.js +52 -0
- package/dist/__tests__/token.test.js.map +1 -0
- package/dist/bundled-skills/lobu/SKILL.md +95 -7
- package/dist/commands/_lib/apply/__tests__/client.test.d.ts +2 -0
- package/dist/commands/_lib/apply/__tests__/client.test.d.ts.map +1 -0
- package/dist/commands/_lib/apply/__tests__/client.test.js +23 -0
- package/dist/commands/_lib/apply/__tests__/client.test.js.map +1 -0
- package/dist/commands/_lib/apply/__tests__/desired-state.test.d.ts +2 -0
- package/dist/commands/_lib/apply/__tests__/desired-state.test.d.ts.map +1 -0
- package/dist/commands/_lib/apply/__tests__/desired-state.test.js +140 -0
- package/dist/commands/_lib/apply/__tests__/desired-state.test.js.map +1 -0
- package/dist/commands/_lib/apply/__tests__/diff.test.d.ts +2 -0
- package/dist/commands/_lib/apply/__tests__/diff.test.d.ts.map +1 -0
- package/dist/commands/_lib/apply/__tests__/diff.test.js +378 -0
- package/dist/commands/_lib/apply/__tests__/diff.test.js.map +1 -0
- package/dist/commands/_lib/apply/apply-cmd.d.ts +12 -0
- package/dist/commands/_lib/apply/apply-cmd.d.ts.map +1 -0
- package/dist/commands/_lib/apply/apply-cmd.js +183 -0
- package/dist/commands/_lib/apply/apply-cmd.js.map +1 -0
- package/dist/commands/_lib/apply/client.d.ts +130 -0
- package/dist/commands/_lib/apply/client.d.ts.map +1 -0
- package/dist/commands/_lib/apply/client.js +243 -0
- package/dist/commands/_lib/apply/client.js.map +1 -0
- package/dist/commands/_lib/apply/desired-state.d.ts +71 -0
- package/dist/commands/_lib/apply/desired-state.d.ts.map +1 -0
- package/dist/commands/_lib/apply/desired-state.js +600 -0
- package/dist/commands/_lib/apply/desired-state.js.map +1 -0
- package/dist/commands/_lib/apply/diff.d.ts +76 -0
- package/dist/commands/_lib/apply/diff.d.ts.map +1 -0
- package/dist/commands/_lib/apply/diff.js +323 -0
- package/dist/commands/_lib/apply/diff.js.map +1 -0
- package/dist/commands/_lib/apply/prompt.d.ts +13 -0
- package/dist/commands/_lib/apply/prompt.d.ts.map +1 -0
- package/dist/commands/_lib/apply/prompt.js +19 -0
- package/dist/commands/_lib/apply/prompt.js.map +1 -0
- package/dist/commands/_lib/apply/render.d.ts +9 -0
- package/dist/commands/_lib/apply/render.d.ts.map +1 -0
- package/dist/commands/_lib/apply/render.js +92 -0
- package/dist/commands/_lib/apply/render.js.map +1 -0
- package/dist/commands/agent.d.ts +27 -0
- package/dist/commands/agent.d.ts.map +1 -0
- package/dist/commands/agent.js +111 -0
- package/dist/commands/agent.js.map +1 -0
- package/dist/commands/apply.d.ts +3 -0
- package/dist/commands/apply.d.ts.map +1 -0
- package/dist/commands/apply.js +5 -0
- package/dist/commands/apply.js.map +1 -0
- package/dist/commands/chat.d.ts.map +1 -1
- package/dist/commands/chat.js +5 -5
- package/dist/commands/chat.js.map +1 -1
- package/dist/commands/dev.d.ts +8 -3
- package/dist/commands/dev.d.ts.map +1 -1
- package/dist/commands/dev.js +128 -124
- package/dist/commands/dev.js.map +1 -1
- package/dist/commands/doctor.d.ts +6 -0
- package/dist/commands/doctor.d.ts.map +1 -0
- package/dist/commands/doctor.js +75 -0
- package/dist/commands/doctor.js.map +1 -0
- package/dist/commands/eval.d.ts +1 -0
- package/dist/commands/eval.d.ts.map +1 -1
- package/dist/commands/eval.js +7 -4
- package/dist/commands/eval.js.map +1 -1
- package/dist/commands/init.d.ts +2 -9
- package/dist/commands/init.d.ts.map +1 -1
- package/dist/commands/init.js +35 -249
- package/dist/commands/init.js.map +1 -1
- package/dist/commands/login.d.ts +11 -3
- package/dist/commands/login.d.ts.map +1 -1
- package/dist/commands/login.js +109 -251
- package/dist/commands/login.js.map +1 -1
- package/dist/commands/logout.d.ts.map +1 -1
- package/dist/commands/logout.js +12 -11
- package/dist/commands/logout.js.map +1 -1
- package/dist/commands/memory/_lib/agent-detect.d.ts +9 -0
- package/dist/commands/memory/_lib/agent-detect.d.ts.map +1 -0
- package/dist/commands/memory/_lib/agent-detect.js +82 -0
- package/dist/commands/memory/_lib/agent-detect.js.map +1 -0
- package/dist/commands/memory/_lib/browser-auth-cmd.d.ts +19 -0
- package/dist/commands/memory/_lib/browser-auth-cmd.d.ts.map +1 -0
- package/dist/commands/memory/_lib/browser-auth-cmd.js +635 -0
- package/dist/commands/memory/_lib/browser-auth-cmd.js.map +1 -0
- package/dist/commands/memory/_lib/browser.d.ts +2 -0
- package/dist/commands/memory/_lib/browser.d.ts.map +1 -0
- package/dist/commands/memory/_lib/browser.js +26 -0
- package/dist/commands/memory/_lib/browser.js.map +1 -0
- package/dist/commands/memory/_lib/errors.d.ts +13 -0
- package/dist/commands/memory/_lib/errors.d.ts.map +1 -0
- package/dist/commands/memory/_lib/errors.js +23 -0
- package/dist/commands/memory/_lib/errors.js.map +1 -0
- package/dist/commands/memory/_lib/init-wizard.d.ts +12 -0
- package/dist/commands/memory/_lib/init-wizard.d.ts.map +1 -0
- package/dist/commands/memory/_lib/init-wizard.js +182 -0
- package/dist/commands/memory/_lib/init-wizard.js.map +1 -0
- package/dist/commands/memory/_lib/install-targets.d.ts +15 -0
- package/dist/commands/memory/_lib/install-targets.d.ts.map +1 -0
- package/dist/commands/memory/_lib/install-targets.js +209 -0
- package/dist/commands/memory/_lib/install-targets.js.map +1 -0
- package/dist/commands/memory/_lib/mcp.d.ts +20 -0
- package/dist/commands/memory/_lib/mcp.d.ts.map +1 -0
- package/dist/commands/memory/_lib/mcp.js +182 -0
- package/dist/commands/memory/_lib/mcp.js.map +1 -0
- package/dist/commands/memory/_lib/openclaw-auth.d.ts +41 -0
- package/dist/commands/memory/_lib/openclaw-auth.d.ts.map +1 -0
- package/dist/commands/memory/_lib/openclaw-auth.js +133 -0
- package/dist/commands/memory/_lib/openclaw-auth.js.map +1 -0
- package/dist/commands/memory/_lib/openclaw-auth.test.d.ts +2 -0
- package/dist/commands/memory/_lib/openclaw-auth.test.d.ts.map +1 -0
- package/dist/commands/memory/_lib/openclaw-auth.test.js +9 -0
- package/dist/commands/memory/_lib/openclaw-auth.test.js.map +1 -0
- package/dist/commands/memory/_lib/openclaw-cmd.d.ts +15 -0
- package/dist/commands/memory/_lib/openclaw-cmd.d.ts.map +1 -0
- package/dist/commands/memory/_lib/openclaw-cmd.js +208 -0
- package/dist/commands/memory/_lib/openclaw-cmd.js.map +1 -0
- package/dist/commands/memory/_lib/output.d.ts +5 -0
- package/dist/commands/memory/_lib/output.d.ts.map +1 -0
- package/dist/commands/memory/_lib/output.js +17 -0
- package/dist/commands/memory/_lib/output.js.map +1 -0
- package/dist/commands/memory/_lib/schema.d.ts +93 -0
- package/dist/commands/memory/_lib/schema.d.ts.map +1 -0
- package/dist/commands/memory/_lib/schema.js +192 -0
- package/dist/commands/memory/_lib/schema.js.map +1 -0
- package/dist/commands/memory/_lib/seed-cmd.d.ts +9 -0
- package/dist/commands/memory/_lib/seed-cmd.d.ts.map +1 -0
- package/dist/commands/memory/_lib/seed-cmd.js +516 -0
- package/dist/commands/memory/_lib/seed-cmd.js.map +1 -0
- package/dist/commands/memory/browser-auth.d.ts +3 -0
- package/dist/commands/memory/browser-auth.d.ts.map +1 -0
- package/dist/commands/memory/browser-auth.js +5 -0
- package/dist/commands/memory/browser-auth.js.map +1 -0
- package/dist/commands/memory/configure.d.ts +3 -0
- package/dist/commands/memory/configure.d.ts.map +1 -0
- package/dist/commands/memory/configure.js +5 -0
- package/dist/commands/memory/configure.js.map +1 -0
- package/dist/commands/memory/health.d.ts +3 -0
- package/dist/commands/memory/health.d.ts.map +1 -0
- package/dist/commands/memory/health.js +5 -0
- package/dist/commands/memory/health.js.map +1 -0
- package/dist/commands/memory/init.d.ts +8 -0
- package/dist/commands/memory/init.d.ts.map +1 -0
- package/dist/commands/memory/init.js +65 -0
- package/dist/commands/memory/init.js.map +1 -0
- package/dist/commands/memory/org.d.ts +7 -0
- package/dist/commands/memory/org.d.ts.map +1 -0
- package/dist/commands/memory/org.js +22 -0
- package/dist/commands/memory/org.js.map +1 -0
- package/dist/commands/memory/run.d.ts +8 -0
- package/dist/commands/memory/run.d.ts.map +1 -0
- package/dist/commands/memory/run.js +58 -0
- package/dist/commands/memory/run.js.map +1 -0
- package/dist/commands/memory/seed.d.ts +3 -0
- package/dist/commands/memory/seed.d.ts.map +1 -0
- package/dist/commands/memory/seed.js +5 -0
- package/dist/commands/memory/seed.js.map +1 -0
- package/dist/commands/org.d.ts +10 -0
- package/dist/commands/org.d.ts.map +1 -0
- package/dist/commands/org.js +34 -0
- package/dist/commands/org.js.map +1 -0
- package/dist/commands/{connections/platforms.d.ts → platforms/platform-prompts.d.ts} +5 -5
- package/dist/commands/platforms/platform-prompts.d.ts.map +1 -0
- package/dist/commands/{connections/platforms.js → platforms/platform-prompts.js} +24 -24
- package/dist/commands/platforms/platform-prompts.js.map +1 -0
- package/dist/commands/status.d.ts +4 -1
- package/dist/commands/status.d.ts.map +1 -1
- package/dist/commands/status.js +15 -84
- package/dist/commands/status.js.map +1 -1
- package/dist/commands/token.d.ts +17 -0
- package/dist/commands/token.d.ts.map +1 -0
- package/dist/commands/token.js +55 -0
- package/dist/commands/token.js.map +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +303 -88
- package/dist/index.js.map +1 -1
- package/dist/internal/__tests__/api-client.test.d.ts +2 -0
- package/dist/internal/__tests__/api-client.test.d.ts.map +1 -0
- package/dist/internal/__tests__/api-client.test.js +95 -0
- package/dist/internal/__tests__/api-client.test.js.map +1 -0
- package/dist/internal/__tests__/context.test.d.ts +2 -0
- package/dist/internal/__tests__/context.test.d.ts.map +1 -0
- package/dist/internal/__tests__/context.test.js +77 -0
- package/dist/internal/__tests__/context.test.js.map +1 -0
- package/dist/internal/api-client.d.ts +39 -0
- package/dist/internal/api-client.d.ts.map +1 -0
- package/dist/internal/api-client.js +217 -0
- package/dist/internal/api-client.js.map +1 -0
- package/dist/internal/context.d.ts +10 -1
- package/dist/internal/context.d.ts.map +1 -1
- package/dist/internal/context.js +109 -2
- package/dist/internal/context.js.map +1 -1
- package/dist/internal/credentials.d.ts +12 -2
- package/dist/internal/credentials.d.ts.map +1 -1
- package/dist/internal/credentials.js +47 -54
- package/dist/internal/credentials.js.map +1 -1
- package/dist/internal/gateway-url.d.ts +4 -4
- package/dist/internal/gateway-url.d.ts.map +1 -1
- package/dist/internal/gateway-url.js +6 -5
- package/dist/internal/gateway-url.js.map +1 -1
- package/dist/internal/index.d.ts +5 -3
- package/dist/internal/index.d.ts.map +1 -1
- package/dist/internal/index.js +3 -2
- package/dist/internal/index.js.map +1 -1
- package/dist/internal/local-env.d.ts +2 -0
- package/dist/internal/local-env.d.ts.map +1 -0
- package/dist/internal/local-env.js +32 -0
- package/dist/internal/local-env.js.map +1 -0
- package/dist/internal/oauth.d.ts +82 -0
- package/dist/internal/oauth.d.ts.map +1 -0
- package/dist/internal/oauth.js +234 -0
- package/dist/internal/oauth.js.map +1 -0
- package/dist/server.bundle.mjs +72219 -0
- package/dist/templates/.env.tmpl +7 -3
- package/dist/templates/README.md.tmpl +20 -53
- package/package.json +60 -6
- package/dist/__tests__/skills.test.d.ts +0 -2
- package/dist/__tests__/skills.test.d.ts.map +0 -1
- package/dist/__tests__/skills.test.js +0 -33
- package/dist/__tests__/skills.test.js.map +0 -1
- package/dist/commands/connections/add.d.ts +0 -2
- package/dist/commands/connections/add.d.ts.map +0 -1
- package/dist/commands/connections/add.js +0 -46
- package/dist/commands/connections/add.js.map +0 -1
- package/dist/commands/connections/list.d.ts +0 -2
- package/dist/commands/connections/list.d.ts.map +0 -1
- package/dist/commands/connections/list.js +0 -25
- package/dist/commands/connections/list.js.map +0 -1
- package/dist/commands/connections/platforms.d.ts.map +0 -1
- package/dist/commands/connections/platforms.js.map +0 -1
- package/dist/commands/providers/add.d.ts +0 -2
- package/dist/commands/providers/add.d.ts.map +0 -1
- package/dist/commands/providers/add.js +0 -50
- package/dist/commands/providers/add.js.map +0 -1
- package/dist/commands/providers/list.d.ts +0 -2
- package/dist/commands/providers/list.d.ts.map +0 -1
- package/dist/commands/providers/list.js +0 -22
- package/dist/commands/providers/list.js.map +0 -1
- package/dist/commands/secrets.d.ts +0 -8
- package/dist/commands/secrets.d.ts.map +0 -1
- package/dist/commands/secrets.js +0 -98
- package/dist/commands/secrets.js.map +0 -1
- package/dist/commands/skills/add.d.ts +0 -5
- package/dist/commands/skills/add.d.ts.map +0 -1
- package/dist/commands/skills/add.js +0 -27
- package/dist/commands/skills/add.js.map +0 -1
- package/dist/commands/skills/list.d.ts +0 -2
- package/dist/commands/skills/list.d.ts.map +0 -1
- package/dist/commands/skills/list.js +0 -19
- package/dist/commands/skills/list.js.map +0 -1
- package/dist/commands/skills/registry.d.ts +0 -19
- package/dist/commands/skills/registry.d.ts.map +0 -1
- package/dist/commands/skills/registry.js +0 -76
- package/dist/commands/skills/registry.js.map +0 -1
- package/dist/config/agent-helpers.d.ts +0 -38
- package/dist/config/agent-helpers.d.ts.map +0 -1
- package/dist/config/agent-helpers.js +0 -58
- package/dist/config/agent-helpers.js.map +0 -1
- package/dist/templates/Dockerfile.worker.tmpl +0 -29
|
@@ -0,0 +1,234 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* OAuth 2.0 device-code client used by `lobu login`.
|
|
3
|
+
*
|
|
4
|
+
* Mirrors the same flow that `@lobu/owletto-openclaw` uses against
|
|
5
|
+
* Owletto-hosted issuers: dynamic client registration (RFC 7591) +
|
|
6
|
+
* device authorization grant (RFC 8628) + refresh-token grant.
|
|
7
|
+
*/
|
|
8
|
+
const CLIENT_NAME = "Lobu CLI";
|
|
9
|
+
const SOFTWARE_ID = "lobu-cli";
|
|
10
|
+
const SCOPE = "mcp:read mcp:write mcp:admin profile:read";
|
|
11
|
+
const GRANT_DEVICE_CODE = "urn:ietf:params:oauth:grant-type:device_code";
|
|
12
|
+
const GRANT_REFRESH_TOKEN = "refresh_token";
|
|
13
|
+
/** RFC 8628 §3.5: on `slow_down`, the device MUST increase the interval by 5s. */
|
|
14
|
+
const SLOW_DOWN_BUMP_SECONDS = 5;
|
|
15
|
+
export const DEVICE_CODE_GRANT_TYPE = GRANT_DEVICE_CODE;
|
|
16
|
+
export class OAuthError extends Error {
|
|
17
|
+
code;
|
|
18
|
+
constructor(code, message) {
|
|
19
|
+
super(message);
|
|
20
|
+
this.code = code;
|
|
21
|
+
this.name = "OAuthError";
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Find the OAuth issuer for an API URL by stripping the path and fetching
|
|
26
|
+
* `<origin>/.well-known/oauth-authorization-server`. Both Owletto-hosted
|
|
27
|
+
* issuers (community.lobu.ai, app.lobu.ai) and the embedded local gateway
|
|
28
|
+
* publish discovery at the API origin.
|
|
29
|
+
*/
|
|
30
|
+
export async function discoverOAuth(apiUrl) {
|
|
31
|
+
const origin = new URL(apiUrl).origin;
|
|
32
|
+
const url = `${origin}/.well-known/oauth-authorization-server`;
|
|
33
|
+
const meta = await getJson(url, "discovery");
|
|
34
|
+
const tokenEndpoint = pickString(meta, "token_endpoint");
|
|
35
|
+
if (!tokenEndpoint) {
|
|
36
|
+
throw new OAuthError("discovery_invalid", `Discovery doc at ${url} is missing token_endpoint.`);
|
|
37
|
+
}
|
|
38
|
+
return {
|
|
39
|
+
issuer: pickString(meta, "issuer") ?? origin,
|
|
40
|
+
authorizationEndpoint: pickString(meta, "authorization_endpoint"),
|
|
41
|
+
tokenEndpoint,
|
|
42
|
+
registrationEndpoint: pickString(meta, "registration_endpoint"),
|
|
43
|
+
deviceAuthorizationEndpoint: pickString(meta, "device_authorization_endpoint"),
|
|
44
|
+
revocationEndpoint: pickString(meta, "revocation_endpoint"),
|
|
45
|
+
userinfoEndpoint: pickString(meta, "userinfo_endpoint"),
|
|
46
|
+
grantTypesSupported: Array.isArray(meta.grant_types_supported)
|
|
47
|
+
? meta.grant_types_supported.filter((g) => typeof g === "string")
|
|
48
|
+
: [],
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Register a public client capable of running the device-code grant.
|
|
53
|
+
* `token_endpoint_auth_method: "none"` keeps the CLI from needing to
|
|
54
|
+
* ship a client secret.
|
|
55
|
+
*/
|
|
56
|
+
export async function registerClient(registrationEndpoint, softwareVersion) {
|
|
57
|
+
const body = await postJson(registrationEndpoint, {
|
|
58
|
+
client_name: CLIENT_NAME,
|
|
59
|
+
software_id: SOFTWARE_ID,
|
|
60
|
+
software_version: softwareVersion,
|
|
61
|
+
grant_types: [GRANT_DEVICE_CODE, GRANT_REFRESH_TOKEN],
|
|
62
|
+
token_endpoint_auth_method: "none",
|
|
63
|
+
scope: SCOPE,
|
|
64
|
+
});
|
|
65
|
+
if (!body.ok) {
|
|
66
|
+
throw new OAuthError("registration_failed", body.errorMessage);
|
|
67
|
+
}
|
|
68
|
+
const clientId = pickString(body.data, "client_id");
|
|
69
|
+
if (!clientId) {
|
|
70
|
+
throw new OAuthError("registration_invalid", "Registration response was missing client_id.");
|
|
71
|
+
}
|
|
72
|
+
return { clientId, clientSecret: pickString(body.data, "client_secret") };
|
|
73
|
+
}
|
|
74
|
+
export async function startDeviceAuthorization(endpoint, client) {
|
|
75
|
+
const body = await postJson(endpoint, withClient(client, { scope: SCOPE }));
|
|
76
|
+
if (!body.ok) {
|
|
77
|
+
throw new OAuthError("device_authorization_failed", body.errorMessage);
|
|
78
|
+
}
|
|
79
|
+
const deviceCode = pickString(body.data, "device_code");
|
|
80
|
+
const userCode = pickString(body.data, "user_code");
|
|
81
|
+
const verificationUri = pickString(body.data, "verification_uri");
|
|
82
|
+
if (!deviceCode || !userCode || !verificationUri) {
|
|
83
|
+
throw new OAuthError("device_authorization_invalid", "Device authorization response was missing required fields.");
|
|
84
|
+
}
|
|
85
|
+
return {
|
|
86
|
+
deviceCode,
|
|
87
|
+
userCode,
|
|
88
|
+
verificationUri,
|
|
89
|
+
verificationUriComplete: pickString(body.data, "verification_uri_complete"),
|
|
90
|
+
expiresIn: pickNumber(body.data, "expires_in") ?? 600,
|
|
91
|
+
interval: Math.max(pickNumber(body.data, "interval") ?? 5, 1),
|
|
92
|
+
};
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* One iteration of the device-code polling loop. Returns `pending` for
|
|
96
|
+
* `authorization_pending` / `slow_down` (with `bumpInterval` set when the
|
|
97
|
+
* server asks us to back off), `complete` once the user approves, and
|
|
98
|
+
* `error` for terminal failures.
|
|
99
|
+
*/
|
|
100
|
+
export async function pollDeviceToken(tokenEndpoint, client, deviceCode) {
|
|
101
|
+
const body = await postJson(tokenEndpoint, withClient(client, {
|
|
102
|
+
grant_type: GRANT_DEVICE_CODE,
|
|
103
|
+
device_code: deviceCode,
|
|
104
|
+
}));
|
|
105
|
+
if (body.ok && typeof body.data.access_token === "string") {
|
|
106
|
+
return { status: "complete", tokens: parseTokenResponse(body.data) };
|
|
107
|
+
}
|
|
108
|
+
const code = pickString(body.data, "error") ?? "unknown_error";
|
|
109
|
+
if (code === "authorization_pending") {
|
|
110
|
+
return { status: "pending", bumpInterval: false };
|
|
111
|
+
}
|
|
112
|
+
if (code === "slow_down") {
|
|
113
|
+
return { status: "pending", bumpInterval: true };
|
|
114
|
+
}
|
|
115
|
+
return {
|
|
116
|
+
status: "error",
|
|
117
|
+
code,
|
|
118
|
+
message: pickString(body.data, "error_description") ??
|
|
119
|
+
`Token endpoint returned ${body.status}.`,
|
|
120
|
+
};
|
|
121
|
+
}
|
|
122
|
+
export async function refreshTokens(tokenEndpoint, client, refreshToken) {
|
|
123
|
+
const body = await postJson(tokenEndpoint, withClient(client, {
|
|
124
|
+
grant_type: GRANT_REFRESH_TOKEN,
|
|
125
|
+
refresh_token: refreshToken,
|
|
126
|
+
}));
|
|
127
|
+
if (!body.ok || typeof body.data.access_token !== "string")
|
|
128
|
+
return null;
|
|
129
|
+
return parseTokenResponse(body.data);
|
|
130
|
+
}
|
|
131
|
+
export async function fetchUserInfo(userinfoEndpoint, accessToken) {
|
|
132
|
+
let response;
|
|
133
|
+
try {
|
|
134
|
+
response = await fetch(userinfoEndpoint, {
|
|
135
|
+
headers: {
|
|
136
|
+
Authorization: `Bearer ${accessToken}`,
|
|
137
|
+
Accept: "application/json",
|
|
138
|
+
},
|
|
139
|
+
});
|
|
140
|
+
}
|
|
141
|
+
catch {
|
|
142
|
+
return null;
|
|
143
|
+
}
|
|
144
|
+
if (!response.ok)
|
|
145
|
+
return null;
|
|
146
|
+
const data = (await response.json().catch(() => null));
|
|
147
|
+
if (!data)
|
|
148
|
+
return null;
|
|
149
|
+
const sub = pickString(data, "sub");
|
|
150
|
+
if (!sub)
|
|
151
|
+
return null;
|
|
152
|
+
return {
|
|
153
|
+
sub,
|
|
154
|
+
email: pickString(data, "email"),
|
|
155
|
+
name: pickString(data, "name"),
|
|
156
|
+
};
|
|
157
|
+
}
|
|
158
|
+
/** RFC 7009 — best-effort. Network failures are intentionally swallowed. */
|
|
159
|
+
export async function revokeToken(revocationEndpoint, client, token, hint) {
|
|
160
|
+
await postJson(revocationEndpoint, withClient(client, { token, token_type_hint: hint }));
|
|
161
|
+
}
|
|
162
|
+
export function bumpInterval(interval, slowDown) {
|
|
163
|
+
return slowDown ? interval + SLOW_DOWN_BUMP_SECONDS : interval;
|
|
164
|
+
}
|
|
165
|
+
function parseTokenResponse(data) {
|
|
166
|
+
const accessToken = pickString(data, "access_token");
|
|
167
|
+
if (!accessToken) {
|
|
168
|
+
throw new OAuthError("invalid_token_response", "Token endpoint response was missing access_token.");
|
|
169
|
+
}
|
|
170
|
+
return {
|
|
171
|
+
accessToken,
|
|
172
|
+
refreshToken: pickString(data, "refresh_token"),
|
|
173
|
+
expiresIn: pickNumber(data, "expires_in"),
|
|
174
|
+
};
|
|
175
|
+
}
|
|
176
|
+
async function postJson(url, body) {
|
|
177
|
+
let response;
|
|
178
|
+
try {
|
|
179
|
+
response = await fetch(url, {
|
|
180
|
+
method: "POST",
|
|
181
|
+
headers: {
|
|
182
|
+
"Content-Type": "application/json",
|
|
183
|
+
Accept: "application/json",
|
|
184
|
+
},
|
|
185
|
+
body: JSON.stringify(body),
|
|
186
|
+
});
|
|
187
|
+
}
|
|
188
|
+
catch (err) {
|
|
189
|
+
return {
|
|
190
|
+
ok: false,
|
|
191
|
+
status: 0,
|
|
192
|
+
data: {},
|
|
193
|
+
errorMessage: `Network error: ${err.message}`,
|
|
194
|
+
};
|
|
195
|
+
}
|
|
196
|
+
const data = (await response.json().catch(() => ({})));
|
|
197
|
+
if (response.ok)
|
|
198
|
+
return { ok: true, status: response.status, data };
|
|
199
|
+
const errorMessage = pickString(data, "error_description") ??
|
|
200
|
+
pickString(data, "error") ??
|
|
201
|
+
`HTTP ${response.status}`;
|
|
202
|
+
return { ok: false, status: response.status, data, errorMessage };
|
|
203
|
+
}
|
|
204
|
+
async function getJson(url, context) {
|
|
205
|
+
let response;
|
|
206
|
+
try {
|
|
207
|
+
response = await fetch(url, { headers: { Accept: "application/json" } });
|
|
208
|
+
}
|
|
209
|
+
catch (err) {
|
|
210
|
+
throw new OAuthError(`${context}_unreachable`, `Could not reach ${url}: ${err.message}`);
|
|
211
|
+
}
|
|
212
|
+
if (!response.ok) {
|
|
213
|
+
throw new OAuthError(`${context}_failed`, `${url} returned HTTP ${response.status}.`);
|
|
214
|
+
}
|
|
215
|
+
return (await response.json());
|
|
216
|
+
}
|
|
217
|
+
function withClient(client, fields) {
|
|
218
|
+
const body = {
|
|
219
|
+
client_id: client.clientId,
|
|
220
|
+
...fields,
|
|
221
|
+
};
|
|
222
|
+
if (client.clientSecret)
|
|
223
|
+
body.client_secret = client.clientSecret;
|
|
224
|
+
return body;
|
|
225
|
+
}
|
|
226
|
+
function pickString(data, key) {
|
|
227
|
+
const v = data[key];
|
|
228
|
+
return typeof v === "string" && v.length > 0 ? v : undefined;
|
|
229
|
+
}
|
|
230
|
+
function pickNumber(data, key) {
|
|
231
|
+
const v = data[key];
|
|
232
|
+
return typeof v === "number" && Number.isFinite(v) ? v : undefined;
|
|
233
|
+
}
|
|
234
|
+
//# sourceMappingURL=oauth.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"oauth.js","sourceRoot":"","sources":["../../src/internal/oauth.ts"],"names":[],"mappings":"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"}
|