reqon-dsl 0.2.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 (388) hide show
  1. package/.claude/settings.local.json +31 -0
  2. package/.claude/skills/api-integration.md +125 -0
  3. package/.claude/skills/database-schema.md +51 -0
  4. package/.claude/skills/dsl-design.md +80 -0
  5. package/.claude/skills/property-testing.md +143 -0
  6. package/.claude/skills/reqon/SKILL.md +44 -0
  7. package/.claude/skills/reqon/references/examples.md +206 -0
  8. package/.claude/skills/reqon/references/syntax.md +263 -0
  9. package/.claude/skills/vscode-extension.md +113 -0
  10. package/.github/dependabot.yml +32 -0
  11. package/.github/pull_request_template.md +21 -0
  12. package/.github/workflows/ci.yml +174 -0
  13. package/.github/workflows/release.yml +73 -0
  14. package/CLAUDE.md +72 -0
  15. package/CONTRIBUTING.md +161 -0
  16. package/README.md +235 -0
  17. package/TODO.md +51 -0
  18. package/dist/ast/index.d.ts +1 -0
  19. package/dist/ast/index.js +1 -0
  20. package/dist/ast/nodes.d.ts +237 -0
  21. package/dist/ast/nodes.js +12 -0
  22. package/dist/auth/auth.test.d.ts +1 -0
  23. package/dist/auth/auth.test.js +255 -0
  24. package/dist/auth/circuit-breaker.d.ts +115 -0
  25. package/dist/auth/circuit-breaker.js +267 -0
  26. package/dist/auth/credentials.d.ts +91 -0
  27. package/dist/auth/credentials.js +169 -0
  28. package/dist/auth/index.d.ts +5 -0
  29. package/dist/auth/index.js +8 -0
  30. package/dist/auth/oauth2-provider.d.ts +41 -0
  31. package/dist/auth/oauth2-provider.js +131 -0
  32. package/dist/auth/rate-limiter.d.ts +61 -0
  33. package/dist/auth/rate-limiter.js +380 -0
  34. package/dist/auth/token-store.d.ts +30 -0
  35. package/dist/auth/token-store.js +148 -0
  36. package/dist/auth/types.d.ts +142 -0
  37. package/dist/auth/types.js +1 -0
  38. package/dist/cli.d.ts +2 -0
  39. package/dist/cli.js +270 -0
  40. package/dist/errors/errors.test.d.ts +1 -0
  41. package/dist/errors/errors.test.js +165 -0
  42. package/dist/errors/index.d.ts +83 -0
  43. package/dist/errors/index.js +159 -0
  44. package/dist/execution/execution.test.d.ts +1 -0
  45. package/dist/execution/execution.test.js +246 -0
  46. package/dist/execution/index.d.ts +4 -0
  47. package/dist/execution/index.js +2 -0
  48. package/dist/execution/state.d.ts +136 -0
  49. package/dist/execution/state.js +82 -0
  50. package/dist/execution/store.d.ts +52 -0
  51. package/dist/execution/store.js +120 -0
  52. package/dist/index.d.ts +27 -0
  53. package/dist/index.js +57 -0
  54. package/dist/integration.test.d.ts +1 -0
  55. package/dist/integration.test.js +168 -0
  56. package/dist/interpreter/context.d.ts +15 -0
  57. package/dist/interpreter/context.js +29 -0
  58. package/dist/interpreter/evaluator.d.ts +5 -0
  59. package/dist/interpreter/evaluator.js +223 -0
  60. package/dist/interpreter/evaluator.test.d.ts +1 -0
  61. package/dist/interpreter/evaluator.test.js +512 -0
  62. package/dist/interpreter/executor.d.ts +131 -0
  63. package/dist/interpreter/executor.js +663 -0
  64. package/dist/interpreter/fetch-handler.d.ts +43 -0
  65. package/dist/interpreter/fetch-handler.js +203 -0
  66. package/dist/interpreter/http.d.ts +57 -0
  67. package/dist/interpreter/http.js +210 -0
  68. package/dist/interpreter/http.test.d.ts +1 -0
  69. package/dist/interpreter/http.test.js +299 -0
  70. package/dist/interpreter/index.d.ts +7 -0
  71. package/dist/interpreter/index.js +7 -0
  72. package/dist/interpreter/pagination.d.ts +63 -0
  73. package/dist/interpreter/pagination.js +155 -0
  74. package/dist/interpreter/progress.test.d.ts +1 -0
  75. package/dist/interpreter/progress.test.js +216 -0
  76. package/dist/interpreter/schema-matcher.d.ts +16 -0
  77. package/dist/interpreter/schema-matcher.js +136 -0
  78. package/dist/interpreter/schema-matcher.test.d.ts +1 -0
  79. package/dist/interpreter/schema-matcher.test.js +122 -0
  80. package/dist/interpreter/signals.d.ts +57 -0
  81. package/dist/interpreter/signals.js +73 -0
  82. package/dist/interpreter/step-handlers/for-handler.d.ts +17 -0
  83. package/dist/interpreter/step-handlers/for-handler.js +51 -0
  84. package/dist/interpreter/step-handlers/index.d.ts +8 -0
  85. package/dist/interpreter/step-handlers/index.js +8 -0
  86. package/dist/interpreter/step-handlers/map-handler.d.ts +10 -0
  87. package/dist/interpreter/step-handlers/map-handler.js +20 -0
  88. package/dist/interpreter/step-handlers/match-handler.d.ts +27 -0
  89. package/dist/interpreter/step-handlers/match-handler.js +61 -0
  90. package/dist/interpreter/step-handlers/store-handler.d.ts +13 -0
  91. package/dist/interpreter/step-handlers/store-handler.js +66 -0
  92. package/dist/interpreter/step-handlers/types.d.ts +15 -0
  93. package/dist/interpreter/step-handlers/types.js +1 -0
  94. package/dist/interpreter/step-handlers/validate-handler.d.ts +10 -0
  95. package/dist/interpreter/step-handlers/validate-handler.js +26 -0
  96. package/dist/interpreter/step-handlers/webhook-handler.d.ts +36 -0
  97. package/dist/interpreter/step-handlers/webhook-handler.js +104 -0
  98. package/dist/lexer/index.d.ts +10 -0
  99. package/dist/lexer/index.js +12 -0
  100. package/dist/lexer/lexer.d.ts +24 -0
  101. package/dist/lexer/lexer.js +264 -0
  102. package/dist/lexer/lexer.test.d.ts +1 -0
  103. package/dist/lexer/lexer.test.js +259 -0
  104. package/dist/lexer/tokens.d.ts +69 -0
  105. package/dist/lexer/tokens.js +146 -0
  106. package/dist/loader/index.d.ts +36 -0
  107. package/dist/loader/index.js +220 -0
  108. package/dist/loader/loader.test.d.ts +1 -0
  109. package/dist/loader/loader.test.js +287 -0
  110. package/dist/oas/index.d.ts +4 -0
  111. package/dist/oas/index.js +2 -0
  112. package/dist/oas/loader.d.ts +21 -0
  113. package/dist/oas/loader.js +82 -0
  114. package/dist/oas/oas.test.d.ts +1 -0
  115. package/dist/oas/oas.test.js +218 -0
  116. package/dist/oas/validator.d.ts +12 -0
  117. package/dist/oas/validator.js +227 -0
  118. package/dist/parser/base.d.ts +33 -0
  119. package/dist/parser/base.js +97 -0
  120. package/dist/parser/expressions.d.ts +27 -0
  121. package/dist/parser/expressions.js +248 -0
  122. package/dist/parser/expressions.test.d.ts +1 -0
  123. package/dist/parser/expressions.test.js +378 -0
  124. package/dist/parser/index.d.ts +3 -0
  125. package/dist/parser/index.js +3 -0
  126. package/dist/parser/match.test.d.ts +1 -0
  127. package/dist/parser/match.test.js +254 -0
  128. package/dist/parser/parser.d.ts +68 -0
  129. package/dist/parser/parser.js +1229 -0
  130. package/dist/parser/parser.test.d.ts +1 -0
  131. package/dist/parser/parser.test.js +333 -0
  132. package/dist/parser/schedule.test.d.ts +1 -0
  133. package/dist/parser/schedule.test.js +241 -0
  134. package/dist/plugin.d.ts +35 -0
  135. package/dist/plugin.js +68 -0
  136. package/dist/scheduler/cron-parser.d.ts +32 -0
  137. package/dist/scheduler/cron-parser.js +198 -0
  138. package/dist/scheduler/cron-parser.test.d.ts +1 -0
  139. package/dist/scheduler/cron-parser.test.js +188 -0
  140. package/dist/scheduler/index.d.ts +3 -0
  141. package/dist/scheduler/index.js +2 -0
  142. package/dist/scheduler/scheduler.d.ts +81 -0
  143. package/dist/scheduler/scheduler.js +376 -0
  144. package/dist/scheduler/types.d.ts +65 -0
  145. package/dist/scheduler/types.js +1 -0
  146. package/dist/stores/factory.d.ts +36 -0
  147. package/dist/stores/factory.js +73 -0
  148. package/dist/stores/file.d.ts +60 -0
  149. package/dist/stores/file.js +173 -0
  150. package/dist/stores/file.test.d.ts +1 -0
  151. package/dist/stores/file.test.js +165 -0
  152. package/dist/stores/index.d.ts +6 -0
  153. package/dist/stores/index.js +5 -0
  154. package/dist/stores/memory.d.ts +19 -0
  155. package/dist/stores/memory.js +51 -0
  156. package/dist/stores/memory.test.d.ts +1 -0
  157. package/dist/stores/memory.test.js +157 -0
  158. package/dist/stores/postgrest.d.ts +55 -0
  159. package/dist/stores/postgrest.js +217 -0
  160. package/dist/stores/stores.test.d.ts +1 -0
  161. package/dist/stores/stores.test.js +158 -0
  162. package/dist/stores/types.d.ts +31 -0
  163. package/dist/stores/types.js +26 -0
  164. package/dist/sync/index.d.ts +4 -0
  165. package/dist/sync/index.js +2 -0
  166. package/dist/sync/state.d.ts +69 -0
  167. package/dist/sync/state.js +66 -0
  168. package/dist/sync/store.d.ts +49 -0
  169. package/dist/sync/store.js +93 -0
  170. package/dist/sync/sync.test.d.ts +1 -0
  171. package/dist/sync/sync.test.js +221 -0
  172. package/dist/utils/async.d.ts +7 -0
  173. package/dist/utils/async.js +9 -0
  174. package/dist/utils/file.d.ts +38 -0
  175. package/dist/utils/file.js +92 -0
  176. package/dist/utils/index.d.ts +4 -0
  177. package/dist/utils/index.js +4 -0
  178. package/dist/utils/logger.d.ts +34 -0
  179. package/dist/utils/logger.js +39 -0
  180. package/dist/utils/path.d.ts +12 -0
  181. package/dist/utils/path.js +41 -0
  182. package/dist/webhook/index.d.ts +8 -0
  183. package/dist/webhook/index.js +7 -0
  184. package/dist/webhook/server.d.ts +84 -0
  185. package/dist/webhook/server.js +319 -0
  186. package/dist/webhook/store.d.ts +67 -0
  187. package/dist/webhook/store.js +193 -0
  188. package/dist/webhook/types.d.ts +88 -0
  189. package/dist/webhook/types.js +6 -0
  190. package/docusaurus/README.md +41 -0
  191. package/docusaurus/docs/advanced/execution-state.md +283 -0
  192. package/docusaurus/docs/advanced/extending-reqon.md +388 -0
  193. package/docusaurus/docs/advanced/multi-file-missions.md +250 -0
  194. package/docusaurus/docs/advanced/parallel-execution.md +353 -0
  195. package/docusaurus/docs/api-reference.md +443 -0
  196. package/docusaurus/docs/authentication/api-key.md +339 -0
  197. package/docusaurus/docs/authentication/basic.md +276 -0
  198. package/docusaurus/docs/authentication/bearer.md +282 -0
  199. package/docusaurus/docs/authentication/oauth2.md +317 -0
  200. package/docusaurus/docs/authentication/overview.md +251 -0
  201. package/docusaurus/docs/cli.md +229 -0
  202. package/docusaurus/docs/core-concepts/actions.md +286 -0
  203. package/docusaurus/docs/core-concepts/missions.md +264 -0
  204. package/docusaurus/docs/core-concepts/schemas.md +353 -0
  205. package/docusaurus/docs/core-concepts/sources.md +339 -0
  206. package/docusaurus/docs/core-concepts/stores.md +332 -0
  207. package/docusaurus/docs/dsl-syntax/expressions.md +361 -0
  208. package/docusaurus/docs/dsl-syntax/fetch.md +293 -0
  209. package/docusaurus/docs/dsl-syntax/for-loops.md +324 -0
  210. package/docusaurus/docs/dsl-syntax/map.md +345 -0
  211. package/docusaurus/docs/dsl-syntax/match.md +387 -0
  212. package/docusaurus/docs/dsl-syntax/pipelines.md +397 -0
  213. package/docusaurus/docs/dsl-syntax/validate.md +401 -0
  214. package/docusaurus/docs/error-handling/dead-letter-queues.md +399 -0
  215. package/docusaurus/docs/error-handling/flow-control.md +337 -0
  216. package/docusaurus/docs/error-handling/retry-strategies.md +368 -0
  217. package/docusaurus/docs/examples.md +488 -0
  218. package/docusaurus/docs/getting-started.md +256 -0
  219. package/docusaurus/docs/http/circuit-breaker.md +401 -0
  220. package/docusaurus/docs/http/incremental-sync.md +394 -0
  221. package/docusaurus/docs/http/pagination.md +361 -0
  222. package/docusaurus/docs/http/rate-limiting.md +383 -0
  223. package/docusaurus/docs/http/requests.md +328 -0
  224. package/docusaurus/docs/http/retry.md +402 -0
  225. package/docusaurus/docs/intro.md +90 -0
  226. package/docusaurus/docs/openapi/loading-specs.md +305 -0
  227. package/docusaurus/docs/openapi/operation-calls.md +314 -0
  228. package/docusaurus/docs/openapi/overview.md +212 -0
  229. package/docusaurus/docs/openapi/response-validation.md +344 -0
  230. package/docusaurus/docs/scheduling/cron.md +305 -0
  231. package/docusaurus/docs/scheduling/daemon-mode.md +317 -0
  232. package/docusaurus/docs/scheduling/intervals.md +289 -0
  233. package/docusaurus/docs/scheduling/overview.md +231 -0
  234. package/docusaurus/docs/stores/custom-adapters.md +376 -0
  235. package/docusaurus/docs/stores/file.md +236 -0
  236. package/docusaurus/docs/stores/memory.md +193 -0
  237. package/docusaurus/docs/stores/overview.md +274 -0
  238. package/docusaurus/docs/stores/postgrest.md +316 -0
  239. package/docusaurus/docusaurus.config.ts +148 -0
  240. package/docusaurus/package-lock.json +18029 -0
  241. package/docusaurus/package.json +47 -0
  242. package/docusaurus/sidebars.ts +155 -0
  243. package/docusaurus/src/components/HomepageFeatures/index.tsx +105 -0
  244. package/docusaurus/src/components/HomepageFeatures/styles.module.css +12 -0
  245. package/docusaurus/src/css/custom.css +169 -0
  246. package/docusaurus/src/pages/index.module.css +48 -0
  247. package/docusaurus/src/pages/index.tsx +110 -0
  248. package/docusaurus/src/pages/markdown-page.md +7 -0
  249. package/docusaurus/static/.nojekyll +0 -0
  250. package/docusaurus/static/img/docusaurus-social-card.jpg +0 -0
  251. package/docusaurus/static/img/docusaurus.png +0 -0
  252. package/docusaurus/static/img/favicon.ico +0 -0
  253. package/docusaurus/static/img/logo.svg +10 -0
  254. package/docusaurus/static/img/undraw_docusaurus_mountain.svg +171 -0
  255. package/docusaurus/static/img/undraw_docusaurus_react.svg +170 -0
  256. package/docusaurus/static/img/undraw_docusaurus_tree.svg +40 -0
  257. package/docusaurus/tsconfig.json +8 -0
  258. package/examples/README.md +112 -0
  259. package/examples/error-handling/README.md +150 -0
  260. package/examples/error-handling/payment-processor.vague +287 -0
  261. package/examples/github-sync/README.md +74 -0
  262. package/examples/github-sync/fetch-issues.vague +47 -0
  263. package/examples/github-sync/fetch-prs.vague +40 -0
  264. package/examples/github-sync/mission.vague +101 -0
  265. package/examples/github-sync/normalize.vague +70 -0
  266. package/examples/jsonplaceholder/README.md +28 -0
  267. package/examples/jsonplaceholder/posts.vague +48 -0
  268. package/examples/petstore/README.md +35 -0
  269. package/examples/petstore/openapi.yaml +97 -0
  270. package/examples/petstore/sync.vague +52 -0
  271. package/examples/temporal-comparison/README.md +297 -0
  272. package/examples/temporal-comparison/reconciliation.vague +355 -0
  273. package/examples/temporal-comparison/temporal/activities/index.ts +8 -0
  274. package/examples/temporal-comparison/temporal/activities/shipstation.ts +225 -0
  275. package/examples/temporal-comparison/temporal/activities/shopify.ts +257 -0
  276. package/examples/temporal-comparison/temporal/activities/storage.ts +198 -0
  277. package/examples/temporal-comparison/temporal/activities/stripe.ts +169 -0
  278. package/examples/temporal-comparison/temporal/activities/validation.ts +205 -0
  279. package/examples/temporal-comparison/temporal/client/schedule.ts +218 -0
  280. package/examples/temporal-comparison/temporal/config/retry.ts +63 -0
  281. package/examples/temporal-comparison/temporal/types/index.ts +129 -0
  282. package/examples/temporal-comparison/temporal/workers/main.ts +130 -0
  283. package/examples/temporal-comparison/temporal/workflows/orderReconciliation.ts +262 -0
  284. package/examples/xero/README.md +88 -0
  285. package/examples/xero/invoices.vague +189 -0
  286. package/package.json +40 -0
  287. package/src/api-integration.test.ts +954 -0
  288. package/src/ast/index.ts +1 -0
  289. package/src/ast/nodes.ts +310 -0
  290. package/src/auth/auth.test.ts +326 -0
  291. package/src/auth/circuit-breaker.test.ts +390 -0
  292. package/src/auth/circuit-breaker.ts +379 -0
  293. package/src/auth/credentials.test.ts +273 -0
  294. package/src/auth/credentials.ts +246 -0
  295. package/src/auth/index.ts +40 -0
  296. package/src/auth/oauth2-provider.ts +177 -0
  297. package/src/auth/rate-limiter.ts +459 -0
  298. package/src/auth/token-store.ts +177 -0
  299. package/src/auth/types.ts +159 -0
  300. package/src/benchmark/e2e.bench.ts +288 -0
  301. package/src/benchmark/evaluator.bench.ts +331 -0
  302. package/src/benchmark/fixtures.ts +295 -0
  303. package/src/benchmark/index.ts +108 -0
  304. package/src/benchmark/lexer.bench.ts +69 -0
  305. package/src/benchmark/parser.bench.ts +103 -0
  306. package/src/benchmark/resilience.bench.ts +193 -0
  307. package/src/benchmark/store.bench.ts +147 -0
  308. package/src/benchmark/utils.ts +230 -0
  309. package/src/cli.ts +313 -0
  310. package/src/errors/errors.test.ts +234 -0
  311. package/src/errors/index.ts +223 -0
  312. package/src/execution/execution.test.ts +307 -0
  313. package/src/execution/index.ts +21 -0
  314. package/src/execution/state.ts +207 -0
  315. package/src/execution/store.ts +188 -0
  316. package/src/index.ts +169 -0
  317. package/src/integration.test.ts +192 -0
  318. package/src/interpreter/context.ts +57 -0
  319. package/src/interpreter/evaluator.test.ts +796 -0
  320. package/src/interpreter/evaluator.ts +245 -0
  321. package/src/interpreter/executor.ts +946 -0
  322. package/src/interpreter/fetch-handler.ts +302 -0
  323. package/src/interpreter/http.test.ts +423 -0
  324. package/src/interpreter/http.ts +308 -0
  325. package/src/interpreter/index.ts +32 -0
  326. package/src/interpreter/pagination.ts +207 -0
  327. package/src/interpreter/progress.test.ts +276 -0
  328. package/src/interpreter/schema-matcher.test.ts +160 -0
  329. package/src/interpreter/schema-matcher.ts +168 -0
  330. package/src/interpreter/signals.ts +73 -0
  331. package/src/interpreter/step-handlers/for-handler.ts +65 -0
  332. package/src/interpreter/step-handlers/index.ts +17 -0
  333. package/src/interpreter/step-handlers/map-handler.ts +24 -0
  334. package/src/interpreter/step-handlers/match-handler.ts +101 -0
  335. package/src/interpreter/step-handlers/store-handler.ts +78 -0
  336. package/src/interpreter/step-handlers/types.ts +17 -0
  337. package/src/interpreter/step-handlers/validate-handler.ts +30 -0
  338. package/src/interpreter/step-handlers/webhook-handler.ts +142 -0
  339. package/src/lexer/index.ts +18 -0
  340. package/src/lexer/lexer.test.ts +316 -0
  341. package/src/lexer/tokens.ts +179 -0
  342. package/src/loader/index.ts +288 -0
  343. package/src/loader/loader.test.ts +360 -0
  344. package/src/oas/index.ts +4 -0
  345. package/src/oas/loader.ts +126 -0
  346. package/src/oas/oas.test.ts +254 -0
  347. package/src/oas/validator.ts +299 -0
  348. package/src/parser/base.ts +124 -0
  349. package/src/parser/expressions.test.ts +525 -0
  350. package/src/parser/expressions.ts +314 -0
  351. package/src/parser/index.ts +3 -0
  352. package/src/parser/match.test.ts +296 -0
  353. package/src/parser/parser.test.ts +739 -0
  354. package/src/parser/parser.ts +1469 -0
  355. package/src/parser/schedule.test.ts +287 -0
  356. package/src/parser/webhook.test.ts +248 -0
  357. package/src/plugin.ts +83 -0
  358. package/src/scheduler/cron-parser.test.ts +236 -0
  359. package/src/scheduler/cron-parser.ts +236 -0
  360. package/src/scheduler/index.ts +10 -0
  361. package/src/scheduler/scheduler.ts +443 -0
  362. package/src/scheduler/types.ts +71 -0
  363. package/src/stores/factory.ts +104 -0
  364. package/src/stores/file.test.ts +276 -0
  365. package/src/stores/file.ts +211 -0
  366. package/src/stores/index.ts +6 -0
  367. package/src/stores/memory.test.ts +238 -0
  368. package/src/stores/memory.ts +63 -0
  369. package/src/stores/postgrest.test.ts +488 -0
  370. package/src/stores/postgrest.ts +263 -0
  371. package/src/stores/stores.test.ts +197 -0
  372. package/src/stores/types.ts +58 -0
  373. package/src/sync/index.ts +16 -0
  374. package/src/sync/state.ts +126 -0
  375. package/src/sync/store.ts +139 -0
  376. package/src/sync/sync.test.ts +271 -0
  377. package/src/utils/async.ts +10 -0
  378. package/src/utils/file.ts +106 -0
  379. package/src/utils/index.ts +14 -0
  380. package/src/utils/logger.ts +53 -0
  381. package/src/utils/path.ts +47 -0
  382. package/src/webhook/index.ts +15 -0
  383. package/src/webhook/server.test.ts +253 -0
  384. package/src/webhook/server.ts +389 -0
  385. package/src/webhook/store.ts +239 -0
  386. package/src/webhook/types.ts +93 -0
  387. package/tsconfig.json +17 -0
  388. package/vitest.config.ts +39 -0
