@iam-brain/opencode-codex-auth 0.3.1 → 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/README.md +4 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +45 -6
- package/dist/index.js.map +1 -1
- package/dist/lib/accounts-tools.d.ts.map +1 -1
- package/dist/lib/accounts-tools.js +88 -4
- package/dist/lib/accounts-tools.js.map +1 -1
- package/dist/lib/auth-refresh.d.ts +2 -0
- package/dist/lib/auth-refresh.d.ts.map +1 -0
- package/dist/lib/auth-refresh.js +2 -0
- package/dist/lib/auth-refresh.js.map +1 -0
- package/dist/lib/cache-io.d.ts +24 -0
- package/dist/lib/cache-io.d.ts.map +1 -0
- package/dist/lib/cache-io.js +95 -0
- package/dist/lib/cache-io.js.map +1 -0
- package/dist/lib/cache-lock.d.ts +7 -0
- package/dist/lib/cache-lock.d.ts.map +1 -0
- package/dist/lib/cache-lock.js +37 -0
- package/dist/lib/cache-lock.js.map +1 -0
- package/dist/lib/claims.d.ts.map +1 -1
- package/dist/lib/claims.js +4 -1
- package/dist/lib/claims.js.map +1 -1
- package/dist/lib/codex-cache-layout.d.ts +15 -0
- package/dist/lib/codex-cache-layout.d.ts.map +1 -0
- package/dist/lib/codex-cache-layout.js +52 -0
- package/dist/lib/codex-cache-layout.js.map +1 -0
- package/dist/lib/codex-native/accounts.d.ts +21 -0
- package/dist/lib/codex-native/accounts.d.ts.map +1 -0
- package/dist/lib/codex-native/accounts.js +203 -0
- package/dist/lib/codex-native/accounts.js.map +1 -0
- package/dist/lib/codex-native/acquire-auth.d.ts +22 -0
- package/dist/lib/codex-native/acquire-auth.d.ts.map +1 -0
- package/dist/lib/codex-native/acquire-auth.js +389 -0
- package/dist/lib/codex-native/acquire-auth.js.map +1 -0
- package/dist/lib/codex-native/auth-menu-flow.d.ts +9 -0
- package/dist/lib/codex-native/auth-menu-flow.d.ts.map +1 -0
- package/dist/lib/codex-native/auth-menu-flow.js +304 -0
- package/dist/lib/codex-native/auth-menu-flow.js.map +1 -0
- package/dist/lib/codex-native/auth-menu-quotas.d.ts +9 -0
- package/dist/lib/codex-native/auth-menu-quotas.d.ts.map +1 -0
- package/dist/lib/codex-native/auth-menu-quotas.js +213 -0
- package/dist/lib/codex-native/auth-menu-quotas.js.map +1 -0
- package/dist/lib/codex-native/catalog-auth.d.ts.map +1 -1
- package/dist/lib/codex-native/catalog-auth.js +4 -1
- package/dist/lib/codex-native/catalog-auth.js.map +1 -1
- package/dist/lib/codex-native/catalog-sync.d.ts +28 -0
- package/dist/lib/codex-native/catalog-sync.d.ts.map +1 -0
- package/dist/lib/codex-native/catalog-sync.js +36 -0
- package/dist/lib/codex-native/catalog-sync.js.map +1 -0
- package/dist/lib/codex-native/chat-hooks.d.ts +85 -0
- package/dist/lib/codex-native/chat-hooks.d.ts.map +1 -0
- package/dist/lib/codex-native/chat-hooks.js +175 -0
- package/dist/lib/codex-native/chat-hooks.js.map +1 -0
- package/dist/lib/codex-native/client-identity.d.ts.map +1 -1
- package/dist/lib/codex-native/client-identity.js +55 -40
- package/dist/lib/codex-native/client-identity.js.map +1 -1
- package/dist/lib/codex-native/collaboration.d.ts +25 -0
- package/dist/lib/codex-native/collaboration.d.ts.map +1 -0
- package/dist/lib/codex-native/collaboration.js +306 -0
- package/dist/lib/codex-native/collaboration.js.map +1 -0
- package/dist/lib/codex-native/oauth-auth-methods.d.ts +45 -0
- package/dist/lib/codex-native/oauth-auth-methods.d.ts.map +1 -0
- package/dist/lib/codex-native/oauth-auth-methods.js +182 -0
- package/dist/lib/codex-native/oauth-auth-methods.js.map +1 -0
- package/dist/lib/codex-native/oauth-persistence.d.ts +4 -0
- package/dist/lib/codex-native/oauth-persistence.d.ts.map +1 -0
- package/dist/lib/codex-native/oauth-persistence.js +28 -0
- package/dist/lib/codex-native/oauth-persistence.js.map +1 -0
- package/dist/lib/codex-native/oauth-server.d.ts.map +1 -1
- package/dist/lib/codex-native/oauth-server.js +63 -5
- package/dist/lib/codex-native/oauth-server.js.map +1 -1
- package/dist/lib/codex-native/oauth-utils.d.ts +51 -0
- package/dist/lib/codex-native/oauth-utils.d.ts.map +1 -0
- package/dist/lib/codex-native/oauth-utils.js +265 -0
- package/dist/lib/codex-native/oauth-utils.js.map +1 -0
- package/dist/lib/codex-native/openai-loader-fetch.d.ts +39 -0
- package/dist/lib/codex-native/openai-loader-fetch.d.ts.map +1 -0
- package/dist/lib/codex-native/openai-loader-fetch.js +337 -0
- package/dist/lib/codex-native/openai-loader-fetch.js.map +1 -0
- package/dist/lib/codex-native/rate-limit-snapshots.d.ts +2 -0
- package/dist/lib/codex-native/rate-limit-snapshots.d.ts.map +1 -0
- package/dist/lib/codex-native/rate-limit-snapshots.js +28 -0
- package/dist/lib/codex-native/rate-limit-snapshots.js.map +1 -0
- package/dist/lib/codex-native/request-routing.d.ts +3 -0
- package/dist/lib/codex-native/request-routing.d.ts.map +1 -0
- package/dist/lib/codex-native/request-routing.js +41 -0
- package/dist/lib/codex-native/request-routing.js.map +1 -0
- package/dist/lib/codex-native/request-transform-pipeline.d.ts +20 -0
- package/dist/lib/codex-native/request-transform-pipeline.d.ts.map +1 -0
- package/dist/lib/codex-native/request-transform-pipeline.js +25 -0
- package/dist/lib/codex-native/request-transform-pipeline.js.map +1 -0
- package/dist/lib/codex-native/request-transform.d.ts +28 -4
- package/dist/lib/codex-native/request-transform.d.ts.map +1 -1
- package/dist/lib/codex-native/request-transform.js +347 -41
- package/dist/lib/codex-native/request-transform.js.map +1 -1
- package/dist/lib/codex-native/session-affinity-state.d.ts +17 -0
- package/dist/lib/codex-native/session-affinity-state.d.ts.map +1 -0
- package/dist/lib/codex-native/session-affinity-state.js +56 -0
- package/dist/lib/codex-native/session-affinity-state.js.map +1 -0
- package/dist/lib/codex-native/session-messages.d.ts +8 -0
- package/dist/lib/codex-native/session-messages.d.ts.map +1 -0
- package/dist/lib/codex-native/session-messages.js +58 -0
- package/dist/lib/codex-native/session-messages.js.map +1 -0
- package/dist/lib/codex-native.d.ts +12 -30
- package/dist/lib/codex-native.d.ts.map +1 -1
- package/dist/lib/codex-native.js +141 -1644
- package/dist/lib/codex-native.js.map +1 -1
- package/dist/lib/codex-prompts-cache.d.ts +17 -0
- package/dist/lib/codex-prompts-cache.d.ts.map +1 -0
- package/dist/lib/codex-prompts-cache.js +184 -0
- package/dist/lib/codex-prompts-cache.js.map +1 -0
- package/dist/lib/codex-status-storage.d.ts.map +1 -1
- package/dist/lib/codex-status-storage.js +8 -43
- package/dist/lib/codex-status-storage.js.map +1 -1
- package/dist/lib/codex-status-tool.js +1 -1
- package/dist/lib/codex-status-tool.js.map +1 -1
- package/dist/lib/codex-status-ui.d.ts.map +1 -1
- package/dist/lib/codex-status-ui.js +14 -8
- package/dist/lib/codex-status-ui.js.map +1 -1
- package/dist/lib/codex-status.d.ts.map +1 -1
- package/dist/lib/codex-status.js +28 -2
- package/dist/lib/codex-status.js.map +1 -1
- package/dist/lib/compat-sanitizer.d.ts.map +1 -1
- package/dist/lib/compat-sanitizer.js +5 -4
- package/dist/lib/compat-sanitizer.js.map +1 -1
- package/dist/lib/config-dir-gitignore.d.ts +3 -0
- package/dist/lib/config-dir-gitignore.d.ts.map +1 -0
- package/dist/lib/config-dir-gitignore.js +45 -0
- package/dist/lib/config-dir-gitignore.js.map +1 -0
- package/dist/lib/config.d.ts +30 -11
- package/dist/lib/config.d.ts.map +1 -1
- package/dist/lib/config.js +359 -153
- package/dist/lib/config.js.map +1 -1
- package/dist/lib/fetch-orchestrator.d.ts +19 -0
- package/dist/lib/fetch-orchestrator.d.ts.map +1 -1
- package/dist/lib/fetch-orchestrator.js +33 -6
- package/dist/lib/fetch-orchestrator.js.map +1 -1
- package/dist/lib/installer-cli.d.ts.map +1 -1
- package/dist/lib/installer-cli.js +14 -1
- package/dist/lib/installer-cli.js.map +1 -1
- package/dist/lib/logger.d.ts.map +1 -1
- package/dist/lib/logger.js +4 -1
- package/dist/lib/logger.js.map +1 -1
- package/dist/lib/model-catalog.d.ts +1 -0
- package/dist/lib/model-catalog.d.ts.map +1 -1
- package/dist/lib/model-catalog.js +198 -103
- package/dist/lib/model-catalog.js.map +1 -1
- package/dist/lib/opencode-install.d.ts.map +1 -1
- package/dist/lib/opencode-install.js +30 -6
- package/dist/lib/opencode-install.js.map +1 -1
- package/dist/lib/orchestrator-agent.d.ts +31 -0
- package/dist/lib/orchestrator-agent.d.ts.map +1 -0
- package/dist/lib/orchestrator-agent.js +268 -0
- package/dist/lib/orchestrator-agent.js.map +1 -0
- package/dist/lib/paths.d.ts +1 -1
- package/dist/lib/paths.d.ts.map +1 -1
- package/dist/lib/paths.js +1 -1
- package/dist/lib/paths.js.map +1 -1
- package/dist/lib/persona-tool-cli.d.ts.map +1 -1
- package/dist/lib/persona-tool-cli.js +4 -1
- package/dist/lib/persona-tool-cli.js.map +1 -1
- package/dist/lib/personalities.d.ts.map +1 -1
- package/dist/lib/personalities.js +9 -2
- package/dist/lib/personalities.js.map +1 -1
- package/dist/lib/personality-command.d.ts.map +1 -1
- package/dist/lib/personality-command.js +4 -1
- package/dist/lib/personality-command.js.map +1 -1
- package/dist/lib/personality-create.d.ts.map +1 -1
- package/dist/lib/personality-create.js +5 -1
- package/dist/lib/personality-create.js.map +1 -1
- package/dist/lib/personality-skill.d.ts.map +1 -1
- package/dist/lib/personality-skill.js +4 -1
- package/dist/lib/personality-skill.js.map +1 -1
- package/dist/lib/prompt-cache-key.d.ts +7 -0
- package/dist/lib/prompt-cache-key.d.ts.map +1 -0
- package/dist/lib/prompt-cache-key.js +17 -0
- package/dist/lib/prompt-cache-key.js.map +1 -0
- package/dist/lib/quarantine.d.ts.map +1 -1
- package/dist/lib/quarantine.js +22 -5
- package/dist/lib/quarantine.js.map +1 -1
- package/dist/lib/quota-threshold-alerts.d.ts +31 -0
- package/dist/lib/quota-threshold-alerts.d.ts.map +1 -0
- package/dist/lib/quota-threshold-alerts.js +97 -0
- package/dist/lib/quota-threshold-alerts.js.map +1 -0
- package/dist/lib/refresh-queue.d.ts.map +1 -1
- package/dist/lib/refresh-queue.js +9 -2
- package/dist/lib/refresh-queue.js.map +1 -1
- package/dist/lib/remote-cache-fetch.d.ts +28 -0
- package/dist/lib/remote-cache-fetch.d.ts.map +1 -0
- package/dist/lib/remote-cache-fetch.js +67 -0
- package/dist/lib/remote-cache-fetch.js.map +1 -0
- package/dist/lib/request-snapshots.d.ts +3 -0
- package/dist/lib/request-snapshots.d.ts.map +1 -1
- package/dist/lib/request-snapshots.js +88 -13
- package/dist/lib/request-snapshots.js.map +1 -1
- package/dist/lib/rotation.d.ts +4 -0
- package/dist/lib/rotation.d.ts.map +1 -1
- package/dist/lib/rotation.js +57 -10
- package/dist/lib/rotation.js.map +1 -1
- package/dist/lib/session-affinity.d.ts.map +1 -1
- package/dist/lib/session-affinity.js +22 -36
- package/dist/lib/session-affinity.js.map +1 -1
- package/dist/lib/storage.d.ts +8 -5
- package/dist/lib/storage.d.ts.map +1 -1
- package/dist/lib/storage.js +50 -39
- package/dist/lib/storage.js.map +1 -1
- package/dist/lib/ui/tty/select.d.ts.map +1 -1
- package/dist/lib/ui/tty/select.js +8 -2
- package/dist/lib/ui/tty/select.js.map +1 -1
- package/dist/lib/util.d.ts +2 -0
- package/dist/lib/util.d.ts.map +1 -0
- package/dist/lib/util.js +4 -0
- package/dist/lib/util.js.map +1 -0
- package/package.json +8 -5
- package/schemas/codex-config.schema.json +29 -43
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { createFetchOrchestratorState } from "../fetch-orchestrator";
|
|
2
|
+
import { defaultSessionAffinityPath } from "../paths";
|
|
3
|
+
import { createStickySessionState } from "../rotation";
|
|
4
|
+
import { createSessionExistsFn, loadSessionAffinity, pruneSessionAffinitySnapshot, readSessionAffinitySnapshot, saveSessionAffinity, writeSessionAffinitySnapshot } from "../session-affinity";
|
|
5
|
+
export async function createSessionAffinityRuntimeState(input) {
|
|
6
|
+
const sessionAffinityPath = defaultSessionAffinityPath(input.env);
|
|
7
|
+
const loadedSessionAffinity = await loadSessionAffinity(sessionAffinityPath).catch(() => ({
|
|
8
|
+
version: 1
|
|
9
|
+
}));
|
|
10
|
+
const initialSessionAffinity = readSessionAffinitySnapshot(loadedSessionAffinity, input.authMode);
|
|
11
|
+
const sessionExists = createSessionExistsFn(input.env);
|
|
12
|
+
await pruneSessionAffinitySnapshot(initialSessionAffinity, sessionExists, {
|
|
13
|
+
missingGraceMs: input.missingGraceMs
|
|
14
|
+
}).catch(() => 0);
|
|
15
|
+
const orchestratorState = createFetchOrchestratorState();
|
|
16
|
+
orchestratorState.seenSessionKeys = initialSessionAffinity.seenSessionKeys;
|
|
17
|
+
const stickySessionState = createStickySessionState();
|
|
18
|
+
stickySessionState.bySessionKey = initialSessionAffinity.stickyBySessionKey;
|
|
19
|
+
const hybridSessionState = createStickySessionState();
|
|
20
|
+
hybridSessionState.bySessionKey = initialSessionAffinity.hybridBySessionKey;
|
|
21
|
+
let sessionAffinityPersistQueue = Promise.resolve();
|
|
22
|
+
let persistenceErrorLogged = false;
|
|
23
|
+
const persistSessionAffinityState = () => {
|
|
24
|
+
sessionAffinityPersistQueue = sessionAffinityPersistQueue
|
|
25
|
+
.then(async () => {
|
|
26
|
+
await pruneSessionAffinitySnapshot({
|
|
27
|
+
seenSessionKeys: orchestratorState.seenSessionKeys,
|
|
28
|
+
stickyBySessionKey: stickySessionState.bySessionKey,
|
|
29
|
+
hybridBySessionKey: hybridSessionState.bySessionKey
|
|
30
|
+
}, sessionExists, {
|
|
31
|
+
missingGraceMs: input.missingGraceMs
|
|
32
|
+
});
|
|
33
|
+
await saveSessionAffinity(async (current) => writeSessionAffinitySnapshot(current, input.authMode, {
|
|
34
|
+
seenSessionKeys: orchestratorState.seenSessionKeys,
|
|
35
|
+
stickyBySessionKey: stickySessionState.bySessionKey,
|
|
36
|
+
hybridBySessionKey: hybridSessionState.bySessionKey
|
|
37
|
+
}), sessionAffinityPath);
|
|
38
|
+
persistenceErrorLogged = false;
|
|
39
|
+
})
|
|
40
|
+
.catch((error) => {
|
|
41
|
+
if (!persistenceErrorLogged) {
|
|
42
|
+
persistenceErrorLogged = true;
|
|
43
|
+
input.log?.debug("session affinity persistence failed", {
|
|
44
|
+
error: error instanceof Error ? error.message : String(error)
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
});
|
|
48
|
+
};
|
|
49
|
+
return {
|
|
50
|
+
orchestratorState,
|
|
51
|
+
stickySessionState,
|
|
52
|
+
hybridSessionState,
|
|
53
|
+
persistSessionAffinityState
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
//# sourceMappingURL=session-affinity-state.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session-affinity-state.js","sourceRoot":"","sources":["../../../lib/codex-native/session-affinity-state.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { PluginInput } from "@opencode-ai/plugin";
|
|
2
|
+
export declare function isRecord(value: unknown): value is Record<string, unknown>;
|
|
3
|
+
export declare function asString(value: unknown): string | undefined;
|
|
4
|
+
export declare function getMessageProviderID(info: Record<string, unknown>): string | undefined;
|
|
5
|
+
export declare function readSessionMessageRows(client: PluginInput["client"] | undefined, sessionID: string): Promise<unknown[]>;
|
|
6
|
+
export declare function sessionUsesOpenAIProvider(client: PluginInput["client"] | undefined, sessionID: string): Promise<boolean>;
|
|
7
|
+
export declare function readSessionMessageInfo(client: PluginInput["client"] | undefined, sessionID: string, messageID: string): Promise<Record<string, unknown> | undefined>;
|
|
8
|
+
//# sourceMappingURL=session-messages.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session-messages.d.ts","sourceRoot":"","sources":["../../../lib/codex-native/session-messages.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAA;AAEtD,wBAAgB,QAAQ,CAAC,KAAK,EAAE,OAAO,GAAG,KAAK,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAEzE;AAED,wBAAgB,QAAQ,CAAC,KAAK,EAAE,OAAO,GAAG,MAAM,GAAG,SAAS,CAI3D;AAED,wBAAgB,oBAAoB,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,GAAG,SAAS,CAGtF;AAED,wBAAsB,sBAAsB,CAC1C,MAAM,EAAE,WAAW,CAAC,QAAQ,CAAC,GAAG,SAAS,EACzC,SAAS,EAAE,MAAM,GAChB,OAAO,CAAC,OAAO,EAAE,CAAC,CAapB;AAED,wBAAsB,yBAAyB,CAC7C,MAAM,EAAE,WAAW,CAAC,QAAQ,CAAC,GAAG,SAAS,EACzC,SAAS,EAAE,MAAM,GAChB,OAAO,CAAC,OAAO,CAAC,CAalB;AAED,wBAAsB,sBAAsB,CAC1C,MAAM,EAAE,WAAW,CAAC,QAAQ,CAAC,GAAG,SAAS,EACzC,SAAS,EAAE,MAAM,EACjB,SAAS,EAAE,MAAM,GAChB,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,SAAS,CAAC,CAW9C"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
export function isRecord(value) {
|
|
2
|
+
return typeof value === "object" && value !== null && !Array.isArray(value);
|
|
3
|
+
}
|
|
4
|
+
export function asString(value) {
|
|
5
|
+
if (typeof value !== "string")
|
|
6
|
+
return undefined;
|
|
7
|
+
const trimmed = value.trim();
|
|
8
|
+
return trimmed ? trimmed : undefined;
|
|
9
|
+
}
|
|
10
|
+
export function getMessageProviderID(info) {
|
|
11
|
+
const model = isRecord(info.model) ? info.model : undefined;
|
|
12
|
+
return model ? asString(model.providerID) : asString(info.providerID);
|
|
13
|
+
}
|
|
14
|
+
export async function readSessionMessageRows(client, sessionID) {
|
|
15
|
+
const sessionApi = client?.session;
|
|
16
|
+
if (!sessionApi || typeof sessionApi.messages !== "function")
|
|
17
|
+
return [];
|
|
18
|
+
try {
|
|
19
|
+
const response = await sessionApi.messages({ sessionID, limit: 100 });
|
|
20
|
+
return isRecord(response) && Array.isArray(response.data) ? response.data : [];
|
|
21
|
+
}
|
|
22
|
+
catch (error) {
|
|
23
|
+
if (error instanceof Error) {
|
|
24
|
+
// best-effort session inspection
|
|
25
|
+
}
|
|
26
|
+
return [];
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
export async function sessionUsesOpenAIProvider(client, sessionID) {
|
|
30
|
+
const rows = await readSessionMessageRows(client, sessionID);
|
|
31
|
+
for (let index = rows.length - 1; index >= 0; index -= 1) {
|
|
32
|
+
const row = rows[index];
|
|
33
|
+
if (!isRecord(row) || !isRecord(row.info))
|
|
34
|
+
continue;
|
|
35
|
+
const info = row.info;
|
|
36
|
+
if (asString(info.role) !== "user")
|
|
37
|
+
continue;
|
|
38
|
+
const providerID = getMessageProviderID(info);
|
|
39
|
+
if (!providerID)
|
|
40
|
+
continue;
|
|
41
|
+
return providerID === "openai";
|
|
42
|
+
}
|
|
43
|
+
return false;
|
|
44
|
+
}
|
|
45
|
+
export async function readSessionMessageInfo(client, sessionID, messageID) {
|
|
46
|
+
const rows = await readSessionMessageRows(client, sessionID);
|
|
47
|
+
for (let index = rows.length - 1; index >= 0; index -= 1) {
|
|
48
|
+
const row = rows[index];
|
|
49
|
+
if (!isRecord(row) || !isRecord(row.info))
|
|
50
|
+
continue;
|
|
51
|
+
const info = row.info;
|
|
52
|
+
if (asString(info.id) !== messageID)
|
|
53
|
+
continue;
|
|
54
|
+
return info;
|
|
55
|
+
}
|
|
56
|
+
return undefined;
|
|
57
|
+
}
|
|
58
|
+
//# sourceMappingURL=session-messages.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session-messages.js","sourceRoot":"","sources":["../../../lib/codex-native/session-messages.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,29 +1,14 @@
|
|
|
1
1
|
import type { Hooks, PluginInput } from "@opencode-ai/plugin";
|
|
2
|
-
import { type IdTokenClaims } from "./claims";
|
|
3
2
|
import type { Logger } from "./logger";
|
|
4
|
-
import type {
|
|
5
|
-
import type {
|
|
3
|
+
import type { OpenAIAuthMode, RotationStrategy } from "./types";
|
|
4
|
+
import type { BehaviorSettings, CodexSpoofMode, PersonalityOption, PluginRuntimeMode, PromptCacheKeyStrategy } from "./config";
|
|
5
|
+
import type { CollaborationToolProfile } from "./codex-native/collaboration";
|
|
6
6
|
import { buildCodexUserAgent, refreshCodexClientVersionFromGitHub, resolveCodexClientVersion, resolveRequestUserAgent } from "./codex-native/client-identity";
|
|
7
|
+
import { buildAuthorizeUrl, buildOAuthErrorHtml, buildOAuthSuccessHtml, composeCodexSuccessRedirectUrl, generatePKCE } from "./codex-native/oauth-utils";
|
|
7
8
|
export { browserOpenInvocationFor } from "./codex-native/browser";
|
|
9
|
+
export { upsertAccount } from "./codex-native/accounts";
|
|
10
|
+
export { extractAccountId, extractAccountIdFromClaims, refreshAccessToken } from "./codex-native/oauth-utils";
|
|
8
11
|
export declare function tryOpenUrlInBrowser(url: string, log?: Logger): Promise<boolean>;
|
|
9
|
-
type PkceCodes = {
|
|
10
|
-
verifier: string;
|
|
11
|
-
challenge: string;
|
|
12
|
-
};
|
|
13
|
-
declare function generatePKCE(): Promise<PkceCodes>;
|
|
14
|
-
export declare function extractAccountIdFromClaims(claims: IdTokenClaims | undefined): string | undefined;
|
|
15
|
-
type TokensWithClaims = {
|
|
16
|
-
id_token?: string;
|
|
17
|
-
access_token?: string;
|
|
18
|
-
};
|
|
19
|
-
export declare function extractAccountId(tokens: TokensWithClaims | undefined): string | undefined;
|
|
20
|
-
export type TokenResponse = {
|
|
21
|
-
id_token?: string;
|
|
22
|
-
access_token: string;
|
|
23
|
-
refresh_token: string;
|
|
24
|
-
expires_in?: number;
|
|
25
|
-
};
|
|
26
|
-
declare function buildAuthorizeUrl(redirectUri: string, pkce: PkceCodes, state: string, originator: "opencode" | "codex_cli_rs"): string;
|
|
27
12
|
export declare const __testOnly: {
|
|
28
13
|
buildAuthorizeUrl: typeof buildAuthorizeUrl;
|
|
29
14
|
generatePKCE: typeof generatePKCE;
|
|
@@ -38,31 +23,28 @@ export declare const __testOnly: {
|
|
|
38
23
|
isOAuthDebugEnabled: typeof isOAuthDebugEnabled;
|
|
39
24
|
stopOAuthServer: typeof stopOAuthServer;
|
|
40
25
|
};
|
|
41
|
-
export declare function refreshAccessToken(refreshToken: string): Promise<TokenResponse>;
|
|
42
|
-
declare function composeCodexSuccessRedirectUrl(tokens: TokenResponse, options?: {
|
|
43
|
-
issuer?: string;
|
|
44
|
-
port?: number;
|
|
45
|
-
}): string;
|
|
46
|
-
declare function buildOAuthSuccessHtml(mode?: CodexSpoofMode): string;
|
|
47
|
-
declare function buildOAuthErrorHtml(error: string): string;
|
|
48
26
|
declare function isOAuthDebugEnabled(): boolean;
|
|
49
27
|
declare function stopOAuthServer(): void;
|
|
50
28
|
declare function modeForRuntimeMode(runtimeMode: PluginRuntimeMode): OpenAIAuthMode;
|
|
51
|
-
export declare function upsertAccount(openai: OpenAIOAuthDomain, incoming: AccountRecord): AccountRecord;
|
|
52
29
|
export type CodexAuthPluginOptions = {
|
|
53
30
|
log?: Logger;
|
|
54
31
|
personality?: PersonalityOption;
|
|
55
|
-
|
|
32
|
+
behaviorSettings?: BehaviorSettings;
|
|
56
33
|
mode?: PluginRuntimeMode;
|
|
57
34
|
quietMode?: boolean;
|
|
58
35
|
pidOffsetEnabled?: boolean;
|
|
59
36
|
rotationStrategy?: RotationStrategy;
|
|
37
|
+
promptCacheKeyStrategy?: PromptCacheKeyStrategy;
|
|
60
38
|
spoofMode?: CodexSpoofMode;
|
|
61
39
|
compatInputSanitizer?: boolean;
|
|
62
40
|
remapDeveloperMessagesToUser?: boolean;
|
|
63
41
|
codexCompactionOverride?: boolean;
|
|
64
42
|
headerSnapshots?: boolean;
|
|
43
|
+
headerSnapshotBodies?: boolean;
|
|
65
44
|
headerTransformDebug?: boolean;
|
|
45
|
+
collaborationProfileEnabled?: boolean;
|
|
46
|
+
orchestratorSubagentsEnabled?: boolean;
|
|
47
|
+
collaborationToolProfile?: CollaborationToolProfile;
|
|
66
48
|
};
|
|
67
49
|
export declare function CodexAuthPlugin(input: PluginInput, opts?: CodexAuthPluginOptions): Promise<Hooks>;
|
|
68
50
|
//# sourceMappingURL=codex-native.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"codex-native.d.ts","sourceRoot":"","sources":["../../lib/codex-native.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAA;
|
|
1
|
+
{"version":3,"file":"codex-native.d.ts","sourceRoot":"","sources":["../../lib/codex-native.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAA;AAI7D,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,UAAU,CAAA;AACtC,OAAO,KAAK,EAAE,cAAc,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAA;AAC/D,OAAO,KAAK,EACV,gBAAgB,EAChB,cAAc,EACd,iBAAiB,EACjB,iBAAiB,EACjB,sBAAsB,EACvB,MAAM,UAAU,CAAA;AACjB,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,8BAA8B,CAAA;AAM5E,OAAO,EACL,mBAAmB,EACnB,mCAAmC,EACnC,yBAAyB,EACzB,uBAAuB,EACxB,MAAM,gCAAgC,CAAA;AAEvC,OAAO,EACL,iBAAiB,EACjB,mBAAmB,EACnB,qBAAqB,EACrB,8BAA8B,EAE9B,YAAY,EAYb,MAAM,4BAA4B,CAAA;AAenC,OAAO,EAAE,wBAAwB,EAAE,MAAM,wBAAwB,CAAA;AACjE,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAA;AACvD,OAAO,EAAE,gBAAgB,EAAE,0BAA0B,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAA;AA6B7G,wBAAsB,mBAAmB,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAMrF;AAED,eAAO,MAAM,UAAU;;;;;;;;;;;;;CAatB,CAAA;AAeD,iBAAS,mBAAmB,IAAI,OAAO,CAEtC;AAMD,iBAAS,eAAe,IAAI,IAAI,CAE/B;AAaD,iBAAS,kBAAkB,CAAC,WAAW,EAAE,iBAAiB,GAAG,cAAc,CAE1E;AAED,MAAM,MAAM,sBAAsB,GAAG;IACnC,GAAG,CAAC,EAAE,MAAM,CAAA;IACZ,WAAW,CAAC,EAAE,iBAAiB,CAAA;IAC/B,gBAAgB,CAAC,EAAE,gBAAgB,CAAA;IACnC,IAAI,CAAC,EAAE,iBAAiB,CAAA;IACxB,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB,gBAAgB,CAAC,EAAE,OAAO,CAAA;IAC1B,gBAAgB,CAAC,EAAE,gBAAgB,CAAA;IACnC,sBAAsB,CAAC,EAAE,sBAAsB,CAAA;IAC/C,SAAS,CAAC,EAAE,cAAc,CAAA;IAC1B,oBAAoB,CAAC,EAAE,OAAO,CAAA;IAC9B,4BAA4B,CAAC,EAAE,OAAO,CAAA;IACtC,uBAAuB,CAAC,EAAE,OAAO,CAAA;IACjC,eAAe,CAAC,EAAE,OAAO,CAAA;IACzB,oBAAoB,CAAC,EAAE,OAAO,CAAA;IAC9B,oBAAoB,CAAC,EAAE,OAAO,CAAA;IAC9B,2BAA2B,CAAC,EAAE,OAAO,CAAA;IACrC,4BAA4B,CAAC,EAAE,OAAO,CAAA;IACtC,wBAAwB,CAAC,EAAE,wBAAwB,CAAA;CACpD,CAAA;AAED,wBAAsB,eAAe,CAAC,KAAK,EAAE,WAAW,EAAE,IAAI,GAAE,sBAA2B,GAAG,OAAO,CAAC,KAAK,CAAC,CAmP3G"}
|