reqon-dsl 0.2.0 → 0.3.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 (396) hide show
  1. package/CHANGELOG.md +7 -0
  2. package/README.md +22 -0
  3. package/dist/ast/nodes.d.ts +83 -4
  4. package/dist/ast/nodes.js +14 -0
  5. package/dist/auth/circuit-breaker.js +7 -6
  6. package/dist/auth/rate-limiter.d.ts +4 -0
  7. package/dist/auth/rate-limiter.js +9 -16
  8. package/dist/cli.d.ts +13 -0
  9. package/dist/cli.js +84 -4
  10. package/dist/config/constants.d.ts +141 -0
  11. package/dist/config/constants.js +128 -0
  12. package/dist/config/index.d.ts +4 -0
  13. package/dist/config/index.js +4 -0
  14. package/dist/control/index.d.ts +2 -0
  15. package/dist/control/index.js +1 -0
  16. package/dist/control/server.d.ts +88 -0
  17. package/dist/control/server.js +238 -0
  18. package/dist/control/types.d.ts +55 -0
  19. package/dist/control/types.js +7 -0
  20. package/dist/debug/cli-debugger.d.ts +17 -0
  21. package/dist/debug/cli-debugger.js +180 -0
  22. package/dist/debug/controller.d.ts +94 -0
  23. package/dist/debug/controller.js +45 -0
  24. package/dist/debug/index.d.ts +6 -0
  25. package/dist/debug/index.js +5 -0
  26. package/dist/errors/index.d.ts +67 -0
  27. package/dist/errors/index.js +89 -1
  28. package/dist/execution/index.d.ts +1 -1
  29. package/dist/execution/state.d.ts +24 -0
  30. package/dist/index.d.ts +21 -1
  31. package/dist/index.js +33 -2
  32. package/dist/interpreter/context.d.ts +14 -0
  33. package/dist/interpreter/context.js +15 -0
  34. package/dist/interpreter/evaluator.d.ts +63 -1
  35. package/dist/interpreter/evaluator.js +186 -39
  36. package/dist/interpreter/executor.d.ts +70 -14
  37. package/dist/interpreter/executor.js +503 -174
  38. package/dist/interpreter/fetch-handler.d.ts +9 -0
  39. package/dist/interpreter/fetch-handler.js +133 -24
  40. package/dist/interpreter/http.d.ts +5 -0
  41. package/dist/interpreter/http.js +26 -12
  42. package/dist/interpreter/index.d.ts +3 -1
  43. package/dist/interpreter/index.js +2 -0
  44. package/dist/interpreter/pagination.d.ts +11 -2
  45. package/dist/interpreter/pagination.js +95 -31
  46. package/dist/interpreter/signals.d.ts +8 -0
  47. package/dist/interpreter/signals.js +12 -0
  48. package/dist/interpreter/source-manager.d.ts +75 -0
  49. package/dist/interpreter/source-manager.js +157 -0
  50. package/dist/interpreter/step-handlers/apply-handler.d.ts +29 -0
  51. package/dist/interpreter/step-handlers/apply-handler.js +79 -0
  52. package/dist/interpreter/step-handlers/for-handler.d.ts +13 -0
  53. package/dist/interpreter/step-handlers/for-handler.js +71 -4
  54. package/dist/interpreter/step-handlers/index.d.ts +4 -2
  55. package/dist/interpreter/step-handlers/index.js +4 -2
  56. package/dist/interpreter/step-handlers/match-handler.d.ts +9 -0
  57. package/dist/interpreter/step-handlers/match-handler.js +43 -16
  58. package/dist/interpreter/step-handlers/pause-handler.d.ts +52 -0
  59. package/dist/interpreter/step-handlers/pause-handler.js +87 -0
  60. package/dist/interpreter/step-handlers/store-handler.d.ts +11 -1
  61. package/dist/interpreter/step-handlers/store-handler.js +45 -13
  62. package/dist/interpreter/step-handlers/types.d.ts +3 -0
  63. package/dist/interpreter/step-handlers/validate-handler.d.ts +2 -1
  64. package/dist/interpreter/step-handlers/validate-handler.js +4 -2
  65. package/dist/interpreter/step-handlers/webhook-handler.d.ts +3 -0
  66. package/dist/interpreter/step-handlers/webhook-handler.js +18 -2
  67. package/dist/interpreter/store-manager.d.ts +46 -0
  68. package/dist/interpreter/store-manager.js +66 -0
  69. package/dist/lexer/index.d.ts +11 -4
  70. package/dist/lexer/index.js +11 -4
  71. package/dist/lexer/tokens.d.ts +17 -1
  72. package/dist/lexer/tokens.js +36 -0
  73. package/dist/mcp/index.d.ts +11 -0
  74. package/dist/mcp/index.js +11 -0
  75. package/dist/mcp/server.d.ts +17 -0
  76. package/dist/mcp/server.js +451 -0
  77. package/dist/oas/index.d.ts +2 -0
  78. package/dist/oas/index.js +1 -0
  79. package/dist/oas/mock-generator.d.ts +12 -0
  80. package/dist/oas/mock-generator.js +187 -0
  81. package/dist/observability/events.d.ts +244 -0
  82. package/dist/observability/events.js +90 -0
  83. package/dist/observability/index.d.ts +15 -0
  84. package/dist/observability/index.js +12 -0
  85. package/dist/observability/logger.d.ts +106 -0
  86. package/dist/observability/logger.js +259 -0
  87. package/dist/observability/otel.d.ts +135 -0
  88. package/dist/observability/otel.js +386 -0
  89. package/dist/parser/action-parser.d.ts +105 -0
  90. package/dist/parser/action-parser.js +645 -0
  91. package/dist/parser/expressions.d.ts +13 -0
  92. package/dist/parser/expressions.js +72 -2
  93. package/dist/parser/fetch-parser.d.ts +27 -0
  94. package/dist/parser/fetch-parser.js +269 -0
  95. package/dist/parser/index.d.ts +17 -0
  96. package/dist/parser/index.js +17 -0
  97. package/dist/parser/parser.d.ts +44 -46
  98. package/dist/parser/parser.js +122 -1070
  99. package/dist/parser/pipeline-parser.d.ts +12 -0
  100. package/dist/parser/pipeline-parser.js +52 -0
  101. package/dist/parser/schedule-parser.d.ts +7 -0
  102. package/dist/parser/schedule-parser.js +137 -0
  103. package/dist/parser/source-parser.d.ts +9 -0
  104. package/dist/parser/source-parser.js +151 -0
  105. package/dist/pause/index.d.ts +14 -0
  106. package/dist/pause/index.js +11 -0
  107. package/dist/pause/manager.d.ts +118 -0
  108. package/dist/pause/manager.js +245 -0
  109. package/dist/pause/state.d.ts +93 -0
  110. package/dist/pause/state.js +103 -0
  111. package/dist/pause/store.d.ts +61 -0
  112. package/dist/pause/store.js +156 -0
  113. package/dist/plugin.d.ts +9 -12
  114. package/dist/plugin.js +10 -13
  115. package/dist/stores/factory.d.ts +1 -1
  116. package/dist/stores/factory.js +3 -2
  117. package/dist/stores/file.d.ts +26 -0
  118. package/dist/stores/file.js +64 -10
  119. package/dist/stores/index.d.ts +16 -1
  120. package/dist/stores/index.js +16 -1
  121. package/dist/stores/memory.d.ts +4 -0
  122. package/dist/stores/memory.js +11 -0
  123. package/dist/stores/types.d.ts +17 -0
  124. package/dist/stores/types.js +12 -0
  125. package/dist/trace/index.d.ts +16 -0
  126. package/dist/trace/index.js +12 -0
  127. package/dist/trace/recorder.d.ts +71 -0
  128. package/dist/trace/recorder.js +144 -0
  129. package/dist/trace/replay.d.ts +132 -0
  130. package/dist/trace/replay.js +264 -0
  131. package/dist/trace/state.d.ts +102 -0
  132. package/dist/trace/state.js +86 -0
  133. package/dist/trace/store.d.ts +69 -0
  134. package/dist/trace/store.js +225 -0
  135. package/dist/utils/index.d.ts +1 -0
  136. package/dist/utils/index.js +1 -0
  137. package/dist/utils/type-guards.d.ts +58 -0
  138. package/dist/utils/type-guards.js +92 -0
  139. package/dist/webhook/server.js +7 -6
  140. package/package.json +55 -6
  141. package/.claude/settings.local.json +0 -31
  142. package/.claude/skills/api-integration.md +0 -125
  143. package/.claude/skills/database-schema.md +0 -51
  144. package/.claude/skills/dsl-design.md +0 -80
  145. package/.claude/skills/property-testing.md +0 -143
  146. package/.claude/skills/reqon/SKILL.md +0 -44
  147. package/.claude/skills/reqon/references/examples.md +0 -206
  148. package/.claude/skills/reqon/references/syntax.md +0 -263
  149. package/.claude/skills/vscode-extension.md +0 -113
  150. package/.github/dependabot.yml +0 -32
  151. package/.github/pull_request_template.md +0 -21
  152. package/.github/workflows/ci.yml +0 -174
  153. package/.github/workflows/release.yml +0 -73
  154. package/CLAUDE.md +0 -72
  155. package/CONTRIBUTING.md +0 -161
  156. package/TODO.md +0 -51
  157. package/dist/auth/auth.test.d.ts +0 -1
  158. package/dist/auth/auth.test.js +0 -255
  159. package/dist/errors/errors.test.d.ts +0 -1
  160. package/dist/errors/errors.test.js +0 -165
  161. package/dist/execution/execution.test.d.ts +0 -1
  162. package/dist/execution/execution.test.js +0 -246
  163. package/dist/integration.test.d.ts +0 -1
  164. package/dist/integration.test.js +0 -168
  165. package/dist/interpreter/evaluator.test.d.ts +0 -1
  166. package/dist/interpreter/evaluator.test.js +0 -512
  167. package/dist/interpreter/http.test.d.ts +0 -1
  168. package/dist/interpreter/http.test.js +0 -299
  169. package/dist/interpreter/progress.test.d.ts +0 -1
  170. package/dist/interpreter/progress.test.js +0 -216
  171. package/dist/interpreter/schema-matcher.test.d.ts +0 -1
  172. package/dist/interpreter/schema-matcher.test.js +0 -122
  173. package/dist/lexer/lexer.d.ts +0 -24
  174. package/dist/lexer/lexer.js +0 -264
  175. package/dist/lexer/lexer.test.d.ts +0 -1
  176. package/dist/lexer/lexer.test.js +0 -259
  177. package/dist/loader/loader.test.d.ts +0 -1
  178. package/dist/loader/loader.test.js +0 -287
  179. package/dist/oas/oas.test.d.ts +0 -1
  180. package/dist/oas/oas.test.js +0 -218
  181. package/dist/parser/expressions.test.d.ts +0 -1
  182. package/dist/parser/expressions.test.js +0 -378
  183. package/dist/parser/match.test.d.ts +0 -1
  184. package/dist/parser/match.test.js +0 -254
  185. package/dist/parser/parser.test.d.ts +0 -1
  186. package/dist/parser/parser.test.js +0 -333
  187. package/dist/parser/schedule.test.d.ts +0 -1
  188. package/dist/parser/schedule.test.js +0 -241
  189. package/dist/scheduler/cron-parser.test.d.ts +0 -1
  190. package/dist/scheduler/cron-parser.test.js +0 -188
  191. package/dist/stores/file.test.d.ts +0 -1
  192. package/dist/stores/file.test.js +0 -165
  193. package/dist/stores/memory.test.d.ts +0 -1
  194. package/dist/stores/memory.test.js +0 -157
  195. package/dist/stores/stores.test.d.ts +0 -1
  196. package/dist/stores/stores.test.js +0 -158
  197. package/dist/sync/sync.test.d.ts +0 -1
  198. package/dist/sync/sync.test.js +0 -221
  199. package/docusaurus/README.md +0 -41
  200. package/docusaurus/docs/advanced/execution-state.md +0 -283
  201. package/docusaurus/docs/advanced/extending-reqon.md +0 -388
  202. package/docusaurus/docs/advanced/multi-file-missions.md +0 -250
  203. package/docusaurus/docs/advanced/parallel-execution.md +0 -353
  204. package/docusaurus/docs/api-reference.md +0 -443
  205. package/docusaurus/docs/authentication/api-key.md +0 -339
  206. package/docusaurus/docs/authentication/basic.md +0 -276
  207. package/docusaurus/docs/authentication/bearer.md +0 -282
  208. package/docusaurus/docs/authentication/oauth2.md +0 -317
  209. package/docusaurus/docs/authentication/overview.md +0 -251
  210. package/docusaurus/docs/cli.md +0 -229
  211. package/docusaurus/docs/core-concepts/actions.md +0 -286
  212. package/docusaurus/docs/core-concepts/missions.md +0 -264
  213. package/docusaurus/docs/core-concepts/schemas.md +0 -353
  214. package/docusaurus/docs/core-concepts/sources.md +0 -339
  215. package/docusaurus/docs/core-concepts/stores.md +0 -332
  216. package/docusaurus/docs/dsl-syntax/expressions.md +0 -361
  217. package/docusaurus/docs/dsl-syntax/fetch.md +0 -293
  218. package/docusaurus/docs/dsl-syntax/for-loops.md +0 -324
  219. package/docusaurus/docs/dsl-syntax/map.md +0 -345
  220. package/docusaurus/docs/dsl-syntax/match.md +0 -387
  221. package/docusaurus/docs/dsl-syntax/pipelines.md +0 -397
  222. package/docusaurus/docs/dsl-syntax/validate.md +0 -401
  223. package/docusaurus/docs/error-handling/dead-letter-queues.md +0 -399
  224. package/docusaurus/docs/error-handling/flow-control.md +0 -337
  225. package/docusaurus/docs/error-handling/retry-strategies.md +0 -368
  226. package/docusaurus/docs/examples.md +0 -488
  227. package/docusaurus/docs/getting-started.md +0 -256
  228. package/docusaurus/docs/http/circuit-breaker.md +0 -401
  229. package/docusaurus/docs/http/incremental-sync.md +0 -394
  230. package/docusaurus/docs/http/pagination.md +0 -361
  231. package/docusaurus/docs/http/rate-limiting.md +0 -383
  232. package/docusaurus/docs/http/requests.md +0 -328
  233. package/docusaurus/docs/http/retry.md +0 -402
  234. package/docusaurus/docs/intro.md +0 -90
  235. package/docusaurus/docs/openapi/loading-specs.md +0 -305
  236. package/docusaurus/docs/openapi/operation-calls.md +0 -314
  237. package/docusaurus/docs/openapi/overview.md +0 -212
  238. package/docusaurus/docs/openapi/response-validation.md +0 -344
  239. package/docusaurus/docs/scheduling/cron.md +0 -305
  240. package/docusaurus/docs/scheduling/daemon-mode.md +0 -317
  241. package/docusaurus/docs/scheduling/intervals.md +0 -289
  242. package/docusaurus/docs/scheduling/overview.md +0 -231
  243. package/docusaurus/docs/stores/custom-adapters.md +0 -376
  244. package/docusaurus/docs/stores/file.md +0 -236
  245. package/docusaurus/docs/stores/memory.md +0 -193
  246. package/docusaurus/docs/stores/overview.md +0 -274
  247. package/docusaurus/docs/stores/postgrest.md +0 -316
  248. package/docusaurus/docusaurus.config.ts +0 -148
  249. package/docusaurus/package-lock.json +0 -18029
  250. package/docusaurus/package.json +0 -47
  251. package/docusaurus/sidebars.ts +0 -155
  252. package/docusaurus/src/components/HomepageFeatures/index.tsx +0 -105
  253. package/docusaurus/src/components/HomepageFeatures/styles.module.css +0 -12
  254. package/docusaurus/src/css/custom.css +0 -169
  255. package/docusaurus/src/pages/index.module.css +0 -48
  256. package/docusaurus/src/pages/index.tsx +0 -110
  257. package/docusaurus/src/pages/markdown-page.md +0 -7
  258. package/docusaurus/static/.nojekyll +0 -0
  259. package/docusaurus/static/img/docusaurus-social-card.jpg +0 -0
  260. package/docusaurus/static/img/docusaurus.png +0 -0
  261. package/docusaurus/static/img/favicon.ico +0 -0
  262. package/docusaurus/static/img/logo.svg +0 -10
  263. package/docusaurus/static/img/undraw_docusaurus_mountain.svg +0 -171
  264. package/docusaurus/static/img/undraw_docusaurus_react.svg +0 -170
  265. package/docusaurus/static/img/undraw_docusaurus_tree.svg +0 -40
  266. package/docusaurus/tsconfig.json +0 -8
  267. package/examples/README.md +0 -112
  268. package/examples/error-handling/README.md +0 -150
  269. package/examples/error-handling/payment-processor.vague +0 -287
  270. package/examples/github-sync/README.md +0 -74
  271. package/examples/github-sync/fetch-issues.vague +0 -47
  272. package/examples/github-sync/fetch-prs.vague +0 -40
  273. package/examples/github-sync/mission.vague +0 -101
  274. package/examples/github-sync/normalize.vague +0 -70
  275. package/examples/jsonplaceholder/README.md +0 -28
  276. package/examples/jsonplaceholder/posts.vague +0 -48
  277. package/examples/petstore/README.md +0 -35
  278. package/examples/petstore/openapi.yaml +0 -97
  279. package/examples/petstore/sync.vague +0 -52
  280. package/examples/temporal-comparison/README.md +0 -297
  281. package/examples/temporal-comparison/reconciliation.vague +0 -355
  282. package/examples/temporal-comparison/temporal/activities/index.ts +0 -8
  283. package/examples/temporal-comparison/temporal/activities/shipstation.ts +0 -225
  284. package/examples/temporal-comparison/temporal/activities/shopify.ts +0 -257
  285. package/examples/temporal-comparison/temporal/activities/storage.ts +0 -198
  286. package/examples/temporal-comparison/temporal/activities/stripe.ts +0 -169
  287. package/examples/temporal-comparison/temporal/activities/validation.ts +0 -205
  288. package/examples/temporal-comparison/temporal/client/schedule.ts +0 -218
  289. package/examples/temporal-comparison/temporal/config/retry.ts +0 -63
  290. package/examples/temporal-comparison/temporal/types/index.ts +0 -129
  291. package/examples/temporal-comparison/temporal/workers/main.ts +0 -130
  292. package/examples/temporal-comparison/temporal/workflows/orderReconciliation.ts +0 -262
  293. package/examples/xero/README.md +0 -88
  294. package/examples/xero/invoices.vague +0 -189
  295. package/src/api-integration.test.ts +0 -954
  296. package/src/ast/index.ts +0 -1
  297. package/src/ast/nodes.ts +0 -310
  298. package/src/auth/auth.test.ts +0 -326
  299. package/src/auth/circuit-breaker.test.ts +0 -390
  300. package/src/auth/circuit-breaker.ts +0 -379
  301. package/src/auth/credentials.test.ts +0 -273
  302. package/src/auth/credentials.ts +0 -246
  303. package/src/auth/index.ts +0 -40
  304. package/src/auth/oauth2-provider.ts +0 -177
  305. package/src/auth/rate-limiter.ts +0 -459
  306. package/src/auth/token-store.ts +0 -177
  307. package/src/auth/types.ts +0 -159
  308. package/src/benchmark/e2e.bench.ts +0 -288
  309. package/src/benchmark/evaluator.bench.ts +0 -331
  310. package/src/benchmark/fixtures.ts +0 -295
  311. package/src/benchmark/index.ts +0 -108
  312. package/src/benchmark/lexer.bench.ts +0 -69
  313. package/src/benchmark/parser.bench.ts +0 -103
  314. package/src/benchmark/resilience.bench.ts +0 -193
  315. package/src/benchmark/store.bench.ts +0 -147
  316. package/src/benchmark/utils.ts +0 -230
  317. package/src/cli.ts +0 -313
  318. package/src/errors/errors.test.ts +0 -234
  319. package/src/errors/index.ts +0 -223
  320. package/src/execution/execution.test.ts +0 -307
  321. package/src/execution/index.ts +0 -21
  322. package/src/execution/state.ts +0 -207
  323. package/src/execution/store.ts +0 -188
  324. package/src/index.ts +0 -169
  325. package/src/integration.test.ts +0 -192
  326. package/src/interpreter/context.ts +0 -57
  327. package/src/interpreter/evaluator.test.ts +0 -796
  328. package/src/interpreter/evaluator.ts +0 -245
  329. package/src/interpreter/executor.ts +0 -946
  330. package/src/interpreter/fetch-handler.ts +0 -302
  331. package/src/interpreter/http.test.ts +0 -423
  332. package/src/interpreter/http.ts +0 -308
  333. package/src/interpreter/index.ts +0 -32
  334. package/src/interpreter/pagination.ts +0 -207
  335. package/src/interpreter/progress.test.ts +0 -276
  336. package/src/interpreter/schema-matcher.test.ts +0 -160
  337. package/src/interpreter/schema-matcher.ts +0 -168
  338. package/src/interpreter/signals.ts +0 -73
  339. package/src/interpreter/step-handlers/for-handler.ts +0 -65
  340. package/src/interpreter/step-handlers/index.ts +0 -17
  341. package/src/interpreter/step-handlers/map-handler.ts +0 -24
  342. package/src/interpreter/step-handlers/match-handler.ts +0 -101
  343. package/src/interpreter/step-handlers/store-handler.ts +0 -78
  344. package/src/interpreter/step-handlers/types.ts +0 -17
  345. package/src/interpreter/step-handlers/validate-handler.ts +0 -30
  346. package/src/interpreter/step-handlers/webhook-handler.ts +0 -142
  347. package/src/lexer/index.ts +0 -18
  348. package/src/lexer/lexer.test.ts +0 -316
  349. package/src/lexer/tokens.ts +0 -179
  350. package/src/loader/index.ts +0 -288
  351. package/src/loader/loader.test.ts +0 -360
  352. package/src/oas/index.ts +0 -4
  353. package/src/oas/loader.ts +0 -126
  354. package/src/oas/oas.test.ts +0 -254
  355. package/src/oas/validator.ts +0 -299
  356. package/src/parser/base.ts +0 -124
  357. package/src/parser/expressions.test.ts +0 -525
  358. package/src/parser/expressions.ts +0 -314
  359. package/src/parser/index.ts +0 -3
  360. package/src/parser/match.test.ts +0 -296
  361. package/src/parser/parser.test.ts +0 -739
  362. package/src/parser/parser.ts +0 -1469
  363. package/src/parser/schedule.test.ts +0 -287
  364. package/src/parser/webhook.test.ts +0 -248
  365. package/src/plugin.ts +0 -83
  366. package/src/scheduler/cron-parser.test.ts +0 -236
  367. package/src/scheduler/cron-parser.ts +0 -236
  368. package/src/scheduler/index.ts +0 -10
  369. package/src/scheduler/scheduler.ts +0 -443
  370. package/src/scheduler/types.ts +0 -71
  371. package/src/stores/factory.ts +0 -104
  372. package/src/stores/file.test.ts +0 -276
  373. package/src/stores/file.ts +0 -211
  374. package/src/stores/index.ts +0 -6
  375. package/src/stores/memory.test.ts +0 -238
  376. package/src/stores/memory.ts +0 -63
  377. package/src/stores/postgrest.test.ts +0 -488
  378. package/src/stores/postgrest.ts +0 -263
  379. package/src/stores/stores.test.ts +0 -197
  380. package/src/stores/types.ts +0 -58
  381. package/src/sync/index.ts +0 -16
  382. package/src/sync/state.ts +0 -126
  383. package/src/sync/store.ts +0 -139
  384. package/src/sync/sync.test.ts +0 -271
  385. package/src/utils/async.ts +0 -10
  386. package/src/utils/file.ts +0 -106
  387. package/src/utils/index.ts +0 -14
  388. package/src/utils/logger.ts +0 -53
  389. package/src/utils/path.ts +0 -47
  390. package/src/webhook/index.ts +0 -15
  391. package/src/webhook/server.test.ts +0 -253
  392. package/src/webhook/server.ts +0 -389
  393. package/src/webhook/store.ts +0 -239
  394. package/src/webhook/types.ts +0 -93
  395. package/tsconfig.json +0 -17
  396. package/vitest.config.ts +0 -39
