@ontrails/warden 1.0.0-beta.14 → 1.0.0-beta.16
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.
- package/CHANGELOG.md +149 -0
- package/README.md +77 -34
- package/bin/warden.ts +22 -0
- package/package.json +26 -6
- package/src/ast.ts +28 -0
- package/src/cli.ts +1169 -116
- package/src/command.ts +927 -0
- package/src/config.ts +184 -0
- package/src/drift.ts +76 -34
- package/src/formatters.ts +54 -7
- package/src/guide.ts +234 -0
- package/src/index.ts +151 -38
- package/src/project-context.ts +163 -0
- package/src/resolve.ts +530 -0
- package/src/rules/activation-orphan.ts +97 -0
- package/src/rules/ast.ts +2884 -124
- package/src/rules/circular-refs.ts +154 -0
- package/src/rules/{context-no-trailhead-types.ts → context-no-surface-types.ts} +72 -12
- package/src/rules/contour-exists.ts +251 -0
- package/src/rules/contour-ids.ts +15 -0
- package/src/rules/cross-declarations.ts +277 -69
- package/src/rules/dead-internal-trail.ts +141 -0
- package/src/rules/draft-file-marking.ts +51 -3
- package/src/rules/draft-visible-debt.ts +40 -15
- package/src/rules/error-mapping-completeness.ts +288 -0
- package/src/rules/example-valid.ts +401 -0
- package/src/rules/fires-declarations.ts +758 -0
- package/src/rules/implementation-returns-result.ts +1042 -122
- package/src/rules/incomplete-accessor-for-standard-op.ts +272 -0
- package/src/rules/incomplete-crud.ts +580 -0
- package/src/rules/index.ts +156 -19
- package/src/rules/intent-propagation.ts +127 -0
- package/src/rules/layer-field-name-drift.ts +96 -0
- package/src/rules/metadata.ts +508 -0
- package/src/rules/missing-reconcile.ts +98 -0
- package/src/rules/missing-visibility.ts +110 -0
- package/src/rules/no-dev-permit-in-source.ts +99 -0
- package/src/rules/no-direct-implementation-call.ts +1 -1
- package/src/rules/no-legacy-layer-imports.ts +193 -0
- package/src/rules/no-native-error-result.ts +111 -0
- package/src/rules/no-sync-result-assumption.ts +1131 -96
- package/src/rules/no-throw-in-detour-recover.ts +225 -0
- package/src/rules/no-throw-in-implementation.ts +6 -4
- package/src/rules/on-references-exist.ts +194 -0
- package/src/rules/orphaned-signal.ts +150 -0
- package/src/rules/owner-projection-parity.ts +146 -0
- package/src/rules/permit-governance.ts +25 -0
- package/src/rules/public-internal-deep-imports.ts +517 -0
- package/src/rules/public-output-schema.ts +29 -0
- package/src/rules/public-union-output-discriminants.ts +150 -0
- package/src/rules/read-intent-fires.ts +187 -0
- package/src/rules/reference-exists.ts +98 -0
- package/src/rules/registry-names.ts +113 -0
- package/src/rules/resolved-import-boundary.ts +146 -0
- package/src/rules/{provision-declarations.ts → resource-declarations.ts} +208 -138
- package/src/rules/{provision-exists.ts → resource-exists.ts} +46 -51
- package/src/rules/resource-id-grammar.ts +65 -0
- package/src/rules/scan.ts +0 -26
- package/src/rules/scheduled-destroy-intent.ts +44 -0
- package/src/rules/signal-graph-coaching.ts +191 -0
- package/src/rules/specs.ts +5 -1
- package/src/rules/static-resource-accessor-preference.ts +657 -0
- package/src/rules/types.ts +187 -7
- package/src/rules/unmaterialized-activation-source.ts +84 -0
- package/src/rules/unreachable-detour-shadowing.ts +344 -0
- package/src/rules/valid-describe-refs.ts +160 -32
- package/src/rules/valid-detour-contract.ts +78 -0
- package/src/rules/warden-export-symmetry.ts +533 -0
- package/src/rules/warden-rules-use-ast.ts +996 -0
- package/src/rules/webhook-route-collision.ts +243 -0
- package/src/trails/activation-orphan.trail.ts +81 -0
- package/src/trails/circular-refs.trail.ts +29 -0
- package/src/trails/{context-no-trailhead-types.trail.ts → context-no-surface-types.trail.ts} +4 -4
- package/src/trails/contour-exists.trail.ts +21 -0
- package/src/trails/dead-internal-trail.trail.ts +26 -0
- package/src/trails/draft-file-marking.trail.ts +16 -0
- package/src/trails/draft-visible-debt.trail.ts +16 -0
- package/src/trails/error-mapping-completeness.trail.ts +29 -0
- package/src/trails/example-valid.trail.ts +25 -0
- package/src/trails/fires-declarations.trail.ts +23 -0
- package/src/trails/incomplete-accessor-for-standard-op.trail.ts +76 -0
- package/src/trails/incomplete-crud.trail.ts +39 -0
- package/src/trails/index.ts +56 -8
- package/src/trails/intent-propagation.trail.ts +30 -0
- package/src/trails/layer-field-name-drift.trail.ts +39 -0
- package/src/trails/missing-reconcile.trail.ts +33 -0
- package/src/trails/missing-visibility.trail.ts +22 -0
- package/src/trails/no-dev-permit-in-source.trail.ts +16 -0
- package/src/trails/no-legacy-layer-imports.trail.ts +35 -0
- package/src/trails/no-native-error-result.trail.ts +18 -0
- package/src/trails/no-throw-in-detour-recover.trail.ts +24 -0
- package/src/trails/on-references-exist.trail.ts +21 -0
- package/src/trails/orphaned-signal.trail.ts +36 -0
- package/src/trails/owner-projection-parity.trail.ts +26 -0
- package/src/trails/permit-governance.trail.ts +51 -0
- package/src/trails/public-internal-deep-imports.trail.ts +94 -0
- package/src/trails/public-output-schema.trail.ts +55 -0
- package/src/trails/public-union-output-discriminants.trail.ts +33 -0
- package/src/trails/read-intent-fires.trail.ts +20 -0
- package/src/trails/reference-exists.trail.ts +25 -0
- package/src/trails/resolved-import-boundary.trail.ts +109 -0
- package/src/trails/{provision-declarations.trail.ts → resource-declarations.trail.ts} +6 -6
- package/src/trails/{provision-exists.trail.ts → resource-exists.trail.ts} +7 -7
- package/src/trails/resource-id-grammar.trail.ts +39 -0
- package/src/trails/run.ts +133 -24
- package/src/trails/scheduled-destroy-intent.trail.ts +56 -0
- package/src/trails/schema.ts +122 -4
- package/src/trails/signal-graph-coaching.trail.ts +74 -0
- package/src/trails/static-resource-accessor-preference.trail.ts +25 -0
- package/src/trails/unmaterialized-activation-source.trail.ts +69 -0
- package/src/trails/unreachable-detour-shadowing.trail.ts +45 -0
- package/src/trails/valid-detour-contract.trail.ts +71 -0
- package/src/trails/warden-export-symmetry.trail.ts +16 -0
- package/src/trails/warden-rules-use-ast.trail.ts +45 -0
- package/src/trails/webhook-route-collision.trail.ts +50 -0
- package/src/trails/wrap-rule.ts +133 -14
- package/src/workspaces.ts +238 -0
- package/.turbo/turbo-build.log +0 -1
- package/.turbo/turbo-lint.log +0 -3
- package/.turbo/turbo-typecheck.log +0 -1
- package/dist/cli.d.ts +0 -46
- package/dist/cli.d.ts.map +0 -1
- package/dist/cli.js +0 -247
- package/dist/cli.js.map +0 -1
- package/dist/draft.d.ts +0 -5
- package/dist/draft.d.ts.map +0 -1
- package/dist/draft.js +0 -16
- package/dist/draft.js.map +0 -1
- package/dist/drift.d.ts +0 -29
- package/dist/drift.d.ts.map +0 -1
- package/dist/drift.js +0 -61
- package/dist/drift.js.map +0 -1
- package/dist/formatters.d.ts +0 -30
- package/dist/formatters.d.ts.map +0 -1
- package/dist/formatters.js +0 -98
- package/dist/formatters.js.map +0 -1
- package/dist/index.d.ts +0 -37
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -38
- package/dist/index.js.map +0 -1
- package/dist/rules/ast.d.ts +0 -82
- package/dist/rules/ast.d.ts.map +0 -1
- package/dist/rules/ast.js +0 -363
- package/dist/rules/ast.js.map +0 -1
- package/dist/rules/context-no-surface-types.d.ts +0 -12
- package/dist/rules/context-no-surface-types.d.ts.map +0 -1
- package/dist/rules/context-no-surface-types.js +0 -96
- package/dist/rules/context-no-surface-types.js.map +0 -1
- package/dist/rules/context-no-trailhead-types.d.ts +0 -12
- package/dist/rules/context-no-trailhead-types.d.ts.map +0 -1
- package/dist/rules/context-no-trailhead-types.js +0 -96
- package/dist/rules/context-no-trailhead-types.js.map +0 -1
- package/dist/rules/cross-declarations.d.ts +0 -13
- package/dist/rules/cross-declarations.d.ts.map +0 -1
- package/dist/rules/cross-declarations.js +0 -264
- package/dist/rules/cross-declarations.js.map +0 -1
- package/dist/rules/draft-file-marking.d.ts +0 -6
- package/dist/rules/draft-file-marking.d.ts.map +0 -1
- package/dist/rules/draft-file-marking.js +0 -65
- package/dist/rules/draft-file-marking.js.map +0 -1
- package/dist/rules/draft-visible-debt.d.ts +0 -12
- package/dist/rules/draft-visible-debt.d.ts.map +0 -1
- package/dist/rules/draft-visible-debt.js +0 -45
- package/dist/rules/draft-visible-debt.js.map +0 -1
- package/dist/rules/follow-declarations.d.ts +0 -13
- package/dist/rules/follow-declarations.d.ts.map +0 -1
- package/dist/rules/follow-declarations.js +0 -264
- package/dist/rules/follow-declarations.js.map +0 -1
- package/dist/rules/implementation-returns-result.d.ts +0 -13
- package/dist/rules/implementation-returns-result.d.ts.map +0 -1
- package/dist/rules/implementation-returns-result.js +0 -277
- package/dist/rules/implementation-returns-result.js.map +0 -1
- package/dist/rules/index.d.ts +0 -20
- package/dist/rules/index.d.ts.map +0 -1
- package/dist/rules/index.js +0 -49
- package/dist/rules/index.js.map +0 -1
- package/dist/rules/no-direct-impl-in-route.d.ts +0 -12
- package/dist/rules/no-direct-impl-in-route.d.ts.map +0 -1
- package/dist/rules/no-direct-impl-in-route.js +0 -47
- package/dist/rules/no-direct-impl-in-route.js.map +0 -1
- package/dist/rules/no-direct-implementation-call.d.ts +0 -12
- package/dist/rules/no-direct-implementation-call.d.ts.map +0 -1
- package/dist/rules/no-direct-implementation-call.js +0 -39
- package/dist/rules/no-direct-implementation-call.js.map +0 -1
- package/dist/rules/no-sync-result-assumption.d.ts +0 -6
- package/dist/rules/no-sync-result-assumption.d.ts.map +0 -1
- package/dist/rules/no-sync-result-assumption.js +0 -98
- package/dist/rules/no-sync-result-assumption.js.map +0 -1
- package/dist/rules/no-throw-in-detour-target.d.ts +0 -12
- package/dist/rules/no-throw-in-detour-target.d.ts.map +0 -1
- package/dist/rules/no-throw-in-detour-target.js +0 -87
- package/dist/rules/no-throw-in-detour-target.js.map +0 -1
- package/dist/rules/no-throw-in-implementation.d.ts +0 -9
- package/dist/rules/no-throw-in-implementation.d.ts.map +0 -1
- package/dist/rules/no-throw-in-implementation.js +0 -34
- package/dist/rules/no-throw-in-implementation.js.map +0 -1
- package/dist/rules/prefer-schema-inference.d.ts +0 -7
- package/dist/rules/prefer-schema-inference.d.ts.map +0 -1
- package/dist/rules/prefer-schema-inference.js +0 -86
- package/dist/rules/prefer-schema-inference.js.map +0 -1
- package/dist/rules/provision-declarations.d.ts +0 -14
- package/dist/rules/provision-declarations.d.ts.map +0 -1
- package/dist/rules/provision-declarations.js +0 -344
- package/dist/rules/provision-declarations.js.map +0 -1
- package/dist/rules/provision-exists.d.ts +0 -6
- package/dist/rules/provision-exists.d.ts.map +0 -1
- package/dist/rules/provision-exists.js +0 -90
- package/dist/rules/provision-exists.js.map +0 -1
- package/dist/rules/scan.d.ts +0 -8
- package/dist/rules/scan.d.ts.map +0 -1
- package/dist/rules/scan.js +0 -32
- package/dist/rules/scan.js.map +0 -1
- package/dist/rules/service-declarations.d.ts +0 -16
- package/dist/rules/service-declarations.d.ts.map +0 -1
- package/dist/rules/service-declarations.js +0 -346
- package/dist/rules/service-declarations.js.map +0 -1
- package/dist/rules/service-exists.d.ts +0 -8
- package/dist/rules/service-exists.d.ts.map +0 -1
- package/dist/rules/service-exists.js +0 -91
- package/dist/rules/service-exists.js.map +0 -1
- package/dist/rules/specs.d.ts +0 -29
- package/dist/rules/specs.d.ts.map +0 -1
- package/dist/rules/specs.js +0 -192
- package/dist/rules/specs.js.map +0 -1
- package/dist/rules/structure.d.ts +0 -13
- package/dist/rules/structure.d.ts.map +0 -1
- package/dist/rules/structure.js +0 -142
- package/dist/rules/structure.js.map +0 -1
- package/dist/rules/types.d.ts +0 -54
- package/dist/rules/types.d.ts.map +0 -1
- package/dist/rules/types.js +0 -2
- package/dist/rules/types.js.map +0 -1
- package/dist/rules/valid-describe-refs.d.ts +0 -7
- package/dist/rules/valid-describe-refs.d.ts.map +0 -1
- package/dist/rules/valid-describe-refs.js +0 -51
- package/dist/rules/valid-describe-refs.js.map +0 -1
- package/dist/rules/valid-detour-refs.d.ts +0 -6
- package/dist/rules/valid-detour-refs.d.ts.map +0 -1
- package/dist/rules/valid-detour-refs.js +0 -117
- package/dist/rules/valid-detour-refs.js.map +0 -1
- package/dist/trails/context-no-surface-types.trail.d.ts +0 -13
- package/dist/trails/context-no-surface-types.trail.d.ts.map +0 -1
- package/dist/trails/context-no-surface-types.trail.js +0 -21
- package/dist/trails/context-no-surface-types.trail.js.map +0 -1
- package/dist/trails/context-no-trailhead-types.trail.d.ts +0 -13
- package/dist/trails/context-no-trailhead-types.trail.d.ts.map +0 -1
- package/dist/trails/context-no-trailhead-types.trail.js +0 -21
- package/dist/trails/context-no-trailhead-types.trail.js.map +0 -1
- package/dist/trails/cross-declarations.trail.d.ts +0 -13
- package/dist/trails/cross-declarations.trail.d.ts.map +0 -1
- package/dist/trails/cross-declarations.trail.js +0 -22
- package/dist/trails/cross-declarations.trail.js.map +0 -1
- package/dist/trails/follow-declarations.trail.d.ts +0 -13
- package/dist/trails/follow-declarations.trail.d.ts.map +0 -1
- package/dist/trails/follow-declarations.trail.js +0 -22
- package/dist/trails/follow-declarations.trail.js.map +0 -1
- package/dist/trails/implementation-returns-result.trail.d.ts +0 -13
- package/dist/trails/implementation-returns-result.trail.d.ts.map +0 -1
- package/dist/trails/implementation-returns-result.trail.js +0 -20
- package/dist/trails/implementation-returns-result.trail.js.map +0 -1
- package/dist/trails/index.d.ts +0 -16
- package/dist/trails/index.d.ts.map +0 -1
- package/dist/trails/index.js +0 -15
- package/dist/trails/index.js.map +0 -1
- package/dist/trails/no-direct-impl-in-route.trail.d.ts +0 -13
- package/dist/trails/no-direct-impl-in-route.trail.d.ts.map +0 -1
- package/dist/trails/no-direct-impl-in-route.trail.js +0 -22
- package/dist/trails/no-direct-impl-in-route.trail.js.map +0 -1
- package/dist/trails/no-direct-implementation-call.trail.d.ts +0 -13
- package/dist/trails/no-direct-implementation-call.trail.d.ts.map +0 -1
- package/dist/trails/no-direct-implementation-call.trail.js +0 -16
- package/dist/trails/no-direct-implementation-call.trail.js.map +0 -1
- package/dist/trails/no-sync-result-assumption.trail.d.ts +0 -13
- package/dist/trails/no-sync-result-assumption.trail.d.ts.map +0 -1
- package/dist/trails/no-sync-result-assumption.trail.js +0 -19
- package/dist/trails/no-sync-result-assumption.trail.js.map +0 -1
- package/dist/trails/no-throw-in-detour-target.trail.d.ts +0 -15
- package/dist/trails/no-throw-in-detour-target.trail.d.ts.map +0 -1
- package/dist/trails/no-throw-in-detour-target.trail.js +0 -20
- package/dist/trails/no-throw-in-detour-target.trail.js.map +0 -1
- package/dist/trails/no-throw-in-implementation.trail.d.ts +0 -13
- package/dist/trails/no-throw-in-implementation.trail.d.ts.map +0 -1
- package/dist/trails/no-throw-in-implementation.trail.js +0 -20
- package/dist/trails/no-throw-in-implementation.trail.js.map +0 -1
- package/dist/trails/prefer-schema-inference.trail.d.ts +0 -13
- package/dist/trails/prefer-schema-inference.trail.d.ts.map +0 -1
- package/dist/trails/prefer-schema-inference.trail.js +0 -21
- package/dist/trails/prefer-schema-inference.trail.js.map +0 -1
- package/dist/trails/provision-declarations.trail.d.ts +0 -13
- package/dist/trails/provision-declarations.trail.d.ts.map +0 -1
- package/dist/trails/provision-declarations.trail.js +0 -25
- package/dist/trails/provision-declarations.trail.js.map +0 -1
- package/dist/trails/provision-exists.trail.d.ts +0 -15
- package/dist/trails/provision-exists.trail.d.ts.map +0 -1
- package/dist/trails/provision-exists.trail.js +0 -27
- package/dist/trails/provision-exists.trail.js.map +0 -1
- package/dist/trails/run.d.ts +0 -17
- package/dist/trails/run.d.ts.map +0 -1
- package/dist/trails/run.js +0 -39
- package/dist/trails/run.js.map +0 -1
- package/dist/trails/schema.d.ts +0 -53
- package/dist/trails/schema.d.ts.map +0 -1
- package/dist/trails/schema.js +0 -42
- package/dist/trails/schema.js.map +0 -1
- package/dist/trails/service-declarations.trail.d.ts +0 -26
- package/dist/trails/service-declarations.trail.d.ts.map +0 -1
- package/dist/trails/service-declarations.trail.js +0 -27
- package/dist/trails/service-declarations.trail.js.map +0 -1
- package/dist/trails/service-exists.trail.d.ts +0 -32
- package/dist/trails/service-exists.trail.d.ts.map +0 -1
- package/dist/trails/service-exists.trail.js +0 -29
- package/dist/trails/service-exists.trail.js.map +0 -1
- package/dist/trails/topo.d.ts +0 -3
- package/dist/trails/topo.d.ts.map +0 -1
- package/dist/trails/topo.js +0 -5
- package/dist/trails/topo.js.map +0 -1
- package/dist/trails/valid-describe-refs.trail.d.ts +0 -15
- package/dist/trails/valid-describe-refs.trail.d.ts.map +0 -1
- package/dist/trails/valid-describe-refs.trail.js +0 -18
- package/dist/trails/valid-describe-refs.trail.js.map +0 -1
- package/dist/trails/valid-detour-refs.trail.d.ts +0 -15
- package/dist/trails/valid-detour-refs.trail.d.ts.map +0 -1
- package/dist/trails/valid-detour-refs.trail.js +0 -24
- package/dist/trails/valid-detour-refs.trail.js.map +0 -1
- package/dist/trails/wrap-rule.d.ts +0 -29
- package/dist/trails/wrap-rule.d.ts.map +0 -1
- package/dist/trails/wrap-rule.js +0 -47
- package/dist/trails/wrap-rule.js.map +0 -1
- package/src/__tests__/cli.test.ts +0 -311
- package/src/__tests__/cross-declarations.test.ts +0 -303
- package/src/__tests__/drift.test.ts +0 -144
- package/src/__tests__/formatters.test.ts +0 -157
- package/src/__tests__/implementation-returns-result.test.ts +0 -129
- package/src/__tests__/no-direct-implementation-call.test.ts +0 -83
- package/src/__tests__/no-sync-result-assumption.test.ts +0 -85
- package/src/__tests__/no-throw-in-detour-target.test.ts +0 -78
- package/src/__tests__/prefer-schema-inference.test.ts +0 -84
- package/src/__tests__/provision-declarations.test.ts +0 -318
- package/src/__tests__/provision-exists.test.ts +0 -122
- package/src/__tests__/rules.test.ts +0 -227
- package/src/__tests__/trails.test.ts +0 -19
- package/src/__tests__/valid-describe-refs.test.ts +0 -60
- package/src/__tests__/wrap-rule.test.ts +0 -41
- package/src/rules/no-direct-impl-in-route.ts +0 -81
- package/src/rules/no-throw-in-detour-target.ts +0 -150
- package/src/rules/valid-detour-refs.ts +0 -189
- package/src/trails/no-direct-impl-in-route.trail.ts +0 -22
- package/src/trails/no-throw-in-detour-target.trail.ts +0 -20
- package/src/trails/valid-detour-refs.trail.ts +0 -24
- package/tsconfig.json +0 -9
- package/tsconfig.tsbuildinfo +0 -1
package/dist/rules/index.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/rules/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Detects trail implementations with `crosses` that call `.blaze()` directly.
|
|
3
|
-
*
|
|
4
|
-
* Uses AST parsing to find trail definitions that declare `crosses` and check for
|
|
5
|
-
* `.blaze()` call expressions in their bodies.
|
|
6
|
-
*/
|
|
7
|
-
import type { WardenRule } from './types.js';
|
|
8
|
-
/**
|
|
9
|
-
* Detects trails with `crosses` that call another trail's `.blaze()` directly.
|
|
10
|
-
*/
|
|
11
|
-
export declare const noDirectImplInRoute: WardenRule;
|
|
12
|
-
//# sourceMappingURL=no-direct-impl-in-route.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"no-direct-impl-in-route.d.ts","sourceRoot":"","sources":["../../src/rules/no-direct-impl-in-route.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAWH,OAAO,KAAK,EAAoB,UAAU,EAAE,MAAM,YAAY,CAAC;AAkC/D;;GAEG;AACH,eAAO,MAAM,mBAAmB,EAAE,UA2BjC,CAAC"}
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Detects trail implementations with `crosses` that call `.blaze()` directly.
|
|
3
|
-
*
|
|
4
|
-
* Uses AST parsing to find trail definitions that declare `crosses` and check for
|
|
5
|
-
* `.blaze()` call expressions in their bodies.
|
|
6
|
-
*/
|
|
7
|
-
import { findConfigProperty, findBlazeBodies, findTrailDefinitions, isBlazeCall, offsetToLine, parse, walk, } from './ast.js';
|
|
8
|
-
const findImplCallsInTrailWithCrosses = (def, filePath, sourceCode, diagnostics) => {
|
|
9
|
-
for (const body of findBlazeBodies(def.config)) {
|
|
10
|
-
walk(body, (node) => {
|
|
11
|
-
if (isBlazeCall(node)) {
|
|
12
|
-
diagnostics.push({
|
|
13
|
-
filePath,
|
|
14
|
-
line: offsetToLine(sourceCode, node.start),
|
|
15
|
-
message: 'Use ctx.cross("trailId", input) instead of direct .blaze() calls. ctx.cross() validates input and propagates tracing.',
|
|
16
|
-
rule: 'no-direct-impl-in-route',
|
|
17
|
-
severity: 'warn',
|
|
18
|
-
});
|
|
19
|
-
}
|
|
20
|
-
});
|
|
21
|
-
}
|
|
22
|
-
};
|
|
23
|
-
const hasCrossesProperty = (config) => findConfigProperty(config, 'crosses') !== null;
|
|
24
|
-
/**
|
|
25
|
-
* Detects trails with `crosses` that call another trail's `.blaze()` directly.
|
|
26
|
-
*/
|
|
27
|
-
export const noDirectImplInRoute = {
|
|
28
|
-
check(sourceCode, filePath) {
|
|
29
|
-
if (!/\btrail\s*\(/.test(sourceCode)) {
|
|
30
|
-
return [];
|
|
31
|
-
}
|
|
32
|
-
const ast = parse(filePath, sourceCode);
|
|
33
|
-
if (!ast) {
|
|
34
|
-
return [];
|
|
35
|
-
}
|
|
36
|
-
const diagnostics = [];
|
|
37
|
-
const crossDefs = findTrailDefinitions(ast).filter((d) => hasCrossesProperty(d.config));
|
|
38
|
-
for (const def of crossDefs) {
|
|
39
|
-
findImplCallsInTrailWithCrosses(def, filePath, sourceCode, diagnostics);
|
|
40
|
-
}
|
|
41
|
-
return diagnostics;
|
|
42
|
-
},
|
|
43
|
-
description: 'Prefer ctx.cross() over direct .blaze() calls in trail bodies with crossings.',
|
|
44
|
-
name: 'no-direct-impl-in-route',
|
|
45
|
-
severity: 'warn',
|
|
46
|
-
};
|
|
47
|
-
//# sourceMappingURL=no-direct-impl-in-route.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"no-direct-impl-in-route.js","sourceRoot":"","sources":["../../src/rules/no-direct-impl-in-route.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EACL,kBAAkB,EAClB,eAAe,EACf,oBAAoB,EACpB,WAAW,EACX,YAAY,EACZ,KAAK,EACL,IAAI,GACL,MAAM,UAAU,CAAC;AAUlB,MAAM,+BAA+B,GAAG,CACtC,GAAiC,EACjC,QAAgB,EAChB,UAAkB,EAClB,WAA+B,EACzB,EAAE;IACR,KAAK,MAAM,IAAI,IAAI,eAAe,CAAC,GAAG,CAAC,MAAiB,CAAC,EAAE,CAAC;QAC1D,IAAI,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,EAAE;YAClB,IAAI,WAAW,CAAC,IAAe,CAAC,EAAE,CAAC;gBACjC,WAAW,CAAC,IAAI,CAAC;oBACf,QAAQ;oBACR,IAAI,EAAE,YAAY,CAAC,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC;oBAC1C,OAAO,EACL,uHAAuH;oBACzH,IAAI,EAAE,yBAAyB;oBAC/B,QAAQ,EAAE,MAAM;iBACjB,CAAC,CAAC;YACL,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;AACH,CAAC,CAAC;AAEF,MAAM,kBAAkB,GAAG,CAAC,MAAe,EAAW,EAAE,CACtD,kBAAkB,CAAC,MAAiB,EAAE,SAAS,CAAC,KAAK,IAAI,CAAC;AAE5D;;GAEG;AACH,MAAM,CAAC,MAAM,mBAAmB,GAAe;IAC7C,KAAK,CAAC,UAAkB,EAAE,QAAgB;QACxC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACrC,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,MAAM,GAAG,GAAG,KAAK,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;QACxC,IAAI,CAAC,GAAG,EAAE,CAAC;YACT,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,MAAM,WAAW,GAAuB,EAAE,CAAC;QAC3C,MAAM,SAAS,GAAG,oBAAoB,CAAC,GAAc,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAClE,kBAAkB,CAAC,CAAC,CAAC,MAAiB,CAAC,CACxC,CAAC;QAEF,KAAK,MAAM,GAAG,IAAI,SAAS,EAAE,CAAC;YAC5B,+BAA+B,CAAC,GAAG,EAAE,QAAQ,EAAE,UAAU,EAAE,WAAW,CAAC,CAAC;QAC1E,CAAC;QAED,OAAO,WAAW,CAAC;IACrB,CAAC;IACD,WAAW,EACT,+EAA+E;IACjF,IAAI,EAAE,yBAAyB;IAE/B,QAAQ,EAAE,MAAM;CACjB,CAAC"}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Flags direct `.blaze()` calls in application code.
|
|
3
|
-
*
|
|
4
|
-
* Uses AST parsing to find `.blaze()` call expressions,
|
|
5
|
-
* ignoring occurrences in strings and comments.
|
|
6
|
-
*/
|
|
7
|
-
import type { WardenRule } from './types.js';
|
|
8
|
-
/**
|
|
9
|
-
* Flags direct `.blaze()` calls in application code.
|
|
10
|
-
*/
|
|
11
|
-
export declare const noDirectImplementationCall: WardenRule;
|
|
12
|
-
//# sourceMappingURL=no-direct-implementation-call.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"no-direct-implementation-call.d.ts","sourceRoot":"","sources":["../../src/rules/no-direct-implementation-call.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH,OAAO,KAAK,EAAoB,UAAU,EAAE,MAAM,YAAY,CAAC;AAE/D;;GAEG;AACH,eAAO,MAAM,0BAA0B,EAAE,UAgCxC,CAAC"}
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Flags direct `.blaze()` calls in application code.
|
|
3
|
-
*
|
|
4
|
-
* Uses AST parsing to find `.blaze()` call expressions,
|
|
5
|
-
* ignoring occurrences in strings and comments.
|
|
6
|
-
*/
|
|
7
|
-
import { isBlazeCall, offsetToLine, parse, walk } from './ast.js';
|
|
8
|
-
import { isFrameworkInternalFile, isTestFile } from './scan.js';
|
|
9
|
-
/**
|
|
10
|
-
* Flags direct `.blaze()` calls in application code.
|
|
11
|
-
*/
|
|
12
|
-
export const noDirectImplementationCall = {
|
|
13
|
-
check(sourceCode, filePath) {
|
|
14
|
-
if (isTestFile(filePath) || isFrameworkInternalFile(filePath)) {
|
|
15
|
-
return [];
|
|
16
|
-
}
|
|
17
|
-
const ast = parse(filePath, sourceCode);
|
|
18
|
-
if (!ast) {
|
|
19
|
-
return [];
|
|
20
|
-
}
|
|
21
|
-
const diagnostics = [];
|
|
22
|
-
walk(ast, (node) => {
|
|
23
|
-
if (isBlazeCall(node)) {
|
|
24
|
-
diagnostics.push({
|
|
25
|
-
filePath,
|
|
26
|
-
line: offsetToLine(sourceCode, node.start),
|
|
27
|
-
message: 'Use ctx.cross("trailId", input) instead of direct .blaze() calls. Direct implementation access bypasses validation, tracing, and gates.',
|
|
28
|
-
rule: 'no-direct-implementation-call',
|
|
29
|
-
severity: 'warn',
|
|
30
|
-
});
|
|
31
|
-
}
|
|
32
|
-
});
|
|
33
|
-
return diagnostics;
|
|
34
|
-
},
|
|
35
|
-
description: 'Disallow direct .blaze() calls in application code. Use ctx.cross() instead.',
|
|
36
|
-
name: 'no-direct-implementation-call',
|
|
37
|
-
severity: 'warn',
|
|
38
|
-
};
|
|
39
|
-
//# sourceMappingURL=no-direct-implementation-call.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"no-direct-implementation-call.js","sourceRoot":"","sources":["../../src/rules/no-direct-implementation-call.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,UAAU,CAAC;AAClE,OAAO,EAAE,uBAAuB,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAGhE;;GAEG;AACH,MAAM,CAAC,MAAM,0BAA0B,GAAe;IACpD,KAAK,CAAC,UAAkB,EAAE,QAAgB;QACxC,IAAI,UAAU,CAAC,QAAQ,CAAC,IAAI,uBAAuB,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC9D,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,MAAM,GAAG,GAAG,KAAK,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;QACxC,IAAI,CAAC,GAAG,EAAE,CAAC;YACT,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,MAAM,WAAW,GAAuB,EAAE,CAAC;QAE3C,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,EAAE,EAAE;YACjB,IAAI,WAAW,CAAC,IAAI,CAAC,EAAE,CAAC;gBACtB,WAAW,CAAC,IAAI,CAAC;oBACf,QAAQ;oBACR,IAAI,EAAE,YAAY,CAAC,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC;oBAC1C,OAAO,EACL,yIAAyI;oBAC3I,IAAI,EAAE,+BAA+B;oBACrC,QAAQ,EAAE,MAAM;iBACjB,CAAC,CAAC;YACL,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,OAAO,WAAW,CAAC;IACrB,CAAC;IACD,WAAW,EACT,8EAA8E;IAChF,IAAI,EAAE,+BAA+B;IACrC,QAAQ,EAAE,MAAM;CACjB,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"no-sync-result-assumption.d.ts","sourceRoot":"","sources":["../../src/rules/no-sync-result-assumption.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAoB,UAAU,EAAE,MAAM,YAAY,CAAC;AA6I/D;;GAEG;AACH,eAAO,MAAM,sBAAsB,EAAE,UAWpC,CAAC"}
|
|
@@ -1,98 +0,0 @@
|
|
|
1
|
-
import { isFrameworkInternalFile, isTestFile, stripQuotedContent, } from './scan.js';
|
|
2
|
-
const RESULT_ACCESS_PATTERN = /\.(?:isOk|isErr|match|map)\s*\(|\.(?:value|error)\b/;
|
|
3
|
-
const IMPLEMENTATION_CALL_PATTERN = /\.blaze\s*\(/;
|
|
4
|
-
const isAwaitedImplementationCall = (line) => {
|
|
5
|
-
const callIndex = line.indexOf('.blaze(');
|
|
6
|
-
if (callIndex === -1) {
|
|
7
|
-
return false;
|
|
8
|
-
}
|
|
9
|
-
const awaitIndex = line.indexOf('await');
|
|
10
|
-
return awaitIndex !== -1 && awaitIndex < callIndex;
|
|
11
|
-
};
|
|
12
|
-
const isDirectResultAccess = (line) => IMPLEMENTATION_CALL_PATTERN.test(line) &&
|
|
13
|
-
RESULT_ACCESS_PATTERN.test(line) &&
|
|
14
|
-
!isAwaitedImplementationCall(line);
|
|
15
|
-
const isPendingUse = (line, variableName) => {
|
|
16
|
-
const escaped = variableName.replaceAll(/[.*+?^${}()|[\]\\]/g, '\\$&');
|
|
17
|
-
const pendingPattern = new RegExp(`\\b${escaped}\\s*(?:\\.(?:isOk|isErr|match|map)\\s*\\(|\\.(?:value|error)\\b)`);
|
|
18
|
-
return pendingPattern.test(line);
|
|
19
|
-
};
|
|
20
|
-
const MISSING_AWAIT_MESSAGE = 'Missing await: .blaze() returns Promise<Result> after normalization. Use `const result = await trail.blaze(input, ctx)`.';
|
|
21
|
-
const createMissingAwaitDiagnostic = (filePath, line) => ({
|
|
22
|
-
filePath,
|
|
23
|
-
line,
|
|
24
|
-
message: MISSING_AWAIT_MESSAGE,
|
|
25
|
-
rule: 'no-sync-result-assumption',
|
|
26
|
-
severity: 'error',
|
|
27
|
-
});
|
|
28
|
-
const trackPendingCall = (line) => {
|
|
29
|
-
const match = line.match(/\b(?:const|let|var)\s+([A-Za-z_$][\w$]*)\s*=\s*([^;]*)/);
|
|
30
|
-
if (!match?.[1] || !match[2] || !IMPLEMENTATION_CALL_PATTERN.test(match[2])) {
|
|
31
|
-
return undefined;
|
|
32
|
-
}
|
|
33
|
-
if (isAwaitedImplementationCall(match[2])) {
|
|
34
|
-
return undefined;
|
|
35
|
-
}
|
|
36
|
-
return match[1];
|
|
37
|
-
};
|
|
38
|
-
const addPendingCall = (pendingCalls, variableName, lineNumber) => {
|
|
39
|
-
pendingCalls.push({
|
|
40
|
-
line: lineNumber,
|
|
41
|
-
remainingLines: 6,
|
|
42
|
-
variableName,
|
|
43
|
-
});
|
|
44
|
-
};
|
|
45
|
-
const advancePendingCalls = (line, filePath, lineNumber, pendingCalls, diagnostics) => {
|
|
46
|
-
for (let j = pendingCalls.length - 1; j >= 0; j -= 1) {
|
|
47
|
-
const pendingCall = pendingCalls[j];
|
|
48
|
-
if (pendingCall && isPendingUse(line, pendingCall.variableName)) {
|
|
49
|
-
diagnostics.push(createMissingAwaitDiagnostic(filePath, lineNumber));
|
|
50
|
-
pendingCalls.splice(j, 1);
|
|
51
|
-
}
|
|
52
|
-
else if (pendingCall) {
|
|
53
|
-
pendingCall.remainingLines -= 1;
|
|
54
|
-
if (pendingCall.remainingLines <= 0) {
|
|
55
|
-
pendingCalls.splice(j, 1);
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
};
|
|
60
|
-
const processLine = (line, filePath, lineNumber, pendingCalls, diagnostics) => {
|
|
61
|
-
if (isDirectResultAccess(line)) {
|
|
62
|
-
diagnostics.push(createMissingAwaitDiagnostic(filePath, lineNumber));
|
|
63
|
-
return;
|
|
64
|
-
}
|
|
65
|
-
const variableName = trackPendingCall(line);
|
|
66
|
-
if (variableName) {
|
|
67
|
-
addPendingCall(pendingCalls, variableName, lineNumber);
|
|
68
|
-
}
|
|
69
|
-
advancePendingCalls(line, filePath, lineNumber, pendingCalls, diagnostics);
|
|
70
|
-
};
|
|
71
|
-
const scanSourceCode = (sourceCode, filePath) => {
|
|
72
|
-
const diagnostics = [];
|
|
73
|
-
const lines = sourceCode.split('\n');
|
|
74
|
-
const pendingCalls = [];
|
|
75
|
-
for (let i = 0; i < lines.length; i += 1) {
|
|
76
|
-
const line = lines[i];
|
|
77
|
-
if (!line) {
|
|
78
|
-
continue;
|
|
79
|
-
}
|
|
80
|
-
processLine(line, filePath, i + 1, pendingCalls, diagnostics);
|
|
81
|
-
}
|
|
82
|
-
return diagnostics;
|
|
83
|
-
};
|
|
84
|
-
/**
|
|
85
|
-
* Flags code that assumes `.blaze()` returns a synchronous result.
|
|
86
|
-
*/
|
|
87
|
-
export const noSyncResultAssumption = {
|
|
88
|
-
check(sourceCode, filePath) {
|
|
89
|
-
if (isTestFile(filePath) || isFrameworkInternalFile(filePath)) {
|
|
90
|
-
return [];
|
|
91
|
-
}
|
|
92
|
-
return scanSourceCode(stripQuotedContent(sourceCode), filePath);
|
|
93
|
-
},
|
|
94
|
-
description: 'Disallow treating .blaze() as synchronous after normalization. Always await the returned Promise<Result>.',
|
|
95
|
-
name: 'no-sync-result-assumption',
|
|
96
|
-
severity: 'error',
|
|
97
|
-
};
|
|
98
|
-
//# sourceMappingURL=no-sync-result-assumption.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"no-sync-result-assumption.js","sourceRoot":"","sources":["../../src/rules/no-sync-result-assumption.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Flags throws in implementations that are used as detour targets.
|
|
3
|
-
*
|
|
4
|
-
* Uses AST parsing for accurate detection of detour target IDs and
|
|
5
|
-
* throw statements within those trail implementations.
|
|
6
|
-
*/
|
|
7
|
-
import type { ProjectAwareWardenRule } from './types.js';
|
|
8
|
-
/**
|
|
9
|
-
* Flags throws in implementations that are used as detour targets.
|
|
10
|
-
*/
|
|
11
|
-
export declare const noThrowInDetourTarget: ProjectAwareWardenRule;
|
|
12
|
-
//# sourceMappingURL=no-throw-in-detour-target.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"no-throw-in-detour-target.d.ts","sourceRoot":"","sources":["../../src/rules/no-throw-in-detour-target.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAUH,OAAO,KAAK,EACV,sBAAsB,EAGvB,MAAM,YAAY,CAAC;AAyFpB;;GAEG;AACH,eAAO,MAAM,qBAAqB,EAAE,sBAsCnC,CAAC"}
|
|
@@ -1,87 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Flags throws in implementations that are used as detour targets.
|
|
3
|
-
*
|
|
4
|
-
* Uses AST parsing for accurate detection of detour target IDs and
|
|
5
|
-
* throw statements within those trail implementations.
|
|
6
|
-
*/
|
|
7
|
-
import { findBlazeBodies, findTrailDefinitions, offsetToLine, parse, walk, } from './ast.js';
|
|
8
|
-
import { isTestFile } from './scan.js';
|
|
9
|
-
/** Collect all trail IDs referenced as detour targets in the AST. */
|
|
10
|
-
const collectDetourTargets = (ast) => {
|
|
11
|
-
const targets = new Set();
|
|
12
|
-
walk(ast, (node) => {
|
|
13
|
-
if (node.type !== 'Property' ||
|
|
14
|
-
node.key?.name !== 'detours' ||
|
|
15
|
-
!node.value) {
|
|
16
|
-
return;
|
|
17
|
-
}
|
|
18
|
-
walk(node.value, (inner) => {
|
|
19
|
-
if (inner.type === 'Literal' || inner.type === 'StringLiteral') {
|
|
20
|
-
const { value } = inner;
|
|
21
|
-
if (typeof value === 'string' && value.includes('.')) {
|
|
22
|
-
targets.add(value);
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
});
|
|
26
|
-
});
|
|
27
|
-
return targets;
|
|
28
|
-
};
|
|
29
|
-
/** Find throws in implementation bodies of targeted trails. */
|
|
30
|
-
const findThrowsInTargetedTrails = (ast, sourceCode, filePath, detourTargets) => {
|
|
31
|
-
const diagnostics = [];
|
|
32
|
-
for (const def of findTrailDefinitions(ast)) {
|
|
33
|
-
if (!detourTargets.has(def.id)) {
|
|
34
|
-
continue;
|
|
35
|
-
}
|
|
36
|
-
for (const body of findBlazeBodies(def.config)) {
|
|
37
|
-
walk(body, (node) => {
|
|
38
|
-
if (node.type === 'ThrowStatement') {
|
|
39
|
-
diagnostics.push({
|
|
40
|
-
filePath,
|
|
41
|
-
line: offsetToLine(sourceCode, node.start),
|
|
42
|
-
message: `Trail "${def.id}" is a detour target and must not throw. Use Result.err() instead.`,
|
|
43
|
-
rule: 'no-throw-in-detour-target',
|
|
44
|
-
severity: 'error',
|
|
45
|
-
});
|
|
46
|
-
}
|
|
47
|
-
});
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
return diagnostics;
|
|
51
|
-
};
|
|
52
|
-
const checkThrowInDetourTargets = (sourceCode, filePath, detourTargets) => {
|
|
53
|
-
if (isTestFile(filePath)) {
|
|
54
|
-
return [];
|
|
55
|
-
}
|
|
56
|
-
const ast = parse(filePath, sourceCode);
|
|
57
|
-
if (!ast) {
|
|
58
|
-
return [];
|
|
59
|
-
}
|
|
60
|
-
return findThrowsInTargetedTrails(ast, sourceCode, filePath, detourTargets);
|
|
61
|
-
};
|
|
62
|
-
/**
|
|
63
|
-
* Flags throws in implementations that are used as detour targets.
|
|
64
|
-
*/
|
|
65
|
-
export const noThrowInDetourTarget = {
|
|
66
|
-
check(sourceCode, filePath) {
|
|
67
|
-
const ast = parse(filePath, sourceCode);
|
|
68
|
-
if (!ast) {
|
|
69
|
-
return [];
|
|
70
|
-
}
|
|
71
|
-
return checkThrowInDetourTargets(sourceCode, filePath, collectDetourTargets(ast));
|
|
72
|
-
},
|
|
73
|
-
checkWithContext(sourceCode, filePath, context) {
|
|
74
|
-
if (context.detourTargetTrailIds) {
|
|
75
|
-
return checkThrowInDetourTargets(sourceCode, filePath, context.detourTargetTrailIds);
|
|
76
|
-
}
|
|
77
|
-
const ast = parse(filePath, sourceCode);
|
|
78
|
-
if (!ast) {
|
|
79
|
-
return [];
|
|
80
|
-
}
|
|
81
|
-
return checkThrowInDetourTargets(sourceCode, filePath, collectDetourTargets(ast));
|
|
82
|
-
},
|
|
83
|
-
description: 'Disallow throw statements inside implementations that are referenced as detour targets.',
|
|
84
|
-
name: 'no-throw-in-detour-target',
|
|
85
|
-
severity: 'error',
|
|
86
|
-
};
|
|
87
|
-
//# sourceMappingURL=no-throw-in-detour-target.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"no-throw-in-detour-target.js","sourceRoot":"","sources":["../../src/rules/no-throw-in-detour-target.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Finds `throw` statements inside `blaze:` function bodies.
|
|
3
|
-
*
|
|
4
|
-
* Uses AST parsing for accurate detection — no false positives from
|
|
5
|
-
* throw in comments, strings, or nested non-implementation functions.
|
|
6
|
-
*/
|
|
7
|
-
import type { WardenRule } from './types.js';
|
|
8
|
-
export declare const noThrowInImplementation: WardenRule;
|
|
9
|
-
//# sourceMappingURL=no-throw-in-implementation.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"no-throw-in-implementation.d.ts","sourceRoot":"","sources":["../../src/rules/no-throw-in-implementation.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAGH,OAAO,KAAK,EAAoB,UAAU,EAAE,MAAM,YAAY,CAAC;AAE/D,eAAO,MAAM,uBAAuB,EAAE,UA8BrC,CAAC"}
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Finds `throw` statements inside `blaze:` function bodies.
|
|
3
|
-
*
|
|
4
|
-
* Uses AST parsing for accurate detection — no false positives from
|
|
5
|
-
* throw in comments, strings, or nested non-implementation functions.
|
|
6
|
-
*/
|
|
7
|
-
import { findBlazeBodies, offsetToLine, parse, walk } from './ast.js';
|
|
8
|
-
export const noThrowInImplementation = {
|
|
9
|
-
check(sourceCode, filePath) {
|
|
10
|
-
const ast = parse(filePath, sourceCode);
|
|
11
|
-
if (!ast) {
|
|
12
|
-
return [];
|
|
13
|
-
}
|
|
14
|
-
const diagnostics = [];
|
|
15
|
-
for (const body of findBlazeBodies(ast)) {
|
|
16
|
-
walk(body, (node) => {
|
|
17
|
-
if (node.type === 'ThrowStatement') {
|
|
18
|
-
diagnostics.push({
|
|
19
|
-
filePath,
|
|
20
|
-
line: offsetToLine(sourceCode, node.start),
|
|
21
|
-
message: 'Do not throw inside implementation. Use Result.err() instead.',
|
|
22
|
-
rule: 'no-throw-in-implementation',
|
|
23
|
-
severity: 'error',
|
|
24
|
-
});
|
|
25
|
-
}
|
|
26
|
-
});
|
|
27
|
-
}
|
|
28
|
-
return diagnostics;
|
|
29
|
-
},
|
|
30
|
-
description: 'Disallow throw statements inside trail/route implementation bodies. Use Result.err() instead.',
|
|
31
|
-
name: 'no-throw-in-implementation',
|
|
32
|
-
severity: 'error',
|
|
33
|
-
};
|
|
34
|
-
//# sourceMappingURL=no-throw-in-implementation.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"no-throw-in-implementation.js","sourceRoot":"","sources":["../../src/rules/no-throw-in-implementation.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,eAAe,EAAE,YAAY,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,UAAU,CAAC;AAGtE,MAAM,CAAC,MAAM,uBAAuB,GAAe;IACjD,KAAK,CAAC,UAAkB,EAAE,QAAgB;QACxC,MAAM,GAAG,GAAG,KAAK,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;QACxC,IAAI,CAAC,GAAG,EAAE,CAAC;YACT,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,MAAM,WAAW,GAAuB,EAAE,CAAC;QAE3C,KAAK,MAAM,IAAI,IAAI,eAAe,CAAC,GAAG,CAAC,EAAE,CAAC;YACxC,IAAI,CAAC,IAAI,EAAE,CAAC,IAAI,EAAE,EAAE;gBAClB,IAAI,IAAI,CAAC,IAAI,KAAK,gBAAgB,EAAE,CAAC;oBACnC,WAAW,CAAC,IAAI,CAAC;wBACf,QAAQ;wBACR,IAAI,EAAE,YAAY,CAAC,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC;wBAC1C,OAAO,EACL,+DAA+D;wBACjE,IAAI,EAAE,4BAA4B;wBAClC,QAAQ,EAAE,OAAO;qBAClB,CAAC,CAAC;gBACL,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC;QAED,OAAO,WAAW,CAAC;IACrB,CAAC;IACD,WAAW,EACT,+FAA+F;IACjG,IAAI,EAAE,4BAA4B;IAClC,QAAQ,EAAE,OAAO;CAClB,CAAC"}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import type { WardenRule } from './types.js';
|
|
2
|
-
/**
|
|
3
|
-
* Warns when a fields override only repeats metadata deriveFields() already gets from
|
|
4
|
-
* the schema.
|
|
5
|
-
*/
|
|
6
|
-
export declare const preferSchemaInference: WardenRule;
|
|
7
|
-
//# sourceMappingURL=prefer-schema-inference.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"prefer-schema-inference.d.ts","sourceRoot":"","sources":["../../src/rules/prefer-schema-inference.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAoB,UAAU,EAAE,MAAM,YAAY,CAAC;AA0H/D;;;GAGG;AACH,eAAO,MAAM,qBAAqB,EAAE,UAcnC,CAAC"}
|
|
@@ -1,86 +0,0 @@
|
|
|
1
|
-
import { isTestFile } from './scan.js';
|
|
2
|
-
import { findTrailLikeSpecs, parseArrayEntries, parseObjectProperties, parseStringLiteral, parseZodObjectShape, } from './specs.js';
|
|
3
|
-
const REDUNDANT_OVERRIDE_KEYS = new Set(['label', 'options']);
|
|
4
|
-
const hasOnlyRedundantKeys = (properties) => [...properties.keys()].every((key) => REDUNDANT_OVERRIDE_KEYS.has(key));
|
|
5
|
-
const redundantLabelPart = (derivedLabel, properties) => {
|
|
6
|
-
const label = parseStringLiteral(properties.get('label')?.value ?? '');
|
|
7
|
-
return label !== null && label === derivedLabel ? ['label'] : [];
|
|
8
|
-
};
|
|
9
|
-
const optionsAreDerivedDefaults = (optionsText, schemaOptions) => {
|
|
10
|
-
const entries = parseArrayEntries(optionsText, 0, optionsText);
|
|
11
|
-
if (entries.length !== schemaOptions.length) {
|
|
12
|
-
return false;
|
|
13
|
-
}
|
|
14
|
-
return entries.every((entry, index) => {
|
|
15
|
-
if (!entry.text.startsWith('{')) {
|
|
16
|
-
return false;
|
|
17
|
-
}
|
|
18
|
-
const properties = parseObjectProperties(entry.text, 0, entry.text);
|
|
19
|
-
if (properties.size !== 1) {
|
|
20
|
-
return false;
|
|
21
|
-
}
|
|
22
|
-
const value = parseStringLiteral(properties.get('value')?.value ?? '');
|
|
23
|
-
return value !== null && value === schemaOptions[index];
|
|
24
|
-
});
|
|
25
|
-
};
|
|
26
|
-
const redundantOptionsPart = (options, schemaOptions) => options !== undefined &&
|
|
27
|
-
schemaOptions !== undefined &&
|
|
28
|
-
optionsAreDerivedDefaults(options.value, schemaOptions)
|
|
29
|
-
? ['options']
|
|
30
|
-
: [];
|
|
31
|
-
const findRedundantParts = (fieldKey, fieldOverride, schemaText) => {
|
|
32
|
-
const fieldInfo = parseZodObjectShape(schemaText).get(fieldKey);
|
|
33
|
-
if (!fieldInfo) {
|
|
34
|
-
return [];
|
|
35
|
-
}
|
|
36
|
-
const properties = parseObjectProperties(fieldOverride, 0, fieldOverride);
|
|
37
|
-
if (properties.size === 0) {
|
|
38
|
-
return ['field metadata'];
|
|
39
|
-
}
|
|
40
|
-
if (!hasOnlyRedundantKeys(properties)) {
|
|
41
|
-
return [];
|
|
42
|
-
}
|
|
43
|
-
const redundant = [
|
|
44
|
-
...redundantLabelPart(fieldInfo.derivedLabel, properties),
|
|
45
|
-
...redundantOptionsPart(properties.get('options'), fieldInfo.options),
|
|
46
|
-
];
|
|
47
|
-
return redundant.length === properties.size ? redundant : [];
|
|
48
|
-
};
|
|
49
|
-
const diagnosticsForSpec = (sourceCode, filePath, spec) => {
|
|
50
|
-
const input = spec.properties.get('input');
|
|
51
|
-
const fields = spec.properties.get('fields');
|
|
52
|
-
if (!input || !fields) {
|
|
53
|
-
return [];
|
|
54
|
-
}
|
|
55
|
-
const fieldEntries = parseObjectProperties(fields.value, fields.start, sourceCode);
|
|
56
|
-
return [...fieldEntries.entries()]
|
|
57
|
-
.map(([fieldKey, fieldEntry]) => ({
|
|
58
|
-
fieldEntry,
|
|
59
|
-
fieldKey,
|
|
60
|
-
redundantParts: findRedundantParts(fieldKey, fieldEntry.value, input.value),
|
|
61
|
-
}))
|
|
62
|
-
.filter(({ redundantParts }) => redundantParts.length > 0)
|
|
63
|
-
.map(({ fieldEntry, fieldKey, redundantParts }) => ({
|
|
64
|
-
filePath,
|
|
65
|
-
line: fieldEntry.line,
|
|
66
|
-
message: `Trail "${spec.id}" field "${fieldKey}" only repeats schema-derived ${redundantParts.join(' and ')}. Remove the override and let deriveFields() infer it.`,
|
|
67
|
-
rule: 'prefer-schema-inference',
|
|
68
|
-
severity: 'warn',
|
|
69
|
-
}));
|
|
70
|
-
};
|
|
71
|
-
/**
|
|
72
|
-
* Warns when a fields override only repeats metadata deriveFields() already gets from
|
|
73
|
-
* the schema.
|
|
74
|
-
*/
|
|
75
|
-
export const preferSchemaInference = {
|
|
76
|
-
check(sourceCode, filePath) {
|
|
77
|
-
if (isTestFile(filePath)) {
|
|
78
|
-
return [];
|
|
79
|
-
}
|
|
80
|
-
return findTrailLikeSpecs(sourceCode).flatMap((spec) => diagnosticsForSpec(sourceCode, filePath, spec));
|
|
81
|
-
},
|
|
82
|
-
description: 'Warn when fields overrides only restate labels or enum options deriveFields() already infers from the Zod schema.',
|
|
83
|
-
name: 'prefer-schema-inference',
|
|
84
|
-
severity: 'warn',
|
|
85
|
-
};
|
|
86
|
-
//# sourceMappingURL=prefer-schema-inference.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"prefer-schema-inference.js","sourceRoot":"","sources":["../../src/rules/prefer-schema-inference.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Validates that provision access matches the declared `provisions` array.
|
|
3
|
-
*
|
|
4
|
-
* Statically analyzes trail `blaze` functions to find `db.from(ctx)` and
|
|
5
|
-
* `ctx.provision('db.main')` calls and compares them against the declared
|
|
6
|
-
* `provisions: [...]` array in the trail config. Reports errors for undeclared
|
|
7
|
-
* access and warnings for unused declarations.
|
|
8
|
-
*/
|
|
9
|
-
import type { WardenRule } from './types.js';
|
|
10
|
-
/**
|
|
11
|
-
* Validates that provision access aligns with declared `provisions` arrays.
|
|
12
|
-
*/
|
|
13
|
-
export declare const provisionDeclarations: WardenRule;
|
|
14
|
-
//# sourceMappingURL=provision-declarations.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"provision-declarations.d.ts","sourceRoot":"","sources":["../../src/rules/provision-declarations.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAiBH,OAAO,KAAK,EAAoB,UAAU,EAAE,MAAM,YAAY,CAAC;AAgkB/D;;GAEG;AACH,eAAO,MAAM,qBAAqB,EAAE,UA8BnC,CAAC"}
|