@forgefabrik/ff-ztn 0.3.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 +149 -0
- package/dist/discover.d.ts +3 -0
- package/dist/discover.d.ts.map +1 -0
- package/dist/discover.js +18 -0
- package/dist/discover.js.map +1 -0
- package/dist/genericagent.d.ts +3 -0
- package/dist/genericagent.d.ts.map +1 -0
- package/dist/genericagent.js +40 -0
- package/dist/genericagent.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +46 -0
- package/dist/index.js.map +1 -0
- package/dist/zero-token/accounts/account-repository.d.ts +7 -0
- package/dist/zero-token/accounts/account-repository.d.ts.map +1 -0
- package/dist/zero-token/accounts/account-repository.js +37 -0
- package/dist/zero-token/accounts/account-repository.js.map +1 -0
- package/dist/zero-token/accounts/account-service.d.ts +11 -0
- package/dist/zero-token/accounts/account-service.d.ts.map +1 -0
- package/dist/zero-token/accounts/account-service.js +66 -0
- package/dist/zero-token/accounts/account-service.js.map +1 -0
- package/dist/zero-token/accounts/account-types.d.ts +42 -0
- package/dist/zero-token/accounts/account-types.d.ts.map +1 -0
- package/dist/zero-token/accounts/account-types.js +2 -0
- package/dist/zero-token/accounts/account-types.js.map +1 -0
- package/dist/zero-token/accounts/account-validation.d.ts +14 -0
- package/dist/zero-token/accounts/account-validation.d.ts.map +1 -0
- package/dist/zero-token/accounts/account-validation.js +88 -0
- package/dist/zero-token/accounts/account-validation.js.map +1 -0
- package/dist/zero-token/agent/cli.d.ts +2 -0
- package/dist/zero-token/agent/cli.d.ts.map +1 -0
- package/dist/zero-token/agent/cli.js +116 -0
- package/dist/zero-token/agent/cli.js.map +1 -0
- package/dist/zero-token/agent/external-backend.d.ts +3 -0
- package/dist/zero-token/agent/external-backend.d.ts.map +1 -0
- package/dist/zero-token/agent/external-backend.js +3 -0
- package/dist/zero-token/agent/external-backend.js.map +1 -0
- package/dist/zero-token/agent/genericagent-config.d.ts +11 -0
- package/dist/zero-token/agent/genericagent-config.d.ts.map +1 -0
- package/dist/zero-token/agent/genericagent-config.js +44 -0
- package/dist/zero-token/agent/genericagent-config.js.map +1 -0
- package/dist/zero-token/agent/genericagent-runtime.d.ts +20 -0
- package/dist/zero-token/agent/genericagent-runtime.d.ts.map +1 -0
- package/dist/zero-token/agent/genericagent-runtime.js +71 -0
- package/dist/zero-token/agent/genericagent-runtime.js.map +1 -0
- package/dist/zero-token/agent/project-init.d.ts +11 -0
- package/dist/zero-token/agent/project-init.d.ts.map +1 -0
- package/dist/zero-token/agent/project-init.js +58 -0
- package/dist/zero-token/agent/project-init.js.map +1 -0
- package/dist/zero-token/agent/yoyo-adapter.d.ts +23 -0
- package/dist/zero-token/agent/yoyo-adapter.d.ts.map +1 -0
- package/dist/zero-token/agent/yoyo-adapter.js +88 -0
- package/dist/zero-token/agent/yoyo-adapter.js.map +1 -0
- package/dist/zero-token/app-meta.d.ts +7 -0
- package/dist/zero-token/app-meta.d.ts.map +1 -0
- package/dist/zero-token/app-meta.js +7 -0
- package/dist/zero-token/app-meta.js.map +1 -0
- package/dist/zero-token/cli/doctor-command.d.ts +18 -0
- package/dist/zero-token/cli/doctor-command.d.ts.map +1 -0
- package/dist/zero-token/cli/doctor-command.js +96 -0
- package/dist/zero-token/cli/doctor-command.js.map +1 -0
- package/dist/zero-token/config/config.d.ts +56 -0
- package/dist/zero-token/config/config.d.ts.map +1 -0
- package/dist/zero-token/config/config.js +98 -0
- package/dist/zero-token/config/config.js.map +1 -0
- package/dist/zero-token/config/paths.d.ts +12 -0
- package/dist/zero-token/config/paths.d.ts.map +1 -0
- package/dist/zero-token/config/paths.js +50 -0
- package/dist/zero-token/config/paths.js.map +1 -0
- package/dist/zero-token/discovery/builtin-catalog.d.ts +13 -0
- package/dist/zero-token/discovery/builtin-catalog.d.ts.map +1 -0
- package/dist/zero-token/discovery/builtin-catalog.js +25 -0
- package/dist/zero-token/discovery/builtin-catalog.js.map +1 -0
- package/dist/zero-token/discovery/candidate-evaluator.d.ts +4 -0
- package/dist/zero-token/discovery/candidate-evaluator.d.ts.map +1 -0
- package/dist/zero-token/discovery/candidate-evaluator.js +132 -0
- package/dist/zero-token/discovery/candidate-evaluator.js.map +1 -0
- package/dist/zero-token/discovery/candidate-probe-capability.d.ts +6 -0
- package/dist/zero-token/discovery/candidate-probe-capability.d.ts.map +1 -0
- package/dist/zero-token/discovery/candidate-probe-capability.js +10 -0
- package/dist/zero-token/discovery/candidate-probe-capability.js.map +1 -0
- package/dist/zero-token/discovery/candidate-probe-evidence.d.ts +13 -0
- package/dist/zero-token/discovery/candidate-probe-evidence.d.ts.map +1 -0
- package/dist/zero-token/discovery/candidate-probe-evidence.js +53 -0
- package/dist/zero-token/discovery/candidate-probe-evidence.js.map +1 -0
- package/dist/zero-token/discovery/candidate-probe-observer.d.ts +3 -0
- package/dist/zero-token/discovery/candidate-probe-observer.d.ts.map +1 -0
- package/dist/zero-token/discovery/candidate-probe-observer.js +36 -0
- package/dist/zero-token/discovery/candidate-probe-observer.js.map +1 -0
- package/dist/zero-token/discovery/candidate-probe-runtime.d.ts +6 -0
- package/dist/zero-token/discovery/candidate-probe-runtime.d.ts.map +1 -0
- package/dist/zero-token/discovery/candidate-probe-runtime.js +120 -0
- package/dist/zero-token/discovery/candidate-probe-runtime.js.map +1 -0
- package/dist/zero-token/discovery/candidate-probe-store.d.ts +9 -0
- package/dist/zero-token/discovery/candidate-probe-store.d.ts.map +1 -0
- package/dist/zero-token/discovery/candidate-probe-store.js +66 -0
- package/dist/zero-token/discovery/candidate-probe-store.js.map +1 -0
- package/dist/zero-token/discovery/candidate-probe-types.d.ts +30 -0
- package/dist/zero-token/discovery/candidate-probe-types.d.ts.map +1 -0
- package/dist/zero-token/discovery/candidate-probe-types.js +2 -0
- package/dist/zero-token/discovery/candidate-probe-types.js.map +1 -0
- package/dist/zero-token/discovery/control-service.d.ts +8 -0
- package/dist/zero-token/discovery/control-service.d.ts.map +1 -0
- package/dist/zero-token/discovery/control-service.js +107 -0
- package/dist/zero-token/discovery/control-service.js.map +1 -0
- package/dist/zero-token/discovery/control-store.d.ts +7 -0
- package/dist/zero-token/discovery/control-store.d.ts.map +1 -0
- package/dist/zero-token/discovery/control-store.js +70 -0
- package/dist/zero-token/discovery/control-store.js.map +1 -0
- package/dist/zero-token/discovery/control-types.d.ts +39 -0
- package/dist/zero-token/discovery/control-types.d.ts.map +1 -0
- package/dist/zero-token/discovery/control-types.js +2 -0
- package/dist/zero-token/discovery/control-types.js.map +1 -0
- package/dist/zero-token/discovery/discovery-routes.d.ts +3 -0
- package/dist/zero-token/discovery/discovery-routes.d.ts.map +1 -0
- package/dist/zero-token/discovery/discovery-routes.js +130 -0
- package/dist/zero-token/discovery/discovery-routes.js.map +1 -0
- package/dist/zero-token/discovery/discovery-service.d.ts +18 -0
- package/dist/zero-token/discovery/discovery-service.d.ts.map +1 -0
- package/dist/zero-token/discovery/discovery-service.js +81 -0
- package/dist/zero-token/discovery/discovery-service.js.map +1 -0
- package/dist/zero-token/discovery/manifest.d.ts +14 -0
- package/dist/zero-token/discovery/manifest.d.ts.map +1 -0
- package/dist/zero-token/discovery/manifest.js +43 -0
- package/dist/zero-token/discovery/manifest.js.map +1 -0
- package/dist/zero-token/discovery/public-site-inspector.d.ts +10 -0
- package/dist/zero-token/discovery/public-site-inspector.d.ts.map +1 -0
- package/dist/zero-token/discovery/public-site-inspector.js +111 -0
- package/dist/zero-token/discovery/public-site-inspector.js.map +1 -0
- package/dist/zero-token/gateway/api-key-auth.d.ts +3 -0
- package/dist/zero-token/gateway/api-key-auth.d.ts.map +1 -0
- package/dist/zero-token/gateway/api-key-auth.js +59 -0
- package/dist/zero-token/gateway/api-key-auth.js.map +1 -0
- package/dist/zero-token/gateway/api-request-logger-quiet.d.ts +3 -0
- package/dist/zero-token/gateway/api-request-logger-quiet.d.ts.map +1 -0
- package/dist/zero-token/gateway/api-request-logger-quiet.js +79 -0
- package/dist/zero-token/gateway/api-request-logger-quiet.js.map +1 -0
- package/dist/zero-token/gateway/api-request-logger.d.ts +3 -0
- package/dist/zero-token/gateway/api-request-logger.d.ts.map +1 -0
- package/dist/zero-token/gateway/api-request-logger.js +67 -0
- package/dist/zero-token/gateway/api-request-logger.js.map +1 -0
- package/dist/zero-token/gateway/complete-gateway.d.ts +16 -0
- package/dist/zero-token/gateway/complete-gateway.d.ts.map +1 -0
- package/dist/zero-token/gateway/complete-gateway.js +25 -0
- package/dist/zero-token/gateway/complete-gateway.js.map +1 -0
- package/dist/zero-token/gateway/dashboard-gateway.d.ts +16 -0
- package/dist/zero-token/gateway/dashboard-gateway.d.ts.map +1 -0
- package/dist/zero-token/gateway/dashboard-gateway.js +33 -0
- package/dist/zero-token/gateway/dashboard-gateway.js.map +1 -0
- package/dist/zero-token/gateway/gateway.d.ts +2 -0
- package/dist/zero-token/gateway/gateway.d.ts.map +1 -0
- package/dist/zero-token/gateway/gateway.js +2 -0
- package/dist/zero-token/gateway/gateway.js.map +1 -0
- package/dist/zero-token/gateway/inference-dispatch.d.ts +3 -0
- package/dist/zero-token/gateway/inference-dispatch.d.ts.map +1 -0
- package/dist/zero-token/gateway/inference-dispatch.js +97 -0
- package/dist/zero-token/gateway/inference-dispatch.js.map +1 -0
- package/dist/zero-token/gateway/playground-routes.d.ts +3 -0
- package/dist/zero-token/gateway/playground-routes.d.ts.map +1 -0
- package/dist/zero-token/gateway/playground-routes.js +33 -0
- package/dist/zero-token/gateway/playground-routes.js.map +1 -0
- package/dist/zero-token/gateway/provider-runtime-routes.d.ts +3 -0
- package/dist/zero-token/gateway/provider-runtime-routes.d.ts.map +1 -0
- package/dist/zero-token/gateway/provider-runtime-routes.js +38 -0
- package/dist/zero-token/gateway/provider-runtime-routes.js.map +1 -0
- package/dist/zero-token/gateway/runtime-gateway.d.ts +20 -0
- package/dist/zero-token/gateway/runtime-gateway.d.ts.map +1 -0
- package/dist/zero-token/gateway/runtime-gateway.js +234 -0
- package/dist/zero-token/gateway/runtime-gateway.js.map +1 -0
- package/dist/zero-token/identities/google-identity-service.d.ts +27 -0
- package/dist/zero-token/identities/google-identity-service.d.ts.map +1 -0
- package/dist/zero-token/identities/google-identity-service.js +162 -0
- package/dist/zero-token/identities/google-identity-service.js.map +1 -0
- package/dist/zero-token/index.d.ts +3 -0
- package/dist/zero-token/index.d.ts.map +1 -0
- package/dist/zero-token/index.js +380 -0
- package/dist/zero-token/index.js.map +1 -0
- package/dist/zero-token/inference/browser-stream-utils.d.ts +5 -0
- package/dist/zero-token/inference/browser-stream-utils.d.ts.map +1 -0
- package/dist/zero-token/inference/browser-stream-utils.js +118 -0
- package/dist/zero-token/inference/browser-stream-utils.js.map +1 -0
- package/dist/zero-token/inference/chatgpt-browser-provider.d.ts +17 -0
- package/dist/zero-token/inference/chatgpt-browser-provider.d.ts.map +1 -0
- package/dist/zero-token/inference/chatgpt-browser-provider.js +242 -0
- package/dist/zero-token/inference/chatgpt-browser-provider.js.map +1 -0
- package/dist/zero-token/inference/chatgpt-conversation-state.d.ts +8 -0
- package/dist/zero-token/inference/chatgpt-conversation-state.d.ts.map +1 -0
- package/dist/zero-token/inference/chatgpt-conversation-state.js +60 -0
- package/dist/zero-token/inference/chatgpt-conversation-state.js.map +1 -0
- package/dist/zero-token/inference/chatgpt-direct-provider.d.ts +15 -0
- package/dist/zero-token/inference/chatgpt-direct-provider.d.ts.map +1 -0
- package/dist/zero-token/inference/chatgpt-direct-provider.js +348 -0
- package/dist/zero-token/inference/chatgpt-direct-provider.js.map +1 -0
- package/dist/zero-token/inference/chatgpt-provider.d.ts +32 -0
- package/dist/zero-token/inference/chatgpt-provider.d.ts.map +1 -0
- package/dist/zero-token/inference/chatgpt-provider.js +312 -0
- package/dist/zero-token/inference/chatgpt-provider.js.map +1 -0
- package/dist/zero-token/inference/claude-browser-provider.d.ts +16 -0
- package/dist/zero-token/inference/claude-browser-provider.d.ts.map +1 -0
- package/dist/zero-token/inference/claude-browser-provider.js +193 -0
- package/dist/zero-token/inference/claude-browser-provider.js.map +1 -0
- package/dist/zero-token/inference/claude-openclaw-provider.d.ts +14 -0
- package/dist/zero-token/inference/claude-openclaw-provider.d.ts.map +1 -0
- package/dist/zero-token/inference/claude-openclaw-provider.js +187 -0
- package/dist/zero-token/inference/claude-openclaw-provider.js.map +1 -0
- package/dist/zero-token/inference/glm-browser-provider.d.ts +15 -0
- package/dist/zero-token/inference/glm-browser-provider.d.ts.map +1 -0
- package/dist/zero-token/inference/glm-browser-provider.js +166 -0
- package/dist/zero-token/inference/glm-browser-provider.js.map +1 -0
- package/dist/zero-token/inference/inference-provider.d.ts +44 -0
- package/dist/zero-token/inference/inference-provider.d.ts.map +1 -0
- package/dist/zero-token/inference/inference-provider.js +32 -0
- package/dist/zero-token/inference/inference-provider.js.map +1 -0
- package/dist/zero-token/inference/model-registry.d.ts +28 -0
- package/dist/zero-token/inference/model-registry.d.ts.map +1 -0
- package/dist/zero-token/inference/model-registry.js +48 -0
- package/dist/zero-token/inference/model-registry.js.map +1 -0
- package/dist/zero-token/inference/qwen-browser-provider.d.ts +14 -0
- package/dist/zero-token/inference/qwen-browser-provider.d.ts.map +1 -0
- package/dist/zero-token/inference/qwen-browser-provider.js +227 -0
- package/dist/zero-token/inference/qwen-browser-provider.js.map +1 -0
- package/dist/zero-token/inference/stream.d.ts +15 -0
- package/dist/zero-token/inference/stream.d.ts.map +1 -0
- package/dist/zero-token/inference/stream.js +94 -0
- package/dist/zero-token/inference/stream.js.map +1 -0
- package/dist/zero-token/inference/types.d.ts +94 -0
- package/dist/zero-token/inference/types.d.ts.map +1 -0
- package/dist/zero-token/inference/types.js +5 -0
- package/dist/zero-token/inference/types.js.map +1 -0
- package/dist/zero-token/logger.d.ts +4 -0
- package/dist/zero-token/logger.d.ts.map +1 -0
- package/dist/zero-token/logger.js +27 -0
- package/dist/zero-token/logger.js.map +1 -0
- package/dist/zero-token/logging/log-events.d.ts +17 -0
- package/dist/zero-token/logging/log-events.d.ts.map +1 -0
- package/dist/zero-token/logging/log-events.js +74 -0
- package/dist/zero-token/logging/log-events.js.map +1 -0
- package/dist/zero-token/logging/log-routes.d.ts +3 -0
- package/dist/zero-token/logging/log-routes.d.ts.map +1 -0
- package/dist/zero-token/logging/log-routes.js +68 -0
- package/dist/zero-token/logging/log-routes.js.map +1 -0
- package/dist/zero-token/models/model-cache.d.ts +7 -0
- package/dist/zero-token/models/model-cache.d.ts.map +1 -0
- package/dist/zero-token/models/model-cache.js +58 -0
- package/dist/zero-token/models/model-cache.js.map +1 -0
- package/dist/zero-token/models/model-normalization.d.ts +4 -0
- package/dist/zero-token/models/model-normalization.d.ts.map +1 -0
- package/dist/zero-token/models/model-normalization.js +33 -0
- package/dist/zero-token/models/model-normalization.js.map +1 -0
- package/dist/zero-token/models/model-service.d.ts +6 -0
- package/dist/zero-token/models/model-service.d.ts.map +1 -0
- package/dist/zero-token/models/model-service.js +110 -0
- package/dist/zero-token/models/model-service.js.map +1 -0
- package/dist/zero-token/models/model-types.d.ts +28 -0
- package/dist/zero-token/models/model-types.d.ts.map +1 -0
- package/dist/zero-token/models/model-types.js +2 -0
- package/dist/zero-token/models/model-types.js.map +1 -0
- package/dist/zero-token/multi-account/router.d.ts +43 -0
- package/dist/zero-token/multi-account/router.d.ts.map +1 -0
- package/dist/zero-token/multi-account/router.js +94 -0
- package/dist/zero-token/multi-account/router.js.map +1 -0
- package/dist/zero-token/providers/browser-bridge-jobs.d.ts +26 -0
- package/dist/zero-token/providers/browser-bridge-jobs.d.ts.map +1 -0
- package/dist/zero-token/providers/browser-bridge-jobs.js +119 -0
- package/dist/zero-token/providers/browser-bridge-jobs.js.map +1 -0
- package/dist/zero-token/providers/browser-bridge-routes.d.ts +3 -0
- package/dist/zero-token/providers/browser-bridge-routes.d.ts.map +1 -0
- package/dist/zero-token/providers/browser-bridge-routes.js +71 -0
- package/dist/zero-token/providers/browser-bridge-routes.js.map +1 -0
- package/dist/zero-token/providers/browser.d.ts +47 -0
- package/dist/zero-token/providers/browser.d.ts.map +1 -0
- package/dist/zero-token/providers/browser.js +330 -0
- package/dist/zero-token/providers/browser.js.map +1 -0
- package/dist/zero-token/providers/chatgpt/chatgpt-account-info.d.ts +12 -0
- package/dist/zero-token/providers/chatgpt/chatgpt-account-info.d.ts.map +1 -0
- package/dist/zero-token/providers/chatgpt/chatgpt-account-info.js +66 -0
- package/dist/zero-token/providers/chatgpt/chatgpt-account-info.js.map +1 -0
- package/dist/zero-token/providers/chatgpt/chatgpt-auth.d.ts +9 -0
- package/dist/zero-token/providers/chatgpt/chatgpt-auth.d.ts.map +1 -0
- package/dist/zero-token/providers/chatgpt/chatgpt-auth.js +81 -0
- package/dist/zero-token/providers/chatgpt/chatgpt-auth.js.map +1 -0
- package/dist/zero-token/providers/chatgpt/chatgpt-browser.d.ts +21 -0
- package/dist/zero-token/providers/chatgpt/chatgpt-browser.d.ts.map +1 -0
- package/dist/zero-token/providers/chatgpt/chatgpt-browser.js +64 -0
- package/dist/zero-token/providers/chatgpt/chatgpt-browser.js.map +1 -0
- package/dist/zero-token/providers/chatgpt/chatgpt-errors.d.ts +22 -0
- package/dist/zero-token/providers/chatgpt/chatgpt-errors.d.ts.map +1 -0
- package/dist/zero-token/providers/chatgpt/chatgpt-errors.js +44 -0
- package/dist/zero-token/providers/chatgpt/chatgpt-errors.js.map +1 -0
- package/dist/zero-token/providers/chatgpt/chatgpt-session.d.ts +10 -0
- package/dist/zero-token/providers/chatgpt/chatgpt-session.d.ts.map +1 -0
- package/dist/zero-token/providers/chatgpt/chatgpt-session.js +71 -0
- package/dist/zero-token/providers/chatgpt/chatgpt-session.js.map +1 -0
- package/dist/zero-token/providers/chatgpt/chatgpt-types.d.ts +36 -0
- package/dist/zero-token/providers/chatgpt/chatgpt-types.d.ts.map +1 -0
- package/dist/zero-token/providers/chatgpt/chatgpt-types.js +2 -0
- package/dist/zero-token/providers/chatgpt/chatgpt-types.js.map +1 -0
- package/dist/zero-token/providers/chatgpt-web-auth.d.ts +10 -0
- package/dist/zero-token/providers/chatgpt-web-auth.d.ts.map +1 -0
- package/dist/zero-token/providers/chatgpt-web-auth.js +143 -0
- package/dist/zero-token/providers/chatgpt-web-auth.js.map +1 -0
- package/dist/zero-token/providers/chatgpt-web-models.d.ts +8 -0
- package/dist/zero-token/providers/chatgpt-web-models.d.ts.map +1 -0
- package/dist/zero-token/providers/chatgpt-web-models.js +99 -0
- package/dist/zero-token/providers/chatgpt-web-models.js.map +1 -0
- package/dist/zero-token/providers/chatgpt-web-validator.d.ts +8 -0
- package/dist/zero-token/providers/chatgpt-web-validator.d.ts.map +1 -0
- package/dist/zero-token/providers/chatgpt-web-validator.js +79 -0
- package/dist/zero-token/providers/chatgpt-web-validator.js.map +1 -0
- package/dist/zero-token/providers/claude-web-auth.d.ts +3 -0
- package/dist/zero-token/providers/claude-web-auth.d.ts.map +1 -0
- package/dist/zero-token/providers/claude-web-auth.js +109 -0
- package/dist/zero-token/providers/claude-web-auth.js.map +1 -0
- package/dist/zero-token/providers/claude-web-models.d.ts +3 -0
- package/dist/zero-token/providers/claude-web-models.d.ts.map +1 -0
- package/dist/zero-token/providers/claude-web-models.js +71 -0
- package/dist/zero-token/providers/claude-web-models.js.map +1 -0
- package/dist/zero-token/providers/claude-web-validator.d.ts +3 -0
- package/dist/zero-token/providers/claude-web-validator.d.ts.map +1 -0
- package/dist/zero-token/providers/claude-web-validator.js +57 -0
- package/dist/zero-token/providers/claude-web-validator.js.map +1 -0
- package/dist/zero-token/providers/deepseek-web-auth.d.ts +7 -0
- package/dist/zero-token/providers/deepseek-web-auth.d.ts.map +1 -0
- package/dist/zero-token/providers/deepseek-web-auth.js +69 -0
- package/dist/zero-token/providers/deepseek-web-auth.js.map +1 -0
- package/dist/zero-token/providers/deepseek-web-validator.d.ts +3 -0
- package/dist/zero-token/providers/deepseek-web-validator.d.ts.map +1 -0
- package/dist/zero-token/providers/deepseek-web-validator.js +24 -0
- package/dist/zero-token/providers/deepseek-web-validator.js.map +1 -0
- package/dist/zero-token/providers/doubao-web-auth.d.ts +7 -0
- package/dist/zero-token/providers/doubao-web-auth.d.ts.map +1 -0
- package/dist/zero-token/providers/doubao-web-auth.js +44 -0
- package/dist/zero-token/providers/doubao-web-auth.js.map +1 -0
- package/dist/zero-token/providers/gemini-web-auth.d.ts +7 -0
- package/dist/zero-token/providers/gemini-web-auth.d.ts.map +1 -0
- package/dist/zero-token/providers/gemini-web-auth.js +47 -0
- package/dist/zero-token/providers/gemini-web-auth.js.map +1 -0
- package/dist/zero-token/providers/glm-intl-web-auth.d.ts +4 -0
- package/dist/zero-token/providers/glm-intl-web-auth.d.ts.map +1 -0
- package/dist/zero-token/providers/glm-intl-web-auth.js +53 -0
- package/dist/zero-token/providers/glm-intl-web-auth.js.map +1 -0
- package/dist/zero-token/providers/glm-web-auth.d.ts +3 -0
- package/dist/zero-token/providers/glm-web-auth.d.ts.map +1 -0
- package/dist/zero-token/providers/glm-web-auth.js +42 -0
- package/dist/zero-token/providers/glm-web-auth.js.map +1 -0
- package/dist/zero-token/providers/glm-web-models.d.ts +3 -0
- package/dist/zero-token/providers/glm-web-models.d.ts.map +1 -0
- package/dist/zero-token/providers/glm-web-models.js +52 -0
- package/dist/zero-token/providers/glm-web-models.js.map +1 -0
- package/dist/zero-token/providers/grok-web-auth.d.ts +7 -0
- package/dist/zero-token/providers/grok-web-auth.d.ts.map +1 -0
- package/dist/zero-token/providers/grok-web-auth.js +47 -0
- package/dist/zero-token/providers/grok-web-auth.js.map +1 -0
- package/dist/zero-token/providers/identity/chatgpt-identity.d.ts +15 -0
- package/dist/zero-token/providers/identity/chatgpt-identity.d.ts.map +1 -0
- package/dist/zero-token/providers/identity/chatgpt-identity.js +15 -0
- package/dist/zero-token/providers/identity/chatgpt-identity.js.map +1 -0
- package/dist/zero-token/providers/identity/identity-validation.d.ts +3 -0
- package/dist/zero-token/providers/identity/identity-validation.d.ts.map +1 -0
- package/dist/zero-token/providers/identity/identity-validation.js +74 -0
- package/dist/zero-token/providers/identity/identity-validation.js.map +1 -0
- package/dist/zero-token/providers/identity/provider-identity-readiness.d.ts +16 -0
- package/dist/zero-token/providers/identity/provider-identity-readiness.d.ts.map +1 -0
- package/dist/zero-token/providers/identity/provider-identity-readiness.js +56 -0
- package/dist/zero-token/providers/identity/provider-identity-readiness.js.map +1 -0
- package/dist/zero-token/providers/identity/provider-identity.d.ts +88 -0
- package/dist/zero-token/providers/identity/provider-identity.d.ts.map +1 -0
- package/dist/zero-token/providers/identity/provider-identity.js +17 -0
- package/dist/zero-token/providers/identity/provider-identity.js.map +1 -0
- package/dist/zero-token/providers/kimi-web-auth.d.ts +7 -0
- package/dist/zero-token/providers/kimi-web-auth.d.ts.map +1 -0
- package/dist/zero-token/providers/kimi-web-auth.js +50 -0
- package/dist/zero-token/providers/kimi-web-auth.js.map +1 -0
- package/dist/zero-token/providers/perplexity-web-auth.d.ts +7 -0
- package/dist/zero-token/providers/perplexity-web-auth.d.ts.map +1 -0
- package/dist/zero-token/providers/perplexity-web-auth.js +68 -0
- package/dist/zero-token/providers/perplexity-web-auth.js.map +1 -0
- package/dist/zero-token/providers/perplexity-web-validator.d.ts +3 -0
- package/dist/zero-token/providers/perplexity-web-validator.d.ts.map +1 -0
- package/dist/zero-token/providers/perplexity-web-validator.js +33 -0
- package/dist/zero-token/providers/perplexity-web-validator.js.map +1 -0
- package/dist/zero-token/providers/provider-account-resolver.d.ts +9 -0
- package/dist/zero-token/providers/provider-account-resolver.d.ts.map +1 -0
- package/dist/zero-token/providers/provider-account-resolver.js +28 -0
- package/dist/zero-token/providers/provider-account-resolver.js.map +1 -0
- package/dist/zero-token/providers/provider-browser-profiles.d.ts +14 -0
- package/dist/zero-token/providers/provider-browser-profiles.d.ts.map +1 -0
- package/dist/zero-token/providers/provider-browser-profiles.js +78 -0
- package/dist/zero-token/providers/provider-browser-profiles.js.map +1 -0
- package/dist/zero-token/providers/provider-catalog.d.ts +7 -0
- package/dist/zero-token/providers/provider-catalog.d.ts.map +1 -0
- package/dist/zero-token/providers/provider-catalog.js +27 -0
- package/dist/zero-token/providers/provider-catalog.js.map +1 -0
- package/dist/zero-token/providers/provider-login-jobs.d.ts +21 -0
- package/dist/zero-token/providers/provider-login-jobs.d.ts.map +1 -0
- package/dist/zero-token/providers/provider-login-jobs.js +185 -0
- package/dist/zero-token/providers/provider-login-jobs.js.map +1 -0
- package/dist/zero-token/providers/provider-runtime-registry.d.ts +16 -0
- package/dist/zero-token/providers/provider-runtime-registry.d.ts.map +1 -0
- package/dist/zero-token/providers/provider-runtime-registry.js +88 -0
- package/dist/zero-token/providers/provider-runtime-registry.js.map +1 -0
- package/dist/zero-token/providers/provider-runtime-registry.test.d.ts +2 -0
- package/dist/zero-token/providers/provider-runtime-registry.test.d.ts.map +1 -0
- package/dist/zero-token/providers/provider-runtime-registry.test.js +26 -0
- package/dist/zero-token/providers/provider-runtime-registry.test.js.map +1 -0
- package/dist/zero-token/providers/provider-types.d.ts +72 -0
- package/dist/zero-token/providers/provider-types.d.ts.map +1 -0
- package/dist/zero-token/providers/provider-types.js +2 -0
- package/dist/zero-token/providers/provider-types.js.map +1 -0
- package/dist/zero-token/providers/qwen-cn-web-auth.d.ts +4 -0
- package/dist/zero-token/providers/qwen-cn-web-auth.d.ts.map +1 -0
- package/dist/zero-token/providers/qwen-cn-web-auth.js +58 -0
- package/dist/zero-token/providers/qwen-cn-web-auth.js.map +1 -0
- package/dist/zero-token/providers/qwen-web-auth.d.ts +3 -0
- package/dist/zero-token/providers/qwen-web-auth.d.ts.map +1 -0
- package/dist/zero-token/providers/qwen-web-auth.js +67 -0
- package/dist/zero-token/providers/qwen-web-auth.js.map +1 -0
- package/dist/zero-token/providers/qwen-web-models.d.ts +3 -0
- package/dist/zero-token/providers/qwen-web-models.d.ts.map +1 -0
- package/dist/zero-token/providers/qwen-web-models.js +27 -0
- package/dist/zero-token/providers/qwen-web-models.js.map +1 -0
- package/dist/zero-token/providers/registry.d.ts +4 -0
- package/dist/zero-token/providers/registry.d.ts.map +1 -0
- package/dist/zero-token/providers/registry.js +39 -0
- package/dist/zero-token/providers/registry.js.map +1 -0
- package/dist/zero-token/providers/registry.next.d.ts +4 -0
- package/dist/zero-token/providers/registry.next.d.ts.map +1 -0
- package/dist/zero-token/providers/registry.next.js +30 -0
- package/dist/zero-token/providers/registry.next.js.map +1 -0
- package/dist/zero-token/providers/remote-browser-session.d.ts +7 -0
- package/dist/zero-token/providers/remote-browser-session.d.ts.map +1 -0
- package/dist/zero-token/providers/remote-browser-session.js +85 -0
- package/dist/zero-token/providers/remote-browser-session.js.map +1 -0
- package/dist/zero-token/providers/xiaomimo-web-auth.d.ts +7 -0
- package/dist/zero-token/providers/xiaomimo-web-auth.d.ts.map +1 -0
- package/dist/zero-token/providers/xiaomimo-web-auth.js +44 -0
- package/dist/zero-token/providers/xiaomimo-web-auth.js.map +1 -0
- package/dist/zero-token/quota/quota-manager.d.ts +2 -0
- package/dist/zero-token/quota/quota-manager.d.ts.map +1 -0
- package/dist/zero-token/quota/quota-manager.js +2 -0
- package/dist/zero-token/quota/quota-manager.js.map +1 -0
- package/dist/zero-token/quota/runtime-quota-manager.d.ts +19 -0
- package/dist/zero-token/quota/runtime-quota-manager.d.ts.map +1 -0
- package/dist/zero-token/quota/runtime-quota-manager.js +118 -0
- package/dist/zero-token/quota/runtime-quota-manager.js.map +1 -0
- package/dist/zero-token/session/session-service.d.ts +11 -0
- package/dist/zero-token/session/session-service.d.ts.map +1 -0
- package/dist/zero-token/session/session-service.js +169 -0
- package/dist/zero-token/session/session-service.js.map +1 -0
- package/dist/zero-token/session/session-types.d.ts +22 -0
- package/dist/zero-token/session/session-types.d.ts.map +1 -0
- package/dist/zero-token/session/session-types.js +2 -0
- package/dist/zero-token/session/session-types.js.map +1 -0
- package/dist/zero-token/storage/atomic-json-store.d.ts +10 -0
- package/dist/zero-token/storage/atomic-json-store.d.ts.map +1 -0
- package/dist/zero-token/storage/atomic-json-store.js +60 -0
- package/dist/zero-token/storage/atomic-json-store.js.map +1 -0
- package/package.json +59 -0
- package/web-console/dist/assets/index-B_4vEorW.css +1 -0
- package/web-console/dist/assets/index-DFs1Oo-1.js +27 -0
- package/web-console/dist/index.html +20 -0
- package/web-console/dist/nova-mark.svg +18 -0
- package/web-console/dist/nova-network.svg +36 -0
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
const DEEPSEEK_API = "https://chat.deepseek.com/api/v1/user/info";
|
|
2
|
+
export async function validateSession(cookies, accessToken, userAgent) {
|
|
3
|
+
const headers = {
|
|
4
|
+
Accept: "application/json",
|
|
5
|
+
"User-Agent": userAgent ?? "zero-token/0.1.0",
|
|
6
|
+
Cookie: cookies,
|
|
7
|
+
};
|
|
8
|
+
if (accessToken)
|
|
9
|
+
headers["Authorization"] = `Bearer ${accessToken}`;
|
|
10
|
+
try {
|
|
11
|
+
const response = await fetch(DEEPSEEK_API, { headers });
|
|
12
|
+
if (response.status === 401 || response.status === 403) {
|
|
13
|
+
return { accountId: "", provider: "deepseek", valid: false, status: "expired", error: "Session abgelaufen" };
|
|
14
|
+
}
|
|
15
|
+
if (!response.ok) {
|
|
16
|
+
return { accountId: "", provider: "deepseek", valid: false, status: "error", error: `HTTP ${response.status}` };
|
|
17
|
+
}
|
|
18
|
+
return { accountId: "", provider: "deepseek", valid: true, status: "valid", plan: "free" };
|
|
19
|
+
}
|
|
20
|
+
catch (err) {
|
|
21
|
+
return { accountId: "", provider: "deepseek", valid: false, status: "error", error: `Netzwerkfehler: ${err instanceof Error ? err.message : String(err)}` };
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=deepseek-web-validator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deepseek-web-validator.js","sourceRoot":"","sources":["../../../src/zero-token/providers/deepseek-web-validator.ts"],"names":[],"mappings":"AAEA,MAAM,YAAY,GAAG,4CAA4C,CAAC;AAElE,MAAM,CAAC,KAAK,UAAU,eAAe,CACnC,OAAe,EACf,WAA+B,EAC/B,SAA6B;IAE7B,MAAM,OAAO,GAA2B;QACtC,MAAM,EAAE,kBAAkB;QAC1B,YAAY,EAAE,SAAS,IAAI,kBAAkB;QAC7C,MAAM,EAAE,OAAO;KAChB,CAAC;IACF,IAAI,WAAW;QAAE,OAAO,CAAC,eAAe,CAAC,GAAG,UAAU,WAAW,EAAE,CAAC;IAEpE,IAAI,CAAC;QACH,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,YAAY,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC;QACxD,IAAI,QAAQ,CAAC,MAAM,KAAK,GAAG,IAAI,QAAQ,CAAC,MAAM,KAAK,GAAG,EAAE,CAAC;YACvD,OAAO,EAAE,SAAS,EAAE,EAAE,EAAE,QAAQ,EAAE,UAAU,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,oBAAoB,EAAE,CAAC;QAC/G,CAAC;QACD,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC;YACjB,OAAO,EAAE,SAAS,EAAE,EAAE,EAAE,QAAQ,EAAE,UAAU,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,QAAQ,CAAC,MAAM,EAAE,EAAE,CAAC;QAClH,CAAC;QACD,OAAO,EAAE,SAAS,EAAE,EAAE,EAAE,QAAQ,EAAE,UAAU,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;IAC7F,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,OAAO,EAAE,SAAS,EAAE,EAAE,EAAE,QAAQ,EAAE,UAAU,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,mBAAmB,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC;IAC9J,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { ProviderAuthFunction } from "./provider-types.js";
|
|
2
|
+
/**
|
|
3
|
+
* Doubao-Web-Auth: Browser öffnen, auf manuellen Login warten,
|
|
4
|
+
* Cookies und Token extrahieren.
|
|
5
|
+
*/
|
|
6
|
+
export declare const auth: ProviderAuthFunction;
|
|
7
|
+
//# sourceMappingURL=doubao-web-auth.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"doubao-web-auth.d.ts","sourceRoot":"","sources":["../../../src/zero-token/providers/doubao-web-auth.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAuB,MAAM,qBAAqB,CAAC;AAarF;;;GAGG;AACH,eAAO,MAAM,IAAI,EAAE,oBAgClB,CAAC"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { openProviderBrowser, waitForUrlLogin, extractCookies, extractLocalStorage, } from "./browser.js";
|
|
2
|
+
const DOUBAO_URL = "https://www.doubao.com";
|
|
3
|
+
const AUTH_PATTERNS = ["/auth/", "/login", "/signin"];
|
|
4
|
+
const COOKIE_NAMES = ["doubao", "session", "token", "Authorization"];
|
|
5
|
+
const TOKEN_KEYS = ["accessToken", "doubao-token", "userToken"];
|
|
6
|
+
/**
|
|
7
|
+
* Doubao-Web-Auth: Browser öffnen, auf manuellen Login warten,
|
|
8
|
+
* Cookies und Token extrahieren.
|
|
9
|
+
*/
|
|
10
|
+
export const auth = async (config) => {
|
|
11
|
+
let browserInstance = null;
|
|
12
|
+
try {
|
|
13
|
+
const { browser, page } = await openProviderBrowser({
|
|
14
|
+
targetUrl: DOUBAO_URL,
|
|
15
|
+
cdpPort: config.cdpPort,
|
|
16
|
+
headless: config.headless,
|
|
17
|
+
proxy: config.proxy,
|
|
18
|
+
loginTimeout: config.loginTimeout,
|
|
19
|
+
});
|
|
20
|
+
browserInstance = browser;
|
|
21
|
+
await waitForUrlLogin(page, DOUBAO_URL, AUTH_PATTERNS, config.loginTimeout ?? 300_000);
|
|
22
|
+
const cookies = await extractCookies(page, COOKIE_NAMES);
|
|
23
|
+
const accessToken = await extractLocalStorage(page, TOKEN_KEYS);
|
|
24
|
+
const userAgent = await page.evaluate(() => navigator.userAgent);
|
|
25
|
+
return {
|
|
26
|
+
ok: true,
|
|
27
|
+
session: { cookies, accessToken: accessToken ?? undefined, userAgent },
|
|
28
|
+
info: { plan: "free" },
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
catch (err) {
|
|
32
|
+
const msg = err instanceof Error ? err.message : String(err);
|
|
33
|
+
if (msg.includes("Login nicht innerhalb"))
|
|
34
|
+
return { ok: false, reason: "login-timeout" };
|
|
35
|
+
if (msg.includes("Browser konnte nicht geöffnet"))
|
|
36
|
+
return { ok: false, reason: "browser-launch-failed" };
|
|
37
|
+
return { ok: false, reason: "unknown-error" };
|
|
38
|
+
}
|
|
39
|
+
finally {
|
|
40
|
+
if (browserInstance)
|
|
41
|
+
await browserInstance.close().catch(() => { });
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
//# sourceMappingURL=doubao-web-auth.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"doubao-web-auth.js","sourceRoot":"","sources":["../../../src/zero-token/providers/doubao-web-auth.ts"],"names":[],"mappings":"AACA,OAAO,EACL,mBAAmB,EACnB,eAAe,EACf,cAAc,EACd,mBAAmB,GACpB,MAAM,cAAc,CAAC;AAEtB,MAAM,UAAU,GAAG,wBAAwB,CAAC;AAC5C,MAAM,aAAa,GAAG,CAAC,QAAQ,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC;AACtD,MAAM,YAAY,GAAG,CAAC,QAAQ,EAAE,SAAS,EAAE,OAAO,EAAE,eAAe,CAAC,CAAC;AACrE,MAAM,UAAU,GAAG,CAAC,aAAa,EAAE,cAAc,EAAE,WAAW,CAAC,CAAC;AAEhE;;;GAGG;AACH,MAAM,CAAC,MAAM,IAAI,GAAyB,KAAK,EAAE,MAAM,EAAE,EAAE;IACzD,IAAI,eAAe,GAA0C,IAAI,CAAC;IAElE,IAAI,CAAC;QACH,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,GAAG,MAAM,mBAAmB,CAAC;YAClD,SAAS,EAAE,UAAU;YACrB,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,QAAQ,EAAE,MAAM,CAAC,QAAQ;YACzB,KAAK,EAAE,MAAM,CAAC,KAAK;YACnB,YAAY,EAAE,MAAM,CAAC,YAAY;SAClC,CAAC,CAAC;QACH,eAAe,GAAG,OAAO,CAAC;QAE1B,MAAM,eAAe,CAAC,IAAI,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,CAAC,YAAY,IAAI,OAAO,CAAC,CAAC;QAEvF,MAAM,OAAO,GAAG,MAAM,cAAc,CAAC,IAAI,EAAE,YAAY,CAAC,CAAC;QACzD,MAAM,WAAW,GAAG,MAAM,mBAAmB,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;QAChE,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAEjE,OAAO;YACL,EAAE,EAAE,IAAI;YACR,OAAO,EAAE,EAAE,OAAO,EAAE,WAAW,EAAE,WAAW,IAAI,SAAS,EAAE,SAAS,EAAE;YACtE,IAAI,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE;SACvB,CAAC;IACJ,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,MAAM,GAAG,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QAC7D,IAAI,GAAG,CAAC,QAAQ,CAAC,uBAAuB,CAAC;YAAE,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,eAAe,EAAE,CAAC;QACzF,IAAI,GAAG,CAAC,QAAQ,CAAC,+BAA+B,CAAC;YAAE,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,uBAAuB,EAAE,CAAC;QACzG,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,eAAe,EAAE,CAAC;IAChD,CAAC;YAAS,CAAC;QACT,IAAI,eAAe;YAAE,MAAM,eAAe,CAAC,KAAK,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;IACrE,CAAC;AACH,CAAC,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { ProviderAuthFunction } from "./provider-types.js";
|
|
2
|
+
/**
|
|
3
|
+
* Gemini-Web-Auth: Browser öffnen, auf manuellen Login warten,
|
|
4
|
+
* Google-Session-Cookies extrahieren.
|
|
5
|
+
*/
|
|
6
|
+
export declare const auth: ProviderAuthFunction;
|
|
7
|
+
//# sourceMappingURL=gemini-web-auth.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gemini-web-auth.d.ts","sourceRoot":"","sources":["../../../src/zero-token/providers/gemini-web-auth.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAuB,MAAM,qBAAqB,CAAC;AAYrF;;;GAGG;AACH,eAAO,MAAM,IAAI,EAAE,oBAkClB,CAAC"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { openProviderBrowser, waitForUrlLogin, extractCookies, getCookieValue, } from "./browser.js";
|
|
2
|
+
const GEMINI_URL = "https://gemini.google.com";
|
|
3
|
+
const AUTH_PATTERNS = ["/auth/", "/signin", "/signup", "/Login"];
|
|
4
|
+
const COOKIE_NAMES = ["__Secure-", "SAPISID", "APISID", "HSID", "SSID"];
|
|
5
|
+
/**
|
|
6
|
+
* Gemini-Web-Auth: Browser öffnen, auf manuellen Login warten,
|
|
7
|
+
* Google-Session-Cookies extrahieren.
|
|
8
|
+
*/
|
|
9
|
+
export const auth = async (config) => {
|
|
10
|
+
let browserInstance = null;
|
|
11
|
+
try {
|
|
12
|
+
const { browser, page } = await openProviderBrowser({
|
|
13
|
+
targetUrl: GEMINI_URL,
|
|
14
|
+
cdpPort: config.cdpPort,
|
|
15
|
+
headless: config.headless,
|
|
16
|
+
proxy: config.proxy,
|
|
17
|
+
loginTimeout: config.loginTimeout,
|
|
18
|
+
});
|
|
19
|
+
browserInstance = browser;
|
|
20
|
+
await waitForUrlLogin(page, GEMINI_URL, AUTH_PATTERNS, config.loginTimeout ?? 300_000);
|
|
21
|
+
const cookies = await extractCookies(page, COOKIE_NAMES);
|
|
22
|
+
const sapisid = await getCookieValue(page, "SAPISID");
|
|
23
|
+
const userAgent = await page.evaluate(() => navigator.userAgent);
|
|
24
|
+
const info = await fetchGeminiAccountInfo({ cookies, userAgent });
|
|
25
|
+
return {
|
|
26
|
+
ok: true,
|
|
27
|
+
session: { cookies, accessToken: sapisid, userAgent },
|
|
28
|
+
info,
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
catch (err) {
|
|
32
|
+
const msg = err instanceof Error ? err.message : String(err);
|
|
33
|
+
if (msg.includes("Login nicht innerhalb"))
|
|
34
|
+
return { ok: false, reason: "login-timeout" };
|
|
35
|
+
if (msg.includes("Browser konnte nicht geöffnet"))
|
|
36
|
+
return { ok: false, reason: "browser-launch-failed" };
|
|
37
|
+
return { ok: false, reason: "unknown-error" };
|
|
38
|
+
}
|
|
39
|
+
finally {
|
|
40
|
+
if (browserInstance)
|
|
41
|
+
await browserInstance.close().catch(() => { });
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
async function fetchGeminiAccountInfo(session) {
|
|
45
|
+
return { plan: "free" };
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=gemini-web-auth.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gemini-web-auth.js","sourceRoot":"","sources":["../../../src/zero-token/providers/gemini-web-auth.ts"],"names":[],"mappings":"AACA,OAAO,EACL,mBAAmB,EACnB,eAAe,EACf,cAAc,EACd,cAAc,GACf,MAAM,cAAc,CAAC;AAEtB,MAAM,UAAU,GAAG,2BAA2B,CAAC;AAC/C,MAAM,aAAa,GAAG,CAAC,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,QAAQ,CAAC,CAAC;AACjE,MAAM,YAAY,GAAG,CAAC,WAAW,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;AAExE;;;GAGG;AACH,MAAM,CAAC,MAAM,IAAI,GAAyB,KAAK,EAAE,MAAM,EAAE,EAAE;IACzD,IAAI,eAAe,GAA0C,IAAI,CAAC;IAElE,IAAI,CAAC;QACH,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,GAAG,MAAM,mBAAmB,CAAC;YAClD,SAAS,EAAE,UAAU;YACrB,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,QAAQ,EAAE,MAAM,CAAC,QAAQ;YACzB,KAAK,EAAE,MAAM,CAAC,KAAK;YACnB,YAAY,EAAE,MAAM,CAAC,YAAY;SAClC,CAAC,CAAC;QACH,eAAe,GAAG,OAAO,CAAC;QAE1B,MAAM,eAAe,CAAC,IAAI,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,CAAC,YAAY,IAAI,OAAO,CAAC,CAAC;QAEvF,MAAM,OAAO,GAAG,MAAM,cAAc,CAAC,IAAI,EAAE,YAAY,CAAC,CAAC;QACzD,MAAM,OAAO,GAAG,MAAM,cAAc,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;QACtD,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAEjE,MAAM,IAAI,GAAG,MAAM,sBAAsB,CAAC,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC,CAAC;QAElE,OAAO;YACL,EAAE,EAAE,IAAI;YACR,OAAO,EAAE,EAAE,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,SAAS,EAAE;YACrD,IAAI;SACL,CAAC;IACJ,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,MAAM,GAAG,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QAC7D,IAAI,GAAG,CAAC,QAAQ,CAAC,uBAAuB,CAAC;YAAE,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,eAAe,EAAE,CAAC;QACzF,IAAI,GAAG,CAAC,QAAQ,CAAC,+BAA+B,CAAC;YAAE,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,uBAAuB,EAAE,CAAC;QACzG,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,eAAe,EAAE,CAAC;IAChD,CAAC;YAAS,CAAC;QACT,IAAI,eAAe;YAAE,MAAM,eAAe,CAAC,KAAK,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;IACrE,CAAC;AACH,CAAC,CAAC;AAEF,KAAK,UAAU,sBAAsB,CACnC,OAAgD;IAEhD,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;AAC1B,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"glm-intl-web-auth.d.ts","sourceRoot":"","sources":["../../../src/zero-token/providers/glm-intl-web-auth.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AAUhE,qDAAqD;AACrD,eAAO,MAAM,IAAI,EAAE,oBAwDlB,CAAC"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { extractCookies, extractLocalStorage, openProviderBrowser, } from "./browser.js";
|
|
2
|
+
const GLM_INTL_URL = "https://chat.z.ai";
|
|
3
|
+
const TOKEN_KEYS = ["accessToken", "access_token", "auth_token", "token"];
|
|
4
|
+
/** GLM International browser login for chat.z.ai. */
|
|
5
|
+
export const auth = async (config) => {
|
|
6
|
+
let browserInstance = null;
|
|
7
|
+
try {
|
|
8
|
+
const { browser, page } = await openProviderBrowser({
|
|
9
|
+
targetUrl: GLM_INTL_URL,
|
|
10
|
+
cdpPort: config.cdpPort,
|
|
11
|
+
headless: config.headless,
|
|
12
|
+
proxy: config.proxy,
|
|
13
|
+
loginTimeout: config.loginTimeout,
|
|
14
|
+
});
|
|
15
|
+
browserInstance = browser;
|
|
16
|
+
await page.waitForFunction(() => {
|
|
17
|
+
const cookie = document.cookie;
|
|
18
|
+
const hasAuthCookie = [
|
|
19
|
+
"chatglm_refresh_token",
|
|
20
|
+
"refresh_token",
|
|
21
|
+
"auth_token",
|
|
22
|
+
"access_token",
|
|
23
|
+
"session",
|
|
24
|
+
].some((name) => cookie.includes(name));
|
|
25
|
+
const hasChatInput = Boolean(document.querySelector('textarea, [contenteditable="true"], .chat-input, .message-input'));
|
|
26
|
+
const onAuthPage = /login|signin|auth/i.test(window.location.pathname);
|
|
27
|
+
return hasAuthCookie || (hasChatInput && !onAuthPage);
|
|
28
|
+
}, undefined, { timeout: config.loginTimeout ?? 300_000, polling: 1000 });
|
|
29
|
+
const cookies = await extractCookies(page);
|
|
30
|
+
const accessToken = await extractLocalStorage(page, TOKEN_KEYS);
|
|
31
|
+
const userAgent = await page.evaluate(() => navigator.userAgent);
|
|
32
|
+
return {
|
|
33
|
+
ok: true,
|
|
34
|
+
session: { cookies, accessToken: accessToken ?? undefined, userAgent },
|
|
35
|
+
info: { plan: "free" },
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
catch (err) {
|
|
39
|
+
const message = err instanceof Error ? err.message : String(err);
|
|
40
|
+
if (message.includes("Timeout") || message.includes("Login nicht innerhalb")) {
|
|
41
|
+
return { ok: false, reason: "login-timeout" };
|
|
42
|
+
}
|
|
43
|
+
if (message.includes("Browser konnte nicht geöffnet")) {
|
|
44
|
+
return { ok: false, reason: "browser-launch-failed" };
|
|
45
|
+
}
|
|
46
|
+
return { ok: false, reason: "unknown-error" };
|
|
47
|
+
}
|
|
48
|
+
finally {
|
|
49
|
+
if (browserInstance)
|
|
50
|
+
await browserInstance.close().catch(() => { });
|
|
51
|
+
}
|
|
52
|
+
};
|
|
53
|
+
//# sourceMappingURL=glm-intl-web-auth.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"glm-intl-web-auth.js","sourceRoot":"","sources":["../../../src/zero-token/providers/glm-intl-web-auth.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"glm-web-auth.d.ts","sourceRoot":"","sources":["../../../src/zero-token/providers/glm-web-auth.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AAahE,eAAO,MAAM,IAAI,EAAE,oBAmClB,CAAC"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { openProviderBrowser, waitForUrlLogin, extractCookies, extractLocalStorage, } from "./browser.js";
|
|
2
|
+
const GLM_URL = "https://chatglm.cn";
|
|
3
|
+
const AUTH_PATTERNS = ["/auth/", "/login", "/signin"];
|
|
4
|
+
const COOKIE_NAMES = ["chatglm", "session", "token", "Authorization"];
|
|
5
|
+
const TOKEN_KEYS = ["accessToken", "glm-token", "userToken"];
|
|
6
|
+
export const auth = async (config) => {
|
|
7
|
+
let browserInstance = null;
|
|
8
|
+
try {
|
|
9
|
+
const { browser, page } = await openProviderBrowser({
|
|
10
|
+
targetUrl: GLM_URL,
|
|
11
|
+
cdpUrl: config.cdpUrl,
|
|
12
|
+
cdpPort: config.cdpPort,
|
|
13
|
+
headless: config.headless,
|
|
14
|
+
proxy: config.proxy,
|
|
15
|
+
loginTimeout: config.loginTimeout,
|
|
16
|
+
});
|
|
17
|
+
browserInstance = browser;
|
|
18
|
+
await waitForUrlLogin(page, GLM_URL, AUTH_PATTERNS, config.loginTimeout ?? 300_000);
|
|
19
|
+
const cookies = await extractCookies(page, COOKIE_NAMES);
|
|
20
|
+
const accessToken = await extractLocalStorage(page, TOKEN_KEYS);
|
|
21
|
+
const userAgent = await page.evaluate(() => navigator.userAgent);
|
|
22
|
+
return {
|
|
23
|
+
ok: true,
|
|
24
|
+
session: { cookies, accessToken: accessToken ?? undefined, userAgent },
|
|
25
|
+
info: { plan: "free" },
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
catch (err) {
|
|
29
|
+
const msg = err instanceof Error ? err.message : String(err);
|
|
30
|
+
if (msg.includes("Login nicht innerhalb"))
|
|
31
|
+
return { ok: false, reason: "login-timeout" };
|
|
32
|
+
if (msg.includes("Browser konnte nicht geöffnet"))
|
|
33
|
+
return { ok: false, reason: "browser-launch-failed" };
|
|
34
|
+
return { ok: false, reason: "unknown-error" };
|
|
35
|
+
}
|
|
36
|
+
finally {
|
|
37
|
+
if (browserInstance && !config.cdpUrl) {
|
|
38
|
+
await browserInstance.close().catch(() => { });
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
};
|
|
42
|
+
//# sourceMappingURL=glm-web-auth.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"glm-web-auth.js","sourceRoot":"","sources":["../../../src/zero-token/providers/glm-web-auth.ts"],"names":[],"mappings":"AACA,OAAO,EACL,mBAAmB,EACnB,eAAe,EACf,cAAc,EACd,mBAAmB,GACpB,MAAM,cAAc,CAAC;AAEtB,MAAM,OAAO,GAAG,oBAAoB,CAAC;AACrC,MAAM,aAAa,GAAG,CAAC,QAAQ,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC;AACtD,MAAM,YAAY,GAAG,CAAC,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,eAAe,CAAC,CAAC;AACtE,MAAM,UAAU,GAAG,CAAC,aAAa,EAAE,WAAW,EAAE,WAAW,CAAC,CAAC;AAE7D,MAAM,CAAC,MAAM,IAAI,GAAyB,KAAK,EAAE,MAAM,EAAE,EAAE;IACzD,IAAI,eAAe,GAA0C,IAAI,CAAC;IAElE,IAAI,CAAC;QACH,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,GAAG,MAAM,mBAAmB,CAAC;YAClD,SAAS,EAAE,OAAO;YAClB,MAAM,EAAE,MAAM,CAAC,MAAM;YACrB,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,QAAQ,EAAE,MAAM,CAAC,QAAQ;YACzB,KAAK,EAAE,MAAM,CAAC,KAAK;YACnB,YAAY,EAAE,MAAM,CAAC,YAAY;SAClC,CAAC,CAAC;QACH,eAAe,GAAG,OAAO,CAAC;QAE1B,MAAM,eAAe,CAAC,IAAI,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,CAAC,YAAY,IAAI,OAAO,CAAC,CAAC;QAEpF,MAAM,OAAO,GAAG,MAAM,cAAc,CAAC,IAAI,EAAE,YAAY,CAAC,CAAC;QACzD,MAAM,WAAW,GAAG,MAAM,mBAAmB,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;QAChE,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAEjE,OAAO;YACL,EAAE,EAAE,IAAI;YACR,OAAO,EAAE,EAAE,OAAO,EAAE,WAAW,EAAE,WAAW,IAAI,SAAS,EAAE,SAAS,EAAE;YACtE,IAAI,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE;SACvB,CAAC;IACJ,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,MAAM,GAAG,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QAC7D,IAAI,GAAG,CAAC,QAAQ,CAAC,uBAAuB,CAAC;YAAE,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,eAAe,EAAE,CAAC;QACzF,IAAI,GAAG,CAAC,QAAQ,CAAC,+BAA+B,CAAC;YAAE,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,uBAAuB,EAAE,CAAC;QACzG,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,eAAe,EAAE,CAAC;IAChD,CAAC;YAAS,CAAC;QACT,IAAI,eAAe,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;YACtC,MAAM,eAAe,CAAC,KAAK,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;QAChD,CAAC;IACH,CAAC;AACH,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"glm-web-models.d.ts","sourceRoot":"","sources":["../../../src/zero-token/providers/glm-web-models.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAa,MAAM,0BAA0B,CAAC;AA0C3E,eAAO,MAAM,cAAc,EAAE,eAa5B,CAAC"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { getProviderBrowserPage } from "./remote-browser-session.js";
|
|
2
|
+
const SUPPORTED_MODELS = [
|
|
3
|
+
{
|
|
4
|
+
id: "glm-4-plus",
|
|
5
|
+
slug: "glm-4-plus",
|
|
6
|
+
name: "GLM-4 Plus",
|
|
7
|
+
provider: "glm",
|
|
8
|
+
capabilities: { text: true },
|
|
9
|
+
maxTokens: 4096,
|
|
10
|
+
enabled: true,
|
|
11
|
+
},
|
|
12
|
+
{
|
|
13
|
+
id: "glm-4",
|
|
14
|
+
slug: "glm-4",
|
|
15
|
+
name: "GLM-4",
|
|
16
|
+
provider: "glm",
|
|
17
|
+
capabilities: { text: true },
|
|
18
|
+
maxTokens: 4096,
|
|
19
|
+
enabled: true,
|
|
20
|
+
},
|
|
21
|
+
{
|
|
22
|
+
id: "glm-4-think",
|
|
23
|
+
slug: "glm-4-think",
|
|
24
|
+
name: "GLM-4 Think",
|
|
25
|
+
provider: "glm",
|
|
26
|
+
capabilities: { text: true },
|
|
27
|
+
maxTokens: 4096,
|
|
28
|
+
enabled: true,
|
|
29
|
+
},
|
|
30
|
+
{
|
|
31
|
+
id: "glm-4-zero",
|
|
32
|
+
slug: "glm-4-zero",
|
|
33
|
+
name: "GLM-4 Zero",
|
|
34
|
+
provider: "glm",
|
|
35
|
+
capabilities: { text: true },
|
|
36
|
+
maxTokens: 4096,
|
|
37
|
+
enabled: true,
|
|
38
|
+
},
|
|
39
|
+
];
|
|
40
|
+
export const discoverModels = async () => {
|
|
41
|
+
const page = await getProviderBrowserPage("https://chatglm.cn/");
|
|
42
|
+
await page.goto("https://chatglm.cn/", {
|
|
43
|
+
waitUntil: "domcontentloaded",
|
|
44
|
+
timeout: 30_000,
|
|
45
|
+
});
|
|
46
|
+
const current = new URL(page.url());
|
|
47
|
+
if (/login|signin|auth/i.test(current.pathname)) {
|
|
48
|
+
throw new Error("GLM-Browserprofil ist nicht angemeldet.");
|
|
49
|
+
}
|
|
50
|
+
return SUPPORTED_MODELS;
|
|
51
|
+
};
|
|
52
|
+
//# sourceMappingURL=glm-web-models.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"glm-web-models.js","sourceRoot":"","sources":["../../../src/zero-token/providers/glm-web-models.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,sBAAsB,EAAE,MAAM,6BAA6B,CAAC;AAErE,MAAM,gBAAgB,GAAgB;IACpC;QACE,EAAE,EAAE,YAAY;QAChB,IAAI,EAAE,YAAY;QAClB,IAAI,EAAE,YAAY;QAClB,QAAQ,EAAE,KAAK;QACf,YAAY,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE;QAC5B,SAAS,EAAE,IAAI;QACf,OAAO,EAAE,IAAI;KACd;IACD;QACE,EAAE,EAAE,OAAO;QACX,IAAI,EAAE,OAAO;QACb,IAAI,EAAE,OAAO;QACb,QAAQ,EAAE,KAAK;QACf,YAAY,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE;QAC5B,SAAS,EAAE,IAAI;QACf,OAAO,EAAE,IAAI;KACd;IACD;QACE,EAAE,EAAE,aAAa;QACjB,IAAI,EAAE,aAAa;QACnB,IAAI,EAAE,aAAa;QACnB,QAAQ,EAAE,KAAK;QACf,YAAY,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE;QAC5B,SAAS,EAAE,IAAI;QACf,OAAO,EAAE,IAAI;KACd;IACD;QACE,EAAE,EAAE,YAAY;QAChB,IAAI,EAAE,YAAY;QAClB,IAAI,EAAE,YAAY;QAClB,QAAQ,EAAE,KAAK;QACf,YAAY,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE;QAC5B,SAAS,EAAE,IAAI;QACf,OAAO,EAAE,IAAI;KACd;CACF,CAAC;AAEF,MAAM,CAAC,MAAM,cAAc,GAAoB,KAAK,IAAI,EAAE;IACxD,MAAM,IAAI,GAAG,MAAM,sBAAsB,CAAC,qBAAqB,CAAC,CAAC;IACjE,MAAM,IAAI,CAAC,IAAI,CAAC,qBAAqB,EAAE;QACrC,SAAS,EAAE,kBAAkB;QAC7B,OAAO,EAAE,MAAM;KAChB,CAAC,CAAC;IAEH,MAAM,OAAO,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;IACpC,IAAI,oBAAoB,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC;QAChD,MAAM,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAC;IAC7D,CAAC;IAED,OAAO,gBAAgB,CAAC;AAC1B,CAAC,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { ProviderAuthFunction } from "./provider-types.js";
|
|
2
|
+
/**
|
|
3
|
+
* Grok-Web-Auth: Browser öffnen, auf manuellen Login warten,
|
|
4
|
+
* Cookies und Auth-Token extrahieren.
|
|
5
|
+
*/
|
|
6
|
+
export declare const auth: ProviderAuthFunction;
|
|
7
|
+
//# sourceMappingURL=grok-web-auth.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"grok-web-auth.d.ts","sourceRoot":"","sources":["../../../src/zero-token/providers/grok-web-auth.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAuB,MAAM,qBAAqB,CAAC;AAarF;;;GAGG;AACH,eAAO,MAAM,IAAI,EAAE,oBAgClB,CAAC"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { openProviderBrowser, waitForUrlLogin, extractCookies, extractLocalStorage, } from "./browser.js";
|
|
2
|
+
const GROK_URL = "https://grok.com";
|
|
3
|
+
const AUTH_PATTERNS = ["/auth/", "/login", "/signin"];
|
|
4
|
+
const COOKIE_NAMES = ["grok", "session", "token", "x-auth-token"];
|
|
5
|
+
const TOKEN_KEYS = ["accessToken", "authToken", "grokToken"];
|
|
6
|
+
/**
|
|
7
|
+
* Grok-Web-Auth: Browser öffnen, auf manuellen Login warten,
|
|
8
|
+
* Cookies und Auth-Token extrahieren.
|
|
9
|
+
*/
|
|
10
|
+
export const auth = async (config) => {
|
|
11
|
+
let browserInstance = null;
|
|
12
|
+
try {
|
|
13
|
+
const { browser, page } = await openProviderBrowser({
|
|
14
|
+
targetUrl: GROK_URL,
|
|
15
|
+
cdpPort: config.cdpPort,
|
|
16
|
+
headless: config.headless,
|
|
17
|
+
proxy: config.proxy,
|
|
18
|
+
loginTimeout: config.loginTimeout,
|
|
19
|
+
});
|
|
20
|
+
browserInstance = browser;
|
|
21
|
+
await waitForUrlLogin(page, GROK_URL, AUTH_PATTERNS, config.loginTimeout ?? 300_000);
|
|
22
|
+
const cookies = await extractCookies(page, COOKIE_NAMES);
|
|
23
|
+
const accessToken = await extractLocalStorage(page, TOKEN_KEYS);
|
|
24
|
+
const userAgent = await page.evaluate(() => navigator.userAgent);
|
|
25
|
+
return {
|
|
26
|
+
ok: true,
|
|
27
|
+
session: { cookies, accessToken: accessToken ?? undefined, userAgent },
|
|
28
|
+
info: await fetchGrokAccountInfo({ cookies, accessToken, userAgent }),
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
catch (err) {
|
|
32
|
+
const msg = err instanceof Error ? err.message : String(err);
|
|
33
|
+
if (msg.includes("Login nicht innerhalb"))
|
|
34
|
+
return { ok: false, reason: "login-timeout" };
|
|
35
|
+
if (msg.includes("Browser konnte nicht geöffnet"))
|
|
36
|
+
return { ok: false, reason: "browser-launch-failed" };
|
|
37
|
+
return { ok: false, reason: "unknown-error" };
|
|
38
|
+
}
|
|
39
|
+
finally {
|
|
40
|
+
if (browserInstance)
|
|
41
|
+
await browserInstance.close().catch(() => { });
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
async function fetchGrokAccountInfo(session) {
|
|
45
|
+
return { plan: "free" };
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=grok-web-auth.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"grok-web-auth.js","sourceRoot":"","sources":["../../../src/zero-token/providers/grok-web-auth.ts"],"names":[],"mappings":"AACA,OAAO,EACL,mBAAmB,EACnB,eAAe,EACf,cAAc,EACd,mBAAmB,GACpB,MAAM,cAAc,CAAC;AAEtB,MAAM,QAAQ,GAAG,kBAAkB,CAAC;AACpC,MAAM,aAAa,GAAG,CAAC,QAAQ,EAAE,QAAQ,EAAE,SAAS,CAAC,CAAC;AACtD,MAAM,YAAY,GAAG,CAAC,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,cAAc,CAAC,CAAC;AAClE,MAAM,UAAU,GAAG,CAAC,aAAa,EAAE,WAAW,EAAE,WAAW,CAAC,CAAC;AAE7D;;;GAGG;AACH,MAAM,CAAC,MAAM,IAAI,GAAyB,KAAK,EAAE,MAAM,EAAE,EAAE;IACzD,IAAI,eAAe,GAA0C,IAAI,CAAC;IAElE,IAAI,CAAC;QACH,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,GAAG,MAAM,mBAAmB,CAAC;YAClD,SAAS,EAAE,QAAQ;YACnB,OAAO,EAAE,MAAM,CAAC,OAAO;YACvB,QAAQ,EAAE,MAAM,CAAC,QAAQ;YACzB,KAAK,EAAE,MAAM,CAAC,KAAK;YACnB,YAAY,EAAE,MAAM,CAAC,YAAY;SAClC,CAAC,CAAC;QACH,eAAe,GAAG,OAAO,CAAC;QAE1B,MAAM,eAAe,CAAC,IAAI,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,CAAC,YAAY,IAAI,OAAO,CAAC,CAAC;QAErF,MAAM,OAAO,GAAG,MAAM,cAAc,CAAC,IAAI,EAAE,YAAY,CAAC,CAAC;QACzD,MAAM,WAAW,GAAG,MAAM,mBAAmB,CAAC,IAAI,EAAE,UAAU,CAAC,CAAC;QAChE,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAEjE,OAAO;YACL,EAAE,EAAE,IAAI;YACR,OAAO,EAAE,EAAE,OAAO,EAAE,WAAW,EAAE,WAAW,IAAI,SAAS,EAAE,SAAS,EAAE;YACtE,IAAI,EAAE,MAAM,oBAAoB,CAAC,EAAE,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,CAAC;SACtE,CAAC;IACJ,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,MAAM,GAAG,GAAG,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QAC7D,IAAI,GAAG,CAAC,QAAQ,CAAC,uBAAuB,CAAC;YAAE,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,eAAe,EAAE,CAAC;QACzF,IAAI,GAAG,CAAC,QAAQ,CAAC,+BAA+B,CAAC;YAAE,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,uBAAuB,EAAE,CAAC;QACzG,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,eAAe,EAAE,CAAC;IAChD,CAAC;YAAS,CAAC;QACT,IAAI,eAAe;YAAE,MAAM,eAAe,CAAC,KAAK,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,GAAE,CAAC,CAAC,CAAC;IACrE,CAAC;AACH,CAAC,CAAC;AAEF,KAAK,UAAU,oBAAoB,CACjC,OAA6E;IAE7E,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;AAC1B,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export declare const CHATGPT_IDENTITY_SPEC: Readonly<{
|
|
2
|
+
provider: "chatgpt";
|
|
3
|
+
allowedHosts: string[];
|
|
4
|
+
sessionCookieNames: never[];
|
|
5
|
+
accessTokenCandidates: never[];
|
|
6
|
+
refreshTokenCandidates: never[];
|
|
7
|
+
deviceIdCandidates: never[];
|
|
8
|
+
csrfTokenCandidates: never[];
|
|
9
|
+
requirements: {
|
|
10
|
+
sessionCredential: true;
|
|
11
|
+
deviceId: false;
|
|
12
|
+
csrfToken: false;
|
|
13
|
+
};
|
|
14
|
+
}>;
|
|
15
|
+
//# sourceMappingURL=chatgpt-identity.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chatgpt-identity.d.ts","sourceRoot":"","sources":["../../../../src/zero-token/providers/identity/chatgpt-identity.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,qBAAqB;;;;;;;;;;;;;EAaD,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
export const CHATGPT_IDENTITY_SPEC = Object.freeze({
|
|
2
|
+
provider: "chatgpt",
|
|
3
|
+
allowedHosts: ["chatgpt.com"],
|
|
4
|
+
sessionCookieNames: [],
|
|
5
|
+
accessTokenCandidates: [],
|
|
6
|
+
refreshTokenCandidates: [],
|
|
7
|
+
deviceIdCandidates: [],
|
|
8
|
+
csrfTokenCandidates: [],
|
|
9
|
+
requirements: {
|
|
10
|
+
sessionCredential: true,
|
|
11
|
+
deviceId: false,
|
|
12
|
+
csrfToken: false,
|
|
13
|
+
},
|
|
14
|
+
});
|
|
15
|
+
//# sourceMappingURL=chatgpt-identity.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chatgpt-identity.js","sourceRoot":"","sources":["../../../../src/zero-token/providers/identity/chatgpt-identity.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,qBAAqB,GAAG,MAAM,CAAC,MAAM,CAAC;IACjD,QAAQ,EAAE,SAAS;IACnB,YAAY,EAAE,CAAC,aAAa,CAAC;IAC7B,kBAAkB,EAAE,EAAE;IACtB,qBAAqB,EAAE,EAAE;IACzB,sBAAsB,EAAE,EAAE;IAC1B,kBAAkB,EAAE,EAAE;IACtB,mBAAmB,EAAE,EAAE;IACvB,YAAY,EAAE;QACZ,iBAAiB,EAAE,IAAI;QACvB,QAAQ,EAAE,KAAK;QACf,SAAS,EAAE,KAAK;KACjB;CAC6B,CAAC,CAAC"}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import type { IdentityValidationResult, ProviderIdentity, ProviderIdentitySpec } from "./provider-identity.js";
|
|
2
|
+
export declare function validateProviderIdentity(spec: ProviderIdentitySpec, identity: ProviderIdentity): IdentityValidationResult;
|
|
3
|
+
//# sourceMappingURL=identity-validation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"identity-validation.d.ts","sourceRoot":"","sources":["../../../../src/zero-token/providers/identity/identity-validation.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAEV,wBAAwB,EACxB,gBAAgB,EAChB,oBAAoB,EACrB,MAAM,wBAAwB,CAAC;AAMhC,wBAAgB,wBAAwB,CACtC,IAAI,EAAE,oBAAoB,EAC1B,QAAQ,EAAE,gBAAgB,GACzB,wBAAwB,CA2E1B"}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
function hostMatches(hostname, allowedHost) {
|
|
2
|
+
return hostname === allowedHost || hostname.endsWith(`.${allowedHost}`);
|
|
3
|
+
}
|
|
4
|
+
export function validateProviderIdentity(spec, identity) {
|
|
5
|
+
const issues = [];
|
|
6
|
+
if (!identity.userAgent.trim()) {
|
|
7
|
+
issues.push({
|
|
8
|
+
code: "missing-user-agent",
|
|
9
|
+
severity: "error",
|
|
10
|
+
field: "userAgent",
|
|
11
|
+
message: `${spec.provider}: User-Agent fehlt.`,
|
|
12
|
+
});
|
|
13
|
+
}
|
|
14
|
+
if (!identity.origin.trim()) {
|
|
15
|
+
issues.push({
|
|
16
|
+
code: "missing-origin",
|
|
17
|
+
severity: "error",
|
|
18
|
+
field: "origin",
|
|
19
|
+
message: `${spec.provider}: Browser-Origin fehlt.`,
|
|
20
|
+
});
|
|
21
|
+
}
|
|
22
|
+
else {
|
|
23
|
+
try {
|
|
24
|
+
const hostname = new URL(identity.origin).hostname.toLowerCase();
|
|
25
|
+
if (!spec.allowedHosts.some((allowed) => hostMatches(hostname, allowed))) {
|
|
26
|
+
issues.push({
|
|
27
|
+
code: "origin-host-mismatch",
|
|
28
|
+
severity: "error",
|
|
29
|
+
field: "origin",
|
|
30
|
+
message: `${spec.provider}: Origin ${hostname} gehört nicht zum Providerprofil.`,
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
catch {
|
|
35
|
+
issues.push({
|
|
36
|
+
code: "invalid-origin",
|
|
37
|
+
severity: "error",
|
|
38
|
+
field: "origin",
|
|
39
|
+
message: `${spec.provider}: Browser-Origin ist ungültig.`,
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
if (spec.requirements.sessionCredential &&
|
|
44
|
+
!identity.accessToken &&
|
|
45
|
+
Object.keys(identity.cookies).length === 0) {
|
|
46
|
+
issues.push({
|
|
47
|
+
code: "missing-session-credential",
|
|
48
|
+
severity: "error",
|
|
49
|
+
field: "sessionCredential",
|
|
50
|
+
message: `${spec.provider}: Keine Session-Credentials verfügbar.`,
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
if (spec.requirements.deviceId && !identity.deviceId) {
|
|
54
|
+
issues.push({
|
|
55
|
+
code: "missing-device-id",
|
|
56
|
+
severity: "error",
|
|
57
|
+
field: "deviceId",
|
|
58
|
+
message: `${spec.provider}: Persistente Geräte-ID fehlt.`,
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
if (spec.requirements.csrfToken && !identity.csrfToken) {
|
|
62
|
+
issues.push({
|
|
63
|
+
code: "missing-csrf-token",
|
|
64
|
+
severity: "error",
|
|
65
|
+
field: "csrfToken",
|
|
66
|
+
message: `${spec.provider}: CSRF-Token fehlt.`,
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
return Object.freeze({
|
|
70
|
+
valid: !issues.some((issue) => issue.severity === "error"),
|
|
71
|
+
issues: Object.freeze(issues),
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
//# sourceMappingURL=identity-validation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"identity-validation.js","sourceRoot":"","sources":["../../../../src/zero-token/providers/identity/identity-validation.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { ProviderType } from "../../accounts/account-types.js";
|
|
2
|
+
export interface ProviderIdentitySignals {
|
|
3
|
+
provider: ProviderType;
|
|
4
|
+
origin: string;
|
|
5
|
+
userAgentPresent: boolean;
|
|
6
|
+
accountSessionPresent: boolean;
|
|
7
|
+
deviceBindingPresent: boolean;
|
|
8
|
+
requestProtectionPresent: boolean;
|
|
9
|
+
}
|
|
10
|
+
export interface ProviderIdentityReadiness {
|
|
11
|
+
provider: ProviderType;
|
|
12
|
+
ready: boolean;
|
|
13
|
+
missing: readonly string[];
|
|
14
|
+
}
|
|
15
|
+
export declare function evaluateProviderIdentityReadiness(signals: ProviderIdentitySignals): ProviderIdentityReadiness;
|
|
16
|
+
//# sourceMappingURL=provider-identity-readiness.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"provider-identity-readiness.d.ts","sourceRoot":"","sources":["../../../../src/zero-token/providers/identity/provider-identity-readiness.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,iCAAiC,CAAC;AAEpE,MAAM,WAAW,uBAAuB;IACtC,QAAQ,EAAE,YAAY,CAAC;IACvB,MAAM,EAAE,MAAM,CAAC;IACf,gBAAgB,EAAE,OAAO,CAAC;IAC1B,qBAAqB,EAAE,OAAO,CAAC;IAC/B,oBAAoB,EAAE,OAAO,CAAC;IAC9B,wBAAwB,EAAE,OAAO,CAAC;CACnC;AAED,MAAM,WAAW,yBAAyB;IACxC,QAAQ,EAAE,YAAY,CAAC;IACvB,KAAK,EAAE,OAAO,CAAC;IACf,OAAO,EAAE,SAAS,MAAM,EAAE,CAAC;CAC5B;AA0CD,wBAAgB,iCAAiC,CAC/C,OAAO,EAAE,uBAAuB,GAC/B,yBAAyB,CAsB3B"}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
const RULES = {
|
|
2
|
+
chatgpt: {
|
|
3
|
+
allowedHosts: ["chatgpt.com"],
|
|
4
|
+
requireDeviceBinding: false,
|
|
5
|
+
requireRequestProtection: false,
|
|
6
|
+
},
|
|
7
|
+
claude: {
|
|
8
|
+
allowedHosts: ["claude.ai"],
|
|
9
|
+
requireDeviceBinding: true,
|
|
10
|
+
requireRequestProtection: false,
|
|
11
|
+
},
|
|
12
|
+
qwen: {
|
|
13
|
+
allowedHosts: ["chat.qwen.ai"],
|
|
14
|
+
requireDeviceBinding: false,
|
|
15
|
+
requireRequestProtection: false,
|
|
16
|
+
},
|
|
17
|
+
glm: {
|
|
18
|
+
allowedHosts: ["chatglm.cn"],
|
|
19
|
+
requireDeviceBinding: true,
|
|
20
|
+
requireRequestProtection: false,
|
|
21
|
+
},
|
|
22
|
+
};
|
|
23
|
+
function matchesAllowedHost(origin, allowedHosts) {
|
|
24
|
+
try {
|
|
25
|
+
const hostname = new URL(origin).hostname.toLowerCase();
|
|
26
|
+
return allowedHosts.some((allowed) => hostname === allowed || hostname.endsWith(`.${allowed}`));
|
|
27
|
+
}
|
|
28
|
+
catch {
|
|
29
|
+
return false;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
export function evaluateProviderIdentityReadiness(signals) {
|
|
33
|
+
const rule = RULES[signals.provider];
|
|
34
|
+
const missing = [];
|
|
35
|
+
if (!rule)
|
|
36
|
+
missing.push("provider-rule");
|
|
37
|
+
if (!signals.userAgentPresent)
|
|
38
|
+
missing.push("user-agent");
|
|
39
|
+
if (!signals.accountSessionPresent)
|
|
40
|
+
missing.push("account-session");
|
|
41
|
+
if (!rule || !matchesAllowedHost(signals.origin, rule.allowedHosts)) {
|
|
42
|
+
missing.push("provider-origin");
|
|
43
|
+
}
|
|
44
|
+
if (rule?.requireDeviceBinding && !signals.deviceBindingPresent) {
|
|
45
|
+
missing.push("device-binding");
|
|
46
|
+
}
|
|
47
|
+
if (rule?.requireRequestProtection && !signals.requestProtectionPresent) {
|
|
48
|
+
missing.push("request-protection");
|
|
49
|
+
}
|
|
50
|
+
return Object.freeze({
|
|
51
|
+
provider: signals.provider,
|
|
52
|
+
ready: missing.length === 0,
|
|
53
|
+
missing: Object.freeze(missing),
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
//# sourceMappingURL=provider-identity-readiness.js.map
|