@@ -1,282 +0,0 @@
1
- ---
2
- sidebar_position: 3
3
- ---
4
-
5
- # Bearer Token Authentication
6
-
7
- Bearer token authentication is the most common auth method for REST APIs. The token is sent in the `Authorization` header with each request.
8
-
9
- ## Configuration
10
-
11
- ### Mission File
12
-
13
- ```vague
14
- source API {
15
- auth: bearer,
16
- base: "https://api.example.com"
17
- }
18
- ```
19
-
20
- ### Credentials File
21
-
22
- ```json
23
- {
24
- "API": {
25
- "type": "bearer",
26
- "token": "your-api-token"
27
- }
28
- }
29
- ```
30
-
31
- ## How It Works
32
-
33
- Reqon adds the token to every request:
34
-
35
- ```http
36
- GET /api/users HTTP/1.1
37
- Host: api.example.com
38
- Authorization: Bearer your-api-token
39
- ```
40
-
41
- ## Credential Options
42
-
43
- | Field | Required | Description |
44
- |-------|----------|-------------|
45
- | `type` | Yes | Must be `"bearer"` |
46
- | `token` | Yes | The bearer token |
47
-
48
- ## Environment Variables
49
-
50
- ### In Credentials File
51
-
52
- ```json
53
- {
54
- "API": {
55
- "type": "bearer",
56
- "token": "${API_TOKEN}"
57
- }
58
- }
59
- ```
60
-
61
- Then set the environment variable:
62
-
63
- ```bash
64
- export API_TOKEN="your-token"
65
- reqon mission.vague --auth credentials.json
66
- ```
67
-
68
- ### In Mission File
69
-
70
- ```vague
71
- source API {
72
- auth: bearer,
73
- base: "https://api.example.com",
74
- token: env("API_TOKEN")
75
- }
76
- ```
77
-
78
- ## Common Use Cases
79
-
80
- ### GitHub API
81
-
82
- ```vague
83
- source GitHub {
84
- auth: bearer,
85
- base: "https://api.github.com"
86
- }
87
- ```
88
-
89
- ```json
90
- {
91
- "GitHub": {
92
- "type": "bearer",
93
- "token": "ghp_xxxxxxxxxxxxxxxxxxxx"
94
- }
95
- }
96
- ```
97
-
98
- ### Stripe API
99
-
100
- ```vague
101
- source Stripe {
102
- auth: bearer,
103
- base: "https://api.stripe.com/v1"
104
- }
105
- ```
106
-
107
- ```json
108
- {
109
- "Stripe": {
110
- "type": "bearer",
111
- "token": "sk_live_xxxxxxxxxxxxxxxxxxxx"
112
- }
113
- }
114
- ```
115
-
116
- ### Custom API
117
-
118
- ```vague
119
- source CustomAPI {
120
- auth: bearer,
121
- base: "https://api.mycompany.com/v1"
122
- }
123
- ```
124
-
125
- ```json
126
- {
127
- "CustomAPI": {
128
- "type": "bearer",
129
- "token": "your-custom-token"
130
- }
131
- }
132
- ```
133
-
134
- ## Token Rotation
135
-
136
- ### Manual Rotation
137
-
138
- 1. Generate new token in API provider
139
- 2. Update credentials file
140
- 3. Run mission
141
-
142
- ### Programmatic Rotation
143
-
144
- ```typescript
145
- import { execute } from 'reqon';
146
-
147
- const token = await fetchNewToken(); // Your logic
148
-
149
- await execute(source, {
150
- auth: {
151
- API: {
152
- type: 'bearer',
153
- token
154
- }
155
- }
156
- });
157
- ```
158
-
159
- ## Handling Expiration
160
-
161
- Bearer tokens may expire. Handle with match:
162
-
163
- ```vague
164
- action FetchData {
165
- get "/data"
166
-
167
- match response {
168
- { error: _, code: 401 } -> abort "Token expired - please update credentials",
169
- _ -> continue
170
- }
171
- }
172
- ```
173
-
174
- Or with token refresh:
175
-
176
- ```vague
177
- action FetchData {
178
- get "/data"
179
-
180
- match response {
181
- { error: _, code: 401 } -> jump RefreshToken then retry,
182
- _ -> continue
183
- }
184
- }
185
-
186
- action RefreshToken {
187
- post "/auth/token" {
188
- body: { apiKey: env("API_KEY") }
189
- }
190
- // Response contains new token
191
- }
192
- ```
193
-
194
- ## Multiple Tokens
195
-
196
- For APIs requiring different tokens per endpoint:
197
-
198
- ```vague
199
- source ReadAPI {
200
- auth: bearer,
201
- base: "https://api.example.com"
202
- }
203
-
204
- source WriteAPI {
205
- auth: bearer,
206
- base: "https://api.example.com"
207
- }
208
- ```
209
-
210
- ```json
211
- {
212
- "ReadAPI": {
213
- "type": "bearer",
214
- "token": "read-only-token"
215
- },
216
- "WriteAPI": {
217
- "type": "bearer",
218
- "token": "write-token"
219
- }
220
- }
221
- ```
222
-
223
- ## Security Best Practices
224
-
225
- ### Store Tokens Securely
226
-
227
- ```bash
228
- # Never commit tokens
229
- echo "credentials.json" >> .gitignore
230
- ```
231
-
232
- ### Use Environment Variables
233
-
234
- ```bash
235
- export API_TOKEN=$(cat ~/.secrets/api-token)
236
- ```
237
-
238
- ### Rotate Regularly
239
-
240
- Set up periodic token rotation in your CI/CD pipeline.
241
-
242
- ### Use Minimal Scopes
243
-
244
- If the API supports scoped tokens, use the minimum required permissions.
245
-
246
- ## Troubleshooting
247
-
248
- ### "401 Unauthorized"
249
-
250
- 1. Check token is correct
251
- 2. Check token hasn't expired
252
- 3. Verify token has required permissions
253
-
254
- ### "Invalid token format"
255
-
256
- Ensure token doesn't have extra whitespace:
257
-
258
- ```json
259
- {
260
- "API": {
261
- "type": "bearer",
262
- "token": "your-token" // No leading/trailing spaces
263
- }
264
- }
265
- ```
266
-
267
- ### Token Not Being Sent
268
-
269
- Verify source name matches:
270
-
271
- ```vague
272
- source MyAPI { auth: bearer } // Name: MyAPI
273
- ```
274
-
275
- ```json
276
- {
277
- "MyAPI": { // Must match exactly
278
- "type": "bearer",
279
- "token": "..."
280
- }
281
- }
282
- ```
@@ -1,317 +0,0 @@
1
- ---
2
- sidebar_position: 2
3
- ---
4
-
5
- # OAuth 2.0 Authentication
6
-
7
- OAuth 2.0 is the industry standard for API authentication, used by most enterprise APIs. Reqon supports OAuth 2.0 with automatic token refresh.
8
-
9
- ## Configuration
10
-
11
- ### Mission File
12
-
13
- ```vague
14
- source Xero {
15
- auth: oauth2,
16
- base: "https://api.xero.com/api.xro/2.0"
17
- }
18
- ```
19
-
20
- ### Credentials File
21
-
22
- ```json
23
- {
24
- "Xero": {
25
- "type": "oauth2",
26
- "clientId": "your-client-id",
27
- "clientSecret": "your-client-secret",
28
- "accessToken": "current-access-token",
29
- "refreshToken": "current-refresh-token",
30
- "tokenUrl": "https://identity.xero.com/connect/token",
31
- "scopes": ["accounting.transactions.read", "accounting.contacts.read"],
32
- "expiresAt": "2024-01-20T10:30:00Z"
33
- }
34
- }
35
- ```
36
-
37
- ## Credential Options
38
-
39
- | Field | Required | Description |
40
- |-------|----------|-------------|
41
- | `type` | Yes | Must be `"oauth2"` |
42
- | `clientId` | Yes | OAuth client ID |
43
- | `clientSecret` | Yes | OAuth client secret |
44
- | `accessToken` | Yes | Current access token |
45
- | `refreshToken` | Yes | Token used to get new access tokens |
46
- | `tokenUrl` | Yes | Token endpoint URL |
47
- | `scopes` | No | Requested scopes |
48
- | `expiresAt` | No | When current token expires |
49
-
50
- ## Token Refresh
51
-
52
- ### Automatic Refresh
53
-
54
- When `expiresAt` is set and token expires, Reqon automatically:
55
-
56
- 1. Calls `tokenUrl` with refresh token
57
- 2. Updates access token
58
- 3. Retries the failed request
59
-
60
- ```json
61
- {
62
- "Xero": {
63
- "type": "oauth2",
64
- "clientId": "...",
65
- "clientSecret": "...",
66
- "accessToken": "old-token",
67
- "refreshToken": "refresh-token",
68
- "tokenUrl": "https://identity.xero.com/connect/token",
69
- "expiresAt": "2024-01-20T10:30:00Z"
70
- }
71
- }
72
- ```
73
-
74
- ### On 401 Response
75
-
76
- Even without `expiresAt`, Reqon refreshes on 401:
77
-
78
- ```vague
79
- action FetchData {
80
- get "/data"
81
- // If 401, automatic refresh attempt
82
- }
83
- ```
84
-
85
- ### Manual Refresh Pattern
86
-
87
- For non-standard APIs:
88
-
89
- ```vague
90
- action FetchData {
91
- get "/data"
92
-
93
- match response {
94
- { error: _, code: 401 } -> jump RefreshToken then retry,
95
- _ -> continue
96
- }
97
- }
98
-
99
- action RefreshToken {
100
- post "/oauth/token" {
101
- headers: {
102
- "Content-Type": "application/x-www-form-urlencoded"
103
- },
104
- body: {
105
- grant_type: "refresh_token",
106
- refresh_token: env("REFRESH_TOKEN"),
107
- client_id: env("CLIENT_ID"),
108
- client_secret: env("CLIENT_SECRET")
109
- }
110
- }
111
-
112
- // Store new tokens
113
- store {
114
- accessToken: response.access_token,
115
- refreshToken: response.refresh_token
116
- } -> tokens
117
- }
118
- ```
119
-
120
- ## Common OAuth2 Providers
121
-
122
- ### Xero
123
-
124
- ```json
125
- {
126
- "Xero": {
127
- "type": "oauth2",
128
- "clientId": "your-client-id",
129
- "clientSecret": "your-client-secret",
130
- "accessToken": "...",
131
- "refreshToken": "...",
132
- "tokenUrl": "https://identity.xero.com/connect/token"
133
- }
134
- }
135
- ```
136
-
137
- ### QuickBooks
138
-
139
- ```json
140
- {
141
- "QuickBooks": {
142
- "type": "oauth2",
143
- "clientId": "your-client-id",
144
- "clientSecret": "your-client-secret",
145
- "accessToken": "...",
146
- "refreshToken": "...",
147
- "tokenUrl": "https://oauth.platform.intuit.com/oauth2/v1/tokens/bearer"
148
- }
149
- }
150
- ```
151
-
152
- ### Salesforce
153
-
154
- ```json
155
- {
156
- "Salesforce": {
157
- "type": "oauth2",
158
- "clientId": "your-client-id",
159
- "clientSecret": "your-client-secret",
160
- "accessToken": "...",
161
- "refreshToken": "...",
162
- "tokenUrl": "https://login.salesforce.com/services/oauth2/token"
163
- }
164
- }
165
- ```
166
-
167
- ### Google APIs
168
-
169
- ```json
170
- {
171
- "Google": {
172
- "type": "oauth2",
173
- "clientId": "your-client-id.apps.googleusercontent.com",
174
- "clientSecret": "your-client-secret",
175
- "accessToken": "...",
176
- "refreshToken": "...",
177
- "tokenUrl": "https://oauth2.googleapis.com/token"
178
- }
179
- }
180
- ```
181
-
182
- ### Microsoft Graph
183
-
184
- ```json
185
- {
186
- "Microsoft": {
187
- "type": "oauth2",
188
- "clientId": "your-client-id",
189
- "clientSecret": "your-client-secret",
190
- "accessToken": "...",
191
- "refreshToken": "...",
192
- "tokenUrl": "https://login.microsoftonline.com/common/oauth2/v2.0/token"
193
- }
194
- }
195
- ```
196
-
197
- ## Token Storage
198
-
199
- ### File-Based (Development)
200
-
201
- Tokens are stored in the credentials file. Reqon updates them after refresh.
202
-
203
- ### Secure Storage (Production)
204
-
205
- For production, use secure storage:
206
-
207
- ```typescript
208
- import { execute } from 'reqon';
209
- import { getSecureTokens, saveSecureTokens } from './secure-storage';
210
-
211
- const tokens = await getSecureTokens('Xero');
212
-
213
- const result = await execute(source, {
214
- auth: {
215
- Xero: {
216
- type: 'oauth2',
217
- ...tokens
218
- }
219
- },
220
- onTokenRefresh: async (source, newTokens) => {
221
- await saveSecureTokens(source, newTokens);
222
- }
223
- });
224
- ```
225
-
226
- ## Scopes
227
-
228
- Request specific scopes:
229
-
230
- ```json
231
- {
232
- "API": {
233
- "type": "oauth2",
234
- "scopes": [
235
- "read:users",
236
- "write:users",
237
- "read:orders"
238
- ]
239
- }
240
- }
241
- ```
242
-
243
- ## Additional Headers
244
-
245
- Some APIs require extra headers:
246
-
247
- ```vague
248
- source API {
249
- auth: oauth2,
250
- base: "https://api.example.com",
251
- headers: {
252
- "Xero-Tenant-Id": env("XERO_TENANT_ID")
253
- }
254
- }
255
- ```
256
-
257
- ## Handling Multi-Tenant
258
-
259
- For APIs like Xero with multiple organizations:
260
-
261
- ```vague
262
- mission XeroSync {
263
- source Xero {
264
- auth: oauth2,
265
- base: "https://api.xero.com/api.xro/2.0",
266
- headers: {
267
- "Xero-Tenant-Id": env("XERO_TENANT_ID")
268
- }
269
- }
270
- }
271
- ```
272
-
273
- Or iterate over tenants:
274
-
275
- ```vague
276
- action SyncAllTenants {
277
- get "/connections"
278
-
279
- for tenant in response {
280
- // Each tenant request
281
- get concat("/", tenant.tenantId, "/invoices") {
282
- headers: { "Xero-Tenant-Id": tenant.tenantId }
283
- }
284
- }
285
- }
286
- ```
287
-
288
- ## Troubleshooting
289
-
290
- ### "invalid_grant" Error
291
-
292
- Refresh token is invalid or expired. Re-authenticate:
293
-
294
- 1. Go through OAuth flow again
295
- 2. Get new access and refresh tokens
296
- 3. Update credentials file
297
-
298
- ### "Token expired" but No Refresh
299
-
300
- Ensure `refreshToken` and `tokenUrl` are set:
301
-
302
- ```json
303
- {
304
- "API": {
305
- "refreshToken": "must-be-present",
306
- "tokenUrl": "must-be-present"
307
- }
308
- }
309
- ```
310
-
311
- ### "Invalid client" Error
312
-
313
- Check `clientId` and `clientSecret` are correct.
314
-
315
- ### Scope Issues
316
-
317
- Ensure requested scopes are authorized for your app.