gitlab-mcp-test 6.62.1
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/LICENSE +202 -0
- package/LICENSE.MIT +21 -0
- package/README.md +122 -0
- package/README.md.in +122 -0
- 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 +75 -0
- package/dist/generated/prisma/internal/class.js.map +1 -0
- package/dist/generated/prisma/internal/prismaNamespace.d.ts +714 -0
- package/dist/generated/prisma/internal/prismaNamespace.js +141 -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 +603 -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 +1037 -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/src/cli/docker/container-runtime.d.ts +4 -0
- package/dist/src/cli/docker/container-runtime.js +85 -0
- package/dist/src/cli/docker/container-runtime.js.map +1 -0
- package/dist/src/cli/docker/docker-command.d.ts +15 -0
- package/dist/src/cli/docker/docker-command.js +421 -0
- package/dist/src/cli/docker/docker-command.js.map +1 -0
- package/dist/src/cli/docker/docker-utils.d.ts +25 -0
- package/dist/src/cli/docker/docker-utils.js +386 -0
- package/dist/src/cli/docker/docker-utils.js.map +1 -0
- package/dist/src/cli/docker/index.d.ts +4 -0
- package/dist/src/cli/docker/index.js +24 -0
- package/dist/src/cli/docker/index.js.map +1 -0
- package/dist/src/cli/docker/types.d.ts +83 -0
- package/dist/src/cli/docker/types.js +21 -0
- package/dist/src/cli/docker/types.js.map +1 -0
- package/dist/src/cli/init/browser.d.ts +7 -0
- package/dist/src/cli/init/browser.js +27 -0
- package/dist/src/cli/init/browser.js.map +1 -0
- package/dist/src/cli/init/config-generator.d.ts +11 -0
- package/dist/src/cli/init/config-generator.js +87 -0
- package/dist/src/cli/init/config-generator.js.map +1 -0
- package/dist/src/cli/init/connection.d.ts +8 -0
- package/dist/src/cli/init/connection.js +118 -0
- package/dist/src/cli/init/connection.js.map +1 -0
- package/dist/src/cli/init/index.d.ts +4 -0
- package/dist/src/cli/init/index.js +32 -0
- package/dist/src/cli/init/index.js.map +1 -0
- package/dist/src/cli/init/types.d.ts +31 -0
- package/dist/src/cli/init/types.js +66 -0
- package/dist/src/cli/init/types.js.map +1 -0
- package/dist/src/cli/init/wizard.d.ts +1 -0
- package/dist/src/cli/init/wizard.js +283 -0
- package/dist/src/cli/init/wizard.js.map +1 -0
- package/dist/src/cli/inject-tool-refs.d.ts +35 -0
- package/dist/src/cli/inject-tool-refs.js +261 -0
- package/dist/src/cli/inject-tool-refs.js.map +1 -0
- package/dist/src/cli/install/backup.d.ts +4 -0
- package/dist/src/cli/install/backup.js +63 -0
- package/dist/src/cli/install/backup.js.map +1 -0
- package/dist/src/cli/install/detector.d.ts +10 -0
- package/dist/src/cli/install/detector.js +133 -0
- package/dist/src/cli/install/detector.js.map +1 -0
- package/dist/src/cli/install/index.d.ts +5 -0
- package/dist/src/cli/install/index.js +27 -0
- package/dist/src/cli/install/index.js.map +1 -0
- package/dist/src/cli/install/install-command.d.ts +19 -0
- package/dist/src/cli/install/install-command.js +300 -0
- package/dist/src/cli/install/install-command.js.map +1 -0
- package/dist/src/cli/install/installers.d.ts +12 -0
- package/dist/src/cli/install/installers.js +439 -0
- package/dist/src/cli/install/installers.js.map +1 -0
- package/dist/src/cli/install/types.d.ts +52 -0
- package/dist/src/cli/install/types.js +87 -0
- package/dist/src/cli/install/types.js.map +1 -0
- package/dist/src/cli/instances/index.d.ts +2 -0
- package/dist/src/cli/instances/index.js +7 -0
- package/dist/src/cli/instances/index.js.map +1 -0
- package/dist/src/cli/instances/instances-command.d.ts +6 -0
- package/dist/src/cli/instances/instances-command.js +351 -0
- package/dist/src/cli/instances/instances-command.js.map +1 -0
- package/dist/src/cli/list-tools.d.ts +2 -0
- package/dist/src/cli/list-tools.js +1431 -0
- package/dist/src/cli/list-tools.js.map +1 -0
- package/dist/src/cli/setup/discovery.d.ts +3 -0
- package/dist/src/cli/setup/discovery.js +71 -0
- package/dist/src/cli/setup/discovery.js.map +1 -0
- package/dist/src/cli/setup/flows/configure-existing.d.ts +2 -0
- package/dist/src/cli/setup/flows/configure-existing.js +211 -0
- package/dist/src/cli/setup/flows/configure-existing.js.map +1 -0
- package/dist/src/cli/setup/flows/local-setup.d.ts +2 -0
- package/dist/src/cli/setup/flows/local-setup.js +206 -0
- package/dist/src/cli/setup/flows/local-setup.js.map +1 -0
- package/dist/src/cli/setup/flows/server-setup.d.ts +2 -0
- package/dist/src/cli/setup/flows/server-setup.js +185 -0
- package/dist/src/cli/setup/flows/server-setup.js.map +1 -0
- package/dist/src/cli/setup/flows/tool-selection.d.ts +3 -0
- package/dist/src/cli/setup/flows/tool-selection.js +275 -0
- package/dist/src/cli/setup/flows/tool-selection.js.map +1 -0
- package/dist/src/cli/setup/index.d.ts +4 -0
- package/dist/src/cli/setup/index.js +29 -0
- package/dist/src/cli/setup/index.js.map +1 -0
- package/dist/src/cli/setup/presets.d.ts +7 -0
- package/dist/src/cli/setup/presets.js +261 -0
- package/dist/src/cli/setup/presets.js.map +1 -0
- package/dist/src/cli/setup/types.d.ts +68 -0
- package/dist/src/cli/setup/types.js +3 -0
- package/dist/src/cli/setup/types.js.map +1 -0
- package/dist/src/cli/setup/wizard.d.ts +4 -0
- package/dist/src/cli/setup/wizard.js +128 -0
- package/dist/src/cli/setup/wizard.js.map +1 -0
- package/dist/src/cli/utils/index.d.ts +1 -0
- package/dist/src/cli/utils/index.js +6 -0
- package/dist/src/cli/utils/index.js.map +1 -0
- package/dist/src/cli/utils/path-utils.d.ts +1 -0
- package/dist/src/cli/utils/path-utils.js +18 -0
- package/dist/src/cli/utils/path-utils.js.map +1 -0
- package/dist/src/cli-utils.d.ts +19 -0
- package/dist/src/cli-utils.js +183 -0
- package/dist/src/cli-utils.js.map +1 -0
- package/dist/src/config/index.d.ts +4 -0
- package/dist/src/config/index.js +19 -0
- package/dist/src/config/index.js.map +1 -0
- package/dist/src/config/instances-loader.d.ts +10 -0
- package/dist/src/config/instances-loader.js +294 -0
- package/dist/src/config/instances-loader.js.map +1 -0
- package/dist/src/config/instances-schema.d.ts +89 -0
- package/dist/src/config/instances-schema.js +196 -0
- package/dist/src/config/instances-schema.js.map +1 -0
- package/dist/src/config.d.ts +82 -0
- package/dist/src/config.js +379 -0
- package/dist/src/config.js.map +1 -0
- package/dist/src/dashboard/handler.d.ts +4 -0
- package/dist/src/dashboard/handler.js +37 -0
- package/dist/src/dashboard/handler.js.map +1 -0
- package/dist/src/dashboard/html-template.d.ts +2 -0
- package/dist/src/dashboard/html-template.js +443 -0
- package/dist/src/dashboard/html-template.js.map +1 -0
- package/dist/src/dashboard/index.d.ts +4 -0
- package/dist/src/dashboard/index.js +15 -0
- package/dist/src/dashboard/index.js.map +1 -0
- package/dist/src/dashboard/metrics.d.ts +79 -0
- package/dist/src/dashboard/metrics.js +194 -0
- package/dist/src/dashboard/metrics.js.map +1 -0
- package/dist/src/discovery/auto.d.ts +22 -0
- package/dist/src/discovery/auto.js +170 -0
- package/dist/src/discovery/auto.js.map +1 -0
- package/dist/src/discovery/git-remote.d.ts +19 -0
- package/dist/src/discovery/git-remote.js +197 -0
- package/dist/src/discovery/git-remote.js.map +1 -0
- package/dist/src/discovery/index.d.ts +3 -0
- package/dist/src/discovery/index.js +16 -0
- package/dist/src/discovery/index.js.map +1 -0
- package/dist/src/discovery/profile-matcher.d.ts +8 -0
- package/dist/src/discovery/profile-matcher.js +48 -0
- package/dist/src/discovery/profile-matcher.js.map +1 -0
- package/dist/src/entities/context/context-manager.d.ts +31 -0
- package/dist/src/entities/context/context-manager.js +352 -0
- package/dist/src/entities/context/context-manager.js.map +1 -0
- package/dist/src/entities/context/handlers.d.ts +11 -0
- package/dist/src/entities/context/handlers.js +67 -0
- package/dist/src/entities/context/handlers.js.map +1 -0
- package/dist/src/entities/context/index.d.ts +11 -0
- package/dist/src/entities/context/index.js +34 -0
- package/dist/src/entities/context/index.js.map +1 -0
- package/dist/src/entities/context/registry.d.ts +5 -0
- package/dist/src/entities/context/registry.js +66 -0
- package/dist/src/entities/context/registry.js.map +1 -0
- package/dist/src/entities/context/schema.d.ts +60 -0
- package/dist/src/entities/context/schema.js +61 -0
- package/dist/src/entities/context/schema.js.map +1 -0
- package/dist/src/entities/context/types.d.ts +112 -0
- package/dist/src/entities/context/types.js +3 -0
- package/dist/src/entities/context/types.js.map +1 -0
- package/dist/src/entities/context/whoami.d.ts +2 -0
- package/dist/src/entities/context/whoami.js +267 -0
- package/dist/src/entities/context/whoami.js.map +1 -0
- package/dist/src/entities/core/index.d.ts +7 -0
- package/dist/src/entities/core/index.js +31 -0
- package/dist/src/entities/core/index.js.map +1 -0
- package/dist/src/entities/core/registry.d.ts +5 -0
- package/dist/src/entities/core/registry.js +784 -0
- package/dist/src/entities/core/registry.js.map +1 -0
- package/dist/src/entities/core/schema-readonly.d.ts +268 -0
- package/dist/src/entities/core/schema-readonly.js +289 -0
- package/dist/src/entities/core/schema-readonly.js.map +1 -0
- package/dist/src/entities/core/schema.d.ts +116 -0
- package/dist/src/entities/core/schema.js +173 -0
- package/dist/src/entities/core/schema.js.map +1 -0
- package/dist/src/entities/files/index.d.ts +7 -0
- package/dist/src/entities/files/index.js +31 -0
- package/dist/src/entities/files/index.js.map +1 -0
- package/dist/src/entities/files/registry.d.ts +5 -0
- package/dist/src/entities/files/registry.js +267 -0
- package/dist/src/entities/files/registry.js.map +1 -0
- package/dist/src/entities/files/schema-readonly.d.ts +83 -0
- package/dist/src/entities/files/schema-readonly.js +64 -0
- package/dist/src/entities/files/schema-readonly.js.map +1 -0
- package/dist/src/entities/files/schema.d.ts +43 -0
- package/dist/src/entities/files/schema.js +54 -0
- package/dist/src/entities/files/schema.js.map +1 -0
- package/dist/src/entities/index.d.ts +17 -0
- package/dist/src/entities/index.js +34 -0
- package/dist/src/entities/index.js.map +1 -0
- package/dist/src/entities/integrations/index.d.ts +4 -0
- package/dist/src/entities/integrations/index.js +21 -0
- package/dist/src/entities/integrations/index.js.map +1 -0
- package/dist/src/entities/integrations/registry.d.ts +5 -0
- package/dist/src/entities/integrations/registry.js +127 -0
- package/dist/src/entities/integrations/registry.js.map +1 -0
- package/dist/src/entities/integrations/schema-readonly.d.ts +63 -0
- package/dist/src/entities/integrations/schema-readonly.js +22 -0
- package/dist/src/entities/integrations/schema-readonly.js.map +1 -0
- package/dist/src/entities/integrations/schema.d.ts +180 -0
- package/dist/src/entities/integrations/schema.js +106 -0
- package/dist/src/entities/integrations/schema.js.map +1 -0
- package/dist/src/entities/iterations/index.d.ts +2 -0
- package/dist/src/entities/iterations/index.js +19 -0
- package/dist/src/entities/iterations/index.js.map +1 -0
- package/dist/src/entities/iterations/registry.d.ts +5 -0
- package/dist/src/entities/iterations/registry.js +106 -0
- package/dist/src/entities/iterations/registry.js.map +1 -0
- package/dist/src/entities/iterations/schema-readonly.d.ts +21 -0
- package/dist/src/entities/iterations/schema-readonly.js +28 -0
- package/dist/src/entities/iterations/schema-readonly.js.map +1 -0
- package/dist/src/entities/labels/index.d.ts +7 -0
- package/dist/src/entities/labels/index.js +31 -0
- package/dist/src/entities/labels/index.js.map +1 -0
- package/dist/src/entities/labels/registry.d.ts +5 -0
- package/dist/src/entities/labels/registry.js +131 -0
- package/dist/src/entities/labels/registry.js.map +1 -0
- package/dist/src/entities/labels/schema-readonly.d.ts +16 -0
- package/dist/src/entities/labels/schema-readonly.js +28 -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 +46 -0
- package/dist/src/entities/labels/schema.js.map +1 -0
- package/dist/src/entities/members/index.d.ts +3 -0
- package/dist/src/entities/members/index.js +25 -0
- package/dist/src/entities/members/index.js.map +1 -0
- package/dist/src/entities/members/registry.d.ts +5 -0
- package/dist/src/entities/members/registry.js +224 -0
- package/dist/src/entities/members/registry.js.map +1 -0
- package/dist/src/entities/members/schema-readonly.d.ts +53 -0
- package/dist/src/entities/members/schema-readonly.js +79 -0
- package/dist/src/entities/members/schema-readonly.js.map +1 -0
- package/dist/src/entities/members/schema.d.ts +40 -0
- package/dist/src/entities/members/schema.js +80 -0
- package/dist/src/entities/members/schema.js.map +1 -0
- package/dist/src/entities/milestones/index.d.ts +7 -0
- package/dist/src/entities/milestones/index.js +31 -0
- package/dist/src/entities/milestones/index.js.map +1 -0
- package/dist/src/entities/milestones/registry.d.ts +5 -0
- package/dist/src/entities/milestones/registry.js +150 -0
- package/dist/src/entities/milestones/registry.js.map +1 -0
- package/dist/src/entities/milestones/schema-readonly.d.ts +57 -0
- package/dist/src/entities/milestones/schema-readonly.js +81 -0
- package/dist/src/entities/milestones/schema-readonly.js.map +1 -0
- package/dist/src/entities/milestones/schema.d.ts +30 -0
- package/dist/src/entities/milestones/schema.js +47 -0
- package/dist/src/entities/milestones/schema.js.map +1 -0
- package/dist/src/entities/mrs/index.d.ts +7 -0
- package/dist/src/entities/mrs/index.js +31 -0
- package/dist/src/entities/mrs/index.js.map +1 -0
- package/dist/src/entities/mrs/registry.d.ts +22 -0
- package/dist/src/entities/mrs/registry.js +495 -0
- package/dist/src/entities/mrs/registry.js.map +1 -0
- package/dist/src/entities/mrs/schema-readonly.d.ts +135 -0
- package/dist/src/entities/mrs/schema-readonly.js +326 -0
- package/dist/src/entities/mrs/schema-readonly.js.map +1 -0
- package/dist/src/entities/mrs/schema.d.ts +339 -0
- package/dist/src/entities/mrs/schema.js +259 -0
- package/dist/src/entities/mrs/schema.js.map +1 -0
- package/dist/src/entities/pipelines/index.d.ts +7 -0
- package/dist/src/entities/pipelines/index.js +31 -0
- package/dist/src/entities/pipelines/index.js.map +1 -0
- package/dist/src/entities/pipelines/registry.d.ts +5 -0
- package/dist/src/entities/pipelines/registry.js +323 -0
- package/dist/src/entities/pipelines/registry.js.map +1 -0
- package/dist/src/entities/pipelines/schema-readonly.d.ts +239 -0
- package/dist/src/entities/pipelines/schema-readonly.js +278 -0
- package/dist/src/entities/pipelines/schema-readonly.js.map +1 -0
- package/dist/src/entities/pipelines/schema.d.ts +47 -0
- package/dist/src/entities/pipelines/schema.js +73 -0
- package/dist/src/entities/pipelines/schema.js.map +1 -0
- package/dist/src/entities/refs/index.d.ts +3 -0
- package/dist/src/entities/refs/index.js +25 -0
- package/dist/src/entities/refs/index.js.map +1 -0
- package/dist/src/entities/refs/registry.d.ts +5 -0
- package/dist/src/entities/refs/registry.js +233 -0
- package/dist/src/entities/refs/registry.js.map +1 -0
- package/dist/src/entities/refs/schema-readonly.d.ts +48 -0
- package/dist/src/entities/refs/schema-readonly.js +76 -0
- package/dist/src/entities/refs/schema-readonly.js.map +1 -0
- package/dist/src/entities/refs/schema.d.ts +85 -0
- package/dist/src/entities/refs/schema.js +149 -0
- package/dist/src/entities/refs/schema.js.map +1 -0
- package/dist/src/entities/releases/index.d.ts +3 -0
- package/dist/src/entities/releases/index.js +13 -0
- package/dist/src/entities/releases/index.js.map +1 -0
- package/dist/src/entities/releases/registry.d.ts +5 -0
- package/dist/src/entities/releases/registry.js +183 -0
- package/dist/src/entities/releases/registry.js.map +1 -0
- package/dist/src/entities/releases/schema-readonly.d.ts +28 -0
- package/dist/src/entities/releases/schema-readonly.js +56 -0
- package/dist/src/entities/releases/schema-readonly.js.map +1 -0
- package/dist/src/entities/releases/schema.d.ts +56 -0
- package/dist/src/entities/releases/schema.js +97 -0
- package/dist/src/entities/releases/schema.js.map +1 -0
- package/dist/src/entities/search/index.d.ts +2 -0
- package/dist/src/entities/search/index.js +24 -0
- package/dist/src/entities/search/index.js.map +1 -0
- package/dist/src/entities/search/registry.d.ts +5 -0
- package/dist/src/entities/search/registry.js +113 -0
- package/dist/src/entities/search/registry.js.map +1 -0
- package/dist/src/entities/search/schema-readonly.d.ts +228 -0
- package/dist/src/entities/search/schema-readonly.js +64 -0
- package/dist/src/entities/search/schema-readonly.js.map +1 -0
- package/dist/src/entities/shared.d.ts +291 -0
- package/dist/src/entities/shared.js +269 -0
- package/dist/src/entities/shared.js.map +1 -0
- package/dist/src/entities/snippets/index.d.ts +7 -0
- package/dist/src/entities/snippets/index.js +31 -0
- package/dist/src/entities/snippets/index.js.map +1 -0
- package/dist/src/entities/snippets/registry.d.ts +5 -0
- package/dist/src/entities/snippets/registry.js +200 -0
- package/dist/src/entities/snippets/registry.js.map +1 -0
- package/dist/src/entities/snippets/schema-readonly.d.ts +25 -0
- package/dist/src/entities/snippets/schema-readonly.js +45 -0
- package/dist/src/entities/snippets/schema-readonly.js.map +1 -0
- package/dist/src/entities/snippets/schema.d.ts +56 -0
- package/dist/src/entities/snippets/schema.js +89 -0
- package/dist/src/entities/snippets/schema.js.map +1 -0
- package/dist/src/entities/utils.d.ts +16 -0
- package/dist/src/entities/utils.js +57 -0
- package/dist/src/entities/utils.js.map +1 -0
- package/dist/src/entities/variables/index.d.ts +7 -0
- package/dist/src/entities/variables/index.js +31 -0
- package/dist/src/entities/variables/index.js.map +1 -0
- package/dist/src/entities/variables/registry.d.ts +5 -0
- package/dist/src/entities/variables/registry.js +140 -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 +33 -0
- package/dist/src/entities/variables/schema-readonly.js.map +1 -0
- package/dist/src/entities/variables/schema.d.ts +41 -0
- package/dist/src/entities/variables/schema.js +92 -0
- package/dist/src/entities/variables/schema.js.map +1 -0
- package/dist/src/entities/webhooks/index.d.ts +4 -0
- package/dist/src/entities/webhooks/index.js +21 -0
- package/dist/src/entities/webhooks/index.js.map +1 -0
- package/dist/src/entities/webhooks/registry.d.ts +5 -0
- package/dist/src/entities/webhooks/registry.js +162 -0
- package/dist/src/entities/webhooks/registry.js.map +1 -0
- package/dist/src/entities/webhooks/schema-readonly.d.ts +22 -0
- package/dist/src/entities/webhooks/schema-readonly.js +25 -0
- package/dist/src/entities/webhooks/schema-readonly.js.map +1 -0
- package/dist/src/entities/webhooks/schema.d.ts +101 -0
- package/dist/src/entities/webhooks/schema.js +101 -0
- package/dist/src/entities/webhooks/schema.js.map +1 -0
- package/dist/src/entities/wiki/index.d.ts +7 -0
- package/dist/src/entities/wiki/index.js +31 -0
- package/dist/src/entities/wiki/index.js.map +1 -0
- package/dist/src/entities/wiki/registry.d.ts +5 -0
- package/dist/src/entities/wiki/registry.js +127 -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 +27 -0
- package/dist/src/entities/wiki/schema-readonly.js.map +1 -0
- package/dist/src/entities/wiki/schema.d.ts +30 -0
- package/dist/src/entities/wiki/schema.js +38 -0
- package/dist/src/entities/wiki/schema.js.map +1 -0
- package/dist/src/entities/workitems/index.d.ts +7 -0
- package/dist/src/entities/workitems/index.js +31 -0
- package/dist/src/entities/workitems/index.js.map +1 -0
- package/dist/src/entities/workitems/registry.d.ts +5 -0
- package/dist/src/entities/workitems/registry.js +725 -0
- package/dist/src/entities/workitems/registry.js.map +1 -0
- package/dist/src/entities/workitems/schema-readonly.d.ts +49 -0
- package/dist/src/entities/workitems/schema-readonly.js +87 -0
- package/dist/src/entities/workitems/schema-readonly.js.map +1 -0
- package/dist/src/entities/workitems/schema.d.ts +97 -0
- package/dist/src/entities/workitems/schema.js +187 -0
- package/dist/src/entities/workitems/schema.js.map +1 -0
- package/dist/src/graphql/DynamicWorkItemsQuery.d.ts +56 -0
- package/dist/src/graphql/DynamicWorkItemsQuery.js +190 -0
- package/dist/src/graphql/DynamicWorkItemsQuery.js.map +1 -0
- package/dist/src/graphql/client.d.ts +17 -0
- package/dist/src/graphql/client.js +56 -0
- package/dist/src/graphql/client.js.map +1 -0
- package/dist/src/graphql/index.d.ts +2 -0
- package/dist/src/graphql/index.js +21 -0
- package/dist/src/graphql/index.js.map +1 -0
- package/dist/src/graphql/workItems.d.ts +659 -0
- package/dist/src/graphql/workItems.js +1545 -0
- package/dist/src/graphql/workItems.js.map +1 -0
- package/dist/src/handlers.d.ts +2 -0
- package/dist/src/handlers.js +346 -0
- package/dist/src/handlers.js.map +1 -0
- package/dist/src/http-client.d.ts +1 -0
- package/dist/src/http-client.js +9 -0
- package/dist/src/http-client.js.map +1 -0
- package/dist/src/logger.d.ts +9 -0
- package/dist/src/logger.js +129 -0
- package/dist/src/logger.js.map +1 -0
- package/dist/src/logging/access-log.d.ts +15 -0
- package/dist/src/logging/access-log.js +157 -0
- package/dist/src/logging/access-log.js.map +1 -0
- package/dist/src/logging/connection-tracker.d.ts +21 -0
- package/dist/src/logging/connection-tracker.js +106 -0
- package/dist/src/logging/connection-tracker.js.map +1 -0
- package/dist/src/logging/index.d.ts +5 -0
- package/dist/src/logging/index.js +27 -0
- package/dist/src/logging/index.js.map +1 -0
- package/dist/src/logging/request-tracker.d.ts +39 -0
- package/dist/src/logging/request-tracker.js +208 -0
- package/dist/src/logging/request-tracker.js.map +1 -0
- package/dist/src/logging/types.d.ts +55 -0
- package/dist/src/logging/types.js +5 -0
- package/dist/src/logging/types.js.map +1 -0
- package/dist/src/main.d.ts +2 -0
- package/dist/src/main.js +219 -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 +137 -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 +183 -0
- package/dist/src/middleware/rate-limiter.js.map +1 -0
- package/dist/src/oauth/config.d.ts +25 -0
- package/dist/src/oauth/config.js +109 -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 +134 -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 +19 -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 +42 -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 +167 -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 +69 -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 +311 -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 +73 -0
- package/dist/src/oauth/storage/factory.js.map +1 -0
- package/dist/src/oauth/storage/file.d.ts +48 -0
- package/dist/src/oauth/storage/file.js +307 -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 +280 -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 +444 -0
- package/dist/src/oauth/storage/postgresql.js.map +1 -0
- package/dist/src/oauth/storage/types.d.ts +66 -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 +10 -0
- package/dist/src/oauth/token-context.js +50 -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 +117 -0
- package/dist/src/oauth/types.js +3 -0
- package/dist/src/oauth/types.js.map +1 -0
- package/dist/src/profiles/applicator.d.ts +19 -0
- package/dist/src/profiles/applicator.js +256 -0
- package/dist/src/profiles/applicator.js.map +1 -0
- package/dist/src/profiles/builtin/admin.yaml +30 -0
- package/dist/src/profiles/builtin/ci.yaml +35 -0
- package/dist/src/profiles/builtin/code-reviewer.yaml +41 -0
- package/dist/src/profiles/builtin/developer.yaml +40 -0
- package/dist/src/profiles/builtin/devops.yaml +33 -0
- package/dist/src/profiles/builtin/full-access.yaml +29 -0
- package/dist/src/profiles/builtin/gitlab-com.yaml +40 -0
- package/dist/src/profiles/builtin/junior-dev.yaml +35 -0
- package/dist/src/profiles/builtin/pm.yaml +36 -0
- package/dist/src/profiles/builtin/readonly.yaml +33 -0
- package/dist/src/profiles/builtin/senior-dev.yaml +41 -0
- package/dist/src/profiles/builtin/team-lead.yaml +42 -0
- package/dist/src/profiles/index.d.ts +5 -0
- package/dist/src/profiles/index.js +34 -0
- package/dist/src/profiles/index.js.map +1 -0
- package/dist/src/profiles/loader.d.ts +32 -0
- package/dist/src/profiles/loader.js +319 -0
- package/dist/src/profiles/loader.js.map +1 -0
- package/dist/src/profiles/project-loader.d.ts +12 -0
- package/dist/src/profiles/project-loader.js +214 -0
- package/dist/src/profiles/project-loader.js.map +1 -0
- package/dist/src/profiles/scope-enforcer.d.ts +28 -0
- package/dist/src/profiles/scope-enforcer.js +236 -0
- package/dist/src/profiles/scope-enforcer.js.map +1 -0
- package/dist/src/profiles/types.d.ts +261 -0
- package/dist/src/profiles/types.js +153 -0
- package/dist/src/profiles/types.js.map +1 -0
- package/dist/src/registry-manager.d.ts +37 -0
- package/dist/src/registry-manager.js +488 -0
- package/dist/src/registry-manager.js.map +1 -0
- package/dist/src/server.d.ts +2 -0
- package/dist/src/server.js +624 -0
- package/dist/src/server.js.map +1 -0
- package/dist/src/services/ConnectionManager.d.ts +41 -0
- package/dist/src/services/ConnectionManager.js +438 -0
- package/dist/src/services/ConnectionManager.js.map +1 -0
- package/dist/src/services/GitLabVersionDetector.d.ts +52 -0
- package/dist/src/services/GitLabVersionDetector.js +215 -0
- package/dist/src/services/GitLabVersionDetector.js.map +1 -0
- package/dist/src/services/InstanceConnectionPool.d.ts +54 -0
- package/dist/src/services/InstanceConnectionPool.js +180 -0
- package/dist/src/services/InstanceConnectionPool.js.map +1 -0
- package/dist/src/services/InstanceRateLimiter.d.ts +35 -0
- package/dist/src/services/InstanceRateLimiter.js +131 -0
- package/dist/src/services/InstanceRateLimiter.js.map +1 -0
- package/dist/src/services/InstanceRegistry.d.ts +61 -0
- package/dist/src/services/InstanceRegistry.js +250 -0
- package/dist/src/services/InstanceRegistry.js.map +1 -0
- package/dist/src/services/NamespaceTierDetector.d.ts +9 -0
- package/dist/src/services/NamespaceTierDetector.js +249 -0
- package/dist/src/services/NamespaceTierDetector.js.map +1 -0
- package/dist/src/services/SchemaIntrospector.d.ts +39 -0
- package/dist/src/services/SchemaIntrospector.js +190 -0
- package/dist/src/services/SchemaIntrospector.js.map +1 -0
- package/dist/src/services/TokenScopeDetector.d.ts +35 -0
- package/dist/src/services/TokenScopeDetector.js +232 -0
- package/dist/src/services/TokenScopeDetector.js.map +1 -0
- package/dist/src/services/ToolAvailability.d.ts +32 -0
- package/dist/src/services/ToolAvailability.js +410 -0
- package/dist/src/services/ToolAvailability.js.map +1 -0
- package/dist/src/services/WidgetAvailability.d.ts +23 -0
- package/dist/src/services/WidgetAvailability.js +158 -0
- package/dist/src/services/WidgetAvailability.js.map +1 -0
- package/dist/src/session-manager.d.ts +19 -0
- package/dist/src/session-manager.js +131 -0
- package/dist/src/session-manager.js.map +1 -0
- package/dist/src/types.d.ts +28 -0
- package/dist/src/types.js +11 -0
- package/dist/src/types.js.map +1 -0
- package/dist/src/utils/description-utils.d.ts +2 -0
- package/dist/src/utils/description-utils.js +25 -0
- package/dist/src/utils/description-utils.js.map +1 -0
- package/dist/src/utils/error-handler.d.ts +93 -0
- package/dist/src/utils/error-handler.js +597 -0
- package/dist/src/utils/error-handler.js.map +1 -0
- package/dist/src/utils/fetch.d.ts +13 -0
- package/dist/src/utils/fetch.js +539 -0
- package/dist/src/utils/fetch.js.map +1 -0
- package/dist/src/utils/gitlab-api.d.ts +24 -0
- package/dist/src/utils/gitlab-api.js +139 -0
- package/dist/src/utils/gitlab-api.js.map +1 -0
- package/dist/src/utils/idConversion.d.ts +81 -0
- package/dist/src/utils/idConversion.js +193 -0
- package/dist/src/utils/idConversion.js.map +1 -0
- package/dist/src/utils/namespace.d.ts +7 -0
- package/dist/src/utils/namespace.js +59 -0
- package/dist/src/utils/namespace.js.map +1 -0
- package/dist/src/utils/projectIdentifier.d.ts +9 -0
- package/dist/src/utils/projectIdentifier.js +59 -0
- package/dist/src/utils/projectIdentifier.js.map +1 -0
- package/dist/src/utils/request-logger.d.ts +24 -0
- package/dist/src/utils/request-logger.js +55 -0
- package/dist/src/utils/request-logger.js.map +1 -0
- package/dist/src/utils/schema-utils.d.ts +31 -0
- package/dist/src/utils/schema-utils.js +288 -0
- package/dist/src/utils/schema-utils.js.map +1 -0
- package/dist/src/utils/smart-user-search.d.ts +33 -0
- package/dist/src/utils/smart-user-search.js +142 -0
- package/dist/src/utils/smart-user-search.js.map +1 -0
- package/dist/src/utils/version.d.ts +1 -0
- package/dist/src/utils/version.js +14 -0
- package/dist/src/utils/version.js.map +1 -0
- package/dist/src/utils/workItemTypes.d.ts +6 -0
- package/dist/src/utils/workItemTypes.js +14 -0
- package/dist/src/utils/workItemTypes.js.map +1 -0
- package/dist/tsconfig.build.tsbuildinfo +1 -0
- package/package.json +511 -0
|
@@ -0,0 +1,157 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AccessLogFormatter = void 0;
|
|
4
|
+
exports.truncateSessionId = truncateSessionId;
|
|
5
|
+
exports.formatDuration = formatDuration;
|
|
6
|
+
exports.formatGitLabStatus = formatGitLabStatus;
|
|
7
|
+
exports.formatDetails = formatDetails;
|
|
8
|
+
exports.createAccessLogEntry = createAccessLogEntry;
|
|
9
|
+
exports.formatAccessLog = formatAccessLog;
|
|
10
|
+
exports.createConnectionCloseEntry = createConnectionCloseEntry;
|
|
11
|
+
exports.formatConnectionClose = formatConnectionClose;
|
|
12
|
+
const logger_js_1 = require("../logger.js");
|
|
13
|
+
function truncateSessionId(sessionId) {
|
|
14
|
+
if (!sessionId)
|
|
15
|
+
return "-";
|
|
16
|
+
return (0, logger_js_1.truncateId)(sessionId);
|
|
17
|
+
}
|
|
18
|
+
function formatDuration(ms) {
|
|
19
|
+
const seconds = Math.floor(ms / 1000);
|
|
20
|
+
const minutes = Math.floor(seconds / 60);
|
|
21
|
+
const hours = Math.floor(minutes / 60);
|
|
22
|
+
if (hours > 0) {
|
|
23
|
+
const remainingMinutes = minutes % 60;
|
|
24
|
+
return `${hours}h${remainingMinutes}m`;
|
|
25
|
+
}
|
|
26
|
+
if (minutes > 0) {
|
|
27
|
+
const remainingSeconds = seconds % 60;
|
|
28
|
+
return `${minutes}m${remainingSeconds}s`;
|
|
29
|
+
}
|
|
30
|
+
return `${seconds}s`;
|
|
31
|
+
}
|
|
32
|
+
function formatGitLabStatus(status) {
|
|
33
|
+
if (status === undefined)
|
|
34
|
+
return "-";
|
|
35
|
+
if (status === "timeout")
|
|
36
|
+
return "GL:timeout";
|
|
37
|
+
if (status === "error")
|
|
38
|
+
return "GL:error";
|
|
39
|
+
return `GL:${status}`;
|
|
40
|
+
}
|
|
41
|
+
function escapeLogValue(value) {
|
|
42
|
+
return value
|
|
43
|
+
.replace(/\\/g, "\\\\")
|
|
44
|
+
.replace(/"/g, '\\"')
|
|
45
|
+
.replace(/\n/g, "\\n")
|
|
46
|
+
.replace(/\r/g, "\\r")
|
|
47
|
+
.replace(/\t/g, "\\t");
|
|
48
|
+
}
|
|
49
|
+
function needsQuoting(value) {
|
|
50
|
+
return /[\s"\\]/.test(value) || /[\n\r\t]/.test(value);
|
|
51
|
+
}
|
|
52
|
+
function formatDetails(details) {
|
|
53
|
+
const entries = Object.entries(details);
|
|
54
|
+
if (entries.length === 0)
|
|
55
|
+
return "";
|
|
56
|
+
return entries
|
|
57
|
+
.map(([key, value]) => {
|
|
58
|
+
const strValue = String(value);
|
|
59
|
+
if (needsQuoting(strValue)) {
|
|
60
|
+
return `${key}="${escapeLogValue(strValue)}"`;
|
|
61
|
+
}
|
|
62
|
+
return `${key}=${strValue}`;
|
|
63
|
+
})
|
|
64
|
+
.join(" ");
|
|
65
|
+
}
|
|
66
|
+
function createAccessLogEntry(stack) {
|
|
67
|
+
const now = Date.now();
|
|
68
|
+
const durationMs = now - stack.startTime;
|
|
69
|
+
return {
|
|
70
|
+
timestamp: new Date(now).toISOString(),
|
|
71
|
+
clientIp: stack.clientIp,
|
|
72
|
+
session: truncateSessionId(stack.sessionId),
|
|
73
|
+
ctx: stack.context ?? "-",
|
|
74
|
+
ro: stack.readOnly ? "RO" : "-",
|
|
75
|
+
method: stack.method,
|
|
76
|
+
path: stack.path,
|
|
77
|
+
status: stack.status ?? 0,
|
|
78
|
+
durationMs,
|
|
79
|
+
tool: stack.tool ?? "-",
|
|
80
|
+
action: stack.action ?? "-",
|
|
81
|
+
gitlabStatus: formatGitLabStatus(stack.gitlabStatus),
|
|
82
|
+
gitlabDurationMs: stack.gitlabDuration !== undefined ? `${stack.gitlabDuration}ms` : "-",
|
|
83
|
+
details: formatDetails(stack.details),
|
|
84
|
+
};
|
|
85
|
+
}
|
|
86
|
+
function formatAccessLog(entry) {
|
|
87
|
+
const parts = [
|
|
88
|
+
entry.clientIp,
|
|
89
|
+
entry.session,
|
|
90
|
+
entry.ctx,
|
|
91
|
+
entry.ro,
|
|
92
|
+
entry.method,
|
|
93
|
+
entry.path,
|
|
94
|
+
String(entry.status),
|
|
95
|
+
`${entry.durationMs}ms`,
|
|
96
|
+
"|",
|
|
97
|
+
entry.tool,
|
|
98
|
+
entry.action,
|
|
99
|
+
"|",
|
|
100
|
+
entry.gitlabStatus,
|
|
101
|
+
entry.gitlabDurationMs,
|
|
102
|
+
"|",
|
|
103
|
+
entry.details || "-",
|
|
104
|
+
];
|
|
105
|
+
return parts.join(" ");
|
|
106
|
+
}
|
|
107
|
+
function createConnectionCloseEntry(stats, reason) {
|
|
108
|
+
const now = Date.now();
|
|
109
|
+
const durationMs = now - stats.connectedAt;
|
|
110
|
+
return {
|
|
111
|
+
timestamp: new Date(now).toISOString(),
|
|
112
|
+
clientIp: stats.clientIp,
|
|
113
|
+
session: truncateSessionId(stats.sessionId),
|
|
114
|
+
duration: formatDuration(durationMs),
|
|
115
|
+
reason,
|
|
116
|
+
requests: stats.requestCount,
|
|
117
|
+
tools: stats.toolCount,
|
|
118
|
+
errors: stats.errorCount,
|
|
119
|
+
lastError: stats.lastError,
|
|
120
|
+
};
|
|
121
|
+
}
|
|
122
|
+
function formatConnectionClose(entry) {
|
|
123
|
+
const parts = [
|
|
124
|
+
`[${entry.timestamp}]`,
|
|
125
|
+
"CONN_CLOSE",
|
|
126
|
+
entry.clientIp,
|
|
127
|
+
entry.session,
|
|
128
|
+
entry.duration,
|
|
129
|
+
entry.reason,
|
|
130
|
+
"|",
|
|
131
|
+
`reqs=${entry.requests}`,
|
|
132
|
+
`tools=${entry.tools}`,
|
|
133
|
+
`errs=${entry.errors}`,
|
|
134
|
+
];
|
|
135
|
+
if (entry.lastError) {
|
|
136
|
+
parts.push(`last_err="${escapeLogValue(entry.lastError)}"`);
|
|
137
|
+
}
|
|
138
|
+
return parts.join(" ");
|
|
139
|
+
}
|
|
140
|
+
class AccessLogFormatter {
|
|
141
|
+
formatRequest(stack) {
|
|
142
|
+
const entry = createAccessLogEntry(stack);
|
|
143
|
+
return formatAccessLog(entry);
|
|
144
|
+
}
|
|
145
|
+
formatConnectionClose(stats, reason) {
|
|
146
|
+
const entry = createConnectionCloseEntry(stats, reason);
|
|
147
|
+
return formatConnectionClose(entry);
|
|
148
|
+
}
|
|
149
|
+
getAccessLogEntry(stack) {
|
|
150
|
+
return createAccessLogEntry(stack);
|
|
151
|
+
}
|
|
152
|
+
getConnectionCloseEntry(stats, reason) {
|
|
153
|
+
return createConnectionCloseEntry(stats, reason);
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
exports.AccessLogFormatter = AccessLogFormatter;
|
|
157
|
+
//# sourceMappingURL=access-log.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"access-log.js","sourceRoot":"","sources":["../../../src/logging/access-log.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import type { ConnectionStats, ConnectionCloseReason } from "./types.js";
|
|
2
|
+
export declare class ConnectionTracker {
|
|
3
|
+
private connections;
|
|
4
|
+
private enabled;
|
|
5
|
+
constructor(enabled?: boolean);
|
|
6
|
+
isEnabled(): boolean;
|
|
7
|
+
setEnabled(enabled: boolean): void;
|
|
8
|
+
openConnection(sessionId: string, clientIp: string): void;
|
|
9
|
+
getStats(sessionId: string): ConnectionStats | undefined;
|
|
10
|
+
incrementRequests(sessionId: string): void;
|
|
11
|
+
incrementTools(sessionId: string): void;
|
|
12
|
+
recordError(sessionId: string, error: string): void;
|
|
13
|
+
closeConnection(sessionId: string, reason: ConnectionCloseReason): string | undefined;
|
|
14
|
+
hasConnection(sessionId: string): boolean;
|
|
15
|
+
getActiveConnectionCount(): number;
|
|
16
|
+
getAllSessionIds(): string[];
|
|
17
|
+
closeAllConnections(reason?: ConnectionCloseReason): void;
|
|
18
|
+
clear(): void;
|
|
19
|
+
}
|
|
20
|
+
export declare function getConnectionTracker(): ConnectionTracker;
|
|
21
|
+
export declare function resetConnectionTracker(): void;
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ConnectionTracker = void 0;
|
|
4
|
+
exports.getConnectionTracker = getConnectionTracker;
|
|
5
|
+
exports.resetConnectionTracker = resetConnectionTracker;
|
|
6
|
+
const access_log_js_1 = require("./access-log.js");
|
|
7
|
+
const logger_js_1 = require("../logger.js");
|
|
8
|
+
class ConnectionTracker {
|
|
9
|
+
connections = new Map();
|
|
10
|
+
enabled;
|
|
11
|
+
constructor(enabled = true) {
|
|
12
|
+
this.enabled = enabled;
|
|
13
|
+
}
|
|
14
|
+
isEnabled() {
|
|
15
|
+
return this.enabled;
|
|
16
|
+
}
|
|
17
|
+
setEnabled(enabled) {
|
|
18
|
+
this.enabled = enabled;
|
|
19
|
+
}
|
|
20
|
+
openConnection(sessionId, clientIp) {
|
|
21
|
+
if (!this.enabled)
|
|
22
|
+
return;
|
|
23
|
+
const stats = {
|
|
24
|
+
connectedAt: Date.now(),
|
|
25
|
+
clientIp,
|
|
26
|
+
sessionId,
|
|
27
|
+
requestCount: 0,
|
|
28
|
+
toolCount: 0,
|
|
29
|
+
errorCount: 0,
|
|
30
|
+
};
|
|
31
|
+
this.connections.set(sessionId, stats);
|
|
32
|
+
(0, logger_js_1.logDebug)("Connection opened for tracking", { sessionId, clientIp });
|
|
33
|
+
}
|
|
34
|
+
getStats(sessionId) {
|
|
35
|
+
return this.connections.get(sessionId);
|
|
36
|
+
}
|
|
37
|
+
incrementRequests(sessionId) {
|
|
38
|
+
const stats = this.connections.get(sessionId);
|
|
39
|
+
if (!stats)
|
|
40
|
+
return;
|
|
41
|
+
stats.requestCount++;
|
|
42
|
+
}
|
|
43
|
+
incrementTools(sessionId) {
|
|
44
|
+
const stats = this.connections.get(sessionId);
|
|
45
|
+
if (!stats)
|
|
46
|
+
return;
|
|
47
|
+
stats.toolCount++;
|
|
48
|
+
}
|
|
49
|
+
recordError(sessionId, error) {
|
|
50
|
+
const stats = this.connections.get(sessionId);
|
|
51
|
+
if (!stats)
|
|
52
|
+
return;
|
|
53
|
+
stats.errorCount++;
|
|
54
|
+
stats.lastError = error;
|
|
55
|
+
}
|
|
56
|
+
closeConnection(sessionId, reason) {
|
|
57
|
+
const stats = this.connections.get(sessionId);
|
|
58
|
+
if (!stats) {
|
|
59
|
+
if (this.enabled) {
|
|
60
|
+
(0, logger_js_1.logDebug)("Connection not found on close", { sessionId });
|
|
61
|
+
}
|
|
62
|
+
return undefined;
|
|
63
|
+
}
|
|
64
|
+
this.connections.delete(sessionId);
|
|
65
|
+
if (!this.enabled) {
|
|
66
|
+
return undefined;
|
|
67
|
+
}
|
|
68
|
+
const entry = (0, access_log_js_1.createConnectionCloseEntry)(stats, reason);
|
|
69
|
+
const logLine = (0, access_log_js_1.formatConnectionClose)(entry);
|
|
70
|
+
if (logger_js_1.LOG_JSON) {
|
|
71
|
+
(0, logger_js_1.logInfo)(logLine, { connectionClose: entry });
|
|
72
|
+
}
|
|
73
|
+
else {
|
|
74
|
+
(0, logger_js_1.logInfo)(logLine);
|
|
75
|
+
}
|
|
76
|
+
return logLine;
|
|
77
|
+
}
|
|
78
|
+
hasConnection(sessionId) {
|
|
79
|
+
return this.connections.has(sessionId);
|
|
80
|
+
}
|
|
81
|
+
getActiveConnectionCount() {
|
|
82
|
+
return this.connections.size;
|
|
83
|
+
}
|
|
84
|
+
getAllSessionIds() {
|
|
85
|
+
return Array.from(this.connections.keys());
|
|
86
|
+
}
|
|
87
|
+
closeAllConnections(reason = "server_shutdown") {
|
|
88
|
+
const sessionIds = this.getAllSessionIds();
|
|
89
|
+
for (const sessionId of sessionIds) {
|
|
90
|
+
this.closeConnection(sessionId, reason);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
clear() {
|
|
94
|
+
this.connections.clear();
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
exports.ConnectionTracker = ConnectionTracker;
|
|
98
|
+
let globalConnectionTracker = null;
|
|
99
|
+
function getConnectionTracker() {
|
|
100
|
+
globalConnectionTracker ??= new ConnectionTracker();
|
|
101
|
+
return globalConnectionTracker;
|
|
102
|
+
}
|
|
103
|
+
function resetConnectionTracker() {
|
|
104
|
+
globalConnectionTracker = null;
|
|
105
|
+
}
|
|
106
|
+
//# sourceMappingURL=connection-tracker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"connection-tracker.js","sourceRoot":"","sources":["../../../src/logging/connection-tracker.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export type { RequestStack, ConnectionStats, AccessLogEntry, ConnectionCloseEntry, ConnectionCloseReason, LogFormat, } from "./types.js";
|
|
2
|
+
export { DEFAULT_LOG_FORMAT } from "./types.js";
|
|
3
|
+
export { AccessLogFormatter, truncateSessionId, formatDuration, formatGitLabStatus, formatDetails, formatAccessLog, formatConnectionClose, createAccessLogEntry, createConnectionCloseEntry, } from "./access-log.js";
|
|
4
|
+
export { RequestTracker, getRequestTracker, resetRequestTracker, getCurrentRequestId, runWithRequestContext, runWithRequestContextAsync, type RequestContext, } from "./request-tracker.js";
|
|
5
|
+
export { ConnectionTracker, getConnectionTracker, resetConnectionTracker, } from "./connection-tracker.js";
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.resetConnectionTracker = exports.getConnectionTracker = exports.ConnectionTracker = exports.runWithRequestContextAsync = exports.runWithRequestContext = exports.getCurrentRequestId = exports.resetRequestTracker = exports.getRequestTracker = exports.RequestTracker = exports.createConnectionCloseEntry = exports.createAccessLogEntry = exports.formatConnectionClose = exports.formatAccessLog = exports.formatDetails = exports.formatGitLabStatus = exports.formatDuration = exports.truncateSessionId = exports.AccessLogFormatter = exports.DEFAULT_LOG_FORMAT = void 0;
|
|
4
|
+
var types_js_1 = require("./types.js");
|
|
5
|
+
Object.defineProperty(exports, "DEFAULT_LOG_FORMAT", { enumerable: true, get: function () { return types_js_1.DEFAULT_LOG_FORMAT; } });
|
|
6
|
+
var access_log_js_1 = require("./access-log.js");
|
|
7
|
+
Object.defineProperty(exports, "AccessLogFormatter", { enumerable: true, get: function () { return access_log_js_1.AccessLogFormatter; } });
|
|
8
|
+
Object.defineProperty(exports, "truncateSessionId", { enumerable: true, get: function () { return access_log_js_1.truncateSessionId; } });
|
|
9
|
+
Object.defineProperty(exports, "formatDuration", { enumerable: true, get: function () { return access_log_js_1.formatDuration; } });
|
|
10
|
+
Object.defineProperty(exports, "formatGitLabStatus", { enumerable: true, get: function () { return access_log_js_1.formatGitLabStatus; } });
|
|
11
|
+
Object.defineProperty(exports, "formatDetails", { enumerable: true, get: function () { return access_log_js_1.formatDetails; } });
|
|
12
|
+
Object.defineProperty(exports, "formatAccessLog", { enumerable: true, get: function () { return access_log_js_1.formatAccessLog; } });
|
|
13
|
+
Object.defineProperty(exports, "formatConnectionClose", { enumerable: true, get: function () { return access_log_js_1.formatConnectionClose; } });
|
|
14
|
+
Object.defineProperty(exports, "createAccessLogEntry", { enumerable: true, get: function () { return access_log_js_1.createAccessLogEntry; } });
|
|
15
|
+
Object.defineProperty(exports, "createConnectionCloseEntry", { enumerable: true, get: function () { return access_log_js_1.createConnectionCloseEntry; } });
|
|
16
|
+
var request_tracker_js_1 = require("./request-tracker.js");
|
|
17
|
+
Object.defineProperty(exports, "RequestTracker", { enumerable: true, get: function () { return request_tracker_js_1.RequestTracker; } });
|
|
18
|
+
Object.defineProperty(exports, "getRequestTracker", { enumerable: true, get: function () { return request_tracker_js_1.getRequestTracker; } });
|
|
19
|
+
Object.defineProperty(exports, "resetRequestTracker", { enumerable: true, get: function () { return request_tracker_js_1.resetRequestTracker; } });
|
|
20
|
+
Object.defineProperty(exports, "getCurrentRequestId", { enumerable: true, get: function () { return request_tracker_js_1.getCurrentRequestId; } });
|
|
21
|
+
Object.defineProperty(exports, "runWithRequestContext", { enumerable: true, get: function () { return request_tracker_js_1.runWithRequestContext; } });
|
|
22
|
+
Object.defineProperty(exports, "runWithRequestContextAsync", { enumerable: true, get: function () { return request_tracker_js_1.runWithRequestContextAsync; } });
|
|
23
|
+
var connection_tracker_js_1 = require("./connection-tracker.js");
|
|
24
|
+
Object.defineProperty(exports, "ConnectionTracker", { enumerable: true, get: function () { return connection_tracker_js_1.ConnectionTracker; } });
|
|
25
|
+
Object.defineProperty(exports, "getConnectionTracker", { enumerable: true, get: function () { return connection_tracker_js_1.getConnectionTracker; } });
|
|
26
|
+
Object.defineProperty(exports, "resetConnectionTracker", { enumerable: true, get: function () { return connection_tracker_js_1.resetConnectionTracker; } });
|
|
27
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/logging/index.ts"],"names":[],"mappings":";;;AAiBA,uCAAgD;AAAvC,8GAAA,kBAAkB,OAAA;AAG3B,iDAUyB;AATvB,mHAAA,kBAAkB,OAAA;AAClB,kHAAA,iBAAiB,OAAA;AACjB,+GAAA,cAAc,OAAA;AACd,mHAAA,kBAAkB,OAAA;AAClB,8GAAA,aAAa,OAAA;AACb,gHAAA,eAAe,OAAA;AACf,sHAAA,qBAAqB,OAAA;AACrB,qHAAA,oBAAoB,OAAA;AACpB,2HAAA,0BAA0B,OAAA;AAI5B,2DAQ8B;AAP5B,oHAAA,cAAc,OAAA;AACd,uHAAA,iBAAiB,OAAA;AACjB,yHAAA,mBAAmB,OAAA;AACnB,yHAAA,mBAAmB,OAAA;AACnB,2HAAA,qBAAqB,OAAA;AACrB,gIAAA,0BAA0B,OAAA;AAK5B,iEAIiC;AAH/B,0HAAA,iBAAiB,OAAA;AACjB,6HAAA,oBAAoB,OAAA;AACpB,+HAAA,sBAAsB,OAAA"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import type { RequestStack } from "./types.js";
|
|
2
|
+
export interface RequestContext {
|
|
3
|
+
requestId: string;
|
|
4
|
+
}
|
|
5
|
+
export declare function getCurrentRequestId(): string | undefined;
|
|
6
|
+
export declare function runWithRequestContext<T>(requestId: string, fn: () => T): T;
|
|
7
|
+
export declare function runWithRequestContextAsync<T>(requestId: string, fn: () => Promise<T>): Promise<T>;
|
|
8
|
+
export declare class RequestTracker {
|
|
9
|
+
private stacks;
|
|
10
|
+
private enabled;
|
|
11
|
+
constructor(enabled?: boolean);
|
|
12
|
+
isEnabled(): boolean;
|
|
13
|
+
setEnabled(enabled: boolean): void;
|
|
14
|
+
openStack(requestId: string, clientIp: string, method: string, path: string, sessionId?: string): void;
|
|
15
|
+
getStack(requestId: string): RequestStack | undefined;
|
|
16
|
+
setTool(requestId: string, tool: string, action?: string): void;
|
|
17
|
+
setGitLabResponse(requestId: string, status: number | "timeout" | "error", durationMs?: number): void;
|
|
18
|
+
addDetail(requestId: string, key: string, value: string | number | boolean): void;
|
|
19
|
+
addDetails(requestId: string, details: Record<string, string | number | boolean>): void;
|
|
20
|
+
setError(requestId: string, error: string): void;
|
|
21
|
+
setContext(requestId: string, context: string): void;
|
|
22
|
+
setReadOnly(requestId: string, readOnly: boolean): void;
|
|
23
|
+
setSessionId(requestId: string, sessionId: string): void;
|
|
24
|
+
closeStack(requestId: string, status: number): string | undefined;
|
|
25
|
+
closeStackWithError(requestId: string, error: string): string | undefined;
|
|
26
|
+
hasStack(requestId: string): boolean;
|
|
27
|
+
getOpenStackCount(): number;
|
|
28
|
+
clear(): void;
|
|
29
|
+
setToolForCurrentRequest(tool: string, action?: string): void;
|
|
30
|
+
setGitLabResponseForCurrentRequest(status: number | "timeout" | "error", durationMs?: number): void;
|
|
31
|
+
addDetailForCurrentRequest(key: string, value: string | number | boolean): void;
|
|
32
|
+
addDetailsForCurrentRequest(details: Record<string, string | number | boolean>): void;
|
|
33
|
+
setErrorForCurrentRequest(error: string): void;
|
|
34
|
+
setContextForCurrentRequest(context: string): void;
|
|
35
|
+
setReadOnlyForCurrentRequest(readOnly: boolean): void;
|
|
36
|
+
setSessionIdForCurrentRequest(sessionId: string): void;
|
|
37
|
+
}
|
|
38
|
+
export declare function getRequestTracker(): RequestTracker;
|
|
39
|
+
export declare function resetRequestTracker(): void;
|
|
@@ -0,0 +1,208 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RequestTracker = void 0;
|
|
4
|
+
exports.getCurrentRequestId = getCurrentRequestId;
|
|
5
|
+
exports.runWithRequestContext = runWithRequestContext;
|
|
6
|
+
exports.runWithRequestContextAsync = runWithRequestContextAsync;
|
|
7
|
+
exports.getRequestTracker = getRequestTracker;
|
|
8
|
+
exports.resetRequestTracker = resetRequestTracker;
|
|
9
|
+
const async_hooks_1 = require("async_hooks");
|
|
10
|
+
const access_log_js_1 = require("./access-log.js");
|
|
11
|
+
const logger_js_1 = require("../logger.js");
|
|
12
|
+
const requestContext = new async_hooks_1.AsyncLocalStorage();
|
|
13
|
+
function getCurrentRequestId() {
|
|
14
|
+
return requestContext.getStore()?.requestId;
|
|
15
|
+
}
|
|
16
|
+
function runWithRequestContext(requestId, fn) {
|
|
17
|
+
return requestContext.run({ requestId }, fn);
|
|
18
|
+
}
|
|
19
|
+
async function runWithRequestContextAsync(requestId, fn) {
|
|
20
|
+
return requestContext.run({ requestId }, fn);
|
|
21
|
+
}
|
|
22
|
+
class RequestTracker {
|
|
23
|
+
stacks = new Map();
|
|
24
|
+
enabled;
|
|
25
|
+
constructor(enabled = true) {
|
|
26
|
+
this.enabled = enabled;
|
|
27
|
+
}
|
|
28
|
+
isEnabled() {
|
|
29
|
+
return this.enabled;
|
|
30
|
+
}
|
|
31
|
+
setEnabled(enabled) {
|
|
32
|
+
this.enabled = enabled;
|
|
33
|
+
}
|
|
34
|
+
openStack(requestId, clientIp, method, path, sessionId) {
|
|
35
|
+
if (!this.enabled)
|
|
36
|
+
return;
|
|
37
|
+
const stack = {
|
|
38
|
+
startTime: Date.now(),
|
|
39
|
+
clientIp,
|
|
40
|
+
method,
|
|
41
|
+
path,
|
|
42
|
+
sessionId,
|
|
43
|
+
details: {},
|
|
44
|
+
};
|
|
45
|
+
this.stacks.set(requestId, stack);
|
|
46
|
+
(0, logger_js_1.logDebug)("Request stack opened", { requestId, clientIp, method, path });
|
|
47
|
+
}
|
|
48
|
+
getStack(requestId) {
|
|
49
|
+
return this.stacks.get(requestId);
|
|
50
|
+
}
|
|
51
|
+
setTool(requestId, tool, action) {
|
|
52
|
+
const stack = this.stacks.get(requestId);
|
|
53
|
+
if (!stack)
|
|
54
|
+
return;
|
|
55
|
+
stack.tool = tool;
|
|
56
|
+
if (action) {
|
|
57
|
+
stack.action = action;
|
|
58
|
+
}
|
|
59
|
+
(0, logger_js_1.logDebug)("Tool set on request stack", { requestId, tool, action });
|
|
60
|
+
}
|
|
61
|
+
setGitLabResponse(requestId, status, durationMs) {
|
|
62
|
+
const stack = this.stacks.get(requestId);
|
|
63
|
+
if (!stack)
|
|
64
|
+
return;
|
|
65
|
+
stack.gitlabStatus = status;
|
|
66
|
+
if (durationMs !== undefined) {
|
|
67
|
+
stack.gitlabDuration = durationMs;
|
|
68
|
+
}
|
|
69
|
+
(0, logger_js_1.logDebug)("GitLab response set on request stack", {
|
|
70
|
+
requestId,
|
|
71
|
+
gitlabStatus: status,
|
|
72
|
+
gitlabDuration: durationMs,
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
addDetail(requestId, key, value) {
|
|
76
|
+
const stack = this.stacks.get(requestId);
|
|
77
|
+
if (!stack)
|
|
78
|
+
return;
|
|
79
|
+
stack.details[key] = value;
|
|
80
|
+
}
|
|
81
|
+
addDetails(requestId, details) {
|
|
82
|
+
const stack = this.stacks.get(requestId);
|
|
83
|
+
if (!stack)
|
|
84
|
+
return;
|
|
85
|
+
Object.assign(stack.details, details);
|
|
86
|
+
}
|
|
87
|
+
setError(requestId, error) {
|
|
88
|
+
const stack = this.stacks.get(requestId);
|
|
89
|
+
if (!stack)
|
|
90
|
+
return;
|
|
91
|
+
stack.error = error;
|
|
92
|
+
stack.details.err = error;
|
|
93
|
+
}
|
|
94
|
+
setContext(requestId, context) {
|
|
95
|
+
const stack = this.stacks.get(requestId);
|
|
96
|
+
if (!stack)
|
|
97
|
+
return;
|
|
98
|
+
stack.context = context;
|
|
99
|
+
}
|
|
100
|
+
setReadOnly(requestId, readOnly) {
|
|
101
|
+
const stack = this.stacks.get(requestId);
|
|
102
|
+
if (!stack)
|
|
103
|
+
return;
|
|
104
|
+
stack.readOnly = readOnly;
|
|
105
|
+
}
|
|
106
|
+
setSessionId(requestId, sessionId) {
|
|
107
|
+
const stack = this.stacks.get(requestId);
|
|
108
|
+
if (!stack)
|
|
109
|
+
return;
|
|
110
|
+
stack.sessionId = sessionId;
|
|
111
|
+
}
|
|
112
|
+
closeStack(requestId, status) {
|
|
113
|
+
const stack = this.stacks.get(requestId);
|
|
114
|
+
if (!stack) {
|
|
115
|
+
(0, logger_js_1.logDebug)("Request stack not found on close", { requestId });
|
|
116
|
+
return undefined;
|
|
117
|
+
}
|
|
118
|
+
this.stacks.delete(requestId);
|
|
119
|
+
stack.status = status;
|
|
120
|
+
if (!this.enabled) {
|
|
121
|
+
return undefined;
|
|
122
|
+
}
|
|
123
|
+
const entry = (0, access_log_js_1.createAccessLogEntry)(stack);
|
|
124
|
+
const logLine = (0, access_log_js_1.formatAccessLog)(entry);
|
|
125
|
+
if (logger_js_1.LOG_JSON) {
|
|
126
|
+
logger_js_1.logger.info({ accessLog: entry }, logLine);
|
|
127
|
+
}
|
|
128
|
+
else {
|
|
129
|
+
logger_js_1.logger.info(logLine);
|
|
130
|
+
}
|
|
131
|
+
return logLine;
|
|
132
|
+
}
|
|
133
|
+
closeStackWithError(requestId, error) {
|
|
134
|
+
const stack = this.stacks.get(requestId);
|
|
135
|
+
if (!stack)
|
|
136
|
+
return undefined;
|
|
137
|
+
stack.error = error;
|
|
138
|
+
stack.details.err = error;
|
|
139
|
+
return this.closeStack(requestId, 0);
|
|
140
|
+
}
|
|
141
|
+
hasStack(requestId) {
|
|
142
|
+
return this.stacks.has(requestId);
|
|
143
|
+
}
|
|
144
|
+
getOpenStackCount() {
|
|
145
|
+
return this.stacks.size;
|
|
146
|
+
}
|
|
147
|
+
clear() {
|
|
148
|
+
this.stacks.clear();
|
|
149
|
+
}
|
|
150
|
+
setToolForCurrentRequest(tool, action) {
|
|
151
|
+
const requestId = getCurrentRequestId();
|
|
152
|
+
if (requestId) {
|
|
153
|
+
this.setTool(requestId, tool, action);
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
setGitLabResponseForCurrentRequest(status, durationMs) {
|
|
157
|
+
const requestId = getCurrentRequestId();
|
|
158
|
+
if (requestId) {
|
|
159
|
+
this.setGitLabResponse(requestId, status, durationMs);
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
addDetailForCurrentRequest(key, value) {
|
|
163
|
+
const requestId = getCurrentRequestId();
|
|
164
|
+
if (requestId) {
|
|
165
|
+
this.addDetail(requestId, key, value);
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
addDetailsForCurrentRequest(details) {
|
|
169
|
+
const requestId = getCurrentRequestId();
|
|
170
|
+
if (requestId) {
|
|
171
|
+
this.addDetails(requestId, details);
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
setErrorForCurrentRequest(error) {
|
|
175
|
+
const requestId = getCurrentRequestId();
|
|
176
|
+
if (requestId) {
|
|
177
|
+
this.setError(requestId, error);
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
setContextForCurrentRequest(context) {
|
|
181
|
+
const requestId = getCurrentRequestId();
|
|
182
|
+
if (requestId) {
|
|
183
|
+
this.setContext(requestId, context);
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
setReadOnlyForCurrentRequest(readOnly) {
|
|
187
|
+
const requestId = getCurrentRequestId();
|
|
188
|
+
if (requestId) {
|
|
189
|
+
this.setReadOnly(requestId, readOnly);
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
setSessionIdForCurrentRequest(sessionId) {
|
|
193
|
+
const requestId = getCurrentRequestId();
|
|
194
|
+
if (requestId) {
|
|
195
|
+
this.setSessionId(requestId, sessionId);
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
exports.RequestTracker = RequestTracker;
|
|
200
|
+
let globalTracker = null;
|
|
201
|
+
function getRequestTracker() {
|
|
202
|
+
globalTracker ??= new RequestTracker();
|
|
203
|
+
return globalTracker;
|
|
204
|
+
}
|
|
205
|
+
function resetRequestTracker() {
|
|
206
|
+
globalTracker = null;
|
|
207
|
+
}
|
|
208
|
+
//# sourceMappingURL=request-tracker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"request-tracker.js","sourceRoot":"","sources":["../../../src/logging/request-tracker.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
export interface RequestStack {
|
|
2
|
+
startTime: number;
|
|
3
|
+
clientIp: string;
|
|
4
|
+
sessionId?: string;
|
|
5
|
+
context?: string;
|
|
6
|
+
readOnly?: boolean;
|
|
7
|
+
method: string;
|
|
8
|
+
path: string;
|
|
9
|
+
tool?: string;
|
|
10
|
+
action?: string;
|
|
11
|
+
gitlabStatus?: number | "timeout" | "error";
|
|
12
|
+
gitlabDuration?: number;
|
|
13
|
+
details: Record<string, string | number | boolean>;
|
|
14
|
+
status?: number;
|
|
15
|
+
error?: string;
|
|
16
|
+
}
|
|
17
|
+
export type ConnectionCloseReason = "client_disconnect" | "idle_timeout" | "server_shutdown" | "transport_error" | "auth_expired" | "session_closed" | "destroyed" | "normal_close" | "heartbeat_failed" | `peer_reset:${string}`;
|
|
18
|
+
export interface ConnectionStats {
|
|
19
|
+
connectedAt: number;
|
|
20
|
+
clientIp: string;
|
|
21
|
+
sessionId: string;
|
|
22
|
+
requestCount: number;
|
|
23
|
+
toolCount: number;
|
|
24
|
+
errorCount: number;
|
|
25
|
+
lastError?: string;
|
|
26
|
+
}
|
|
27
|
+
export interface AccessLogEntry {
|
|
28
|
+
timestamp: string;
|
|
29
|
+
clientIp: string;
|
|
30
|
+
session: string;
|
|
31
|
+
ctx: string;
|
|
32
|
+
ro: string;
|
|
33
|
+
method: string;
|
|
34
|
+
path: string;
|
|
35
|
+
status: number;
|
|
36
|
+
durationMs: number;
|
|
37
|
+
tool: string;
|
|
38
|
+
action: string;
|
|
39
|
+
gitlabStatus: string;
|
|
40
|
+
gitlabDurationMs: string;
|
|
41
|
+
details: string;
|
|
42
|
+
}
|
|
43
|
+
export interface ConnectionCloseEntry {
|
|
44
|
+
timestamp: string;
|
|
45
|
+
clientIp: string;
|
|
46
|
+
session: string;
|
|
47
|
+
duration: string;
|
|
48
|
+
reason: ConnectionCloseReason;
|
|
49
|
+
requests: number;
|
|
50
|
+
tools: number;
|
|
51
|
+
errors: number;
|
|
52
|
+
lastError?: string;
|
|
53
|
+
}
|
|
54
|
+
export type LogFormat = "condensed" | "verbose";
|
|
55
|
+
export declare const DEFAULT_LOG_FORMAT: LogFormat;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/logging/types.ts"],"names":[],"mappings":";;;AA+La,QAAA,kBAAkB,GAAc,WAAW,CAAC"}
|