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,31 @@
1
+ {
2
+ "permissions": {
3
+ "allow": [
4
+ "Bash(npm init -y)",
5
+ "Bash(npm install)",
6
+ "Bash(npm run build:*)",
7
+ "Bash(npm run test:run:*)",
8
+ "Bash(npx vitest run src/debug.test.ts)",
9
+ "Bash(npx vitest:*)",
10
+ "Bash(git init:*)",
11
+ "Bash(git add:*)",
12
+ "Bash(git commit:*)",
13
+ "Bash(git push:*)",
14
+ "Bash(npm install:*)",
15
+ "Bash(node dist/cli.js:*)",
16
+ "Bash(ls:*)",
17
+ "Bash(node:*)",
18
+ "Bash(cat:*)",
19
+ "Bash(git checkout:*)",
20
+ "Bash(git rebase:*)",
21
+ "Bash(find:*)",
22
+ "Bash(git fetch:*)",
23
+ "Bash(xargs sed:*)",
24
+ "Bash(for f in examples/**/*.reqon)",
25
+ "Bash(do mv $f $f%.reqon.vague)",
26
+ "Bash(done)",
27
+ "Bash(npx:*)",
28
+ "Skill(reqon)"
29
+ ]
30
+ }
31
+ }
@@ -0,0 +1,125 @@
1
+ # API Integration Patterns Skill
2
+
3
+ Use this skill when implementing API client functionality, authentication flows, rate limiting, or pagination in Reqon.
4
+
5
+ ## Capabilities
6
+
7
+ ### OAuth2 Token Refresh Flows
8
+ - Implement automatic token refresh on 401 responses
9
+ - Handle refresh token rotation
10
+ - Store and retrieve tokens securely
11
+ - Support authorization_code, client_credentials, and refresh_token grants
12
+
13
+ ### Rate Limiting with Exponential Backoff
14
+ - Parse rate limit headers (X-RateLimit-*, Retry-After)
15
+ - Implement exponential backoff with jitter
16
+ - Queue requests when rate limited
17
+ - Respect per-endpoint rate limits
18
+
19
+ ### Pagination Pattern Implementations
20
+ - **Cursor-based**: Use `next_cursor` or `after` parameters
21
+ - **Offset-based**: Use `offset` and `limit` parameters
22
+ - **Page-based**: Use `page` and `per_page` parameters
23
+ - **Link header**: Parse RFC 5988 Link headers
24
+
25
+ ## Context Files
26
+ When using this skill, read:
27
+ - `src/interpreter/http.ts` - HTTP client implementation
28
+ - `src/interpreter/executor.ts` - Fetch execution logic
29
+ - `src/ast/nodes.ts` - FetchNode, PaginationConfig types
30
+
31
+ ## Implementation Patterns
32
+
33
+ ### OAuth2 Token Refresh
34
+ ```typescript
35
+ async function fetchWithAuth(url: string, auth: OAuth2Auth): Promise<Response> {
36
+ let response = await fetch(url, {
37
+ headers: { Authorization: `Bearer ${auth.accessToken}` }
38
+ });
39
+
40
+ if (response.status === 401 && auth.refreshToken) {
41
+ const newTokens = await refreshAccessToken(auth);
42
+ auth.accessToken = newTokens.access_token;
43
+ response = await fetch(url, {
44
+ headers: { Authorization: `Bearer ${auth.accessToken}` }
45
+ });
46
+ }
47
+
48
+ return response;
49
+ }
50
+ ```
51
+
52
+ ### Exponential Backoff
53
+ ```typescript
54
+ async function fetchWithBackoff(
55
+ url: string,
56
+ maxRetries = 5,
57
+ baseDelay = 1000
58
+ ): Promise<Response> {
59
+ for (let attempt = 0; attempt < maxRetries; attempt++) {
60
+ const response = await fetch(url);
61
+
62
+ if (response.status === 429) {
63
+ const retryAfter = response.headers.get('Retry-After');
64
+ const delay = retryAfter
65
+ ? parseInt(retryAfter) * 1000
66
+ : baseDelay * Math.pow(2, attempt) + Math.random() * 1000;
67
+ await sleep(delay);
68
+ continue;
69
+ }
70
+
71
+ return response;
72
+ }
73
+ throw new Error('Max retries exceeded');
74
+ }
75
+ ```
76
+
77
+ ### Pagination Patterns
78
+
79
+ #### Cursor-based
80
+ ```typescript
81
+ async function* paginateCursor(baseUrl: string) {
82
+ let cursor: string | undefined;
83
+ do {
84
+ const url = cursor ? `${baseUrl}?cursor=${cursor}` : baseUrl;
85
+ const response = await fetch(url);
86
+ const data = await response.json();
87
+ yield data.items;
88
+ cursor = data.next_cursor;
89
+ } while (cursor);
90
+ }
91
+ ```
92
+
93
+ #### Offset-based
94
+ ```typescript
95
+ async function* paginateOffset(baseUrl: string, limit = 100) {
96
+ let offset = 0;
97
+ let hasMore = true;
98
+ while (hasMore) {
99
+ const response = await fetch(`${baseUrl}?offset=${offset}&limit=${limit}`);
100
+ const data = await response.json();
101
+ yield data.items;
102
+ offset += limit;
103
+ hasMore = data.items.length === limit;
104
+ }
105
+ }
106
+ ```
107
+
108
+ #### Link Header
109
+ ```typescript
110
+ function parseLinks(header: string): Record<string, string> {
111
+ const links: Record<string, string> = {};
112
+ header.split(',').forEach(part => {
113
+ const match = part.match(/<([^>]+)>;\s*rel="([^"]+)"/);
114
+ if (match) links[match[2]] = match[1];
115
+ });
116
+ return links;
117
+ }
118
+ ```
119
+
120
+ ## Rate Limit Headers
121
+ Common headers to parse:
122
+ - `X-RateLimit-Limit` - Request limit per window
123
+ - `X-RateLimit-Remaining` - Requests remaining
124
+ - `X-RateLimit-Reset` - Unix timestamp when limit resets
125
+ - `Retry-After` - Seconds to wait (on 429/503)
@@ -0,0 +1,51 @@
1
+ # Database Schema Skill
2
+
3
+ Use this skill when working on SQL/NoSQL store adapters or database-related functionality in Reqon.
4
+
5
+ ## Capabilities
6
+
7
+ ### Generating Store Implementations
8
+ - Create PostgreSQL store adapters implementing the `StoreAdapter` interface from `src/stores/types.ts`
9
+ - Create MySQL store adapters with appropriate driver usage
10
+ - Create MongoDB/DynamoDB NoSQL adapters
11
+
12
+ ### Creating Migration Files
13
+ - Generate SQL migration files for schema creation
14
+ - Create up/down migration pairs for reversibility
15
+ - Handle incremental schema changes
16
+
17
+ ### Type Mapping
18
+ Map Reqon/Vague DSL types to database column types:
19
+
20
+ | DSL Type | PostgreSQL | MySQL | MongoDB |
21
+ |----------|------------|-------|---------|
22
+ | string | TEXT/VARCHAR | VARCHAR | String |
23
+ | number | NUMERIC/INTEGER | DECIMAL/INT | Number |
24
+ | boolean | BOOLEAN | TINYINT(1) | Boolean |
25
+ | array | JSONB | JSON | Array |
26
+ | object | JSONB | JSON | Object |
27
+ | date | TIMESTAMP | DATETIME | Date |
28
+
29
+ ## Context Files
30
+ When using this skill, read:
31
+ - `src/stores/types.ts` - StoreAdapter interface
32
+ - `src/stores/memory.ts` - Reference implementation
33
+ - `src/ast/nodes.ts` - Schema and type definitions
34
+
35
+ ## Implementation Patterns
36
+
37
+ ### Store Adapter Structure
38
+ ```typescript
39
+ import { StoreAdapter, StoreRecord } from './types';
40
+
41
+ export class PostgresStore implements StoreAdapter {
42
+ async get(key: string): Promise<StoreRecord | undefined> { }
43
+ async set(key: string, value: StoreRecord): Promise<void> { }
44
+ async delete(key: string): Promise<boolean> { }
45
+ async query(filter: Record<string, unknown>): Promise<StoreRecord[]> { }
46
+ async upsert(key: string, value: StoreRecord): Promise<void> { }
47
+ }
48
+ ```
49
+
50
+ ### Migration File Naming
51
+ Use timestamp-based naming: `YYYYMMDDHHMMSS_description.sql`
@@ -0,0 +1,80 @@
1
+ # Language/DSL Design Skill
2
+
3
+ Use this skill when extending Reqon's DSL syntax, implementing new language constructs, or working on the lexer/parser.
4
+
5
+ ## Architecture Overview
6
+
7
+ Reqon extends Vague's language infrastructure:
8
+ - **Vague** provides: lexer base, expression syntax, match expressions, core AST
9
+ - **Reqon** adds: mission/action/fetch/store constructs, execution semantics
10
+
11
+ ## Capabilities
12
+
13
+ ### Implementing New DSL Constructs
14
+ - Add new keywords to `src/lexer/tokens.ts`
15
+ - Extend the lexer in `src/lexer/lexer.ts`
16
+ - Add parser rules in `src/parser/parser.ts`
17
+ - Define AST nodes in `src/ast/nodes.ts`
18
+
19
+ ### Writing Parser Tests
20
+ - Create comprehensive test cases in `src/parser/parser.test.ts`
21
+ - Test edge cases and error conditions
22
+ - Use Vitest's describe/it/expect patterns
23
+
24
+ ### Generating Better Error Messages
25
+ - Include line and column numbers in parse errors
26
+ - Provide context about what was expected
27
+ - Suggest fixes for common mistakes
28
+
29
+ ## Context Files
30
+ When using this skill, read:
31
+ - `src/lexer/tokens.ts` - Token definitions
32
+ - `src/lexer/lexer.ts` - Lexer implementation
33
+ - `src/parser/parser.ts` - Main parser
34
+ - `src/parser/base.ts` - Parser utilities
35
+ - `src/ast/nodes.ts` - AST node types
36
+
37
+ ## Implementation Patterns
38
+
39
+ ### Adding a New Keyword
40
+ 1. Add token type to `ReqonTokenType` enum in `tokens.ts`
41
+ 2. Add keyword mapping in `REQON_KEYWORDS` in `lexer.ts`
42
+ 3. Add parsing logic in `parser.ts`
43
+ 4. Define AST node in `nodes.ts`
44
+
45
+ ### Token Definition Pattern
46
+ ```typescript
47
+ export enum ReqonTokenType {
48
+ // ... existing tokens
49
+ NEW_KEYWORD = 'NEW_KEYWORD',
50
+ }
51
+
52
+ export const REQON_KEYWORDS: Record<string, ReqonTokenType> = {
53
+ // ... existing keywords
54
+ 'newkeyword': ReqonTokenType.NEW_KEYWORD,
55
+ };
56
+ ```
57
+
58
+ ### Parser Rule Pattern
59
+ ```typescript
60
+ private parseNewConstruct(): NewConstructNode {
61
+ this.expect(ReqonTokenType.NEW_KEYWORD);
62
+ const name = this.parseIdentifier();
63
+ // ... parse body
64
+ return { type: 'NewConstruct', name, ... };
65
+ }
66
+ ```
67
+
68
+ ### Error Message Pattern
69
+ ```typescript
70
+ throw new ParseError(
71
+ `Expected ${expected} but found ${actual}`,
72
+ { line: token.line, column: token.column }
73
+ );
74
+ ```
75
+
76
+ ## Planned Constructs (from TODO.md)
77
+ - `is` type checking: `assume .items is array`
78
+ - Parallel execution: `run Step1, Step2 then Step3`
79
+ - Conditional actions: `run Step1 then Step2 if condition`
80
+ - Variables/let bindings: `let x = expression`
@@ -0,0 +1,143 @@
1
+ # Property-Based Testing Skill
2
+
3
+ Use this skill when implementing property-based tests, fuzzing the parser, or generating mock API responses.
4
+
5
+ ## Capabilities
6
+
7
+ ### Generating Fuzzing Inputs for the Parser
8
+ - Generate random valid Reqon programs
9
+ - Generate edge-case inputs (empty strings, unicode, deeply nested)
10
+ - Generate semi-valid inputs to test error recovery
11
+ - Mutate valid programs to find parser bugs
12
+
13
+ ### Writing Vitest Property-Based Tests
14
+ - Use fast-check or similar libraries
15
+ - Define properties that should hold for all inputs
16
+ - Shrink failing cases to minimal reproductions
17
+ - Combine with traditional example-based tests
18
+
19
+ ### Creating Mock API Responses
20
+ - Generate responses matching Reqon schemas
21
+ - Create varied test data (edge cases, nulls, arrays)
22
+ - Simulate pagination responses
23
+ - Mock error responses (4xx, 5xx)
24
+
25
+ ## Context Files
26
+ When using this skill, read:
27
+ - `src/parser/parser.test.ts` - Existing parser tests
28
+ - `src/integration.test.ts` - Integration test patterns
29
+ - `src/ast/nodes.ts` - AST structure for generation
30
+ - `src/lexer/tokens.ts` - Valid tokens for fuzzing
31
+
32
+ ## Implementation Patterns
33
+
34
+ ### Property-Based Test Setup
35
+ ```typescript
36
+ import { describe, it, expect } from 'vitest';
37
+ import * as fc from 'fast-check';
38
+ import { parse } from './parser';
39
+ import { lex } from '../lexer';
40
+
41
+ describe('Parser Properties', () => {
42
+ it('should parse any valid mission without throwing', () => {
43
+ fc.assert(
44
+ fc.property(validMissionArb, (mission) => {
45
+ expect(() => parse(lex(mission))).not.toThrow();
46
+ })
47
+ );
48
+ });
49
+ });
50
+ ```
51
+
52
+ ### Arbitrary Generators for Reqon
53
+
54
+ ```typescript
55
+ // Generate valid identifiers
56
+ const identifierArb = fc.stringOf(
57
+ fc.constantFrom(...'abcdefghijklmnopqrstuvwxyz_'),
58
+ { minLength: 1, maxLength: 20 }
59
+ ).filter(s => /^[a-z_][a-z0-9_]*$/i.test(s));
60
+
61
+ // Generate valid string literals
62
+ const stringLiteralArb = fc.string().map(s => `"${s.replace(/"/g, '\\"')}"`);
63
+
64
+ // Generate valid fetch paths
65
+ const pathArb = fc.array(identifierArb, { minLength: 1, maxLength: 5 })
66
+ .map(parts => '/' + parts.join('/'));
67
+
68
+ // Generate valid actions
69
+ const actionArb = fc.record({
70
+ name: identifierArb,
71
+ path: pathArb,
72
+ }).map(({ name, path }) => `action ${name} { fetch ${path} }`);
73
+
74
+ // Generate valid missions
75
+ const validMissionArb = fc.record({
76
+ name: identifierArb,
77
+ url: fc.webUrl(),
78
+ actions: fc.array(actionArb, { minLength: 1, maxLength: 5 }),
79
+ }).map(({ name, url, actions }) => `
80
+ mission ${name} {
81
+ source api { url: "${url}" }
82
+ ${actions.join('\n')}
83
+ }
84
+ `);
85
+ ```
86
+
87
+ ### Mock Response Generation
88
+ ```typescript
89
+ // Generate mock response matching schema
90
+ const mockResponseArb = (schema: SchemaNode): fc.Arbitrary<unknown> => {
91
+ switch (schema.type) {
92
+ case 'string': return fc.string();
93
+ case 'number': return fc.double();
94
+ case 'boolean': return fc.boolean();
95
+ case 'array': return fc.array(mockResponseArb(schema.items));
96
+ case 'object': return fc.record(
97
+ Object.fromEntries(
98
+ Object.entries(schema.properties).map(
99
+ ([k, v]) => [k, mockResponseArb(v)]
100
+ )
101
+ )
102
+ );
103
+ }
104
+ };
105
+
106
+ // Generate paginated response
107
+ const paginatedResponseArb = <T>(itemArb: fc.Arbitrary<T>) =>
108
+ fc.record({
109
+ items: fc.array(itemArb, { minLength: 0, maxLength: 100 }),
110
+ next_cursor: fc.option(fc.hexaString({ minLength: 16, maxLength: 16 })),
111
+ total: fc.nat(),
112
+ });
113
+ ```
114
+
115
+ ### Parser Fuzzing Strategies
116
+ ```typescript
117
+ // Mutation-based fuzzing
118
+ const mutateProgram = (valid: string): fc.Arbitrary<string> =>
119
+ fc.oneof(
120
+ // Delete random character
121
+ fc.nat({ max: valid.length - 1 }).map(i =>
122
+ valid.slice(0, i) + valid.slice(i + 1)
123
+ ),
124
+ // Insert random character
125
+ fc.tuple(fc.nat({ max: valid.length }), fc.char()).map(([i, c]) =>
126
+ valid.slice(0, i) + c + valid.slice(i)
127
+ ),
128
+ // Replace random character
129
+ fc.tuple(fc.nat({ max: valid.length - 1 }), fc.char()).map(([i, c]) =>
130
+ valid.slice(0, i) + c + valid.slice(i + 1)
131
+ )
132
+ );
133
+ ```
134
+
135
+ ## Dependencies
136
+ Add to `package.json`:
137
+ ```json
138
+ {
139
+ "devDependencies": {
140
+ "fast-check": "^3.15.0"
141
+ }
142
+ }
143
+ ```
@@ -0,0 +1,44 @@
1
+ ---
2
+ name: reqon
3
+ # prettier-ignore
4
+ description: Use when writing or editing .vague files for Reqon declarative API data pipelines
5
+ ---
6
+
7
+ # Reqon
8
+
9
+ Declarative DSL for fetch, map, validate pipelines. File extension: `.vague`
10
+
11
+ ## Quick Start
12
+
13
+ ```
14
+ mission SyncData {
15
+ source API { auth: bearer, base: "https://api.example.com" }
16
+ store items: memory("items")
17
+
18
+ action Fetch {
19
+ get "/items" { paginate: page(page, 100), until: length(response) == 0 }
20
+ store response -> items { key: .id }
21
+ }
22
+
23
+ run Fetch
24
+ }
25
+ ```
26
+
27
+ ## Core Constructs
28
+
29
+ - `mission` - Pipeline container (sources, stores, schemas, actions)
30
+ - `source` - API: auth (bearer/basic/api_key/oauth2), base, headers, rateLimit
31
+ - `store` - Storage: `memory("name")`, `file("path")`, `sql("table")`
32
+ - `action` - Pipeline step: fetch, map, validate, store
33
+ - `run [A, B] then C` - Parallel then sequential execution
34
+ - `match response { Schema -> ..., _ -> skip }` - Pattern matching
35
+ - `for item in store where .active { ... }` - Iteration with filter
36
+
37
+ ## Flow Control
38
+
39
+ `continue`, `skip`, `abort "msg"`, `retry {...}`, `queue dlq`, `jump Action then retry`
40
+
41
+ ## Reference Files
42
+
43
+ - [references/syntax.md](references/syntax.md) - Full DSL syntax
44
+ - [references/examples.md](references/examples.md) - Complete examples
@@ -0,0 +1,206 @@
1
+ # Reqon Examples
2
+
3
+ ## Simple API Sync
4
+
5
+ ```
6
+ mission SyncUsers {
7
+ source API {
8
+ auth: bearer,
9
+ base: "https://api.example.com"
10
+ }
11
+
12
+ store users: memory("users")
13
+
14
+ action FetchUsers {
15
+ get "/users" {
16
+ paginate: page(page, 50),
17
+ until: length(response) == 0
18
+ }
19
+ store response -> users { key: .id }
20
+ }
21
+
22
+ run FetchUsers
23
+ }
24
+ ```
25
+
26
+ ## Multi-File Mission Structure
27
+
28
+ ```
29
+ project/
30
+ ├── mission.vague # Main: sources, stores, schemas, pipeline
31
+ ├── fetch-data.vague # Action: FetchData
32
+ ├── transform.vague # Action: Transform
33
+ └── validate.vague # Action: Validate
34
+ ```
35
+
36
+ Actions in separate files are automatically merged into the mission.
37
+
38
+ ## Error Handling with Match
39
+
40
+ ```
41
+ action FetchWithErrorHandling {
42
+ get "/data"
43
+
44
+ match response {
45
+ [DataSchema] -> {
46
+ store response -> data { key: .id }
47
+ },
48
+
49
+ RateLimitError -> retry {
50
+ maxAttempts: 5,
51
+ backoff: exponential,
52
+ initialDelay: 60000
53
+ },
54
+
55
+ AuthError -> jump RefreshToken then retry,
56
+
57
+ NotFoundError -> abort "Resource not found",
58
+
59
+ _ -> {
60
+ store {
61
+ error: "Unexpected response",
62
+ response: response,
63
+ timestamp: now()
64
+ } -> errors { key: now() }
65
+ }
66
+ }
67
+ }
68
+ ```
69
+
70
+ ## Data Transformation Pipeline
71
+
72
+ ```
73
+ action TransformData {
74
+ for item in raw_items {
75
+ map item -> NormalizedItem {
76
+ id: "item_" + .id,
77
+ title: .name,
78
+ description: .body,
79
+ status: match .state {
80
+ "open" => "active",
81
+ "closed" => "completed",
82
+ _ => "unknown"
83
+ },
84
+ author: .user.login,
85
+ created_at: .created_at,
86
+ synced_at: now()
87
+ }
88
+
89
+ validate response {
90
+ assume length(.title) > 0
91
+ assume .id != null
92
+ }
93
+
94
+ store response -> normalized_items {
95
+ key: .id,
96
+ upsert: true
97
+ }
98
+ }
99
+ }
100
+ ```
101
+
102
+ ## Parallel Execution
103
+
104
+ ```
105
+ mission ParallelSync {
106
+ source GitHubAPI { auth: bearer, base: "https://api.github.com" }
107
+
108
+ store issues: memory("issues")
109
+ store prs: memory("prs")
110
+ store work_items: memory("work_items")
111
+
112
+ action FetchIssues {
113
+ get "/repos/{owner}/{repo}/issues"
114
+ store response -> issues { key: .id }
115
+ }
116
+
117
+ action FetchPRs {
118
+ get "/repos/{owner}/{repo}/pulls"
119
+ store response -> prs { key: .id }
120
+ }
121
+
122
+ action Normalize {
123
+ // Process both issues and PRs after parallel fetch
124
+ for issue in issues { ... }
125
+ for pr in prs { ... }
126
+ }
127
+
128
+ // FetchIssues and FetchPRs run in parallel, then Normalize
129
+ run [FetchIssues, FetchPRs] then Normalize
130
+ }
131
+ ```
132
+
133
+ ## Incremental Sync
134
+
135
+ ```
136
+ action IncrementalFetch {
137
+ get "/items" {
138
+ body: { "updated_after": lastSync },
139
+ since: lastSync
140
+ }
141
+ store response -> items { key: .id, upsert: true }
142
+ }
143
+ ```
144
+
145
+ ## Dead Letter Queue Pattern
146
+
147
+ ```
148
+ action ProcessWithDLQ {
149
+ for item in pending {
150
+ post "/process/{item.id}"
151
+
152
+ match response {
153
+ SuccessSchema -> {
154
+ store response -> completed { key: .id }
155
+ },
156
+
157
+ TransientError -> retry {
158
+ maxAttempts: 3,
159
+ backoff: exponential,
160
+ initialDelay: 1000
161
+ },
162
+
163
+ // After retries exhausted or permanent error, queue for later
164
+ _ -> queue dead_letter_queue
165
+ }
166
+ }
167
+ }
168
+ ```
169
+
170
+ ## Conditional Processing
171
+
172
+ ```
173
+ action ProcessConditionally {
174
+ for payment in pending_payments
175
+ where not exists(fraud_queue[payment.id]) {
176
+
177
+ post "/payments/{payment.id}/capture"
178
+
179
+ match response {
180
+ PaymentSuccess -> {
181
+ store response -> completed { key: .id }
182
+ },
183
+ _ -> skip
184
+ }
185
+ }
186
+ }
187
+ ```
188
+
189
+ ## OpenAPI Integration
190
+
191
+ ```
192
+ mission OpenAPIExample {
193
+ source API from "./openapi.yaml" {
194
+ auth: bearer,
195
+ base: "https://api.example.com"
196
+ }
197
+
198
+ action FetchUsers {
199
+ // Use operation ID from OpenAPI spec
200
+ call API.listUsers { query: { limit: 100 } }
201
+ store response -> users { key: .id }
202
+ }
203
+
204
+ run FetchUsers
205
+ }
206
+ ```