@structured-world/gitlab-mcp 5.7.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 +251 -1
- package/dist/generated/prisma/client.d.ts +13 -0
- package/dist/generated/prisma/client.js +46 -0
- package/dist/generated/prisma/client.js.map +1 -0
- package/dist/generated/prisma/commonInputTypes.d.ts +245 -0
- package/dist/generated/prisma/commonInputTypes.js +3 -0
- package/dist/generated/prisma/commonInputTypes.js.map +1 -0
- package/dist/generated/prisma/enums.d.ts +1 -0
- package/dist/generated/prisma/enums.js +3 -0
- package/dist/generated/prisma/enums.js.map +1 -0
- package/dist/generated/prisma/internal/class.d.ts +47 -0
- package/dist/generated/prisma/internal/class.js +66 -0
- package/dist/generated/prisma/internal/class.js.map +1 -0
- package/dist/generated/prisma/internal/prismaNamespace.d.ts +712 -0
- package/dist/generated/prisma/internal/prismaNamespace.js +139 -0
- package/dist/generated/prisma/internal/prismaNamespace.js.map +1 -0
- package/dist/generated/prisma/models/AuthCodeFlowState.d.ts +513 -0
- package/dist/generated/prisma/models/AuthCodeFlowState.js +3 -0
- package/dist/generated/prisma/models/AuthCodeFlowState.js.map +1 -0
- package/dist/generated/prisma/models/AuthorizationCode.d.ts +641 -0
- package/dist/generated/prisma/models/AuthorizationCode.js +3 -0
- package/dist/generated/prisma/models/AuthorizationCode.js.map +1 -0
- package/dist/generated/prisma/models/DeviceFlowState.d.ts +606 -0
- package/dist/generated/prisma/models/DeviceFlowState.js +3 -0
- package/dist/generated/prisma/models/DeviceFlowState.js.map +1 -0
- package/dist/generated/prisma/models/McpSessionMapping.d.ts +438 -0
- package/dist/generated/prisma/models/McpSessionMapping.js +3 -0
- package/dist/generated/prisma/models/McpSessionMapping.js.map +1 -0
- package/dist/generated/prisma/models/OAuthSession.d.ts +962 -0
- package/dist/generated/prisma/models/OAuthSession.js +3 -0
- package/dist/generated/prisma/models/OAuthSession.js.map +1 -0
- package/dist/generated/prisma/models.d.ts +6 -0
- package/dist/generated/prisma/models.js +3 -0
- package/dist/generated/prisma/models.js.map +1 -0
- package/dist/{config.d.ts → src/config.d.ts} +11 -0
- package/dist/{config.js → src/config.js} +12 -1
- package/dist/src/config.js.map +1 -0
- package/dist/src/entities/core/index.js.map +1 -0
- package/dist/src/entities/core/registry.js +745 -0
- package/dist/src/entities/core/registry.js.map +1 -0
- package/dist/src/entities/core/schema-readonly.d.ts +290 -0
- package/dist/src/entities/core/schema-readonly.js +296 -0
- package/dist/src/entities/core/schema-readonly.js.map +1 -0
- package/dist/src/entities/core/schema.d.ts +71 -0
- package/dist/src/entities/core/schema.js +93 -0
- package/dist/src/entities/core/schema.js.map +1 -0
- package/dist/src/entities/files/index.js.map +1 -0
- package/dist/src/entities/files/registry.js +165 -0
- package/dist/src/entities/files/registry.js.map +1 -0
- package/dist/src/entities/files/schema-readonly.d.ts +93 -0
- package/dist/{entities → src/entities}/files/schema-readonly.js +20 -1
- package/dist/src/entities/files/schema-readonly.js.map +1 -0
- package/dist/src/entities/files/schema.d.ts +82 -0
- package/dist/src/entities/files/schema.js +79 -0
- package/dist/src/entities/files/schema.js.map +1 -0
- package/dist/src/entities/index.js.map +1 -0
- package/dist/src/entities/labels/index.js.map +1 -0
- package/dist/src/entities/labels/registry.js +139 -0
- package/dist/src/entities/labels/registry.js.map +1 -0
- package/dist/src/entities/labels/schema-readonly.d.ts +14 -0
- package/dist/src/entities/labels/schema-readonly.js.map +1 -0
- package/dist/src/entities/labels/schema.d.ts +23 -0
- package/dist/src/entities/labels/schema.js.map +1 -0
- package/dist/src/entities/milestones/index.js.map +1 -0
- package/dist/src/entities/milestones/registry.js +197 -0
- package/dist/src/entities/milestones/registry.js.map +1 -0
- package/dist/src/entities/milestones/schema-readonly.d.ts +58 -0
- package/dist/src/entities/milestones/schema-readonly.js.map +1 -0
- package/dist/src/entities/milestones/schema.d.ts +32 -0
- package/dist/src/entities/milestones/schema.js.map +1 -0
- package/dist/src/entities/mrs/index.js.map +1 -0
- package/dist/{entities → src/entities}/mrs/registry.js +64 -81
- package/dist/src/entities/mrs/registry.js.map +1 -0
- package/dist/src/entities/mrs/schema-readonly.d.ts +127 -0
- package/dist/src/entities/mrs/schema-readonly.js.map +1 -0
- package/dist/src/entities/mrs/schema.d.ts +285 -0
- package/dist/src/entities/mrs/schema.js.map +1 -0
- package/dist/src/entities/pipelines/index.js.map +1 -0
- package/dist/{entities → src/entities}/pipelines/registry.js +72 -200
- package/dist/src/entities/pipelines/registry.js.map +1 -0
- package/dist/src/entities/pipelines/schema-readonly.d.ts +238 -0
- package/dist/src/entities/pipelines/schema-readonly.js.map +1 -0
- package/dist/src/entities/pipelines/schema.d.ts +49 -0
- package/dist/src/entities/pipelines/schema.js.map +1 -0
- package/dist/src/entities/shared.d.ts +291 -0
- package/dist/src/entities/shared.js.map +1 -0
- package/dist/src/entities/utils.d.ts +3 -0
- package/dist/src/entities/utils.js.map +1 -0
- package/dist/src/entities/variables/index.js.map +1 -0
- package/dist/src/entities/variables/registry.js +153 -0
- package/dist/src/entities/variables/registry.js.map +1 -0
- package/dist/src/entities/variables/schema-readonly.d.ts +15 -0
- package/dist/src/entities/variables/schema-readonly.js.map +1 -0
- package/dist/src/entities/variables/schema.d.ts +42 -0
- package/dist/src/entities/variables/schema.js.map +1 -0
- package/dist/src/entities/wiki/index.js.map +1 -0
- package/dist/src/entities/wiki/registry.js +136 -0
- package/dist/src/entities/wiki/registry.js.map +1 -0
- package/dist/src/entities/wiki/schema-readonly.d.ts +22 -0
- package/dist/src/entities/wiki/schema-readonly.js.map +1 -0
- package/dist/{entities → src/entities}/wiki/schema.d.ts +3 -31
- package/dist/src/entities/wiki/schema.js.map +1 -0
- package/dist/src/entities/workitems/index.js.map +1 -0
- package/dist/{entities → src/entities}/workitems/registry.js +40 -7
- package/dist/src/entities/workitems/registry.js.map +1 -0
- package/dist/src/entities/workitems/schema-readonly.d.ts +52 -0
- package/dist/{entities → src/entities}/workitems/schema-readonly.js +1 -1
- package/dist/src/entities/workitems/schema-readonly.js.map +1 -0
- package/dist/src/entities/workitems/schema.d.ts +37 -0
- package/dist/src/entities/workitems/schema.js.map +1 -0
- package/dist/src/graphql/DynamicWorkItemsQuery.js.map +1 -0
- package/dist/src/graphql/client.js.map +1 -0
- package/dist/src/graphql/index.js.map +1 -0
- package/dist/src/graphql/workItems.js.map +1 -0
- package/dist/{handlers.js → src/handlers.js} +15 -0
- package/dist/src/handlers.js.map +1 -0
- package/dist/{http-client.js → src/http-client.js} +0 -4
- package/dist/src/http-client.js.map +1 -0
- package/dist/src/logger.js.map +1 -0
- package/dist/src/main.js.map +1 -0
- package/dist/src/middleware/index.d.ts +2 -0
- package/dist/src/middleware/index.js +12 -0
- package/dist/src/middleware/index.js.map +1 -0
- package/dist/src/middleware/oauth-auth.d.ts +4 -0
- package/dist/src/middleware/oauth-auth.js +119 -0
- package/dist/src/middleware/oauth-auth.js.map +1 -0
- package/dist/src/middleware/rate-limiter.d.ts +11 -0
- package/dist/src/middleware/rate-limiter.js +145 -0
- package/dist/src/middleware/rate-limiter.js.map +1 -0
- package/dist/src/oauth/config.d.ts +19 -0
- package/dist/src/oauth/config.js +70 -0
- package/dist/src/oauth/config.js.map +1 -0
- package/dist/src/oauth/endpoints/authorize.d.ts +3 -0
- package/dist/src/oauth/endpoints/authorize.js +454 -0
- package/dist/src/oauth/endpoints/authorize.js.map +1 -0
- package/dist/src/oauth/endpoints/callback.d.ts +2 -0
- package/dist/src/oauth/endpoints/callback.js +129 -0
- package/dist/src/oauth/endpoints/callback.js.map +1 -0
- package/dist/src/oauth/endpoints/index.d.ts +5 -0
- package/dist/src/oauth/endpoints/index.js +20 -0
- package/dist/src/oauth/endpoints/index.js.map +1 -0
- package/dist/src/oauth/endpoints/metadata.d.ts +5 -0
- package/dist/src/oauth/endpoints/metadata.js +48 -0
- package/dist/src/oauth/endpoints/metadata.js.map +1 -0
- package/dist/src/oauth/endpoints/register.d.ts +15 -0
- package/dist/src/oauth/endpoints/register.js +85 -0
- package/dist/src/oauth/endpoints/register.js.map +1 -0
- package/dist/src/oauth/endpoints/token.d.ts +2 -0
- package/dist/src/oauth/endpoints/token.js +159 -0
- package/dist/src/oauth/endpoints/token.js.map +1 -0
- package/dist/src/oauth/gitlab-device-flow.d.ts +10 -0
- package/dist/src/oauth/gitlab-device-flow.js +215 -0
- package/dist/src/oauth/gitlab-device-flow.js.map +1 -0
- package/dist/src/oauth/index.d.ts +10 -0
- package/dist/src/oauth/index.js +65 -0
- package/dist/src/oauth/index.js.map +1 -0
- package/dist/src/oauth/session-store.d.ts +54 -0
- package/dist/src/oauth/session-store.js +302 -0
- package/dist/src/oauth/session-store.js.map +1 -0
- package/dist/src/oauth/storage/factory.d.ts +4 -0
- package/dist/src/oauth/storage/factory.js +75 -0
- package/dist/src/oauth/storage/factory.js.map +1 -0
- package/dist/src/oauth/storage/file.d.ts +50 -0
- package/dist/src/oauth/storage/file.js +287 -0
- package/dist/src/oauth/storage/file.js.map +1 -0
- package/dist/src/oauth/storage/index.d.ts +5 -0
- package/dist/src/oauth/storage/index.js +22 -0
- package/dist/src/oauth/storage/index.js.map +1 -0
- package/dist/src/oauth/storage/memory.d.ts +76 -0
- package/dist/src/oauth/storage/memory.js +277 -0
- package/dist/src/oauth/storage/memory.js.map +1 -0
- package/dist/src/oauth/storage/postgresql.d.ts +41 -0
- package/dist/src/oauth/storage/postgresql.js +435 -0
- package/dist/src/oauth/storage/postgresql.js.map +1 -0
- package/dist/src/oauth/storage/types.d.ts +67 -0
- package/dist/src/oauth/storage/types.js +5 -0
- package/dist/src/oauth/storage/types.js.map +1 -0
- package/dist/src/oauth/token-context.d.ts +8 -0
- package/dist/src/oauth/token-context.js +40 -0
- package/dist/src/oauth/token-context.js.map +1 -0
- package/dist/src/oauth/token-utils.d.ts +14 -0
- package/dist/src/oauth/token-utils.js +148 -0
- package/dist/src/oauth/token-utils.js.map +1 -0
- package/dist/src/oauth/types.d.ts +104 -0
- package/dist/src/oauth/types.js +3 -0
- package/dist/src/oauth/types.js.map +1 -0
- package/dist/src/registry-manager.js.map +1 -0
- package/dist/{server.d.ts → src/server.d.ts} +11 -0
- package/dist/src/server.js +444 -0
- package/dist/src/server.js.map +1 -0
- package/dist/{services → src/services}/ConnectionManager.d.ts +2 -0
- package/dist/{services → src/services}/ConnectionManager.js +99 -7
- package/dist/src/services/ConnectionManager.js.map +1 -0
- package/dist/src/services/GitLabVersionDetector.js.map +1 -0
- package/dist/src/services/SchemaIntrospector.js.map +1 -0
- package/dist/{services → src/services}/ToolAvailability.js +3 -4
- package/dist/src/services/ToolAvailability.js.map +1 -0
- package/dist/src/services/WidgetAvailability.js.map +1 -0
- package/dist/src/types.js.map +1 -0
- package/dist/src/utils/fetch.d.ts +5 -0
- package/dist/{utils → src/utils}/fetch.js +89 -52
- package/dist/src/utils/fetch.js.map +1 -0
- package/dist/src/utils/gitlab-api.d.ts +21 -0
- package/dist/src/utils/gitlab-api.js +132 -0
- package/dist/src/utils/gitlab-api.js.map +1 -0
- package/dist/src/utils/idConversion.js.map +1 -0
- package/dist/{utils → src/utils}/namespace.js +1 -5
- package/dist/src/utils/namespace.js.map +1 -0
- package/dist/src/utils/projectIdentifier.js.map +1 -0
- package/dist/{utils → src/utils}/smart-user-search.js +1 -5
- package/dist/src/utils/smart-user-search.js.map +1 -0
- package/dist/src/utils/workItemTypes.js.map +1 -0
- package/dist/structured-world-gitlab-mcp-6.0.0.tgz +0 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/package.json +34 -31
- package/dist/config.js.map +0 -1
- package/dist/entities/core/index.js.map +0 -1
- package/dist/entities/core/registry.js +0 -778
- package/dist/entities/core/registry.js.map +0 -1
- package/dist/entities/core/schema-readonly.d.ts +0 -547
- package/dist/entities/core/schema-readonly.js +0 -471
- package/dist/entities/core/schema-readonly.js.map +0 -1
- package/dist/entities/core/schema.d.ts +0 -210
- package/dist/entities/core/schema.js +0 -230
- package/dist/entities/core/schema.js.map +0 -1
- package/dist/entities/files/index.js.map +0 -1
- package/dist/entities/files/registry.js +0 -207
- package/dist/entities/files/registry.js.map +0 -1
- package/dist/entities/files/schema-readonly.d.ts +0 -178
- package/dist/entities/files/schema-readonly.js.map +0 -1
- package/dist/entities/files/schema.d.ts +0 -107
- package/dist/entities/files/schema.js +0 -38
- package/dist/entities/files/schema.js.map +0 -1
- package/dist/entities/index.js.map +0 -1
- package/dist/entities/labels/index.js.map +0 -1
- package/dist/entities/labels/registry.js +0 -176
- package/dist/entities/labels/registry.js.map +0 -1
- package/dist/entities/labels/schema-readonly.d.ts +0 -32
- package/dist/entities/labels/schema-readonly.js.map +0 -1
- package/dist/entities/labels/schema.d.ts +0 -55
- package/dist/entities/labels/schema.js.map +0 -1
- package/dist/entities/milestones/index.js.map +0 -1
- package/dist/entities/milestones/registry.js +0 -300
- package/dist/entities/milestones/registry.js.map +0 -1
- package/dist/entities/milestones/schema-readonly.d.ts +0 -138
- package/dist/entities/milestones/schema-readonly.js.map +0 -1
- package/dist/entities/milestones/schema.d.ts +0 -69
- package/dist/entities/milestones/schema.js.map +0 -1
- package/dist/entities/mrs/index.js.map +0 -1
- package/dist/entities/mrs/registry.js.map +0 -1
- package/dist/entities/mrs/schema-readonly.d.ts +0 -302
- package/dist/entities/mrs/schema-readonly.js.map +0 -1
- package/dist/entities/mrs/schema.d.ts +0 -1028
- package/dist/entities/mrs/schema.js.map +0 -1
- package/dist/entities/pipelines/index.js.map +0 -1
- package/dist/entities/pipelines/registry.js.map +0 -1
- package/dist/entities/pipelines/schema-readonly.d.ts +0 -648
- package/dist/entities/pipelines/schema-readonly.js.map +0 -1
- package/dist/entities/pipelines/schema.d.ts +0 -123
- package/dist/entities/pipelines/schema.js.map +0 -1
- package/dist/entities/shared.d.ts +0 -968
- package/dist/entities/shared.js.map +0 -1
- package/dist/entities/utils.d.ts +0 -3
- package/dist/entities/utils.js.map +0 -1
- package/dist/entities/variables/index.js.map +0 -1
- package/dist/entities/variables/registry.js +0 -308
- package/dist/entities/variables/registry.js.map +0 -1
- package/dist/entities/variables/schema-readonly.d.ts +0 -40
- package/dist/entities/variables/schema-readonly.js.map +0 -1
- package/dist/entities/variables/schema.d.ts +0 -102
- package/dist/entities/variables/schema.js.map +0 -1
- package/dist/entities/wiki/index.js.map +0 -1
- package/dist/entities/wiki/registry.js +0 -173
- package/dist/entities/wiki/registry.js.map +0 -1
- package/dist/entities/wiki/schema-readonly.d.ts +0 -53
- package/dist/entities/wiki/schema-readonly.js.map +0 -1
- package/dist/entities/wiki/schema.js.map +0 -1
- package/dist/entities/workitems/index.js.map +0 -1
- package/dist/entities/workitems/registry.js.map +0 -1
- package/dist/entities/workitems/schema-readonly.d.ts +0 -49
- package/dist/entities/workitems/schema-readonly.js.map +0 -1
- package/dist/entities/workitems/schema.d.ts +0 -61
- package/dist/entities/workitems/schema.js.map +0 -1
- package/dist/graphql/DynamicWorkItemsQuery.js.map +0 -1
- package/dist/graphql/client.js.map +0 -1
- package/dist/graphql/index.js.map +0 -1
- package/dist/graphql/workItems.js.map +0 -1
- package/dist/handlers.js.map +0 -1
- package/dist/http-client.js.map +0 -1
- package/dist/logger.js.map +0 -1
- package/dist/main.js.map +0 -1
- package/dist/registry-manager.js.map +0 -1
- package/dist/server.js +0 -202
- package/dist/server.js.map +0 -1
- package/dist/services/ConnectionManager.js.map +0 -1
- package/dist/services/GitLabVersionDetector.js.map +0 -1
- package/dist/services/SchemaIntrospector.js.map +0 -1
- package/dist/services/ToolAvailability.js.map +0 -1
- package/dist/services/WidgetAvailability.js.map +0 -1
- package/dist/structured-world-gitlab-mcp-5.7.0.tgz +0 -0
- package/dist/types.js.map +0 -1
- package/dist/utils/fetch.d.ts +0 -9
- package/dist/utils/fetch.js.map +0 -1
- package/dist/utils/idConversion.js.map +0 -1
- package/dist/utils/namespace.js.map +0 -1
- package/dist/utils/projectIdentifier.js.map +0 -1
- package/dist/utils/smart-user-search.js.map +0 -1
- package/dist/utils/workItemTypes.js.map +0 -1
- /package/dist/{entities → src/entities}/core/index.d.ts +0 -0
- /package/dist/{entities → src/entities}/core/index.js +0 -0
- /package/dist/{entities → src/entities}/core/registry.d.ts +0 -0
- /package/dist/{entities → src/entities}/files/index.d.ts +0 -0
- /package/dist/{entities → src/entities}/files/index.js +0 -0
- /package/dist/{entities → src/entities}/files/registry.d.ts +0 -0
- /package/dist/{entities → src/entities}/index.d.ts +0 -0
- /package/dist/{entities → src/entities}/index.js +0 -0
- /package/dist/{entities → src/entities}/labels/index.d.ts +0 -0
- /package/dist/{entities → src/entities}/labels/index.js +0 -0
- /package/dist/{entities → src/entities}/labels/registry.d.ts +0 -0
- /package/dist/{entities → src/entities}/labels/schema-readonly.js +0 -0
- /package/dist/{entities → src/entities}/labels/schema.js +0 -0
- /package/dist/{entities → src/entities}/milestones/index.d.ts +0 -0
- /package/dist/{entities → src/entities}/milestones/index.js +0 -0
- /package/dist/{entities → src/entities}/milestones/registry.d.ts +0 -0
- /package/dist/{entities → src/entities}/milestones/schema-readonly.js +0 -0
- /package/dist/{entities → src/entities}/milestones/schema.js +0 -0
- /package/dist/{entities → src/entities}/mrs/index.d.ts +0 -0
- /package/dist/{entities → src/entities}/mrs/index.js +0 -0
- /package/dist/{entities → src/entities}/mrs/registry.d.ts +0 -0
- /package/dist/{entities → src/entities}/mrs/schema-readonly.js +0 -0
- /package/dist/{entities → src/entities}/mrs/schema.js +0 -0
- /package/dist/{entities → src/entities}/pipelines/index.d.ts +0 -0
- /package/dist/{entities → src/entities}/pipelines/index.js +0 -0
- /package/dist/{entities → src/entities}/pipelines/registry.d.ts +0 -0
- /package/dist/{entities → src/entities}/pipelines/schema-readonly.js +0 -0
- /package/dist/{entities → src/entities}/pipelines/schema.js +0 -0
- /package/dist/{entities → src/entities}/shared.js +0 -0
- /package/dist/{entities → src/entities}/utils.js +0 -0
- /package/dist/{entities → src/entities}/variables/index.d.ts +0 -0
- /package/dist/{entities → src/entities}/variables/index.js +0 -0
- /package/dist/{entities → src/entities}/variables/registry.d.ts +0 -0
- /package/dist/{entities → src/entities}/variables/schema-readonly.js +0 -0
- /package/dist/{entities → src/entities}/variables/schema.js +0 -0
- /package/dist/{entities → src/entities}/wiki/index.d.ts +0 -0
- /package/dist/{entities → src/entities}/wiki/index.js +0 -0
- /package/dist/{entities → src/entities}/wiki/registry.d.ts +0 -0
- /package/dist/{entities → src/entities}/wiki/schema-readonly.js +0 -0
- /package/dist/{entities → src/entities}/wiki/schema.js +0 -0
- /package/dist/{entities → src/entities}/workitems/index.d.ts +0 -0
- /package/dist/{entities → src/entities}/workitems/index.js +0 -0
- /package/dist/{entities → src/entities}/workitems/registry.d.ts +0 -0
- /package/dist/{entities → src/entities}/workitems/schema.js +0 -0
- /package/dist/{graphql → src/graphql}/DynamicWorkItemsQuery.d.ts +0 -0
- /package/dist/{graphql → src/graphql}/DynamicWorkItemsQuery.js +0 -0
- /package/dist/{graphql → src/graphql}/client.d.ts +0 -0
- /package/dist/{graphql → src/graphql}/client.js +0 -0
- /package/dist/{graphql → src/graphql}/index.d.ts +0 -0
- /package/dist/{graphql → src/graphql}/index.js +0 -0
- /package/dist/{graphql → src/graphql}/workItems.d.ts +0 -0
- /package/dist/{graphql → src/graphql}/workItems.js +0 -0
- /package/dist/{handlers.d.ts → src/handlers.d.ts} +0 -0
- /package/dist/{http-client.d.ts → src/http-client.d.ts} +0 -0
- /package/dist/{logger.d.ts → src/logger.d.ts} +0 -0
- /package/dist/{logger.js → src/logger.js} +0 -0
- /package/dist/{main.d.ts → src/main.d.ts} +0 -0
- /package/dist/{main.js → src/main.js} +0 -0
- /package/dist/{registry-manager.d.ts → src/registry-manager.d.ts} +0 -0
- /package/dist/{registry-manager.js → src/registry-manager.js} +0 -0
- /package/dist/{services → src/services}/GitLabVersionDetector.d.ts +0 -0
- /package/dist/{services → src/services}/GitLabVersionDetector.js +0 -0
- /package/dist/{services → src/services}/SchemaIntrospector.d.ts +0 -0
- /package/dist/{services → src/services}/SchemaIntrospector.js +0 -0
- /package/dist/{services → src/services}/ToolAvailability.d.ts +0 -0
- /package/dist/{services → src/services}/WidgetAvailability.d.ts +0 -0
- /package/dist/{services → src/services}/WidgetAvailability.js +0 -0
- /package/dist/{types.d.ts → src/types.d.ts} +0 -0
- /package/dist/{types.js → src/types.js} +0 -0
- /package/dist/{utils → src/utils}/idConversion.d.ts +0 -0
- /package/dist/{utils → src/utils}/idConversion.js +0 -0
- /package/dist/{utils → src/utils}/namespace.d.ts +0 -0
- /package/dist/{utils → src/utils}/projectIdentifier.d.ts +0 -0
- /package/dist/{utils → src/utils}/projectIdentifier.js +0 -0
- /package/dist/{utils → src/utils}/smart-user-search.d.ts +0 -0
- /package/dist/{utils → src/utils}/workItemTypes.d.ts +0 -0
- /package/dist/{utils → src/utils}/workItemTypes.js +0 -0
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.tokenHandler = exports.callbackHandler = exports.pollHandler = exports.authorizeHandler = exports.getBaseUrl = exports.protectedResourceHandler = exports.healthHandler = exports.metadataHandler = exports.buildGitLabAuthUrl = exports.exchangeGitLabAuthCode = exports.validateGitLabToken = exports.getGitLabUser = exports.refreshGitLabToken = exports.pollForToken = exports.pollDeviceFlowOnce = exports.initiateDeviceFlow = exports.calculateTokenExpiry = exports.isTokenExpiringSoon = exports.generateRefreshToken = exports.generateSessionId = exports.generateAuthorizationCode = exports.generateUUID = exports.generateRandomString = exports.verifyCodeChallenge = exports.generateCodeChallenge = exports.generateCodeVerifier = exports.verifyMCPToken = exports.verifyJWT = exports.createJWT = exports.isInOAuthContext = exports.getSessionIdFromContext = exports.getGitLabUsernameFromContext = exports.getGitLabUserIdFromContext = exports.getGitLabTokenFromContext = exports.getTokenContext = exports.runWithTokenContext = exports.STORAGE_DATA_VERSION = exports.PostgreSQLStorageBackend = exports.FileStorageBackend = exports.MemoryStorageBackend = exports.validateStorageConfig = exports.getStorageType = exports.createStorageBackend = exports.SessionStore = exports.sessionStore = exports.resetOAuthConfigCache = exports.getAuthModeDescription = exports.isOAuthEnabled = exports.validateStaticConfig = exports.loadOAuthConfig = void 0;
|
|
4
|
+
exports.isValidRedirectUri = exports.getRegisteredClient = exports.registerHandler = void 0;
|
|
5
|
+
var config_1 = require("./config");
|
|
6
|
+
Object.defineProperty(exports, "loadOAuthConfig", { enumerable: true, get: function () { return config_1.loadOAuthConfig; } });
|
|
7
|
+
Object.defineProperty(exports, "validateStaticConfig", { enumerable: true, get: function () { return config_1.validateStaticConfig; } });
|
|
8
|
+
Object.defineProperty(exports, "isOAuthEnabled", { enumerable: true, get: function () { return config_1.isOAuthEnabled; } });
|
|
9
|
+
Object.defineProperty(exports, "getAuthModeDescription", { enumerable: true, get: function () { return config_1.getAuthModeDescription; } });
|
|
10
|
+
Object.defineProperty(exports, "resetOAuthConfigCache", { enumerable: true, get: function () { return config_1.resetOAuthConfigCache; } });
|
|
11
|
+
var session_store_1 = require("./session-store");
|
|
12
|
+
Object.defineProperty(exports, "sessionStore", { enumerable: true, get: function () { return session_store_1.sessionStore; } });
|
|
13
|
+
Object.defineProperty(exports, "SessionStore", { enumerable: true, get: function () { return session_store_1.SessionStore; } });
|
|
14
|
+
var storage_1 = require("./storage");
|
|
15
|
+
Object.defineProperty(exports, "createStorageBackend", { enumerable: true, get: function () { return storage_1.createStorageBackend; } });
|
|
16
|
+
Object.defineProperty(exports, "getStorageType", { enumerable: true, get: function () { return storage_1.getStorageType; } });
|
|
17
|
+
Object.defineProperty(exports, "validateStorageConfig", { enumerable: true, get: function () { return storage_1.validateStorageConfig; } });
|
|
18
|
+
Object.defineProperty(exports, "MemoryStorageBackend", { enumerable: true, get: function () { return storage_1.MemoryStorageBackend; } });
|
|
19
|
+
Object.defineProperty(exports, "FileStorageBackend", { enumerable: true, get: function () { return storage_1.FileStorageBackend; } });
|
|
20
|
+
Object.defineProperty(exports, "PostgreSQLStorageBackend", { enumerable: true, get: function () { return storage_1.PostgreSQLStorageBackend; } });
|
|
21
|
+
Object.defineProperty(exports, "STORAGE_DATA_VERSION", { enumerable: true, get: function () { return storage_1.STORAGE_DATA_VERSION; } });
|
|
22
|
+
var token_context_1 = require("./token-context");
|
|
23
|
+
Object.defineProperty(exports, "runWithTokenContext", { enumerable: true, get: function () { return token_context_1.runWithTokenContext; } });
|
|
24
|
+
Object.defineProperty(exports, "getTokenContext", { enumerable: true, get: function () { return token_context_1.getTokenContext; } });
|
|
25
|
+
Object.defineProperty(exports, "getGitLabTokenFromContext", { enumerable: true, get: function () { return token_context_1.getGitLabTokenFromContext; } });
|
|
26
|
+
Object.defineProperty(exports, "getGitLabUserIdFromContext", { enumerable: true, get: function () { return token_context_1.getGitLabUserIdFromContext; } });
|
|
27
|
+
Object.defineProperty(exports, "getGitLabUsernameFromContext", { enumerable: true, get: function () { return token_context_1.getGitLabUsernameFromContext; } });
|
|
28
|
+
Object.defineProperty(exports, "getSessionIdFromContext", { enumerable: true, get: function () { return token_context_1.getSessionIdFromContext; } });
|
|
29
|
+
Object.defineProperty(exports, "isInOAuthContext", { enumerable: true, get: function () { return token_context_1.isInOAuthContext; } });
|
|
30
|
+
var token_utils_1 = require("./token-utils");
|
|
31
|
+
Object.defineProperty(exports, "createJWT", { enumerable: true, get: function () { return token_utils_1.createJWT; } });
|
|
32
|
+
Object.defineProperty(exports, "verifyJWT", { enumerable: true, get: function () { return token_utils_1.verifyJWT; } });
|
|
33
|
+
Object.defineProperty(exports, "verifyMCPToken", { enumerable: true, get: function () { return token_utils_1.verifyMCPToken; } });
|
|
34
|
+
Object.defineProperty(exports, "generateCodeVerifier", { enumerable: true, get: function () { return token_utils_1.generateCodeVerifier; } });
|
|
35
|
+
Object.defineProperty(exports, "generateCodeChallenge", { enumerable: true, get: function () { return token_utils_1.generateCodeChallenge; } });
|
|
36
|
+
Object.defineProperty(exports, "verifyCodeChallenge", { enumerable: true, get: function () { return token_utils_1.verifyCodeChallenge; } });
|
|
37
|
+
Object.defineProperty(exports, "generateRandomString", { enumerable: true, get: function () { return token_utils_1.generateRandomString; } });
|
|
38
|
+
Object.defineProperty(exports, "generateUUID", { enumerable: true, get: function () { return token_utils_1.generateUUID; } });
|
|
39
|
+
Object.defineProperty(exports, "generateAuthorizationCode", { enumerable: true, get: function () { return token_utils_1.generateAuthorizationCode; } });
|
|
40
|
+
Object.defineProperty(exports, "generateSessionId", { enumerable: true, get: function () { return token_utils_1.generateSessionId; } });
|
|
41
|
+
Object.defineProperty(exports, "generateRefreshToken", { enumerable: true, get: function () { return token_utils_1.generateRefreshToken; } });
|
|
42
|
+
Object.defineProperty(exports, "isTokenExpiringSoon", { enumerable: true, get: function () { return token_utils_1.isTokenExpiringSoon; } });
|
|
43
|
+
Object.defineProperty(exports, "calculateTokenExpiry", { enumerable: true, get: function () { return token_utils_1.calculateTokenExpiry; } });
|
|
44
|
+
var gitlab_device_flow_1 = require("./gitlab-device-flow");
|
|
45
|
+
Object.defineProperty(exports, "initiateDeviceFlow", { enumerable: true, get: function () { return gitlab_device_flow_1.initiateDeviceFlow; } });
|
|
46
|
+
Object.defineProperty(exports, "pollDeviceFlowOnce", { enumerable: true, get: function () { return gitlab_device_flow_1.pollDeviceFlowOnce; } });
|
|
47
|
+
Object.defineProperty(exports, "pollForToken", { enumerable: true, get: function () { return gitlab_device_flow_1.pollForToken; } });
|
|
48
|
+
Object.defineProperty(exports, "refreshGitLabToken", { enumerable: true, get: function () { return gitlab_device_flow_1.refreshGitLabToken; } });
|
|
49
|
+
Object.defineProperty(exports, "getGitLabUser", { enumerable: true, get: function () { return gitlab_device_flow_1.getGitLabUser; } });
|
|
50
|
+
Object.defineProperty(exports, "validateGitLabToken", { enumerable: true, get: function () { return gitlab_device_flow_1.validateGitLabToken; } });
|
|
51
|
+
Object.defineProperty(exports, "exchangeGitLabAuthCode", { enumerable: true, get: function () { return gitlab_device_flow_1.exchangeGitLabAuthCode; } });
|
|
52
|
+
Object.defineProperty(exports, "buildGitLabAuthUrl", { enumerable: true, get: function () { return gitlab_device_flow_1.buildGitLabAuthUrl; } });
|
|
53
|
+
var index_1 = require("./endpoints/index");
|
|
54
|
+
Object.defineProperty(exports, "metadataHandler", { enumerable: true, get: function () { return index_1.metadataHandler; } });
|
|
55
|
+
Object.defineProperty(exports, "healthHandler", { enumerable: true, get: function () { return index_1.healthHandler; } });
|
|
56
|
+
Object.defineProperty(exports, "protectedResourceHandler", { enumerable: true, get: function () { return index_1.protectedResourceHandler; } });
|
|
57
|
+
Object.defineProperty(exports, "getBaseUrl", { enumerable: true, get: function () { return index_1.getBaseUrl; } });
|
|
58
|
+
Object.defineProperty(exports, "authorizeHandler", { enumerable: true, get: function () { return index_1.authorizeHandler; } });
|
|
59
|
+
Object.defineProperty(exports, "pollHandler", { enumerable: true, get: function () { return index_1.pollHandler; } });
|
|
60
|
+
Object.defineProperty(exports, "callbackHandler", { enumerable: true, get: function () { return index_1.callbackHandler; } });
|
|
61
|
+
Object.defineProperty(exports, "tokenHandler", { enumerable: true, get: function () { return index_1.tokenHandler; } });
|
|
62
|
+
Object.defineProperty(exports, "registerHandler", { enumerable: true, get: function () { return index_1.registerHandler; } });
|
|
63
|
+
Object.defineProperty(exports, "getRegisteredClient", { enumerable: true, get: function () { return index_1.getRegisteredClient; } });
|
|
64
|
+
Object.defineProperty(exports, "isValidRedirectUri", { enumerable: true, get: function () { return index_1.isValidRedirectUri; } });
|
|
65
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/oauth/index.ts"],"names":[],"mappings":";;;;AAQA,mCAMkB;AALhB,yGAAA,eAAe,OAAA;AACf,8GAAA,oBAAoB,OAAA;AACpB,wGAAA,cAAc,OAAA;AACd,gHAAA,sBAAsB,OAAA;AACtB,+GAAA,qBAAqB,OAAA;AAsBvB,iDAA6D;AAApD,6GAAA,YAAY,OAAA;AAAE,6GAAA,YAAY,OAAA;AAGnC,qCAQmB;AAPjB,+GAAA,oBAAoB,OAAA;AACpB,yGAAA,cAAc,OAAA;AACd,gHAAA,qBAAqB,OAAA;AACrB,+GAAA,oBAAoB,OAAA;AACpB,6GAAA,kBAAkB,OAAA;AAClB,mHAAA,wBAAwB,OAAA;AACxB,+GAAA,oBAAoB,OAAA;AAUtB,iDAQyB;AAPvB,oHAAA,mBAAmB,OAAA;AACnB,gHAAA,eAAe,OAAA;AACf,0HAAA,yBAAyB,OAAA;AACzB,2HAAA,0BAA0B,OAAA;AAC1B,6HAAA,4BAA4B,OAAA;AAC5B,wHAAA,uBAAuB,OAAA;AACvB,iHAAA,gBAAgB,OAAA;AAIlB,6CAcuB;AAbrB,wGAAA,SAAS,OAAA;AACT,wGAAA,SAAS,OAAA;AACT,6GAAA,cAAc,OAAA;AACd,mHAAA,oBAAoB,OAAA;AACpB,oHAAA,qBAAqB,OAAA;AACrB,kHAAA,mBAAmB,OAAA;AACnB,mHAAA,oBAAoB,OAAA;AACpB,2GAAA,YAAY,OAAA;AACZ,wHAAA,yBAAyB,OAAA;AACzB,gHAAA,iBAAiB,OAAA;AACjB,mHAAA,oBAAoB,OAAA;AACpB,kHAAA,mBAAmB,OAAA;AACnB,mHAAA,oBAAoB,OAAA;AAItB,2DAS8B;AAR5B,wHAAA,kBAAkB,OAAA;AAClB,wHAAA,kBAAkB,OAAA;AAClB,kHAAA,YAAY,OAAA;AACZ,wHAAA,kBAAkB,OAAA;AAClB,mHAAA,aAAa,OAAA;AACb,yHAAA,mBAAmB,OAAA;AACnB,4HAAA,sBAAsB,OAAA;AACtB,wHAAA,kBAAkB,OAAA;AAIpB,2CAY2B;AAXzB,wGAAA,eAAe,OAAA;AACf,sGAAA,aAAa,OAAA;AACb,iHAAA,wBAAwB,OAAA;AACxB,mGAAA,UAAU,OAAA;AACV,yGAAA,gBAAgB,OAAA;AAChB,oGAAA,WAAW,OAAA;AACX,wGAAA,eAAe,OAAA;AACf,qGAAA,YAAY,OAAA;AACZ,wGAAA,eAAe,OAAA;AACf,4GAAA,mBAAmB,OAAA;AACnB,2GAAA,kBAAkB,OAAA"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { OAuthSession, DeviceFlowState, AuthorizationCode, AuthCodeFlowState } from "./types";
|
|
2
|
+
import { SessionStorageBackend } from "./storage";
|
|
3
|
+
export declare class SessionStore {
|
|
4
|
+
private backend;
|
|
5
|
+
private initialized;
|
|
6
|
+
private sessions;
|
|
7
|
+
private deviceFlows;
|
|
8
|
+
private authCodeFlows;
|
|
9
|
+
private authCodes;
|
|
10
|
+
private tokenToSession;
|
|
11
|
+
private refreshTokenToSession;
|
|
12
|
+
private mcpSessionToOAuthSession;
|
|
13
|
+
private cleanupIntervalId;
|
|
14
|
+
constructor(backend?: SessionStorageBackend);
|
|
15
|
+
initialize(): Promise<void>;
|
|
16
|
+
getBackendType(): string;
|
|
17
|
+
createSession(session: OAuthSession): void;
|
|
18
|
+
getSession(sessionId: string): OAuthSession | undefined;
|
|
19
|
+
getSessionByToken(token: string): OAuthSession | undefined;
|
|
20
|
+
getSessionByRefreshToken(refreshToken: string): OAuthSession | undefined;
|
|
21
|
+
updateSession(sessionId: string, updates: Partial<OAuthSession>): boolean;
|
|
22
|
+
deleteSession(sessionId: string): boolean;
|
|
23
|
+
getAllSessions(): IterableIterator<OAuthSession>;
|
|
24
|
+
getSessionCount(): number;
|
|
25
|
+
storeDeviceFlow(state: string, flow: DeviceFlowState): void;
|
|
26
|
+
getDeviceFlow(state: string): DeviceFlowState | undefined;
|
|
27
|
+
getDeviceFlowByDeviceCode(deviceCode: string): DeviceFlowState | undefined;
|
|
28
|
+
deleteDeviceFlow(state: string): boolean;
|
|
29
|
+
getDeviceFlowCount(): number;
|
|
30
|
+
storeAuthCodeFlow(internalState: string, flow: AuthCodeFlowState): void;
|
|
31
|
+
getAuthCodeFlow(internalState: string): AuthCodeFlowState | undefined;
|
|
32
|
+
deleteAuthCodeFlow(internalState: string): boolean;
|
|
33
|
+
getAuthCodeFlowCount(): number;
|
|
34
|
+
storeAuthCode(code: AuthorizationCode): void;
|
|
35
|
+
getAuthCode(code: string): AuthorizationCode | undefined;
|
|
36
|
+
deleteAuthCode(code: string): boolean;
|
|
37
|
+
getAuthCodeCount(): number;
|
|
38
|
+
associateMcpSession(mcpSessionId: string, oauthSessionId: string): void;
|
|
39
|
+
getSessionByMcpSessionId(mcpSessionId: string): OAuthSession | undefined;
|
|
40
|
+
getGitLabTokenByMcpSessionId(mcpSessionId: string): string | undefined;
|
|
41
|
+
removeMcpSessionAssociation(mcpSessionId: string): boolean;
|
|
42
|
+
cleanup(): void;
|
|
43
|
+
private startCleanupInterval;
|
|
44
|
+
stopCleanupInterval(): void;
|
|
45
|
+
clear(): void;
|
|
46
|
+
close(): Promise<void>;
|
|
47
|
+
getStats(): {
|
|
48
|
+
sessions: number;
|
|
49
|
+
deviceFlows: number;
|
|
50
|
+
authCodeFlows: number;
|
|
51
|
+
authCodes: number;
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
export declare const sessionStore: SessionStore;
|
|
@@ -0,0 +1,302 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.sessionStore = exports.SessionStore = void 0;
|
|
4
|
+
const storage_1 = require("./storage");
|
|
5
|
+
const logger_1 = require("../logger");
|
|
6
|
+
class SessionStore {
|
|
7
|
+
backend;
|
|
8
|
+
initialized = false;
|
|
9
|
+
sessions = new Map();
|
|
10
|
+
deviceFlows = new Map();
|
|
11
|
+
authCodeFlows = new Map();
|
|
12
|
+
authCodes = new Map();
|
|
13
|
+
tokenToSession = new Map();
|
|
14
|
+
refreshTokenToSession = new Map();
|
|
15
|
+
mcpSessionToOAuthSession = new Map();
|
|
16
|
+
cleanupIntervalId = null;
|
|
17
|
+
constructor(backend) {
|
|
18
|
+
this.backend = backend ?? (0, storage_1.createStorageBackend)();
|
|
19
|
+
}
|
|
20
|
+
async initialize() {
|
|
21
|
+
if (this.initialized)
|
|
22
|
+
return;
|
|
23
|
+
await this.backend.initialize();
|
|
24
|
+
if (this.backend.type !== "memory") {
|
|
25
|
+
const sessions = await this.backend.getAllSessions();
|
|
26
|
+
for (const session of sessions) {
|
|
27
|
+
this.sessions.set(session.id, session);
|
|
28
|
+
if (session.mcpAccessToken) {
|
|
29
|
+
this.tokenToSession.set(session.mcpAccessToken, session.id);
|
|
30
|
+
}
|
|
31
|
+
if (session.mcpRefreshToken) {
|
|
32
|
+
this.refreshTokenToSession.set(session.mcpRefreshToken, session.id);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
logger_1.logger.info({ loadedSessions: sessions.length }, "Loaded sessions from storage backend");
|
|
36
|
+
}
|
|
37
|
+
this.startCleanupInterval();
|
|
38
|
+
this.initialized = true;
|
|
39
|
+
logger_1.logger.info({ backendType: this.backend.type }, "Session store initialized");
|
|
40
|
+
}
|
|
41
|
+
getBackendType() {
|
|
42
|
+
return this.backend.type;
|
|
43
|
+
}
|
|
44
|
+
createSession(session) {
|
|
45
|
+
this.sessions.set(session.id, session);
|
|
46
|
+
if (session.mcpAccessToken) {
|
|
47
|
+
this.tokenToSession.set(session.mcpAccessToken, session.id);
|
|
48
|
+
}
|
|
49
|
+
if (session.mcpRefreshToken) {
|
|
50
|
+
this.refreshTokenToSession.set(session.mcpRefreshToken, session.id);
|
|
51
|
+
}
|
|
52
|
+
this.backend.createSession(session).catch(err => {
|
|
53
|
+
logger_1.logger.error({ err, sessionId: session.id }, "Failed to persist session to backend");
|
|
54
|
+
});
|
|
55
|
+
logger_1.logger.debug({ sessionId: session.id, userId: session.gitlabUserId }, "Session created");
|
|
56
|
+
}
|
|
57
|
+
getSession(sessionId) {
|
|
58
|
+
return this.sessions.get(sessionId);
|
|
59
|
+
}
|
|
60
|
+
getSessionByToken(token) {
|
|
61
|
+
const sessionId = this.tokenToSession.get(token);
|
|
62
|
+
return sessionId ? this.sessions.get(sessionId) : undefined;
|
|
63
|
+
}
|
|
64
|
+
getSessionByRefreshToken(refreshToken) {
|
|
65
|
+
const sessionId = this.refreshTokenToSession.get(refreshToken);
|
|
66
|
+
return sessionId ? this.sessions.get(sessionId) : undefined;
|
|
67
|
+
}
|
|
68
|
+
updateSession(sessionId, updates) {
|
|
69
|
+
const session = this.sessions.get(sessionId);
|
|
70
|
+
if (!session) {
|
|
71
|
+
logger_1.logger.warn({ sessionId }, "Attempted to update non-existent session");
|
|
72
|
+
return false;
|
|
73
|
+
}
|
|
74
|
+
if (updates.mcpAccessToken && updates.mcpAccessToken !== session.mcpAccessToken) {
|
|
75
|
+
this.tokenToSession.delete(session.mcpAccessToken);
|
|
76
|
+
this.tokenToSession.set(updates.mcpAccessToken, sessionId);
|
|
77
|
+
}
|
|
78
|
+
if (updates.mcpRefreshToken && updates.mcpRefreshToken !== session.mcpRefreshToken) {
|
|
79
|
+
this.refreshTokenToSession.delete(session.mcpRefreshToken);
|
|
80
|
+
this.refreshTokenToSession.set(updates.mcpRefreshToken, sessionId);
|
|
81
|
+
}
|
|
82
|
+
Object.assign(session, updates, { updatedAt: Date.now() });
|
|
83
|
+
this.backend.updateSession(sessionId, updates).catch(err => {
|
|
84
|
+
logger_1.logger.error({ err, sessionId }, "Failed to update session in backend");
|
|
85
|
+
});
|
|
86
|
+
logger_1.logger.debug({ sessionId }, "Session updated");
|
|
87
|
+
return true;
|
|
88
|
+
}
|
|
89
|
+
deleteSession(sessionId) {
|
|
90
|
+
const session = this.sessions.get(sessionId);
|
|
91
|
+
if (!session) {
|
|
92
|
+
return false;
|
|
93
|
+
}
|
|
94
|
+
if (session.mcpAccessToken) {
|
|
95
|
+
this.tokenToSession.delete(session.mcpAccessToken);
|
|
96
|
+
}
|
|
97
|
+
if (session.mcpRefreshToken) {
|
|
98
|
+
this.refreshTokenToSession.delete(session.mcpRefreshToken);
|
|
99
|
+
}
|
|
100
|
+
this.sessions.delete(sessionId);
|
|
101
|
+
this.backend.deleteSession(sessionId).catch(err => {
|
|
102
|
+
logger_1.logger.error({ err, sessionId }, "Failed to delete session from backend");
|
|
103
|
+
});
|
|
104
|
+
logger_1.logger.debug({ sessionId }, "Session deleted");
|
|
105
|
+
return true;
|
|
106
|
+
}
|
|
107
|
+
getAllSessions() {
|
|
108
|
+
return this.sessions.values();
|
|
109
|
+
}
|
|
110
|
+
getSessionCount() {
|
|
111
|
+
return this.sessions.size;
|
|
112
|
+
}
|
|
113
|
+
storeDeviceFlow(state, flow) {
|
|
114
|
+
this.deviceFlows.set(state, flow);
|
|
115
|
+
this.backend.storeDeviceFlow(state, flow).catch(err => {
|
|
116
|
+
logger_1.logger.error({ err, state }, "Failed to persist device flow to backend");
|
|
117
|
+
});
|
|
118
|
+
logger_1.logger.debug({ state, userCode: flow.userCode }, "Device flow stored");
|
|
119
|
+
}
|
|
120
|
+
getDeviceFlow(state) {
|
|
121
|
+
return this.deviceFlows.get(state);
|
|
122
|
+
}
|
|
123
|
+
getDeviceFlowByDeviceCode(deviceCode) {
|
|
124
|
+
for (const flow of this.deviceFlows.values()) {
|
|
125
|
+
if (flow.deviceCode === deviceCode) {
|
|
126
|
+
return flow;
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
return undefined;
|
|
130
|
+
}
|
|
131
|
+
deleteDeviceFlow(state) {
|
|
132
|
+
const deleted = this.deviceFlows.delete(state);
|
|
133
|
+
if (deleted) {
|
|
134
|
+
this.backend.deleteDeviceFlow(state).catch(err => {
|
|
135
|
+
logger_1.logger.error({ err, state }, "Failed to delete device flow from backend");
|
|
136
|
+
});
|
|
137
|
+
logger_1.logger.debug({ state }, "Device flow deleted");
|
|
138
|
+
}
|
|
139
|
+
return deleted;
|
|
140
|
+
}
|
|
141
|
+
getDeviceFlowCount() {
|
|
142
|
+
return this.deviceFlows.size;
|
|
143
|
+
}
|
|
144
|
+
storeAuthCodeFlow(internalState, flow) {
|
|
145
|
+
this.authCodeFlows.set(internalState, flow);
|
|
146
|
+
this.backend.storeAuthCodeFlow(internalState, flow).catch(err => {
|
|
147
|
+
logger_1.logger.error({ err, internalState: internalState.substring(0, 8) + "..." }, "Failed to persist auth code flow");
|
|
148
|
+
});
|
|
149
|
+
logger_1.logger.debug({ internalState: internalState.substring(0, 8) + "..." }, "Auth code flow stored");
|
|
150
|
+
}
|
|
151
|
+
getAuthCodeFlow(internalState) {
|
|
152
|
+
return this.authCodeFlows.get(internalState);
|
|
153
|
+
}
|
|
154
|
+
deleteAuthCodeFlow(internalState) {
|
|
155
|
+
const deleted = this.authCodeFlows.delete(internalState);
|
|
156
|
+
if (deleted) {
|
|
157
|
+
this.backend.deleteAuthCodeFlow(internalState).catch(err => {
|
|
158
|
+
logger_1.logger.error({ err, internalState: internalState.substring(0, 8) + "..." }, "Failed to delete auth code flow");
|
|
159
|
+
});
|
|
160
|
+
logger_1.logger.debug({ internalState: internalState.substring(0, 8) + "..." }, "Auth code flow deleted");
|
|
161
|
+
}
|
|
162
|
+
return deleted;
|
|
163
|
+
}
|
|
164
|
+
getAuthCodeFlowCount() {
|
|
165
|
+
return this.authCodeFlows.size;
|
|
166
|
+
}
|
|
167
|
+
storeAuthCode(code) {
|
|
168
|
+
this.authCodes.set(code.code, code);
|
|
169
|
+
this.backend.storeAuthCode(code).catch(err => {
|
|
170
|
+
logger_1.logger.error({ err, code: code.code.substring(0, 8) + "..." }, "Failed to persist auth code");
|
|
171
|
+
});
|
|
172
|
+
logger_1.logger.debug({ code: code.code.substring(0, 8) + "..." }, "Auth code stored");
|
|
173
|
+
}
|
|
174
|
+
getAuthCode(code) {
|
|
175
|
+
return this.authCodes.get(code);
|
|
176
|
+
}
|
|
177
|
+
deleteAuthCode(code) {
|
|
178
|
+
const deleted = this.authCodes.delete(code);
|
|
179
|
+
if (deleted) {
|
|
180
|
+
this.backend.deleteAuthCode(code).catch(err => {
|
|
181
|
+
logger_1.logger.error({ err, code: code.substring(0, 8) + "..." }, "Failed to delete auth code");
|
|
182
|
+
});
|
|
183
|
+
logger_1.logger.debug({ code: code.substring(0, 8) + "..." }, "Auth code deleted");
|
|
184
|
+
}
|
|
185
|
+
return deleted;
|
|
186
|
+
}
|
|
187
|
+
getAuthCodeCount() {
|
|
188
|
+
return this.authCodes.size;
|
|
189
|
+
}
|
|
190
|
+
associateMcpSession(mcpSessionId, oauthSessionId) {
|
|
191
|
+
this.mcpSessionToOAuthSession.set(mcpSessionId, oauthSessionId);
|
|
192
|
+
this.backend.associateMcpSession(mcpSessionId, oauthSessionId).catch(err => {
|
|
193
|
+
logger_1.logger.error({ err, mcpSessionId }, "Failed to persist MCP session association");
|
|
194
|
+
});
|
|
195
|
+
logger_1.logger.debug({ mcpSessionId, oauthSessionId: oauthSessionId.substring(0, 8) + "..." }, "MCP session associated with OAuth session");
|
|
196
|
+
}
|
|
197
|
+
getSessionByMcpSessionId(mcpSessionId) {
|
|
198
|
+
const oauthSessionId = this.mcpSessionToOAuthSession.get(mcpSessionId);
|
|
199
|
+
if (!oauthSessionId) {
|
|
200
|
+
return undefined;
|
|
201
|
+
}
|
|
202
|
+
return this.sessions.get(oauthSessionId);
|
|
203
|
+
}
|
|
204
|
+
getGitLabTokenByMcpSessionId(mcpSessionId) {
|
|
205
|
+
const session = this.getSessionByMcpSessionId(mcpSessionId);
|
|
206
|
+
return session?.gitlabAccessToken;
|
|
207
|
+
}
|
|
208
|
+
removeMcpSessionAssociation(mcpSessionId) {
|
|
209
|
+
const deleted = this.mcpSessionToOAuthSession.delete(mcpSessionId);
|
|
210
|
+
if (deleted) {
|
|
211
|
+
this.backend.removeMcpSessionAssociation(mcpSessionId).catch(err => {
|
|
212
|
+
logger_1.logger.error({ err, mcpSessionId }, "Failed to remove MCP session association from backend");
|
|
213
|
+
});
|
|
214
|
+
logger_1.logger.debug({ mcpSessionId }, "MCP session association removed");
|
|
215
|
+
}
|
|
216
|
+
return deleted;
|
|
217
|
+
}
|
|
218
|
+
cleanup() {
|
|
219
|
+
const now = Date.now();
|
|
220
|
+
let expiredSessions = 0;
|
|
221
|
+
let expiredDeviceFlows = 0;
|
|
222
|
+
let expiredAuthCodeFlows = 0;
|
|
223
|
+
let expiredAuthCodes = 0;
|
|
224
|
+
const maxAge = 7 * 24 * 60 * 60 * 1000;
|
|
225
|
+
for (const [id, session] of this.sessions) {
|
|
226
|
+
if (session.createdAt + maxAge < now) {
|
|
227
|
+
this.deleteSession(id);
|
|
228
|
+
expiredSessions++;
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
for (const [state, flow] of this.deviceFlows) {
|
|
232
|
+
if (flow.expiresAt < now) {
|
|
233
|
+
this.deleteDeviceFlow(state);
|
|
234
|
+
expiredDeviceFlows++;
|
|
235
|
+
}
|
|
236
|
+
}
|
|
237
|
+
for (const [state, flow] of this.authCodeFlows) {
|
|
238
|
+
if (flow.expiresAt < now) {
|
|
239
|
+
this.deleteAuthCodeFlow(state);
|
|
240
|
+
expiredAuthCodeFlows++;
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
for (const [code, auth] of this.authCodes) {
|
|
244
|
+
if (auth.expiresAt < now) {
|
|
245
|
+
this.deleteAuthCode(code);
|
|
246
|
+
expiredAuthCodes++;
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
if (expiredSessions > 0 ||
|
|
250
|
+
expiredDeviceFlows > 0 ||
|
|
251
|
+
expiredAuthCodeFlows > 0 ||
|
|
252
|
+
expiredAuthCodes > 0) {
|
|
253
|
+
logger_1.logger.debug({
|
|
254
|
+
expiredSessions,
|
|
255
|
+
expiredDeviceFlows,
|
|
256
|
+
expiredAuthCodeFlows,
|
|
257
|
+
expiredAuthCodes,
|
|
258
|
+
remainingSessions: this.sessions.size,
|
|
259
|
+
}, "Session store cleanup completed");
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
startCleanupInterval() {
|
|
263
|
+
this.cleanupIntervalId = setInterval(() => {
|
|
264
|
+
this.cleanup();
|
|
265
|
+
}, 5 * 60 * 1000);
|
|
266
|
+
if (this.cleanupIntervalId.unref) {
|
|
267
|
+
this.cleanupIntervalId.unref();
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
stopCleanupInterval() {
|
|
271
|
+
if (this.cleanupIntervalId) {
|
|
272
|
+
clearInterval(this.cleanupIntervalId);
|
|
273
|
+
this.cleanupIntervalId = null;
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
clear() {
|
|
277
|
+
this.sessions.clear();
|
|
278
|
+
this.deviceFlows.clear();
|
|
279
|
+
this.authCodeFlows.clear();
|
|
280
|
+
this.authCodes.clear();
|
|
281
|
+
this.tokenToSession.clear();
|
|
282
|
+
this.refreshTokenToSession.clear();
|
|
283
|
+
this.mcpSessionToOAuthSession.clear();
|
|
284
|
+
logger_1.logger.debug("Session store cleared");
|
|
285
|
+
}
|
|
286
|
+
async close() {
|
|
287
|
+
this.stopCleanupInterval();
|
|
288
|
+
await this.backend.close();
|
|
289
|
+
logger_1.logger.info("Session store closed");
|
|
290
|
+
}
|
|
291
|
+
getStats() {
|
|
292
|
+
return {
|
|
293
|
+
sessions: this.sessions.size,
|
|
294
|
+
deviceFlows: this.deviceFlows.size,
|
|
295
|
+
authCodeFlows: this.authCodeFlows.size,
|
|
296
|
+
authCodes: this.authCodes.size,
|
|
297
|
+
};
|
|
298
|
+
}
|
|
299
|
+
}
|
|
300
|
+
exports.SessionStore = SessionStore;
|
|
301
|
+
exports.sessionStore = new SessionStore();
|
|
302
|
+
//# sourceMappingURL=session-store.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session-store.js","sourceRoot":"","sources":["../../../src/oauth/session-store.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { SessionStorageBackend, StorageConfig } from "./types";
|
|
2
|
+
export declare function createStorageBackend(config?: StorageConfig): SessionStorageBackend;
|
|
3
|
+
export declare function getStorageType(config?: StorageConfig): "memory" | "file" | "postgresql";
|
|
4
|
+
export declare function validateStorageConfig(config?: StorageConfig): string[];
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createStorageBackend = createStorageBackend;
|
|
4
|
+
exports.getStorageType = getStorageType;
|
|
5
|
+
exports.validateStorageConfig = validateStorageConfig;
|
|
6
|
+
const memory_1 = require("./memory");
|
|
7
|
+
const file_1 = require("./file");
|
|
8
|
+
const postgresql_1 = require("./postgresql");
|
|
9
|
+
const logger_1 = require("../../logger");
|
|
10
|
+
function createStorageBackend(config) {
|
|
11
|
+
const storageType = config?.type ?? getEnvStorageType();
|
|
12
|
+
switch (storageType) {
|
|
13
|
+
case "file":
|
|
14
|
+
return createFileBackend(config);
|
|
15
|
+
case "postgresql":
|
|
16
|
+
return createPostgreSQLBackend();
|
|
17
|
+
case "memory":
|
|
18
|
+
default:
|
|
19
|
+
return createMemoryBackend();
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
function getEnvStorageType() {
|
|
23
|
+
const type = process.env.OAUTH_STORAGE_TYPE?.toLowerCase();
|
|
24
|
+
if (type === "file" || type === "postgresql") {
|
|
25
|
+
return type;
|
|
26
|
+
}
|
|
27
|
+
return "memory";
|
|
28
|
+
}
|
|
29
|
+
function createMemoryBackend() {
|
|
30
|
+
logger_1.logger.info("Using in-memory session storage (sessions will be lost on restart)");
|
|
31
|
+
return new memory_1.MemoryStorageBackend();
|
|
32
|
+
}
|
|
33
|
+
function createFileBackend(config) {
|
|
34
|
+
const filePath = config?.file?.path ?? process.env.OAUTH_STORAGE_FILE_PATH ?? "./data/oauth-sessions.json";
|
|
35
|
+
const saveInterval = config?.file?.saveInterval ?? parseInt(process.env.OAUTH_STORAGE_SAVE_INTERVAL ?? "30000", 10);
|
|
36
|
+
const prettyPrint = config?.file?.prettyPrint ?? process.env.OAUTH_STORAGE_PRETTY_PRINT === "true";
|
|
37
|
+
logger_1.logger.info({ filePath, saveInterval }, "Using file-based session storage");
|
|
38
|
+
return new file_1.FileStorageBackend({
|
|
39
|
+
filePath,
|
|
40
|
+
saveInterval,
|
|
41
|
+
prettyPrint,
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
function createPostgreSQLBackend() {
|
|
45
|
+
const connectionString = process.env.OAUTH_STORAGE_POSTGRESQL_URL ?? process.env.DATABASE_URL;
|
|
46
|
+
if (!connectionString) {
|
|
47
|
+
throw new Error("PostgreSQL storage requires a connection string. " +
|
|
48
|
+
"Set OAUTH_STORAGE_POSTGRESQL_URL or DATABASE_URL environment variable");
|
|
49
|
+
}
|
|
50
|
+
logger_1.logger.info("Using PostgreSQL session storage (via Prisma)");
|
|
51
|
+
return new postgresql_1.PostgreSQLStorageBackend();
|
|
52
|
+
}
|
|
53
|
+
function getStorageType(config) {
|
|
54
|
+
return config?.type ?? getEnvStorageType();
|
|
55
|
+
}
|
|
56
|
+
function validateStorageConfig(config) {
|
|
57
|
+
const errors = [];
|
|
58
|
+
const type = getStorageType(config);
|
|
59
|
+
if (type === "postgresql") {
|
|
60
|
+
const connectionString = process.env.OAUTH_STORAGE_POSTGRESQL_URL ?? process.env.DATABASE_URL;
|
|
61
|
+
if (!connectionString) {
|
|
62
|
+
errors.push("PostgreSQL storage requires OAUTH_STORAGE_POSTGRESQL_URL or DATABASE_URL environment variable");
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
if (type === "file") {
|
|
66
|
+
const filePath = config?.file?.path ?? process.env.OAUTH_STORAGE_FILE_PATH;
|
|
67
|
+
if (filePath) {
|
|
68
|
+
if (filePath.includes("..")) {
|
|
69
|
+
errors.push("File storage path must not contain '..'");
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
return errors;
|
|
74
|
+
}
|
|
75
|
+
//# sourceMappingURL=factory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"factory.js","sourceRoot":"","sources":["../../../../src/oauth/storage/factory.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { OAuthSession, DeviceFlowState, AuthCodeFlowState, AuthorizationCode } from "../types";
|
|
2
|
+
import { SessionStorageBackend, SessionStorageStats } from "./types";
|
|
3
|
+
export interface FileStorageOptions {
|
|
4
|
+
filePath: string;
|
|
5
|
+
saveInterval?: number;
|
|
6
|
+
prettyPrint?: boolean;
|
|
7
|
+
saveDebounce?: number;
|
|
8
|
+
}
|
|
9
|
+
export declare class FileStorageBackend implements SessionStorageBackend {
|
|
10
|
+
readonly type: "file";
|
|
11
|
+
private memory;
|
|
12
|
+
private filePath;
|
|
13
|
+
private saveInterval;
|
|
14
|
+
private prettyPrint;
|
|
15
|
+
private saveDebounce;
|
|
16
|
+
private saveIntervalId;
|
|
17
|
+
private saveDebounceId;
|
|
18
|
+
private pendingSave;
|
|
19
|
+
private initialized;
|
|
20
|
+
constructor(options: FileStorageOptions);
|
|
21
|
+
initialize(): Promise<void>;
|
|
22
|
+
private loadFromFile;
|
|
23
|
+
private saveToFile;
|
|
24
|
+
private scheduleSave;
|
|
25
|
+
private startSaveInterval;
|
|
26
|
+
createSession(session: OAuthSession): Promise<void>;
|
|
27
|
+
getSession(sessionId: string): Promise<OAuthSession | undefined>;
|
|
28
|
+
getSessionByToken(token: string): Promise<OAuthSession | undefined>;
|
|
29
|
+
getSessionByRefreshToken(refreshToken: string): Promise<OAuthSession | undefined>;
|
|
30
|
+
updateSession(sessionId: string, updates: Partial<OAuthSession>): Promise<boolean>;
|
|
31
|
+
deleteSession(sessionId: string): Promise<boolean>;
|
|
32
|
+
getAllSessions(): Promise<OAuthSession[]>;
|
|
33
|
+
storeDeviceFlow(state: string, flow: DeviceFlowState): Promise<void>;
|
|
34
|
+
getDeviceFlow(state: string): Promise<DeviceFlowState | undefined>;
|
|
35
|
+
getDeviceFlowByDeviceCode(deviceCode: string): Promise<DeviceFlowState | undefined>;
|
|
36
|
+
deleteDeviceFlow(state: string): Promise<boolean>;
|
|
37
|
+
storeAuthCodeFlow(internalState: string, flow: AuthCodeFlowState): Promise<void>;
|
|
38
|
+
getAuthCodeFlow(internalState: string): Promise<AuthCodeFlowState | undefined>;
|
|
39
|
+
deleteAuthCodeFlow(internalState: string): Promise<boolean>;
|
|
40
|
+
storeAuthCode(code: AuthorizationCode): Promise<void>;
|
|
41
|
+
getAuthCode(code: string): Promise<AuthorizationCode | undefined>;
|
|
42
|
+
deleteAuthCode(code: string): Promise<boolean>;
|
|
43
|
+
associateMcpSession(mcpSessionId: string, oauthSessionId: string): Promise<void>;
|
|
44
|
+
getSessionByMcpSessionId(mcpSessionId: string): Promise<OAuthSession | undefined>;
|
|
45
|
+
removeMcpSessionAssociation(mcpSessionId: string): Promise<boolean>;
|
|
46
|
+
cleanup(): Promise<void>;
|
|
47
|
+
close(): Promise<void>;
|
|
48
|
+
getStats(): Promise<SessionStorageStats>;
|
|
49
|
+
forceSave(): Promise<void>;
|
|
50
|
+
}
|