@structured-world/gitlab-mcp 5.7.0 → 6.0.0

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