@structured-world/gitlab-mcp 5.8.0 → 6.1.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 +61 -95
- 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} +6 -0
- package/dist/{config.js → src/config.js} +7 -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/{entities → src/entities}/core/schema-readonly.d.ts +156 -143
- 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/{entities → src/entities}/files/schema-readonly.d.ts +15 -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/{entities → src/entities}/files/schema.d.ts +40 -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/{entities → src/entities}/labels/registry.js +19 -89
- package/dist/src/entities/labels/registry.js.map +1 -0
- package/dist/src/entities/labels/schema-readonly.js.map +1 -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.js.map +1 -0
- package/dist/src/entities/milestones/schema.js.map +1 -0
- package/dist/src/entities/mrs/index.js.map +1 -0
- package/dist/src/entities/mrs/registry.js +290 -0
- package/dist/src/entities/mrs/registry.js.map +1 -0
- package/dist/{entities → src/entities}/mrs/schema-readonly.d.ts +115 -1
- package/dist/src/entities/mrs/schema-readonly.js +261 -0
- package/dist/src/entities/mrs/schema-readonly.js.map +1 -0
- package/dist/{entities → src/entities}/mrs/schema.d.ts +262 -0
- package/dist/src/entities/mrs/schema.js +316 -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 +26 -187
- package/dist/src/entities/pipelines/registry.js.map +1 -0
- package/dist/src/entities/pipelines/schema-readonly.js.map +1 -0
- package/dist/src/entities/pipelines/schema.js.map +1 -0
- package/dist/src/entities/shared.js.map +1 -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.js.map +1 -0
- package/dist/src/entities/variables/schema.js.map +1 -0
- package/dist/src/entities/wiki/index.js.map +1 -0
- package/dist/{entities → src/entities}/wiki/registry.js +19 -89
- package/dist/src/entities/wiki/registry.js.map +1 -0
- package/dist/src/entities/wiki/schema-readonly.js.map +1 -0
- package/dist/src/entities/wiki/schema.js.map +1 -0
- package/dist/src/entities/workitems/index.js.map +1 -0
- package/dist/src/entities/workitems/registry.js.map +1 -0
- package/dist/src/entities/workitems/schema-readonly.js.map +1 -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/{middleware → src/middleware}/oauth-auth.js +24 -40
- 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.js.map +1 -0
- package/dist/{oauth → src/oauth}/endpoints/authorize.js +45 -5
- 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/{oauth → src/oauth}/endpoints/metadata.d.ts +1 -0
- package/dist/{oauth → src/oauth}/endpoints/metadata.js +12 -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.js.map +1 -0
- package/dist/{oauth → src/oauth}/gitlab-device-flow.d.ts +2 -0
- package/dist/{oauth → src/oauth}/gitlab-device-flow.js +44 -1
- package/dist/src/oauth/gitlab-device-flow.js.map +1 -0
- package/dist/src/oauth/index.d.ts +10 -0
- package/dist/{oauth → src/oauth}/index.js +18 -1
- package/dist/src/oauth/index.js.map +1 -0
- package/dist/{oauth → src/oauth}/session-store.d.ts +19 -2
- package/dist/{oauth → src/oauth}/session-store.js +125 -5
- 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.js.map +1 -0
- package/dist/src/oauth/token-utils.js.map +1 -0
- package/dist/{oauth → src/oauth}/types.d.ts +10 -0
- package/dist/{oauth → src/oauth}/types.js.map +1 -1
- package/dist/src/registry-manager.js.map +1 -0
- package/dist/{server.d.ts → src/server.d.ts} +11 -0
- package/dist/{server.js → src/server.js} +113 -9
- 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/{utils → src/utils}/fetch.js +9 -0
- 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.1.0.tgz +0 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/package.json +26 -22
- package/dist/config.js.map +0 -1
- package/dist/entities/core/index.js.map +0 -1
- package/dist/entities/core/registry.js +0 -811
- package/dist/entities/core/registry.js.map +0 -1
- 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 -102
- 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 -230
- package/dist/entities/files/registry.js.map +0 -1
- package/dist/entities/files/schema-readonly.js.map +0 -1
- 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.map +0 -1
- package/dist/entities/labels/schema-readonly.js.map +0 -1
- 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 -333
- package/dist/entities/milestones/registry.js.map +0 -1
- package/dist/entities/milestones/schema-readonly.js.map +0 -1
- package/dist/entities/milestones/schema.js.map +0 -1
- package/dist/entities/mrs/index.js.map +0 -1
- package/dist/entities/mrs/registry.js +0 -664
- package/dist/entities/mrs/registry.js.map +0 -1
- package/dist/entities/mrs/schema-readonly.js +0 -242
- package/dist/entities/mrs/schema-readonly.js.map +0 -1
- package/dist/entities/mrs/schema.js +0 -246
- 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.js.map +0 -1
- package/dist/entities/pipelines/schema.js.map +0 -1
- package/dist/entities/shared.js.map +0 -1
- package/dist/entities/utils.js.map +0 -1
- package/dist/entities/variables/index.js.map +0 -1
- package/dist/entities/variables/registry.js +0 -341
- package/dist/entities/variables/registry.js.map +0 -1
- package/dist/entities/variables/schema-readonly.js.map +0 -1
- package/dist/entities/variables/schema.js.map +0 -1
- package/dist/entities/wiki/index.js.map +0 -1
- package/dist/entities/wiki/registry.js.map +0 -1
- 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.js.map +0 -1
- 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/middleware/index.d.ts +0 -1
- package/dist/middleware/index.js +0 -8
- package/dist/middleware/index.js.map +0 -1
- package/dist/middleware/oauth-auth.js.map +0 -1
- package/dist/oauth/config.js.map +0 -1
- package/dist/oauth/endpoints/authorize.js.map +0 -1
- package/dist/oauth/endpoints/index.d.ts +0 -3
- package/dist/oauth/endpoints/index.js +0 -13
- package/dist/oauth/endpoints/index.js.map +0 -1
- package/dist/oauth/endpoints/metadata.js.map +0 -1
- package/dist/oauth/endpoints/token.js.map +0 -1
- package/dist/oauth/gitlab-device-flow.js.map +0 -1
- package/dist/oauth/index.d.ts +0 -8
- package/dist/oauth/index.js.map +0 -1
- package/dist/oauth/session-store.js.map +0 -1
- package/dist/oauth/token-context.js.map +0 -1
- package/dist/oauth/token-utils.js.map +0 -1
- package/dist/registry-manager.js.map +0 -1
- 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.8.0.tgz +0 -0
- package/dist/types.js.map +0 -1
- 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.d.ts +0 -0
- package/dist/{entities → src/entities}/labels/schema-readonly.js +0 -0
- package/dist/{entities → src/entities}/labels/schema.d.ts +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.d.ts +1 -1
- /package/dist/{entities → src/entities}/milestones/schema-readonly.js +0 -0
- /package/dist/{entities → src/entities}/milestones/schema.d.ts +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}/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.d.ts +0 -0
- /package/dist/{entities → src/entities}/pipelines/schema-readonly.js +0 -0
- /package/dist/{entities → src/entities}/pipelines/schema.d.ts +0 -0
- /package/dist/{entities → src/entities}/pipelines/schema.js +0 -0
- /package/dist/{entities → src/entities}/shared.d.ts +0 -0
- /package/dist/{entities → src/entities}/shared.js +0 -0
- /package/dist/{entities → src/entities}/utils.d.ts +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.d.ts +0 -0
- /package/dist/{entities → src/entities}/variables/schema-readonly.js +0 -0
- /package/dist/{entities → src/entities}/variables/schema.d.ts +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.d.ts +0 -0
- /package/dist/{entities → src/entities}/wiki/schema-readonly.js +0 -0
- /package/dist/{entities → src/entities}/wiki/schema.d.ts +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/registry.js +0 -0
- /package/dist/{entities → src/entities}/workitems/schema-readonly.d.ts +0 -0
- /package/dist/{entities → src/entities}/workitems/schema-readonly.js +0 -0
- /package/dist/{entities → src/entities}/workitems/schema.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/{middleware → src/middleware}/oauth-auth.d.ts +0 -0
- /package/dist/{oauth → src/oauth}/config.d.ts +0 -0
- /package/dist/{oauth → src/oauth}/config.js +0 -0
- /package/dist/{oauth → src/oauth}/endpoints/authorize.d.ts +0 -0
- /package/dist/{oauth → src/oauth}/endpoints/token.d.ts +0 -0
- /package/dist/{oauth → src/oauth}/endpoints/token.js +0 -0
- /package/dist/{oauth → src/oauth}/token-context.d.ts +0 -0
- /package/dist/{oauth → src/oauth}/token-context.js +0 -0
- /package/dist/{oauth → src/oauth}/token-utils.d.ts +0 -0
- /package/dist/{oauth → src/oauth}/token-utils.js +0 -0
- /package/dist/{oauth → src/oauth}/types.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}/fetch.d.ts +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
|
@@ -6,11 +6,14 @@ exports.pollForToken = pollForToken;
|
|
|
6
6
|
exports.refreshGitLabToken = refreshGitLabToken;
|
|
7
7
|
exports.getGitLabUser = getGitLabUser;
|
|
8
8
|
exports.validateGitLabToken = validateGitLabToken;
|
|
9
|
+
exports.exchangeGitLabAuthCode = exchangeGitLabAuthCode;
|
|
10
|
+
exports.buildGitLabAuthUrl = buildGitLabAuthUrl;
|
|
9
11
|
const config_1 = require("../config");
|
|
10
12
|
const logger_1 = require("../logger");
|
|
11
13
|
async function initiateDeviceFlow(config) {
|
|
12
14
|
const url = `${config_1.GITLAB_BASE_URL}/oauth/authorize_device`;
|
|
13
15
|
logger_1.logger.debug({ url, clientId: config.gitlabClientId }, "Initiating GitLab device flow");
|
|
16
|
+
const scopes = config.gitlabScopes.replace(/,/g, " ");
|
|
14
17
|
const response = await fetch(url, {
|
|
15
18
|
method: "POST",
|
|
16
19
|
headers: {
|
|
@@ -19,7 +22,7 @@ async function initiateDeviceFlow(config) {
|
|
|
19
22
|
},
|
|
20
23
|
body: new URLSearchParams({
|
|
21
24
|
client_id: config.gitlabClientId,
|
|
22
|
-
scope:
|
|
25
|
+
scope: scopes,
|
|
23
26
|
}),
|
|
24
27
|
});
|
|
25
28
|
if (!response.ok) {
|
|
@@ -166,6 +169,46 @@ async function validateGitLabToken(accessToken) {
|
|
|
166
169
|
return false;
|
|
167
170
|
}
|
|
168
171
|
}
|
|
172
|
+
async function exchangeGitLabAuthCode(code, redirectUri, config) {
|
|
173
|
+
const url = `${config_1.GITLAB_BASE_URL}/oauth/token`;
|
|
174
|
+
const params = {
|
|
175
|
+
client_id: config.gitlabClientId,
|
|
176
|
+
code: code,
|
|
177
|
+
grant_type: "authorization_code",
|
|
178
|
+
redirect_uri: redirectUri,
|
|
179
|
+
};
|
|
180
|
+
if (config.gitlabClientSecret) {
|
|
181
|
+
params.client_secret = config.gitlabClientSecret;
|
|
182
|
+
}
|
|
183
|
+
logger_1.logger.debug({ redirectUri }, "Exchanging GitLab authorization code for tokens");
|
|
184
|
+
const response = await fetch(url, {
|
|
185
|
+
method: "POST",
|
|
186
|
+
headers: {
|
|
187
|
+
"Content-Type": "application/x-www-form-urlencoded",
|
|
188
|
+
Accept: "application/json",
|
|
189
|
+
},
|
|
190
|
+
body: new URLSearchParams(params),
|
|
191
|
+
});
|
|
192
|
+
if (!response.ok) {
|
|
193
|
+
const errorText = await response.text();
|
|
194
|
+
logger_1.logger.error({ status: response.status, error: errorText }, "Failed to exchange GitLab auth code");
|
|
195
|
+
throw new Error(`Failed to exchange authorization code: ${response.status} ${errorText}`);
|
|
196
|
+
}
|
|
197
|
+
const data = (await response.json());
|
|
198
|
+
logger_1.logger.info("GitLab authorization code exchanged successfully");
|
|
199
|
+
return data;
|
|
200
|
+
}
|
|
201
|
+
function buildGitLabAuthUrl(config, redirectUri, state) {
|
|
202
|
+
const scopes = config.gitlabScopes.replace(/,/g, " ");
|
|
203
|
+
const params = new URLSearchParams({
|
|
204
|
+
client_id: config.gitlabClientId,
|
|
205
|
+
redirect_uri: redirectUri,
|
|
206
|
+
response_type: "code",
|
|
207
|
+
state: state,
|
|
208
|
+
scope: scopes,
|
|
209
|
+
});
|
|
210
|
+
return `${config_1.GITLAB_BASE_URL}/oauth/authorize?${params.toString()}`;
|
|
211
|
+
}
|
|
169
212
|
function sleep(ms) {
|
|
170
213
|
return new Promise(resolve => setTimeout(resolve, ms));
|
|
171
214
|
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"gitlab-device-flow.js","sourceRoot":"","sources":["../../../src/oauth/gitlab-device-flow.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export { loadOAuthConfig, validateStaticConfig, isOAuthEnabled, getAuthModeDescription, resetOAuthConfigCache, } from "./config";
|
|
2
|
+
export type { OAuthConfig } from "./config";
|
|
3
|
+
export type { OAuthSession, AuthCodeFlowState, DeviceFlowState, AuthorizationCode, GitLabTokenResponse, GitLabDeviceResponse, TokenContext, GitLabUserInfo, MCPTokenResponse, OAuthErrorResponse, DeviceFlowPollStatus, DeviceFlowPollResponse, MCPTokenPayload, } from "./types";
|
|
4
|
+
export { sessionStore, SessionStore } from "./session-store";
|
|
5
|
+
export { createStorageBackend, getStorageType, validateStorageConfig, MemoryStorageBackend, FileStorageBackend, PostgreSQLStorageBackend, STORAGE_DATA_VERSION, } from "./storage";
|
|
6
|
+
export type { SessionStorageBackend, StorageConfig, SessionStorageStats, StorageData, } from "./storage";
|
|
7
|
+
export { runWithTokenContext, getTokenContext, getGitLabTokenFromContext, getGitLabUserIdFromContext, getGitLabUsernameFromContext, getSessionIdFromContext, isInOAuthContext, } from "./token-context";
|
|
8
|
+
export { createJWT, verifyJWT, verifyMCPToken, generateCodeVerifier, generateCodeChallenge, verifyCodeChallenge, generateRandomString, generateUUID, generateAuthorizationCode, generateSessionId, generateRefreshToken, isTokenExpiringSoon, calculateTokenExpiry, } from "./token-utils";
|
|
9
|
+
export { initiateDeviceFlow, pollDeviceFlowOnce, pollForToken, refreshGitLabToken, getGitLabUser, validateGitLabToken, exchangeGitLabAuthCode, buildGitLabAuthUrl, } from "./gitlab-device-flow";
|
|
10
|
+
export { metadataHandler, healthHandler, protectedResourceHandler, getBaseUrl, authorizeHandler, pollHandler, callbackHandler, tokenHandler, registerHandler, getRegisteredClient, isValidRedirectUri, } from "./endpoints/index";
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.tokenHandler = exports.pollHandler = exports.authorizeHandler = exports.getBaseUrl = exports.healthHandler = exports.metadataHandler = 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.sessionStore = exports.resetOAuthConfigCache = exports.getAuthModeDescription = exports.isOAuthEnabled = exports.validateStaticConfig = exports.loadOAuthConfig = void 0;
|
|
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;
|
|
4
5
|
var config_1 = require("./config");
|
|
5
6
|
Object.defineProperty(exports, "loadOAuthConfig", { enumerable: true, get: function () { return config_1.loadOAuthConfig; } });
|
|
6
7
|
Object.defineProperty(exports, "validateStaticConfig", { enumerable: true, get: function () { return config_1.validateStaticConfig; } });
|
|
@@ -9,6 +10,15 @@ Object.defineProperty(exports, "getAuthModeDescription", { enumerable: true, get
|
|
|
9
10
|
Object.defineProperty(exports, "resetOAuthConfigCache", { enumerable: true, get: function () { return config_1.resetOAuthConfigCache; } });
|
|
10
11
|
var session_store_1 = require("./session-store");
|
|
11
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; } });
|
|
12
22
|
var token_context_1 = require("./token-context");
|
|
13
23
|
Object.defineProperty(exports, "runWithTokenContext", { enumerable: true, get: function () { return token_context_1.runWithTokenContext; } });
|
|
14
24
|
Object.defineProperty(exports, "getTokenContext", { enumerable: true, get: function () { return token_context_1.getTokenContext; } });
|
|
@@ -38,11 +48,18 @@ Object.defineProperty(exports, "pollForToken", { enumerable: true, get: function
|
|
|
38
48
|
Object.defineProperty(exports, "refreshGitLabToken", { enumerable: true, get: function () { return gitlab_device_flow_1.refreshGitLabToken; } });
|
|
39
49
|
Object.defineProperty(exports, "getGitLabUser", { enumerable: true, get: function () { return gitlab_device_flow_1.getGitLabUser; } });
|
|
40
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; } });
|
|
41
53
|
var index_1 = require("./endpoints/index");
|
|
42
54
|
Object.defineProperty(exports, "metadataHandler", { enumerable: true, get: function () { return index_1.metadataHandler; } });
|
|
43
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; } });
|
|
44
57
|
Object.defineProperty(exports, "getBaseUrl", { enumerable: true, get: function () { return index_1.getBaseUrl; } });
|
|
45
58
|
Object.defineProperty(exports, "authorizeHandler", { enumerable: true, get: function () { return index_1.authorizeHandler; } });
|
|
46
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; } });
|
|
47
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; } });
|
|
48
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"}
|
|
@@ -1,12 +1,19 @@
|
|
|
1
|
-
import { OAuthSession, DeviceFlowState, AuthorizationCode } from "./types";
|
|
1
|
+
import { OAuthSession, DeviceFlowState, AuthorizationCode, AuthCodeFlowState } from "./types";
|
|
2
|
+
import { SessionStorageBackend } from "./storage";
|
|
2
3
|
export declare class SessionStore {
|
|
4
|
+
private backend;
|
|
5
|
+
private initialized;
|
|
3
6
|
private sessions;
|
|
4
7
|
private deviceFlows;
|
|
8
|
+
private authCodeFlows;
|
|
5
9
|
private authCodes;
|
|
6
10
|
private tokenToSession;
|
|
7
11
|
private refreshTokenToSession;
|
|
12
|
+
private mcpSessionToOAuthSession;
|
|
8
13
|
private cleanupIntervalId;
|
|
9
|
-
constructor();
|
|
14
|
+
constructor(backend?: SessionStorageBackend);
|
|
15
|
+
initialize(): Promise<void>;
|
|
16
|
+
getBackendType(): string;
|
|
10
17
|
createSession(session: OAuthSession): void;
|
|
11
18
|
getSession(sessionId: string): OAuthSession | undefined;
|
|
12
19
|
getSessionByToken(token: string): OAuthSession | undefined;
|
|
@@ -20,17 +27,27 @@ export declare class SessionStore {
|
|
|
20
27
|
getDeviceFlowByDeviceCode(deviceCode: string): DeviceFlowState | undefined;
|
|
21
28
|
deleteDeviceFlow(state: string): boolean;
|
|
22
29
|
getDeviceFlowCount(): number;
|
|
30
|
+
storeAuthCodeFlow(internalState: string, flow: AuthCodeFlowState): void;
|
|
31
|
+
getAuthCodeFlow(internalState: string): AuthCodeFlowState | undefined;
|
|
32
|
+
deleteAuthCodeFlow(internalState: string): boolean;
|
|
33
|
+
getAuthCodeFlowCount(): number;
|
|
23
34
|
storeAuthCode(code: AuthorizationCode): void;
|
|
24
35
|
getAuthCode(code: string): AuthorizationCode | undefined;
|
|
25
36
|
deleteAuthCode(code: string): boolean;
|
|
26
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;
|
|
27
42
|
cleanup(): void;
|
|
28
43
|
private startCleanupInterval;
|
|
29
44
|
stopCleanupInterval(): void;
|
|
30
45
|
clear(): void;
|
|
46
|
+
close(): Promise<void>;
|
|
31
47
|
getStats(): {
|
|
32
48
|
sessions: number;
|
|
33
49
|
deviceFlows: number;
|
|
50
|
+
authCodeFlows: number;
|
|
34
51
|
authCodes: number;
|
|
35
52
|
};
|
|
36
53
|
}
|
|
@@ -1,16 +1,45 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.sessionStore = exports.SessionStore = void 0;
|
|
4
|
+
const storage_1 = require("./storage");
|
|
4
5
|
const logger_1 = require("../logger");
|
|
5
6
|
class SessionStore {
|
|
7
|
+
backend;
|
|
8
|
+
initialized = false;
|
|
6
9
|
sessions = new Map();
|
|
7
10
|
deviceFlows = new Map();
|
|
11
|
+
authCodeFlows = new Map();
|
|
8
12
|
authCodes = new Map();
|
|
9
13
|
tokenToSession = new Map();
|
|
10
14
|
refreshTokenToSession = new Map();
|
|
15
|
+
mcpSessionToOAuthSession = new Map();
|
|
11
16
|
cleanupIntervalId = null;
|
|
12
|
-
constructor() {
|
|
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
|
+
}
|
|
13
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;
|
|
14
43
|
}
|
|
15
44
|
createSession(session) {
|
|
16
45
|
this.sessions.set(session.id, session);
|
|
@@ -20,6 +49,9 @@ class SessionStore {
|
|
|
20
49
|
if (session.mcpRefreshToken) {
|
|
21
50
|
this.refreshTokenToSession.set(session.mcpRefreshToken, session.id);
|
|
22
51
|
}
|
|
52
|
+
this.backend.createSession(session).catch(err => {
|
|
53
|
+
logger_1.logger.error({ err, sessionId: session.id }, "Failed to persist session to backend");
|
|
54
|
+
});
|
|
23
55
|
logger_1.logger.debug({ sessionId: session.id, userId: session.gitlabUserId }, "Session created");
|
|
24
56
|
}
|
|
25
57
|
getSession(sessionId) {
|
|
@@ -48,6 +80,9 @@ class SessionStore {
|
|
|
48
80
|
this.refreshTokenToSession.set(updates.mcpRefreshToken, sessionId);
|
|
49
81
|
}
|
|
50
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
|
+
});
|
|
51
86
|
logger_1.logger.debug({ sessionId }, "Session updated");
|
|
52
87
|
return true;
|
|
53
88
|
}
|
|
@@ -63,6 +98,9 @@ class SessionStore {
|
|
|
63
98
|
this.refreshTokenToSession.delete(session.mcpRefreshToken);
|
|
64
99
|
}
|
|
65
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
|
+
});
|
|
66
104
|
logger_1.logger.debug({ sessionId }, "Session deleted");
|
|
67
105
|
return true;
|
|
68
106
|
}
|
|
@@ -74,6 +112,9 @@ class SessionStore {
|
|
|
74
112
|
}
|
|
75
113
|
storeDeviceFlow(state, flow) {
|
|
76
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
|
+
});
|
|
77
118
|
logger_1.logger.debug({ state, userCode: flow.userCode }, "Device flow stored");
|
|
78
119
|
}
|
|
79
120
|
getDeviceFlow(state) {
|
|
@@ -90,6 +131,9 @@ class SessionStore {
|
|
|
90
131
|
deleteDeviceFlow(state) {
|
|
91
132
|
const deleted = this.deviceFlows.delete(state);
|
|
92
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
|
+
});
|
|
93
137
|
logger_1.logger.debug({ state }, "Device flow deleted");
|
|
94
138
|
}
|
|
95
139
|
return deleted;
|
|
@@ -97,8 +141,34 @@ class SessionStore {
|
|
|
97
141
|
getDeviceFlowCount() {
|
|
98
142
|
return this.deviceFlows.size;
|
|
99
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
|
+
}
|
|
100
167
|
storeAuthCode(code) {
|
|
101
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
|
+
});
|
|
102
172
|
logger_1.logger.debug({ code: code.code.substring(0, 8) + "..." }, "Auth code stored");
|
|
103
173
|
}
|
|
104
174
|
getAuthCode(code) {
|
|
@@ -107,6 +177,9 @@ class SessionStore {
|
|
|
107
177
|
deleteAuthCode(code) {
|
|
108
178
|
const deleted = this.authCodes.delete(code);
|
|
109
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
|
+
});
|
|
110
183
|
logger_1.logger.debug({ code: code.substring(0, 8) + "..." }, "Auth code deleted");
|
|
111
184
|
}
|
|
112
185
|
return deleted;
|
|
@@ -114,13 +187,42 @@ class SessionStore {
|
|
|
114
187
|
getAuthCodeCount() {
|
|
115
188
|
return this.authCodes.size;
|
|
116
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
|
+
}
|
|
117
218
|
cleanup() {
|
|
118
219
|
const now = Date.now();
|
|
119
220
|
let expiredSessions = 0;
|
|
120
221
|
let expiredDeviceFlows = 0;
|
|
222
|
+
let expiredAuthCodeFlows = 0;
|
|
121
223
|
let expiredAuthCodes = 0;
|
|
224
|
+
const maxAge = 7 * 24 * 60 * 60 * 1000;
|
|
122
225
|
for (const [id, session] of this.sessions) {
|
|
123
|
-
const maxAge = 7 * 24 * 60 * 60 * 1000;
|
|
124
226
|
if (session.createdAt + maxAge < now) {
|
|
125
227
|
this.deleteSession(id);
|
|
126
228
|
expiredSessions++;
|
|
@@ -128,20 +230,30 @@ class SessionStore {
|
|
|
128
230
|
}
|
|
129
231
|
for (const [state, flow] of this.deviceFlows) {
|
|
130
232
|
if (flow.expiresAt < now) {
|
|
131
|
-
this.
|
|
233
|
+
this.deleteDeviceFlow(state);
|
|
132
234
|
expiredDeviceFlows++;
|
|
133
235
|
}
|
|
134
236
|
}
|
|
237
|
+
for (const [state, flow] of this.authCodeFlows) {
|
|
238
|
+
if (flow.expiresAt < now) {
|
|
239
|
+
this.deleteAuthCodeFlow(state);
|
|
240
|
+
expiredAuthCodeFlows++;
|
|
241
|
+
}
|
|
242
|
+
}
|
|
135
243
|
for (const [code, auth] of this.authCodes) {
|
|
136
244
|
if (auth.expiresAt < now) {
|
|
137
|
-
this.
|
|
245
|
+
this.deleteAuthCode(code);
|
|
138
246
|
expiredAuthCodes++;
|
|
139
247
|
}
|
|
140
248
|
}
|
|
141
|
-
if (expiredSessions > 0 ||
|
|
249
|
+
if (expiredSessions > 0 ||
|
|
250
|
+
expiredDeviceFlows > 0 ||
|
|
251
|
+
expiredAuthCodeFlows > 0 ||
|
|
252
|
+
expiredAuthCodes > 0) {
|
|
142
253
|
logger_1.logger.debug({
|
|
143
254
|
expiredSessions,
|
|
144
255
|
expiredDeviceFlows,
|
|
256
|
+
expiredAuthCodeFlows,
|
|
145
257
|
expiredAuthCodes,
|
|
146
258
|
remainingSessions: this.sessions.size,
|
|
147
259
|
}, "Session store cleanup completed");
|
|
@@ -164,15 +276,23 @@ class SessionStore {
|
|
|
164
276
|
clear() {
|
|
165
277
|
this.sessions.clear();
|
|
166
278
|
this.deviceFlows.clear();
|
|
279
|
+
this.authCodeFlows.clear();
|
|
167
280
|
this.authCodes.clear();
|
|
168
281
|
this.tokenToSession.clear();
|
|
169
282
|
this.refreshTokenToSession.clear();
|
|
283
|
+
this.mcpSessionToOAuthSession.clear();
|
|
170
284
|
logger_1.logger.debug("Session store cleared");
|
|
171
285
|
}
|
|
286
|
+
async close() {
|
|
287
|
+
this.stopCleanupInterval();
|
|
288
|
+
await this.backend.close();
|
|
289
|
+
logger_1.logger.info("Session store closed");
|
|
290
|
+
}
|
|
172
291
|
getStats() {
|
|
173
292
|
return {
|
|
174
293
|
sessions: this.sessions.size,
|
|
175
294
|
deviceFlows: this.deviceFlows.size,
|
|
295
|
+
authCodeFlows: this.authCodeFlows.size,
|
|
176
296
|
authCodes: this.authCodes.size,
|
|
177
297
|
};
|
|
178
298
|
}
|
|
@@ -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
|
+
}
|