@@ -0,0 +1,47 @@
1
+ {
2
+ "name": "docusaurus",
3
+ "version": "0.0.0",
4
+ "private": true,
5
+ "scripts": {
6
+ "docusaurus": "docusaurus",
7
+ "start": "docusaurus start",
8
+ "build": "docusaurus build",
9
+ "swizzle": "docusaurus swizzle",
10
+ "deploy": "docusaurus deploy",
11
+ "clear": "docusaurus clear",
12
+ "serve": "docusaurus serve",
13
+ "write-translations": "docusaurus write-translations",
14
+ "write-heading-ids": "docusaurus write-heading-ids",
15
+ "typecheck": "tsc"
16
+ },
17
+ "dependencies": {
18
+ "@docusaurus/core": "3.9.2",
19
+ "@docusaurus/preset-classic": "3.9.2",
20
+ "@mdx-js/react": "^3.0.0",
21
+ "clsx": "^2.0.0",
22
+ "prism-react-renderer": "^2.3.0",
23
+ "react": "^19.0.0",
24
+ "react-dom": "^19.0.0"
25
+ },
26
+ "devDependencies": {
27
+ "@docusaurus/module-type-aliases": "3.9.2",
28
+ "@docusaurus/tsconfig": "3.9.2",
29
+ "@docusaurus/types": "3.9.2",
30
+ "typescript": "~5.6.2"
31
+ },
32
+ "browserslist": {
33
+ "production": [
34
+ ">0.5%",
35
+ "not dead",
36
+ "not op_mini all"
37
+ ],
38
+ "development": [
39
+ "last 3 chrome version",
40
+ "last 3 firefox version",
41
+ "last 5 safari version"
42
+ ]
43
+ },
44
+ "engines": {
45
+ "node": ">=20.0"
46
+ }
47
+ }
@@ -0,0 +1,155 @@
1
+ import type {SidebarsConfig} from '@docusaurus/plugin-content-docs';
2
+
3
+ const sidebars: SidebarsConfig = {
4
+ docsSidebar: [
5
+ 'intro',
6
+ 'getting-started',
7
+ 'cli',
8
+ {
9
+ type: 'category',
10
+ label: 'Core Concepts',
11
+ link: {
12
+ type: 'generated-index',
13
+ title: 'Core Concepts',
14
+ description: 'Learn about the fundamental building blocks of Reqon',
15
+ },
16
+ items: [
17
+ 'core-concepts/missions',
18
+ 'core-concepts/actions',
19
+ 'core-concepts/sources',
20
+ 'core-concepts/stores',
21
+ 'core-concepts/schemas',
22
+ ],
23
+ },
24
+ {
25
+ type: 'category',
26
+ label: 'DSL Syntax',
27
+ link: {
28
+ type: 'generated-index',
29
+ title: 'DSL Syntax Reference',
30
+ description: 'Complete reference for Reqon DSL syntax',
31
+ },
32
+ items: [
33
+ 'dsl-syntax/fetch',
34
+ 'dsl-syntax/for-loops',
35
+ 'dsl-syntax/map',
36
+ 'dsl-syntax/validate',
37
+ 'dsl-syntax/match',
38
+ 'dsl-syntax/pipelines',
39
+ 'dsl-syntax/expressions',
40
+ ],
41
+ },
42
+ {
43
+ type: 'category',
44
+ label: 'HTTP & Fetching',
45
+ link: {
46
+ type: 'generated-index',
47
+ title: 'HTTP & Fetching',
48
+ description: 'Learn about HTTP requests, pagination, and retry strategies',
49
+ },
50
+ items: [
51
+ 'http/requests',
52
+ 'http/pagination',
53
+ 'http/retry',
54
+ 'http/incremental-sync',
55
+ 'http/rate-limiting',
56
+ 'http/circuit-breaker',
57
+ ],
58
+ },
59
+ {
60
+ type: 'category',
61
+ label: 'Authentication',
62
+ link: {
63
+ type: 'generated-index',
64
+ title: 'Authentication',
65
+ description: 'Configure authentication for API sources',
66
+ },
67
+ items: [
68
+ 'authentication/overview',
69
+ 'authentication/oauth2',
70
+ 'authentication/bearer',
71
+ 'authentication/api-key',
72
+ 'authentication/basic',
73
+ ],
74
+ },
75
+ {
76
+ type: 'category',
77
+ label: 'Error Handling',
78
+ link: {
79
+ type: 'generated-index',
80
+ title: 'Error Handling',
81
+ description: 'Handle errors with flow control directives',
82
+ },
83
+ items: [
84
+ 'error-handling/flow-control',
85
+ 'error-handling/retry-strategies',
86
+ 'error-handling/dead-letter-queues',
87
+ ],
88
+ },
89
+ {
90
+ type: 'category',
91
+ label: 'Store Adapters',
92
+ link: {
93
+ type: 'generated-index',
94
+ title: 'Store Adapters',
95
+ description: 'Persist data to various backends',
96
+ },
97
+ items: [
98
+ 'stores/overview',
99
+ 'stores/memory',
100
+ 'stores/file',
101
+ 'stores/postgrest',
102
+ 'stores/custom-adapters',
103
+ ],
104
+ },
105
+ {
106
+ type: 'category',
107
+ label: 'OpenAPI Integration',
108
+ link: {
109
+ type: 'generated-index',
110
+ title: 'OpenAPI Integration',
111
+ description: 'Use OpenAPI specs for type-safe API calls',
112
+ },
113
+ items: [
114
+ 'openapi/overview',
115
+ 'openapi/loading-specs',
116
+ 'openapi/operation-calls',
117
+ 'openapi/response-validation',
118
+ ],
119
+ },
120
+ {
121
+ type: 'category',
122
+ label: 'Scheduling',
123
+ link: {
124
+ type: 'generated-index',
125
+ title: 'Scheduling',
126
+ description: 'Schedule missions to run automatically',
127
+ },
128
+ items: [
129
+ 'scheduling/overview',
130
+ 'scheduling/cron',
131
+ 'scheduling/intervals',
132
+ 'scheduling/daemon-mode',
133
+ ],
134
+ },
135
+ {
136
+ type: 'category',
137
+ label: 'Advanced Topics',
138
+ link: {
139
+ type: 'generated-index',
140
+ title: 'Advanced Topics',
141
+ description: 'Deep dive into advanced Reqon features',
142
+ },
143
+ items: [
144
+ 'advanced/multi-file-missions',
145
+ 'advanced/execution-state',
146
+ 'advanced/parallel-execution',
147
+ 'advanced/extending-reqon',
148
+ ],
149
+ },
150
+ 'examples',
151
+ 'api-reference',
152
+ ],
153
+ };
154
+
155
+ export default sidebars;
@@ -0,0 +1,105 @@
1
+ import type {ReactNode} from 'react';
2
+ import clsx from 'clsx';
3
+ import Heading from '@theme/Heading';
4
+ import styles from './styles.module.css';
5
+
6
+ type FeatureItem = {
7
+ title: string;
8
+ icon: string;
9
+ description: ReactNode;
10
+ };
11
+
12
+ const FeatureList: FeatureItem[] = [
13
+ {
14
+ title: 'Declarative Syntax',
15
+ icon: '📝',
16
+ description: (
17
+ <>
18
+ Write clean, readable pipelines that describe what you want, not how to do it.
19
+ Reqon handles pagination, retries, and error handling automatically.
20
+ </>
21
+ ),
22
+ },
23
+ {
24
+ title: 'Built-in Best Practices',
25
+ icon: '⚡',
26
+ description: (
27
+ <>
28
+ Automatic pagination, exponential backoff, rate limiting, circuit breakers,
29
+ and incremental sync are all built in. No boilerplate required.
30
+ </>
31
+ ),
32
+ },
33
+ {
34
+ title: 'Multiple Auth Methods',
35
+ icon: '🔐',
36
+ description: (
37
+ <>
38
+ Support for OAuth 2.0, Bearer tokens, API keys, and Basic auth.
39
+ Automatic token refresh for OAuth flows.
40
+ </>
41
+ ),
42
+ },
43
+ {
44
+ title: 'OpenAPI Integration',
45
+ icon: '📋',
46
+ description: (
47
+ <>
48
+ Load OpenAPI specs for type-safe API calls. Validate responses against
49
+ schema definitions automatically.
50
+ </>
51
+ ),
52
+ },
53
+ {
54
+ title: 'Flexible Storage',
55
+ icon: '💾',
56
+ description: (
57
+ <>
58
+ Store data in memory, files, SQL (via PostgREST/Supabase), or NoSQL.
59
+ Create custom adapters for any backend.
60
+ </>
61
+ ),
62
+ },
63
+ {
64
+ title: 'Production Ready',
65
+ icon: '🚀',
66
+ description: (
67
+ <>
68
+ Built-in scheduling with cron and intervals. Run as a daemon with
69
+ health checks, metrics, and graceful shutdown.
70
+ </>
71
+ ),
72
+ },
73
+ ];
74
+
75
+ function Feature({title, icon, description}: FeatureItem) {
76
+ return (
77
+ <div className={clsx('col col--4')}>
78
+ <div className="text--center padding-horiz--md">
79
+ <div className={styles.featureIcon}>{icon}</div>
80
+ <Heading as="h3">{title}</Heading>
81
+ <p>{description}</p>
82
+ </div>
83
+ </div>
84
+ );
85
+ }
86
+
87
+ export default function HomepageFeatures(): ReactNode {
88
+ return (
89
+ <section className={styles.features}>
90
+ <div className="container">
91
+ <div className="text--center margin-bottom--xl">
92
+ <Heading as="h2">Why Reqon?</Heading>
93
+ <p className="hero__subtitle">
94
+ Stop writing boilerplate. Start building data pipelines.
95
+ </p>
96
+ </div>
97
+ <div className="row">
98
+ {FeatureList.map((props, idx) => (
99
+ <Feature key={idx} {...props} />
100
+ ))}
101
+ </div>
102
+ </div>
103
+ </section>
104
+ );
105
+ }
@@ -0,0 +1,12 @@
1
+ .features {
2
+ display: flex;
3
+ align-items: center;
4
+ padding: 4rem 0;
5
+ width: 100%;
6
+ background-color: var(--ifm-background-surface-color);
7
+ }
8
+
9
+ .featureIcon {
10
+ font-size: 3rem;
11
+ margin-bottom: 1rem;
12
+ }
@@ -0,0 +1,169 @@
1
+ /**
2
+ * Reqon Documentation Theme
3
+ * Based on a modern purple/violet color palette
4
+ */
5
+
6
+ :root {
7
+ --ifm-color-primary: #6366f1;
8
+ --ifm-color-primary-dark: #4f46e5;
9
+ --ifm-color-primary-darker: #4338ca;
10
+ --ifm-color-primary-darkest: #3730a3;
11
+ --ifm-color-primary-light: #818cf8;
12
+ --ifm-color-primary-lighter: #a5b4fc;
13
+ --ifm-color-primary-lightest: #c7d2fe;
14
+
15
+ --ifm-code-font-size: 95%;
16
+ --ifm-font-family-base: 'Inter', system-ui, -apple-system, sans-serif;
17
+ --ifm-font-family-monospace: 'JetBrains Mono', 'Fira Code', 'Consolas', monospace;
18
+
19
+ --docusaurus-highlighted-code-line-bg: rgba(99, 102, 241, 0.1);
20
+
21
+ --ifm-heading-font-weight: 600;
22
+ --ifm-navbar-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
23
+ }
24
+
25
+ [data-theme='dark'] {
26
+ --ifm-color-primary: #818cf8;
27
+ --ifm-color-primary-dark: #6366f1;
28
+ --ifm-color-primary-darker: #4f46e5;
29
+ --ifm-color-primary-darkest: #4338ca;
30
+ --ifm-color-primary-light: #a5b4fc;
31
+ --ifm-color-primary-lighter: #c7d2fe;
32
+ --ifm-color-primary-lightest: #e0e7ff;
33
+
34
+ --docusaurus-highlighted-code-line-bg: rgba(129, 140, 248, 0.2);
35
+ --ifm-background-color: #0f172a;
36
+ --ifm-background-surface-color: #1e293b;
37
+ }
38
+
39
+ /* Code blocks */
40
+ .prism-code {
41
+ border-radius: 8px;
42
+ }
43
+
44
+ code {
45
+ border-radius: 4px;
46
+ padding: 2px 6px;
47
+ }
48
+
49
+ /* Navbar styling */
50
+ .navbar {
51
+ backdrop-filter: blur(8px);
52
+ }
53
+
54
+ .navbar__title {
55
+ font-weight: 700;
56
+ }
57
+
58
+ /* Hero section on homepage */
59
+ .hero {
60
+ background: linear-gradient(135deg, var(--ifm-color-primary-lightest) 0%, var(--ifm-background-color) 100%);
61
+ }
62
+
63
+ [data-theme='dark'] .hero {
64
+ background: linear-gradient(135deg, var(--ifm-color-primary-darkest) 0%, var(--ifm-background-color) 100%);
65
+ }
66
+
67
+ /* Sidebar improvements */
68
+ .menu__link {
69
+ border-radius: 6px;
70
+ transition: all 0.15s ease;
71
+ }
72
+
73
+ .menu__link:hover {
74
+ background-color: var(--ifm-color-primary-lightest);
75
+ }
76
+
77
+ [data-theme='dark'] .menu__link:hover {
78
+ background-color: rgba(129, 140, 248, 0.1);
79
+ }
80
+
81
+ .menu__link--active {
82
+ font-weight: 600;
83
+ }
84
+
85
+ /* Card styling for category indexes */
86
+ .card {
87
+ border-radius: 12px;
88
+ border: 1px solid var(--ifm-color-emphasis-200);
89
+ transition: all 0.2s ease;
90
+ }
91
+
92
+ .card:hover {
93
+ border-color: var(--ifm-color-primary);
94
+ box-shadow: 0 4px 12px rgba(99, 102, 241, 0.1);
95
+ }
96
+
97
+ /* Tables */
98
+ table {
99
+ border-radius: 8px;
100
+ overflow: hidden;
101
+ }
102
+
103
+ th {
104
+ background-color: var(--ifm-color-emphasis-100);
105
+ }
106
+
107
+ /* Admonitions */
108
+ .admonition {
109
+ border-radius: 8px;
110
+ }
111
+
112
+ /* Footer */
113
+ .footer {
114
+ background-color: var(--ifm-background-surface-color);
115
+ }
116
+
117
+ /* Custom syntax highlighting for Reqon DSL */
118
+ .token.keyword {
119
+ color: var(--ifm-color-primary);
120
+ font-weight: 500;
121
+ }
122
+
123
+ /* Feature cards on homepage */
124
+ .feature-card {
125
+ background: var(--ifm-background-surface-color);
126
+ border-radius: 12px;
127
+ padding: 1.5rem;
128
+ border: 1px solid var(--ifm-color-emphasis-200);
129
+ transition: all 0.2s ease;
130
+ }
131
+
132
+ .feature-card:hover {
133
+ transform: translateY(-2px);
134
+ box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
135
+ }
136
+
137
+ /* TOC styling */
138
+ .table-of-contents__link:hover {
139
+ color: var(--ifm-color-primary);
140
+ }
141
+
142
+ .table-of-contents__link--active {
143
+ color: var(--ifm-color-primary);
144
+ font-weight: 500;
145
+ }
146
+
147
+ /* Breadcrumbs */
148
+ .breadcrumbs__link {
149
+ border-radius: 4px;
150
+ }
151
+
152
+ /* Scrollbar styling */
153
+ ::-webkit-scrollbar {
154
+ width: 8px;
155
+ height: 8px;
156
+ }
157
+
158
+ ::-webkit-scrollbar-track {
159
+ background: transparent;
160
+ }
161
+
162
+ ::-webkit-scrollbar-thumb {
163
+ background: var(--ifm-color-emphasis-300);
164
+ border-radius: 4px;
165
+ }
166
+
167
+ ::-webkit-scrollbar-thumb:hover {
168
+ background: var(--ifm-color-emphasis-400);
169
+ }
@@ -0,0 +1,48 @@
1
+ .heroBanner {
2
+ padding: 4rem 0;
3
+ text-align: center;
4
+ position: relative;
5
+ overflow: hidden;
6
+ }
7
+
8
+ @media screen and (max-width: 996px) {
9
+ .heroBanner {
10
+ padding: 2rem;
11
+ }
12
+ }
13
+
14
+ .buttons {
15
+ display: flex;
16
+ align-items: center;
17
+ justify-content: center;
18
+ gap: 1rem;
19
+ flex-wrap: wrap;
20
+ }
21
+
22
+ .codeExample {
23
+ padding: 4rem 0;
24
+ background-color: var(--ifm-background-color);
25
+ }
26
+
27
+ .codeExample h2 {
28
+ margin-bottom: 1rem;
29
+ }
30
+
31
+ .codeExample ul {
32
+ margin: 1.5rem 0;
33
+ padding-left: 1.5rem;
34
+ }
35
+
36
+ .codeExample li {
37
+ margin-bottom: 0.5rem;
38
+ }
39
+
40
+ @media screen and (max-width: 996px) {
41
+ .codeExample .row {
42
+ flex-direction: column-reverse;
43
+ }
44
+
45
+ .codeExample .col {
46
+ margin-bottom: 2rem;
47
+ }
48
+ }
@@ -0,0 +1,110 @@
1
+ import type {ReactNode} from 'react';
2
+ import clsx from 'clsx';
3
+ import Link from '@docusaurus/Link';
4
+ import useDocusaurusContext from '@docusaurus/useDocusaurusContext';
5
+ import Layout from '@theme/Layout';
6
+ import HomepageFeatures from '@site/src/components/HomepageFeatures';
7
+ import Heading from '@theme/Heading';
8
+ import CodeBlock from '@theme/CodeBlock';
9
+
10
+ import styles from './index.module.css';
11
+
12
+ const exampleCode = `mission SyncCustomers {
13
+ source API { auth: bearer, base: "https://api.example.com" }
14
+ store customers: file("customers")
15
+
16
+ action Fetch {
17
+ get "/customers" {
18
+ paginate: offset(page, 100),
19
+ until: length(response) == 0,
20
+ since: lastSync
21
+ }
22
+
23
+ for customer in response {
24
+ map customer -> Customer {
25
+ id: .id,
26
+ name: .name,
27
+ email: lowercase(.email)
28
+ }
29
+ store customer -> customers { key: .id, upsert: true }
30
+ }
31
+ }
32
+
33
+ run Fetch
34
+ }`;
35
+
36
+ function HomepageHeader() {
37
+ const {siteConfig} = useDocusaurusContext();
38
+ return (
39
+ <header className={clsx('hero hero--primary', styles.heroBanner)}>
40
+ <div className="container">
41
+ <Heading as="h1" className="hero__title">
42
+ {siteConfig.title}
43
+ </Heading>
44
+ <p className="hero__subtitle">{siteConfig.tagline}</p>
45
+ <div className={styles.buttons}>
46
+ <Link
47
+ className="button button--secondary button--lg"
48
+ to="/docs/">
49
+ Get Started
50
+ </Link>
51
+ <Link
52
+ className="button button--outline button--lg"
53
+ style={{marginLeft: '1rem', color: 'white', borderColor: 'white'}}
54
+ to="/docs/examples">
55
+ View Examples
56
+ </Link>
57
+ </div>
58
+ </div>
59
+ </header>
60
+ );
61
+ }
62
+
63
+ function CodeExample() {
64
+ return (
65
+ <section className={styles.codeExample}>
66
+ <div className="container">
67
+ <div className="row">
68
+ <div className="col col--6">
69
+ <Heading as="h2">Declarative Data Pipelines</Heading>
70
+ <p>
71
+ Define what you want to happen, not how. Reqon handles pagination,
72
+ retries, rate limiting, and error handling automatically.
73
+ </p>
74
+ <ul>
75
+ <li>Automatic pagination with offset, page, or cursor strategies</li>
76
+ <li>Built-in retry with exponential backoff</li>
77
+ <li>Incremental sync with checkpoint tracking</li>
78
+ <li>Pattern matching for error handling</li>
79
+ </ul>
80
+ <Link
81
+ className="button button--primary button--lg"
82
+ to="/docs/getting-started">
83
+ Learn the Syntax
84
+ </Link>
85
+ </div>
86
+ <div className="col col--6">
87
+ <CodeBlock language="typescript" title="sync.vague">
88
+ {exampleCode}
89
+ </CodeBlock>
90
+ </div>
91
+ </div>
92
+ </div>
93
+ </section>
94
+ );
95
+ }
96
+
97
+ export default function Home(): ReactNode {
98
+ const {siteConfig} = useDocusaurusContext();
99
+ return (
100
+ <Layout
101
+ title="Declarative DSL for Data Pipelines"
102
+ description="Reqon is a declarative DSL framework for fetch, map, validate pipelines. Build robust data synchronization with clean, readable syntax.">
103
+ <HomepageHeader />
104
+ <main>
105
+ <HomepageFeatures />
106
+ <CodeExample />
107
+ </main>
108
+ </Layout>
109
+ );
110
+ }
@@ -0,0 +1,7 @@
1
+ ---
2
+ title: Markdown page example
3
+ ---
4
+
5
+ # Markdown page example
6
+
7
+ You don't need React to write simple standalone pages.
File without changes
@@ -0,0 +1,10 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100" width="100" height="100">
2
+ <defs>
3
+ <linearGradient id="grad" x1="0%" y1="0%" x2="100%" y2="100%">
4
+ <stop offset="0%" style="stop-color:#6366f1;stop-opacity:1" />
5
+ <stop offset="100%" style="stop-color:#818cf8;stop-opacity:1" />
6
+ </linearGradient>
7
+ </defs>
8
+ <rect x="10" y="10" width="80" height="80" rx="16" fill="url(#grad)"/>
9
+ <text x="50" y="68" font-family="system-ui, -apple-system, sans-serif" font-size="48" font-weight="700" fill="white" text-anchor="middle">R</text>
10
+ </svg>