@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,70 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.loadOAuthConfig = loadOAuthConfig;
4
+ exports.validateStaticConfig = validateStaticConfig;
5
+ exports.isOAuthEnabled = isOAuthEnabled;
6
+ exports.resetOAuthConfigCache = resetOAuthConfigCache;
7
+ exports.getAuthModeDescription = getAuthModeDescription;
8
+ const zod_1 = require("zod");
9
+ const logger_1 = require("../logger");
10
+ const OAuthConfigSchema = zod_1.z.object({
11
+ enabled: zod_1.z.literal(true),
12
+ sessionSecret: zod_1.z.string().min(32, "OAUTH_SESSION_SECRET must be at least 32 characters"),
13
+ gitlabClientId: zod_1.z.string().min(1, "GITLAB_OAUTH_CLIENT_ID is required"),
14
+ gitlabClientSecret: zod_1.z.string().optional(),
15
+ gitlabScopes: zod_1.z.string().default("api,read_user"),
16
+ tokenTtl: zod_1.z.number().positive().default(3600),
17
+ refreshTokenTtl: zod_1.z.number().positive().default(604800),
18
+ devicePollInterval: zod_1.z.number().positive().default(5),
19
+ deviceTimeout: zod_1.z.number().positive().default(300),
20
+ });
21
+ let cachedOAuthConfig = undefined;
22
+ function loadOAuthConfig() {
23
+ if (cachedOAuthConfig !== undefined) {
24
+ return cachedOAuthConfig;
25
+ }
26
+ if (process.env.OAUTH_ENABLED !== "true") {
27
+ cachedOAuthConfig = null;
28
+ logger_1.logger.debug("OAuth mode disabled (OAUTH_ENABLED !== 'true')");
29
+ return null;
30
+ }
31
+ const result = OAuthConfigSchema.safeParse({
32
+ enabled: true,
33
+ sessionSecret: process.env.OAUTH_SESSION_SECRET,
34
+ gitlabClientId: process.env.GITLAB_OAUTH_CLIENT_ID,
35
+ gitlabClientSecret: process.env.GITLAB_OAUTH_CLIENT_SECRET,
36
+ gitlabScopes: process.env.GITLAB_OAUTH_SCOPES ?? "api,read_user",
37
+ tokenTtl: parseInt(process.env.OAUTH_TOKEN_TTL ?? "3600", 10),
38
+ refreshTokenTtl: parseInt(process.env.OAUTH_REFRESH_TOKEN_TTL ?? "604800", 10),
39
+ devicePollInterval: parseInt(process.env.OAUTH_DEVICE_POLL_INTERVAL ?? "5", 10),
40
+ deviceTimeout: parseInt(process.env.OAUTH_DEVICE_TIMEOUT ?? "300", 10),
41
+ });
42
+ if (!result.success) {
43
+ const errorMessages = result.error.issues
44
+ .map(e => `${e.path.join(".")}: ${e.message}`)
45
+ .join(", ");
46
+ throw new Error(`Invalid OAuth configuration: ${errorMessages}`);
47
+ }
48
+ cachedOAuthConfig = result.data;
49
+ logger_1.logger.info("OAuth mode enabled with valid configuration");
50
+ return result.data;
51
+ }
52
+ function validateStaticConfig() {
53
+ if (!process.env.GITLAB_TOKEN) {
54
+ throw new Error("GITLAB_TOKEN is required when OAUTH_ENABLED is not true");
55
+ }
56
+ logger_1.logger.debug("Static token mode: GITLAB_TOKEN configured");
57
+ }
58
+ function isOAuthEnabled() {
59
+ return loadOAuthConfig() !== null;
60
+ }
61
+ function resetOAuthConfigCache() {
62
+ cachedOAuthConfig = undefined;
63
+ }
64
+ function getAuthModeDescription() {
65
+ if (isOAuthEnabled()) {
66
+ return "OAuth mode (per-user authentication via GitLab Device Flow)";
67
+ }
68
+ return "Static token mode (shared GITLAB_TOKEN)";
69
+ }
70
+ //# sourceMappingURL=config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.js","sourceRoot":"","sources":["../../../src/oauth/config.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import { Request, Response } from "express";
2
+ export declare function authorizeHandler(req: Request, res: Response): Promise<void>;
3
+ export declare function pollHandler(req: Request, res: Response): Promise<void>;
@@ -0,0 +1,454 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.authorizeHandler = authorizeHandler;
4
+ exports.pollHandler = pollHandler;
5
+ const config_1 = require("../config");
6
+ const session_store_1 = require("../session-store");
7
+ const gitlab_device_flow_1 = require("../gitlab-device-flow");
8
+ const token_utils_1 = require("../token-utils");
9
+ const metadata_1 = require("./metadata");
10
+ const logger_1 = require("../../logger");
11
+ async function authorizeHandler(req, res) {
12
+ const config = (0, config_1.loadOAuthConfig)();
13
+ if (!config) {
14
+ res.status(500).json({
15
+ error: "server_error",
16
+ error_description: "OAuth not configured",
17
+ });
18
+ return;
19
+ }
20
+ const { client_id, redirect_uri, response_type, state, code_challenge, code_challenge_method } = req.query;
21
+ if (response_type !== "code") {
22
+ res.status(400).json({
23
+ error: "unsupported_response_type",
24
+ error_description: 'Only "code" response type is supported',
25
+ });
26
+ return;
27
+ }
28
+ if (!client_id) {
29
+ res.status(400).json({
30
+ error: "invalid_request",
31
+ error_description: "client_id is required",
32
+ });
33
+ return;
34
+ }
35
+ if (!code_challenge) {
36
+ res.status(400).json({
37
+ error: "invalid_request",
38
+ error_description: "code_challenge is required (PKCE)",
39
+ });
40
+ return;
41
+ }
42
+ if (code_challenge_method !== "S256") {
43
+ res.status(400).json({
44
+ error: "invalid_request",
45
+ error_description: 'code_challenge_method must be "S256"',
46
+ });
47
+ return;
48
+ }
49
+ if (redirect_uri) {
50
+ await handleAuthorizationCodeFlow(req, res, config, {
51
+ clientId: client_id,
52
+ redirectUri: redirect_uri,
53
+ state: state ?? "",
54
+ codeChallenge: code_challenge,
55
+ codeChallengeMethod: code_challenge_method,
56
+ });
57
+ }
58
+ else {
59
+ await handleDeviceFlow(req, res, config, {
60
+ clientId: client_id,
61
+ state: state ?? "",
62
+ codeChallenge: code_challenge,
63
+ codeChallengeMethod: code_challenge_method,
64
+ });
65
+ }
66
+ }
67
+ async function handleAuthorizationCodeFlow(req, res, config, params) {
68
+ const baseUrl = (0, metadata_1.getBaseUrl)(req);
69
+ const callbackUri = `${baseUrl}/oauth/callback`;
70
+ const internalState = (0, token_utils_1.generateRandomString)(32);
71
+ session_store_1.sessionStore.storeAuthCodeFlow(internalState, {
72
+ clientId: params.clientId,
73
+ codeChallenge: params.codeChallenge,
74
+ codeChallengeMethod: params.codeChallengeMethod,
75
+ clientState: params.state,
76
+ internalState: internalState,
77
+ clientRedirectUri: params.redirectUri,
78
+ callbackUri: callbackUri,
79
+ expiresAt: Date.now() + 10 * 60 * 1000,
80
+ });
81
+ const gitlabAuthUrl = (0, gitlab_device_flow_1.buildGitLabAuthUrl)(config, callbackUri, internalState);
82
+ logger_1.logger.info({
83
+ internalState: internalState.substring(0, 8) + "...",
84
+ clientRedirectUri: params.redirectUri,
85
+ }, "Authorization Code Flow initiated, redirecting to GitLab");
86
+ res.redirect(gitlabAuthUrl);
87
+ }
88
+ async function handleDeviceFlow(req, res, config, params) {
89
+ try {
90
+ const deviceResponse = await (0, gitlab_device_flow_1.initiateDeviceFlow)(config);
91
+ const flowState = (0, token_utils_1.generateRandomString)(32);
92
+ session_store_1.sessionStore.storeDeviceFlow(flowState, {
93
+ deviceCode: deviceResponse.device_code,
94
+ userCode: deviceResponse.user_code,
95
+ verificationUri: deviceResponse.verification_uri,
96
+ verificationUriComplete: deviceResponse.verification_uri_complete,
97
+ expiresAt: Date.now() + deviceResponse.expires_in * 1000,
98
+ interval: deviceResponse.interval,
99
+ clientId: params.clientId,
100
+ codeChallenge: params.codeChallenge,
101
+ codeChallengeMethod: params.codeChallengeMethod,
102
+ state: params.state,
103
+ redirectUri: undefined,
104
+ });
105
+ logger_1.logger.info({
106
+ flowState: flowState.substring(0, 8) + "...",
107
+ userCode: deviceResponse.user_code,
108
+ }, "Device flow initiated for authorization");
109
+ const baseUrl = (0, metadata_1.getBaseUrl)(req);
110
+ const html = getDeviceFlowHTML({
111
+ userCode: deviceResponse.user_code,
112
+ verificationUri: deviceResponse.verification_uri,
113
+ verificationUriComplete: deviceResponse.verification_uri_complete,
114
+ flowState,
115
+ pollUrl: `${baseUrl}/oauth/poll`,
116
+ expiresIn: deviceResponse.expires_in,
117
+ });
118
+ res.setHeader("Content-Type", "text/html");
119
+ res.send(html);
120
+ }
121
+ catch (error) {
122
+ logger_1.logger.error({ err: error }, "Failed to initiate device flow");
123
+ res.status(500).json({
124
+ error: "server_error",
125
+ error_description: "Failed to initiate authentication",
126
+ });
127
+ }
128
+ }
129
+ async function pollHandler(req, res) {
130
+ const config = (0, config_1.loadOAuthConfig)();
131
+ if (!config) {
132
+ res.status(500).json({ error: "server_error" });
133
+ return;
134
+ }
135
+ const { flow_state } = req.query;
136
+ if (!flow_state) {
137
+ res
138
+ .status(400)
139
+ .json({ status: "failed", error: "Missing flow_state" });
140
+ return;
141
+ }
142
+ const flow = session_store_1.sessionStore.getDeviceFlow(flow_state);
143
+ if (!flow) {
144
+ res.status(400).json({ status: "expired", error: "Flow not found" });
145
+ return;
146
+ }
147
+ if (Date.now() > flow.expiresAt) {
148
+ session_store_1.sessionStore.deleteDeviceFlow(flow_state);
149
+ res
150
+ .status(400)
151
+ .json({ status: "expired", error: "Device code expired" });
152
+ return;
153
+ }
154
+ try {
155
+ const tokenResponse = await (0, gitlab_device_flow_1.pollDeviceFlowOnce)(flow.deviceCode, config);
156
+ if (tokenResponse) {
157
+ const userInfo = await (0, gitlab_device_flow_1.getGitLabUser)(tokenResponse.access_token);
158
+ const sessionId = (0, token_utils_1.generateSessionId)();
159
+ const now = Date.now();
160
+ const authCode = (0, token_utils_1.generateAuthorizationCode)();
161
+ session_store_1.sessionStore.storeAuthCode({
162
+ code: authCode,
163
+ sessionId,
164
+ clientId: flow.clientId,
165
+ codeChallenge: flow.codeChallenge,
166
+ codeChallengeMethod: flow.codeChallengeMethod,
167
+ redirectUri: flow.redirectUri,
168
+ expiresAt: now + 10 * 60 * 1000,
169
+ });
170
+ session_store_1.sessionStore.createSession({
171
+ id: sessionId,
172
+ mcpAccessToken: "",
173
+ mcpRefreshToken: "",
174
+ mcpTokenExpiry: 0,
175
+ gitlabAccessToken: tokenResponse.access_token,
176
+ gitlabRefreshToken: tokenResponse.refresh_token,
177
+ gitlabTokenExpiry: (0, token_utils_1.calculateTokenExpiry)(tokenResponse.expires_in),
178
+ gitlabUserId: userInfo.id,
179
+ gitlabUsername: userInfo.username,
180
+ clientId: flow.clientId,
181
+ scopes: ["mcp:tools", "mcp:resources"],
182
+ createdAt: now,
183
+ updatedAt: now,
184
+ });
185
+ session_store_1.sessionStore.deleteDeviceFlow(flow_state);
186
+ logger_1.logger.info({
187
+ sessionId: sessionId.substring(0, 8) + "...",
188
+ userId: userInfo.id,
189
+ username: userInfo.username,
190
+ }, "Device flow authorization completed");
191
+ const response = {
192
+ status: "complete",
193
+ redirect_uri: flow.redirectUri,
194
+ code: authCode,
195
+ state: flow.state ? flow.state : undefined,
196
+ };
197
+ res.json(response);
198
+ }
199
+ else {
200
+ res.json({ status: "pending" });
201
+ }
202
+ }
203
+ catch (error) {
204
+ const message = error instanceof Error ? error.message : "Unknown error";
205
+ if (message.includes("expired") || message.includes("denied") || message.includes("invalid")) {
206
+ session_store_1.sessionStore.deleteDeviceFlow(flow_state);
207
+ res.json({ status: "failed", error: message });
208
+ }
209
+ else {
210
+ logger_1.logger.warn({ err: error }, "Device flow poll error");
211
+ res.json({ status: "pending" });
212
+ }
213
+ }
214
+ }
215
+ function getDeviceFlowHTML(params) {
216
+ const linkUrl = params.verificationUriComplete ?? params.verificationUri;
217
+ return `<!DOCTYPE html>
218
+ <html lang="en">
219
+ <head>
220
+ <meta charset="UTF-8">
221
+ <meta name="viewport" content="width=device-width, initial-scale=1.0">
222
+ <title>GitLab MCP - Authentication</title>
223
+ <style>
224
+ * {
225
+ box-sizing: border-box;
226
+ margin: 0;
227
+ padding: 0;
228
+ }
229
+ body {
230
+ font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif;
231
+ max-width: 600px;
232
+ margin: 0 auto;
233
+ padding: 40px 20px;
234
+ background: #f5f5f5;
235
+ min-height: 100vh;
236
+ }
237
+ .container {
238
+ background: white;
239
+ padding: 40px;
240
+ border-radius: 12px;
241
+ box-shadow: 0 2px 10px rgba(0,0,0,0.1);
242
+ }
243
+ h1 {
244
+ color: #333;
245
+ margin-bottom: 20px;
246
+ font-size: 24px;
247
+ }
248
+ p {
249
+ color: #666;
250
+ line-height: 1.6;
251
+ margin-bottom: 16px;
252
+ }
253
+ .code-container {
254
+ background: #f8f9fa;
255
+ border: 2px dashed #ddd;
256
+ border-radius: 8px;
257
+ padding: 24px;
258
+ margin: 24px 0;
259
+ text-align: center;
260
+ }
261
+ .code {
262
+ font-size: 36px;
263
+ font-weight: bold;
264
+ letter-spacing: 6px;
265
+ color: #333;
266
+ font-family: 'Courier New', monospace;
267
+ }
268
+ .code-label {
269
+ font-size: 12px;
270
+ color: #888;
271
+ text-transform: uppercase;
272
+ margin-bottom: 8px;
273
+ }
274
+ .link-button {
275
+ display: inline-block;
276
+ background: #fc6d26;
277
+ color: white;
278
+ padding: 14px 28px;
279
+ border-radius: 6px;
280
+ text-decoration: none;
281
+ font-weight: 500;
282
+ margin: 16px 0;
283
+ transition: background 0.2s;
284
+ }
285
+ .link-button:hover {
286
+ background: #e24329;
287
+ }
288
+ .status {
289
+ padding: 16px;
290
+ border-radius: 8px;
291
+ margin: 24px 0;
292
+ font-weight: 500;
293
+ }
294
+ .status.pending {
295
+ background: #fff3cd;
296
+ color: #856404;
297
+ border: 1px solid #ffeeba;
298
+ }
299
+ .status.success {
300
+ background: #d4edda;
301
+ color: #155724;
302
+ border: 1px solid #c3e6cb;
303
+ }
304
+ .status.error {
305
+ background: #f8d7da;
306
+ color: #721c24;
307
+ border: 1px solid #f5c6cb;
308
+ }
309
+ .instructions {
310
+ background: #e8f4fd;
311
+ border-left: 4px solid #0366d6;
312
+ padding: 16px;
313
+ margin: 24px 0;
314
+ border-radius: 0 8px 8px 0;
315
+ }
316
+ .instructions ol {
317
+ margin-left: 20px;
318
+ }
319
+ .instructions li {
320
+ margin: 8px 0;
321
+ color: #444;
322
+ }
323
+ .timer {
324
+ font-size: 14px;
325
+ color: #888;
326
+ margin-top: 16px;
327
+ }
328
+ .gitlab-logo {
329
+ width: 40px;
330
+ height: 40px;
331
+ margin-bottom: 16px;
332
+ }
333
+ </style>
334
+ </head>
335
+ <body>
336
+ <div class="container">
337
+ <svg class="gitlab-logo" viewBox="0 0 380 380" xmlns="http://www.w3.org/2000/svg">
338
+ <path d="M190.2 350.2l62.5-192.5H127.7l62.5 192.5z" fill="#e24329"/>
339
+ <path d="M190.2 350.2l-62.5-192.5H38.4l151.8 192.5z" fill="#fc6d26"/>
340
+ <path d="M38.4 157.7L9.1 247.6c-2.7 8.2.1 17.2 6.9 22.5l174.2 126.6L38.4 157.7z" fill="#fca326"/>
341
+ <path d="M38.4 157.7h89.3L91.4 48.5c-3.3-10.2-17.8-10.2-21.1 0L38.4 157.7z" fill="#e24329"/>
342
+ <path d="M190.2 350.2l62.5-192.5h89.3L190.2 350.2z" fill="#fc6d26"/>
343
+ <path d="M342 157.7l29.3 89.9c2.7 8.2-.1 17.2-6.9 22.5L190.2 396.7 342 157.7z" fill="#fca326"/>
344
+ <path d="M342 157.7h-89.3l36.3-109.2c3.3-10.2 17.8-10.2 21.1 0L342 157.7z" fill="#e24329"/>
345
+ </svg>
346
+
347
+ <h1>Authenticate with GitLab</h1>
348
+
349
+ <p>To complete authentication, visit GitLab and enter the code below:</p>
350
+
351
+ <div class="code-container">
352
+ <div class="code-label">Your Code</div>
353
+ <div class="code">${params.userCode}</div>
354
+ </div>
355
+
356
+ <div style="text-align: center;">
357
+ <a href="${linkUrl}" target="_blank" rel="noopener" class="link-button">
358
+ Open GitLab Authentication Page
359
+ </a>
360
+ </div>
361
+
362
+ <div class="instructions">
363
+ <strong>Instructions:</strong>
364
+ <ol>
365
+ <li>Click the button above to open GitLab</li>
366
+ <li>Sign in to your GitLab account if needed</li>
367
+ <li>Enter the code shown above</li>
368
+ <li>Click "Authorize" to grant access</li>
369
+ <li>Return here - you'll be redirected automatically</li>
370
+ </ol>
371
+ </div>
372
+
373
+ <div id="status" class="status pending">
374
+ Waiting for authentication...
375
+ </div>
376
+
377
+ <div class="timer" id="timer">
378
+ Code expires in <span id="countdown">${params.expiresIn}</span> seconds
379
+ </div>
380
+ </div>
381
+
382
+ <script>
383
+ const pollUrl = '${params.pollUrl}?flow_state=${params.flowState}';
384
+ const pollInterval = 5000; // 5 seconds
385
+ let countdown = ${params.expiresIn};
386
+
387
+ // Update countdown timer
388
+ const countdownEl = document.getElementById('countdown');
389
+ const timerInterval = setInterval(() => {
390
+ countdown--;
391
+ if (countdown <= 0) {
392
+ clearInterval(timerInterval);
393
+ document.getElementById('status').className = 'status error';
394
+ document.getElementById('status').textContent = 'Code expired. Please refresh to try again.';
395
+ document.getElementById('timer').style.display = 'none';
396
+ } else {
397
+ countdownEl.textContent = countdown;
398
+ }
399
+ }, 1000);
400
+
401
+ // Poll for completion
402
+ async function poll() {
403
+ try {
404
+ const response = await fetch(pollUrl);
405
+ const data = await response.json();
406
+
407
+ const statusEl = document.getElementById('status');
408
+
409
+ if (data.status === 'complete') {
410
+ clearInterval(timerInterval);
411
+ statusEl.className = 'status success';
412
+ statusEl.textContent = 'Authentication successful! Redirecting...';
413
+
414
+ // Build redirect URL with authorization code
415
+ if (data.redirect_uri) {
416
+ const redirectUrl = new URL(data.redirect_uri);
417
+ redirectUrl.searchParams.set('code', data.code);
418
+ if (data.state) {
419
+ redirectUrl.searchParams.set('state', data.state);
420
+ }
421
+
422
+ // Redirect after a brief delay
423
+ setTimeout(() => {
424
+ window.location.href = redirectUrl.toString();
425
+ }, 1000);
426
+ }
427
+ return;
428
+ }
429
+
430
+ if (data.status === 'failed' || data.status === 'expired') {
431
+ clearInterval(timerInterval);
432
+ statusEl.className = 'status error';
433
+ statusEl.textContent = 'Authentication failed: ' + (data.error || 'Unknown error');
434
+ document.getElementById('timer').style.display = 'none';
435
+ return;
436
+ }
437
+
438
+ // Still pending, continue polling
439
+ setTimeout(poll, pollInterval);
440
+
441
+ } catch (error) {
442
+ console.error('Poll error:', error);
443
+ // Continue polling on transient errors
444
+ setTimeout(poll, pollInterval);
445
+ }
446
+ }
447
+
448
+ // Start polling
449
+ setTimeout(poll, pollInterval);
450
+ </script>
451
+ </body>
452
+ </html>`;
453
+ }
454
+ //# sourceMappingURL=authorize.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"authorize.js","sourceRoot":"","sources":["../../../../src/oauth/endpoints/authorize.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import { Request, Response } from "express";
2
+ export declare function callbackHandler(req: Request, res: Response): Promise<void>;
@@ -0,0 +1,129 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.callbackHandler = callbackHandler;
4
+ const config_1 = require("../config");
5
+ const session_store_1 = require("../session-store");
6
+ const gitlab_device_flow_1 = require("../gitlab-device-flow");
7
+ const token_utils_1 = require("../token-utils");
8
+ const logger_1 = require("../../logger");
9
+ async function callbackHandler(req, res) {
10
+ const config = (0, config_1.loadOAuthConfig)();
11
+ if (!config) {
12
+ res.status(500).json({
13
+ error: "server_error",
14
+ error_description: "OAuth not configured",
15
+ });
16
+ return;
17
+ }
18
+ const { code, state, error, error_description } = req.query;
19
+ if (error) {
20
+ logger_1.logger.warn({ error, error_description }, "GitLab authorization error");
21
+ if (state) {
22
+ const flow = session_store_1.sessionStore.getAuthCodeFlow(state);
23
+ if (flow) {
24
+ session_store_1.sessionStore.deleteAuthCodeFlow(state);
25
+ const redirectUrl = new URL(flow.clientRedirectUri);
26
+ redirectUrl.searchParams.set("error", error);
27
+ if (error_description) {
28
+ redirectUrl.searchParams.set("error_description", error_description);
29
+ }
30
+ if (flow.clientState) {
31
+ redirectUrl.searchParams.set("state", flow.clientState);
32
+ }
33
+ res.redirect(redirectUrl.toString());
34
+ return;
35
+ }
36
+ }
37
+ res.status(400).json({
38
+ error: error,
39
+ error_description: error_description ?? "GitLab authorization failed",
40
+ });
41
+ return;
42
+ }
43
+ if (!code) {
44
+ res.status(400).json({
45
+ error: "invalid_request",
46
+ error_description: "Missing authorization code from GitLab",
47
+ });
48
+ return;
49
+ }
50
+ if (!state) {
51
+ res.status(400).json({
52
+ error: "invalid_request",
53
+ error_description: "Missing state parameter",
54
+ });
55
+ return;
56
+ }
57
+ const flow = session_store_1.sessionStore.getAuthCodeFlow(state);
58
+ if (!flow) {
59
+ res.status(400).json({
60
+ error: "invalid_request",
61
+ error_description: "Invalid or expired state. Please start authorization again.",
62
+ });
63
+ return;
64
+ }
65
+ if (Date.now() > flow.expiresAt) {
66
+ session_store_1.sessionStore.deleteAuthCodeFlow(state);
67
+ res.status(400).json({
68
+ error: "invalid_request",
69
+ error_description: "Authorization flow expired. Please start again.",
70
+ });
71
+ return;
72
+ }
73
+ try {
74
+ const gitlabTokens = await (0, gitlab_device_flow_1.exchangeGitLabAuthCode)(code, flow.callbackUri, config);
75
+ const userInfo = await (0, gitlab_device_flow_1.getGitLabUser)(gitlabTokens.access_token);
76
+ const sessionId = (0, token_utils_1.generateSessionId)();
77
+ const now = Date.now();
78
+ const mcpAuthCode = (0, token_utils_1.generateAuthorizationCode)();
79
+ session_store_1.sessionStore.storeAuthCode({
80
+ code: mcpAuthCode,
81
+ sessionId,
82
+ clientId: flow.clientId,
83
+ codeChallenge: flow.codeChallenge,
84
+ codeChallengeMethod: flow.codeChallengeMethod,
85
+ redirectUri: flow.clientRedirectUri,
86
+ expiresAt: now + 10 * 60 * 1000,
87
+ });
88
+ session_store_1.sessionStore.createSession({
89
+ id: sessionId,
90
+ mcpAccessToken: "",
91
+ mcpRefreshToken: "",
92
+ mcpTokenExpiry: 0,
93
+ gitlabAccessToken: gitlabTokens.access_token,
94
+ gitlabRefreshToken: gitlabTokens.refresh_token,
95
+ gitlabTokenExpiry: (0, token_utils_1.calculateTokenExpiry)(gitlabTokens.expires_in),
96
+ gitlabUserId: userInfo.id,
97
+ gitlabUsername: userInfo.username,
98
+ clientId: flow.clientId,
99
+ scopes: ["mcp:tools", "mcp:resources"],
100
+ createdAt: now,
101
+ updatedAt: now,
102
+ });
103
+ session_store_1.sessionStore.deleteAuthCodeFlow(state);
104
+ logger_1.logger.info({
105
+ sessionId: sessionId.substring(0, 8) + "...",
106
+ userId: userInfo.id,
107
+ username: userInfo.username,
108
+ }, "Authorization Code Flow completed successfully");
109
+ const redirectUrl = new URL(flow.clientRedirectUri);
110
+ redirectUrl.searchParams.set("code", mcpAuthCode);
111
+ if (flow.clientState) {
112
+ redirectUrl.searchParams.set("state", flow.clientState);
113
+ }
114
+ logger_1.logger.debug({ redirectUri: flow.clientRedirectUri }, "Redirecting to client with authorization code");
115
+ res.redirect(redirectUrl.toString());
116
+ }
117
+ catch (error) {
118
+ logger_1.logger.error({ err: error }, "Failed to complete authorization code flow");
119
+ session_store_1.sessionStore.deleteAuthCodeFlow(state);
120
+ const redirectUrl = new URL(flow.clientRedirectUri);
121
+ redirectUrl.searchParams.set("error", "server_error");
122
+ redirectUrl.searchParams.set("error_description", error instanceof Error ? error.message : "Failed to complete authorization");
123
+ if (flow.clientState) {
124
+ redirectUrl.searchParams.set("state", flow.clientState);
125
+ }
126
+ res.redirect(redirectUrl.toString());
127
+ }
128
+ }
129
+ //# sourceMappingURL=callback.js.map