@aicqtools/guardrail 1.0.0-alpha.2
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/LICENSE +21 -0
- package/dist/docs/build.d.ts +12 -0
- package/dist/docs/build.d.ts.map +1 -0
- package/dist/docs/build.js +23 -0
- package/dist/docs/build.js.map +1 -0
- package/dist/docs/index.d.ts +4 -0
- package/dist/docs/index.d.ts.map +1 -0
- package/dist/docs/index.js +3 -0
- package/dist/docs/index.js.map +1 -0
- package/dist/docs/render-rule-md.d.ts +4 -0
- package/dist/docs/render-rule-md.d.ts.map +1 -0
- package/dist/docs/render-rule-md.js +117 -0
- package/dist/docs/render-rule-md.js.map +1 -0
- package/dist/index.d.ts +12 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +7 -0
- package/dist/index.js.map +1 -0
- package/dist/matcher/index.d.ts +4 -0
- package/dist/matcher/index.d.ts.map +1 -0
- package/dist/matcher/index.js +3 -0
- package/dist/matcher/index.js.map +1 -0
- package/dist/matcher/traverse.d.ts +3 -0
- package/dist/matcher/traverse.d.ts.map +1 -0
- package/dist/matcher/traverse.js +9 -0
- package/dist/matcher/traverse.js.map +1 -0
- package/dist/matcher/yaml-rule.d.ts +31 -0
- package/dist/matcher/yaml-rule.d.ts.map +1 -0
- package/dist/matcher/yaml-rule.js +30 -0
- package/dist/matcher/yaml-rule.js.map +1 -0
- package/dist/mcp/handlers.d.ts +36 -0
- package/dist/mcp/handlers.d.ts.map +1 -0
- package/dist/mcp/handlers.js +32 -0
- package/dist/mcp/handlers.js.map +1 -0
- package/dist/mcp/index.d.ts +6 -0
- package/dist/mcp/index.d.ts.map +1 -0
- package/dist/mcp/index.js +4 -0
- package/dist/mcp/index.js.map +1 -0
- package/dist/mcp/server.d.ts +9 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +53 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/mcp/stdio.d.ts +3 -0
- package/dist/mcp/stdio.d.ts.map +1 -0
- package/dist/mcp/stdio.js +8 -0
- package/dist/mcp/stdio.js.map +1 -0
- package/dist/rules-default/ai-explainability-metadata.d.ts +3 -0
- package/dist/rules-default/ai-explainability-metadata.d.ts.map +1 -0
- package/dist/rules-default/ai-explainability-metadata.js +41 -0
- package/dist/rules-default/ai-explainability-metadata.js.map +1 -0
- package/dist/rules-default/api-response-shape.d.ts +3 -0
- package/dist/rules-default/api-response-shape.d.ts.map +1 -0
- package/dist/rules-default/api-response-shape.js +52 -0
- package/dist/rules-default/api-response-shape.js.map +1 -0
- package/dist/rules-default/async-await-consistency.d.ts +3 -0
- package/dist/rules-default/async-await-consistency.d.ts.map +1 -0
- package/dist/rules-default/async-await-consistency.js +38 -0
- package/dist/rules-default/async-await-consistency.js.map +1 -0
- package/dist/rules-default/audit-log-ai-decision.d.ts +3 -0
- package/dist/rules-default/audit-log-ai-decision.d.ts.map +1 -0
- package/dist/rules-default/audit-log-ai-decision.js +33 -0
- package/dist/rules-default/audit-log-ai-decision.js.map +1 -0
- package/dist/rules-default/camelcase-migration-column.d.ts +3 -0
- package/dist/rules-default/camelcase-migration-column.d.ts.map +1 -0
- package/dist/rules-default/camelcase-migration-column.js +56 -0
- package/dist/rules-default/camelcase-migration-column.js.map +1 -0
- package/dist/rules-default/controller-needs-async-wrapper.d.ts +3 -0
- package/dist/rules-default/controller-needs-async-wrapper.d.ts.map +1 -0
- package/dist/rules-default/controller-needs-async-wrapper.js +56 -0
- package/dist/rules-default/controller-needs-async-wrapper.js.map +1 -0
- package/dist/rules-default/enforce-utf8-encoding.d.ts +10 -0
- package/dist/rules-default/enforce-utf8-encoding.d.ts.map +1 -0
- package/dist/rules-default/enforce-utf8-encoding.js +28 -0
- package/dist/rules-default/enforce-utf8-encoding.js.map +1 -0
- package/dist/rules-default/explicit-kst-timezone.d.ts +3 -0
- package/dist/rules-default/explicit-kst-timezone.d.ts.map +1 -0
- package/dist/rules-default/explicit-kst-timezone.js +49 -0
- package/dist/rules-default/explicit-kst-timezone.js.map +1 -0
- package/dist/rules-default/fk-needs-on-delete.d.ts +3 -0
- package/dist/rules-default/fk-needs-on-delete.d.ts.map +1 -0
- package/dist/rules-default/fk-needs-on-delete.js +54 -0
- package/dist/rules-default/fk-needs-on-delete.js.map +1 -0
- package/dist/rules-default/human-oversight-checkpoint.d.ts +3 -0
- package/dist/rules-default/human-oversight-checkpoint.d.ts.map +1 -0
- package/dist/rules-default/human-oversight-checkpoint.js +37 -0
- package/dist/rules-default/human-oversight-checkpoint.js.map +1 -0
- package/dist/rules-default/index.d.ts +6 -0
- package/dist/rules-default/index.d.ts.map +1 -0
- package/dist/rules-default/index.js +138 -0
- package/dist/rules-default/index.js.map +1 -0
- package/dist/rules-default/korean-comment-encoding.d.ts +3 -0
- package/dist/rules-default/korean-comment-encoding.d.ts.map +1 -0
- package/dist/rules-default/korean-comment-encoding.js +28 -0
- package/dist/rules-default/korean-comment-encoding.js.map +1 -0
- package/dist/rules-default/mask-card-number.d.ts +3 -0
- package/dist/rules-default/mask-card-number.d.ts.map +1 -0
- package/dist/rules-default/mask-card-number.js +45 -0
- package/dist/rules-default/mask-card-number.js.map +1 -0
- package/dist/rules-default/mask-pii-in-ai-prompt.d.ts +3 -0
- package/dist/rules-default/mask-pii-in-ai-prompt.d.ts.map +1 -0
- package/dist/rules-default/mask-pii-in-ai-prompt.js +41 -0
- package/dist/rules-default/mask-pii-in-ai-prompt.js.map +1 -0
- package/dist/rules-default/naver-kakao-oauth-webview.d.ts +3 -0
- package/dist/rules-default/naver-kakao-oauth-webview.d.ts.map +1 -0
- package/dist/rules-default/naver-kakao-oauth-webview.js +40 -0
- package/dist/rules-default/naver-kakao-oauth-webview.js.map +1 -0
- package/dist/rules-default/no-bare-except.d.ts +7 -0
- package/dist/rules-default/no-bare-except.d.ts.map +1 -0
- package/dist/rules-default/no-bare-except.js +23 -0
- package/dist/rules-default/no-bare-except.js.map +1 -0
- package/dist/rules-default/no-bare-throw.d.ts +7 -0
- package/dist/rules-default/no-bare-throw.d.ts.map +1 -0
- package/dist/rules-default/no-bare-throw.js +32 -0
- package/dist/rules-default/no-bare-throw.js.map +1 -0
- package/dist/rules-default/no-boolean-trap.d.ts +8 -0
- package/dist/rules-default/no-boolean-trap.d.ts.map +1 -0
- package/dist/rules-default/no-boolean-trap.js +33 -0
- package/dist/rules-default/no-boolean-trap.js.map +1 -0
- package/dist/rules-default/no-console-log.d.ts +3 -0
- package/dist/rules-default/no-console-log.d.ts.map +1 -0
- package/dist/rules-default/no-console-log.js +19 -0
- package/dist/rules-default/no-console-log.js.map +1 -0
- package/dist/rules-default/no-cvv-logging.d.ts +3 -0
- package/dist/rules-default/no-cvv-logging.d.ts.map +1 -0
- package/dist/rules-default/no-cvv-logging.js +36 -0
- package/dist/rules-default/no-cvv-logging.js.map +1 -0
- package/dist/rules-default/no-default-export-from-libs.d.ts +7 -0
- package/dist/rules-default/no-default-export-from-libs.d.ts.map +1 -0
- package/dist/rules-default/no-default-export-from-libs.js +24 -0
- package/dist/rules-default/no-default-export-from-libs.js.map +1 -0
- package/dist/rules-default/no-direct-anthropic.yaml +9 -0
- package/dist/rules-default/no-direct-openai.yaml +9 -0
- package/dist/rules-default/no-empty-catch.d.ts +7 -0
- package/dist/rules-default/no-empty-catch.d.ts.map +1 -0
- package/dist/rules-default/no-empty-catch.js +30 -0
- package/dist/rules-default/no-empty-catch.js.map +1 -0
- package/dist/rules-default/no-fstring-sql.d.ts +3 -0
- package/dist/rules-default/no-fstring-sql.d.ts.map +1 -0
- package/dist/rules-default/no-fstring-sql.js +24 -0
- package/dist/rules-default/no-fstring-sql.js.map +1 -0
- package/dist/rules-default/no-id-overwrite.d.ts +7 -0
- package/dist/rules-default/no-id-overwrite.d.ts.map +1 -0
- package/dist/rules-default/no-id-overwrite.js +26 -0
- package/dist/rules-default/no-id-overwrite.js.map +1 -0
- package/dist/rules-default/no-inline-date.yaml +9 -0
- package/dist/rules-default/no-inline-math-round.yaml +12 -0
- package/dist/rules-default/no-jsonb-circular.d.ts +3 -0
- package/dist/rules-default/no-jsonb-circular.d.ts.map +1 -0
- package/dist/rules-default/no-jsonb-circular.js +33 -0
- package/dist/rules-default/no-jsonb-circular.js.map +1 -0
- package/dist/rules-default/no-magic-number.d.ts +3 -0
- package/dist/rules-default/no-magic-number.d.ts.map +1 -0
- package/dist/rules-default/no-magic-number.js +42 -0
- package/dist/rules-default/no-magic-number.js.map +1 -0
- package/dist/rules-default/no-mutable-default-arg.d.ts +3 -0
- package/dist/rules-default/no-mutable-default-arg.d.ts.map +1 -0
- package/dist/rules-default/no-mutable-default-arg.js +30 -0
- package/dist/rules-default/no-mutable-default-arg.js.map +1 -0
- package/dist/rules-default/no-pickle.yaml +12 -0
- package/dist/rules-default/no-plain-card-number.d.ts +3 -0
- package/dist/rules-default/no-plain-card-number.d.ts.map +1 -0
- package/dist/rules-default/no-plain-card-number.js +51 -0
- package/dist/rules-default/no-plain-card-number.js.map +1 -0
- package/dist/rules-default/no-print-in-prod.yaml +9 -0
- package/dist/rules-default/no-process-env-leak.d.ts +7 -0
- package/dist/rules-default/no-process-env-leak.d.ts.map +1 -0
- package/dist/rules-default/no-process-env-leak.js +34 -0
- package/dist/rules-default/no-process-env-leak.js.map +1 -0
- package/dist/rules-default/no-shell-true.d.ts +3 -0
- package/dist/rules-default/no-shell-true.d.ts.map +1 -0
- package/dist/rules-default/no-shell-true.js +42 -0
- package/dist/rules-default/no-shell-true.js.map +1 -0
- package/dist/rules-default/prefer-const-array.d.ts +9 -0
- package/dist/rules-default/prefer-const-array.d.ts.map +1 -0
- package/dist/rules-default/prefer-const-array.js +34 -0
- package/dist/rules-default/prefer-const-array.js.map +1 -0
- package/dist/rules-default/prefer-named-imports.d.ts +8 -0
- package/dist/rules-default/prefer-named-imports.d.ts.map +1 -0
- package/dist/rules-default/prefer-named-imports.js +25 -0
- package/dist/rules-default/prefer-named-imports.js.map +1 -0
- package/dist/rules-default/preserve-transaction-log.d.ts +3 -0
- package/dist/rules-default/preserve-transaction-log.d.ts.map +1 -0
- package/dist/rules-default/preserve-transaction-log.js +33 -0
- package/dist/rules-default/preserve-transaction-log.js.map +1 -0
- package/dist/rules-default/pytest-fixture-naming.d.ts +3 -0
- package/dist/rules-default/pytest-fixture-naming.d.ts.map +1 -0
- package/dist/rules-default/pytest-fixture-naming.js +36 -0
- package/dist/rules-default/pytest-fixture-naming.js.map +1 -0
- package/dist/rules-default/requests-needs-timeout.d.ts +3 -0
- package/dist/rules-default/requests-needs-timeout.d.ts.map +1 -0
- package/dist/rules-default/requests-needs-timeout.js +43 -0
- package/dist/rules-default/requests-needs-timeout.js.map +1 -0
- package/dist/rules-default/require-idempotency-key.d.ts +3 -0
- package/dist/rules-default/require-idempotency-key.d.ts.map +1 -0
- package/dist/rules-default/require-idempotency-key.js +47 -0
- package/dist/rules-default/require-idempotency-key.js.map +1 -0
- package/dist/rules-default/require-tls-1-2-plus.d.ts +3 -0
- package/dist/rules-default/require-tls-1-2-plus.d.ts.map +1 -0
- package/dist/rules-default/require-tls-1-2-plus.js +30 -0
- package/dist/rules-default/require-tls-1-2-plus.js.map +1 -0
- package/dist/rules-default/rfc5987-korean-filename.d.ts +3 -0
- package/dist/rules-default/rfc5987-korean-filename.d.ts.map +1 -0
- package/dist/rules-default/rfc5987-korean-filename.js +32 -0
- package/dist/rules-default/rfc5987-korean-filename.js.map +1 -0
- package/dist/rules-default/route-needs-auth.d.ts +3 -0
- package/dist/rules-default/route-needs-auth.d.ts.map +1 -0
- package/dist/rules-default/route-needs-auth.js +48 -0
- package/dist/rules-default/route-needs-auth.js.map +1 -0
- package/dist/rules-default/route-needs-rate-limit.d.ts +3 -0
- package/dist/rules-default/route-needs-rate-limit.d.ts.map +1 -0
- package/dist/rules-default/route-needs-rate-limit.js +47 -0
- package/dist/rules-default/route-needs-rate-limit.js.map +1 -0
- package/dist/rules-default/separate-refund-permission.d.ts +3 -0
- package/dist/rules-default/separate-refund-permission.d.ts.map +1 -0
- package/dist/rules-default/separate-refund-permission.js +33 -0
- package/dist/rules-default/separate-refund-permission.js.map +1 -0
- package/dist/rules-default/track-ai-model-version.d.ts +3 -0
- package/dist/rules-default/track-ai-model-version.d.ts.map +1 -0
- package/dist/rules-default/track-ai-model-version.js +37 -0
- package/dist/rules-default/track-ai-model-version.js.map +1 -0
- package/dist/rules-default/type-hint-required-public.d.ts +10 -0
- package/dist/rules-default/type-hint-required-public.d.ts.map +1 -0
- package/dist/rules-default/type-hint-required-public.js +29 -0
- package/dist/rules-default/type-hint-required-public.js.map +1 -0
- package/dist/rules-default/verify-pg-response.d.ts +3 -0
- package/dist/rules-default/verify-pg-response.d.ts.map +1 -0
- package/dist/rules-default/verify-pg-response.js +37 -0
- package/dist/rules-default/verify-pg-response.js.map +1 -0
- package/dist/rules-default/won-format-thousands.d.ts +3 -0
- package/dist/rules-default/won-format-thousands.d.ts.map +1 -0
- package/dist/rules-default/won-format-thousands.js +24 -0
- package/dist/rules-default/won-format-thousands.js.map +1 -0
- package/dist/runner/context.d.ts +12 -0
- package/dist/runner/context.d.ts.map +1 -0
- package/dist/runner/context.js +34 -0
- package/dist/runner/context.js.map +1 -0
- package/dist/runner/index.d.ts +7 -0
- package/dist/runner/index.d.ts.map +1 -0
- package/dist/runner/index.js +5 -0
- package/dist/runner/index.js.map +1 -0
- package/dist/runner/ruleset-signature.d.ts +4 -0
- package/dist/runner/ruleset-signature.d.ts.map +1 -0
- package/dist/runner/ruleset-signature.js +11 -0
- package/dist/runner/ruleset-signature.js.map +1 -0
- package/dist/runner/run-file.d.ts +10 -0
- package/dist/runner/run-file.d.ts.map +1 -0
- package/dist/runner/run-file.js +20 -0
- package/dist/runner/run-file.js.map +1 -0
- package/dist/runner/run-project.d.ts +12 -0
- package/dist/runner/run-project.d.ts.map +1 -0
- package/dist/runner/run-project.js +55 -0
- package/dist/runner/run-project.js.map +1 -0
- package/dist/runner/run-rule.d.ts +5 -0
- package/dist/runner/run-rule.d.ts.map +1 -0
- package/dist/runner/run-rule.js +37 -0
- package/dist/runner/run-rule.js.map +1 -0
- package/dist/sync/index.d.ts +5 -0
- package/dist/sync/index.d.ts.map +1 -0
- package/dist/sync/index.js +3 -0
- package/dist/sync/index.js.map +1 -0
- package/dist/sync/render.d.ts +9 -0
- package/dist/sync/render.d.ts.map +1 -0
- package/dist/sync/render.js +70 -0
- package/dist/sync/render.js.map +1 -0
- package/dist/sync/sync-files.d.ts +12 -0
- package/dist/sync/sync-files.d.ts.map +1 -0
- package/dist/sync/sync-files.js +29 -0
- package/dist/sync/sync-files.js.map +1 -0
- package/package.json +62 -0
- package/scripts/copy-yaml-rules.mjs +19 -0
package/LICENSE
ADDED
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2026 Eom Sik (aicqtools)
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { Rule } from '@aicqtools/rule-sdk';
|
|
2
|
+
export interface BuildDocsOptions {
|
|
3
|
+
readonly cwd: string;
|
|
4
|
+
readonly outDir: string;
|
|
5
|
+
readonly rules: readonly Rule[];
|
|
6
|
+
}
|
|
7
|
+
export interface BuildDocsResult {
|
|
8
|
+
readonly outDir: string;
|
|
9
|
+
readonly files: number;
|
|
10
|
+
}
|
|
11
|
+
export declare function buildRuleDocs(opts: BuildDocsOptions): Promise<BuildDocsResult>;
|
|
12
|
+
//# sourceMappingURL=build.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"build.d.ts","sourceRoot":"","sources":["../../src/docs/build.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,qBAAqB,CAAC;AAGhD,MAAM,WAAW,gBAAgB;IAC/B,QAAQ,CAAC,GAAG,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,KAAK,EAAE,SAAS,IAAI,EAAE,CAAC;CACjC;AAED,MAAM,WAAW,eAAe;IAC9B,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;CACxB;AAED,wBAAsB,aAAa,CAAC,IAAI,EAAE,gBAAgB,GAAG,OAAO,CAAC,eAAe,CAAC,CAsBpF"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { mkdir, writeFile } from 'node:fs/promises';
|
|
2
|
+
import { join, resolve } from 'node:path';
|
|
3
|
+
import { renderRuleMarkdown, renderRulesIndex } from './render-rule-md.js';
|
|
4
|
+
export async function buildRuleDocs(opts) {
|
|
5
|
+
const out = resolve(opts.cwd, opts.outDir);
|
|
6
|
+
const dirs = {
|
|
7
|
+
ko: join(out, 'rules', 'ko'),
|
|
8
|
+
en: join(out, 'rules', 'en'),
|
|
9
|
+
};
|
|
10
|
+
await mkdir(dirs.ko, { recursive: true });
|
|
11
|
+
await mkdir(dirs.en, { recursive: true });
|
|
12
|
+
let files = 0;
|
|
13
|
+
for (const rule of opts.rules) {
|
|
14
|
+
await writeFile(join(dirs.ko, `${rule.id}.md`), renderRuleMarkdown(rule, 'ko'), 'utf-8');
|
|
15
|
+
await writeFile(join(dirs.en, `${rule.id}.md`), renderRuleMarkdown(rule, 'en'), 'utf-8');
|
|
16
|
+
files += 2;
|
|
17
|
+
}
|
|
18
|
+
await writeFile(join(dirs.ko, 'index.md'), renderRulesIndex(opts.rules, 'ko'), 'utf-8');
|
|
19
|
+
await writeFile(join(dirs.en, 'index.md'), renderRulesIndex(opts.rules, 'en'), 'utf-8');
|
|
20
|
+
files += 2;
|
|
21
|
+
return { outDir: out, files };
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=build.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"build.js","sourceRoot":"","sources":["../../src/docs/build.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AACpD,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAE1C,OAAO,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAa3E,MAAM,CAAC,KAAK,UAAU,aAAa,CAAC,IAAsB;IACxD,MAAM,GAAG,GAAG,OAAO,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IAC3C,MAAM,IAAI,GAAG;QACX,EAAE,EAAE,IAAI,CAAC,GAAG,EAAE,OAAO,EAAE,IAAI,CAAC;QAC5B,EAAE,EAAE,IAAI,CAAC,GAAG,EAAE,OAAO,EAAE,IAAI,CAAC;KACpB,CAAC;IAEX,MAAM,KAAK,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAC1C,MAAM,KAAK,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAE1C,IAAI,KAAK,GAAG,CAAC,CAAC;IACd,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;QAC9B,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,EAAE,GAAG,IAAI,CAAC,EAAE,KAAK,CAAC,EAAE,kBAAkB,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,OAAO,CAAC,CAAC;QACzF,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,EAAE,GAAG,IAAI,CAAC,EAAE,KAAK,CAAC,EAAE,kBAAkB,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,OAAO,CAAC,CAAC;QACzF,KAAK,IAAI,CAAC,CAAC;IACb,CAAC;IAED,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,EAAE,UAAU,CAAC,EAAE,gBAAgB,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,EAAE,OAAO,CAAC,CAAC;IACxF,MAAM,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,EAAE,UAAU,CAAC,EAAE,gBAAgB,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,EAAE,OAAO,CAAC,CAAC;IACxF,KAAK,IAAI,CAAC,CAAC;IAEX,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC;AAChC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/docs/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAC3E,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAC3C,YAAY,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/docs/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAC3E,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { Rule } from '@aicqtools/rule-sdk';
|
|
2
|
+
export declare function renderRuleMarkdown(rule: Rule, locale: 'ko' | 'en'): string;
|
|
3
|
+
export declare function renderRulesIndex(rules: readonly Rule[], locale: 'ko' | 'en'): string;
|
|
4
|
+
//# sourceMappingURL=render-rule-md.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"render-rule-md.d.ts","sourceRoot":"","sources":["../../src/docs/render-rule-md.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,qBAAqB,CAAC;AAwBhD,wBAAgB,kBAAkB,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,GAAG,IAAI,GAAG,MAAM,CAsF1E;AAED,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,SAAS,IAAI,EAAE,EAAE,MAAM,EAAE,IAAI,GAAG,IAAI,GAAG,MAAM,CAYpF"}
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
const SEVERITY_LABEL_EN = {
|
|
2
|
+
error: '🔴 error',
|
|
3
|
+
warning: '🟡 warning',
|
|
4
|
+
info: 'ℹ️ info',
|
|
5
|
+
};
|
|
6
|
+
const SEVERITY_LABEL_KO = {
|
|
7
|
+
error: '🔴 오류',
|
|
8
|
+
warning: '🟡 경고',
|
|
9
|
+
info: 'ℹ️ 정보',
|
|
10
|
+
};
|
|
11
|
+
function languagesText(rule) {
|
|
12
|
+
const langs = Array.isArray(rule.language) ? rule.language : [rule.language];
|
|
13
|
+
return langs.join(', ');
|
|
14
|
+
}
|
|
15
|
+
function ruleKindLabel(rule, locale) {
|
|
16
|
+
if (rule.kind === 'pattern')
|
|
17
|
+
return locale === 'ko' ? 'YAML 패턴' : 'YAML pattern';
|
|
18
|
+
return locale === 'ko' ? 'JS/TS 함수' : 'JS/TS function';
|
|
19
|
+
}
|
|
20
|
+
export function renderRuleMarkdown(rule, locale) {
|
|
21
|
+
const messages = locale === 'ko' && rule.messageKo ? rule.messageKo : rule.message;
|
|
22
|
+
const severityLabel = locale === 'ko' ? SEVERITY_LABEL_KO[rule.severity] : SEVERITY_LABEL_EN[rule.severity];
|
|
23
|
+
const docsLink = rule.docs ? `\n**Docs**: ${rule.docs}` : '';
|
|
24
|
+
if (locale === 'ko') {
|
|
25
|
+
return [
|
|
26
|
+
`# ${rule.id}`,
|
|
27
|
+
'',
|
|
28
|
+
`**Severity**: ${severityLabel} `,
|
|
29
|
+
`**Languages**: ${languagesText(rule)} `,
|
|
30
|
+
`**Kind**: ${ruleKindLabel(rule, 'ko')}${docsLink}`,
|
|
31
|
+
'',
|
|
32
|
+
'## 설명',
|
|
33
|
+
'',
|
|
34
|
+
messages,
|
|
35
|
+
'',
|
|
36
|
+
'## 위반 예시',
|
|
37
|
+
'',
|
|
38
|
+
'```typescript',
|
|
39
|
+
'// 룰별 구체 예제는 추후 추가 (커뮤니티 PR 환영)',
|
|
40
|
+
'```',
|
|
41
|
+
'',
|
|
42
|
+
'## 통과 예시',
|
|
43
|
+
'',
|
|
44
|
+
'```typescript',
|
|
45
|
+
'// 룰별 구체 예제는 추후 추가',
|
|
46
|
+
'```',
|
|
47
|
+
'',
|
|
48
|
+
'## 알려진 한계',
|
|
49
|
+
'',
|
|
50
|
+
'- PoC 단계 룰입니다 — false positive 가능성이 있으며, 출시 후 커뮤니티 피드백을 통해 정밀도를 높입니다.',
|
|
51
|
+
'',
|
|
52
|
+
'## 비활성화',
|
|
53
|
+
'',
|
|
54
|
+
'특정 프로젝트에서 이 룰을 끄려면 `aicq.config.yaml`에:',
|
|
55
|
+
'',
|
|
56
|
+
'```yaml',
|
|
57
|
+
'modules:',
|
|
58
|
+
' guardrail:',
|
|
59
|
+
' rules:',
|
|
60
|
+
` ${rule.id}: off`,
|
|
61
|
+
'```',
|
|
62
|
+
'',
|
|
63
|
+
].join('\n');
|
|
64
|
+
}
|
|
65
|
+
return [
|
|
66
|
+
`# ${rule.id}`,
|
|
67
|
+
'',
|
|
68
|
+
`**Severity**: ${severityLabel} `,
|
|
69
|
+
`**Languages**: ${languagesText(rule)} `,
|
|
70
|
+
`**Kind**: ${ruleKindLabel(rule, 'en')}${docsLink}`,
|
|
71
|
+
'',
|
|
72
|
+
'## Description',
|
|
73
|
+
'',
|
|
74
|
+
messages,
|
|
75
|
+
'',
|
|
76
|
+
'## Violation example',
|
|
77
|
+
'',
|
|
78
|
+
'```typescript',
|
|
79
|
+
'// Rule-specific examples to be added (community PRs welcome)',
|
|
80
|
+
'```',
|
|
81
|
+
'',
|
|
82
|
+
'## Passing example',
|
|
83
|
+
'',
|
|
84
|
+
'```typescript',
|
|
85
|
+
'// Rule-specific examples to be added',
|
|
86
|
+
'```',
|
|
87
|
+
'',
|
|
88
|
+
'## Known limitations',
|
|
89
|
+
'',
|
|
90
|
+
'- PoC-grade rule — false positives possible. Precision will improve via community feedback after release.',
|
|
91
|
+
'',
|
|
92
|
+
'## Disabling this rule',
|
|
93
|
+
'',
|
|
94
|
+
'In `aicq.config.yaml`:',
|
|
95
|
+
'',
|
|
96
|
+
'```yaml',
|
|
97
|
+
'modules:',
|
|
98
|
+
' guardrail:',
|
|
99
|
+
' rules:',
|
|
100
|
+
` ${rule.id}: off`,
|
|
101
|
+
'```',
|
|
102
|
+
'',
|
|
103
|
+
].join('\n');
|
|
104
|
+
}
|
|
105
|
+
export function renderRulesIndex(rules, locale) {
|
|
106
|
+
const sorted = [...rules].sort((a, b) => a.id.localeCompare(b.id));
|
|
107
|
+
const header = locale === 'ko'
|
|
108
|
+
? `# 룰셋 (${rules.length}개)\n\naicq의 빌트인 룰 전체 목록.\n\n| ID | Severity | Languages | 설명 |\n|----|----------|-----------|------|`
|
|
109
|
+
: `# Ruleset (${rules.length} rules)\n\nAll built-in aicq rules.\n\n| ID | Severity | Languages | Description |\n|----|----------|-----------|-------------|`;
|
|
110
|
+
const rows = sorted.map((r) => {
|
|
111
|
+
const langs = Array.isArray(r.language) ? r.language.join(', ') : r.language;
|
|
112
|
+
const msg = (locale === 'ko' && r.messageKo ? r.messageKo : r.message).replace(/\n/g, ' ').slice(0, 80);
|
|
113
|
+
return `| [\`${r.id}\`](./${r.id}.md) | ${r.severity} | ${langs} | ${msg} |`;
|
|
114
|
+
});
|
|
115
|
+
return [header, ...rows, ''].join('\n');
|
|
116
|
+
}
|
|
117
|
+
//# sourceMappingURL=render-rule-md.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"render-rule-md.js","sourceRoot":"","sources":["../../src/docs/render-rule-md.ts"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
export { runFile, runFileWithSource, runProject, runRule, } from './runner/index.js';
|
|
2
|
+
export type { RunFileResult, RunProjectOptions } from './runner/index.js';
|
|
3
|
+
export { traverse, parseYamlRule } from './matcher/index.js';
|
|
4
|
+
export type { YamlRuleInput } from './matcher/index.js';
|
|
5
|
+
export { builtinFunctionRules, loadBuiltinYamlRules, loadAllBuiltinRules, loadFunctionRulesFromDir, } from './rules-default/index.js';
|
|
6
|
+
export { buildMcpServer, startStdio, handleCheckSnippet, handleListRules, checkSnippetInputSchema, } from './mcp/index.js';
|
|
7
|
+
export { renderRules, injectIntoMarkdown, syncAiRules, MARKER_START, MARKER_END, } from './sync/index.js';
|
|
8
|
+
export type { RenderOptions, SyncOptions, SyncTarget } from './sync/index.js';
|
|
9
|
+
export { renderRuleMarkdown, renderRulesIndex, buildRuleDocs } from './docs/index.js';
|
|
10
|
+
export type { BuildDocsOptions, BuildDocsResult } from './docs/index.js';
|
|
11
|
+
export type { BuildMcpServerOptions, CheckSnippetInput, CheckSnippetResult, ListRulesResult, } from './mcp/index.js';
|
|
12
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,OAAO,EACP,iBAAiB,EACjB,UAAU,EACV,OAAO,GACR,MAAM,mBAAmB,CAAC;AAC3B,YAAY,EAAE,aAAa,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AAE1E,OAAO,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAC7D,YAAY,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAExD,OAAO,EACL,oBAAoB,EACpB,oBAAoB,EACpB,mBAAmB,EACnB,wBAAwB,GACzB,MAAM,0BAA0B,CAAC;AAElC,OAAO,EACL,cAAc,EACd,UAAU,EACV,kBAAkB,EAClB,eAAe,EACf,uBAAuB,GACxB,MAAM,gBAAgB,CAAC;AAExB,OAAO,EACL,WAAW,EACX,kBAAkB,EAClB,WAAW,EACX,YAAY,EACZ,UAAU,GACX,MAAM,iBAAiB,CAAC;AACzB,YAAY,EAAE,aAAa,EAAE,WAAW,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAE9E,OAAO,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AACtF,YAAY,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AACzE,YAAY,EACV,qBAAqB,EACrB,iBAAiB,EACjB,kBAAkB,EAClB,eAAe,GAChB,MAAM,gBAAgB,CAAC"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export { runFile, runFileWithSource, runProject, runRule, } from './runner/index.js';
|
|
2
|
+
export { traverse, parseYamlRule } from './matcher/index.js';
|
|
3
|
+
export { builtinFunctionRules, loadBuiltinYamlRules, loadAllBuiltinRules, loadFunctionRulesFromDir, } from './rules-default/index.js';
|
|
4
|
+
export { buildMcpServer, startStdio, handleCheckSnippet, handleListRules, checkSnippetInputSchema, } from './mcp/index.js';
|
|
5
|
+
export { renderRules, injectIntoMarkdown, syncAiRules, MARKER_START, MARKER_END, } from './sync/index.js';
|
|
6
|
+
export { renderRuleMarkdown, renderRulesIndex, buildRuleDocs } from './docs/index.js';
|
|
7
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,OAAO,EACP,iBAAiB,EACjB,UAAU,EACV,OAAO,GACR,MAAM,mBAAmB,CAAC;AAG3B,OAAO,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAG7D,OAAO,EACL,oBAAoB,EACpB,oBAAoB,EACpB,mBAAmB,EACnB,wBAAwB,GACzB,MAAM,0BAA0B,CAAC;AAElC,OAAO,EACL,cAAc,EACd,UAAU,EACV,kBAAkB,EAClB,eAAe,EACf,uBAAuB,GACxB,MAAM,gBAAgB,CAAC;AAExB,OAAO,EACL,WAAW,EACX,kBAAkB,EAClB,WAAW,EACX,YAAY,EACZ,UAAU,GACX,MAAM,iBAAiB,CAAC;AAGzB,OAAO,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/matcher/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAC/C,YAAY,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/matcher/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"traverse.d.ts","sourceRoot":"","sources":["../../src/matcher/traverse.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,aAAa,CAAC;AAEtC,wBAAgB,QAAQ,CACtB,IAAI,EAAE,MAAM,CAAC,UAAU,EACvB,KAAK,EAAE,CAAC,IAAI,EAAE,MAAM,CAAC,UAAU,KAAK,IAAI,GACvC,IAAI,CAMN"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"traverse.js","sourceRoot":"","sources":["../../src/matcher/traverse.ts"],"names":[],"mappings":"AAEA,MAAM,UAAU,QAAQ,CACtB,IAAuB,EACvB,KAAwC;IAExC,KAAK,CAAC,IAAI,CAAC,CAAC;IACZ,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC,EAAE,EAAE,CAAC;QAC9C,MAAM,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QACjC,IAAI,KAAK;YAAE,QAAQ,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IACpC,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
import type { PatternRule } from '@aicqtools/rule-sdk';
|
|
3
|
+
declare const yamlRuleSchema: z.ZodObject<{
|
|
4
|
+
id: z.ZodString;
|
|
5
|
+
language: z.ZodUnion<[z.ZodEnum<["typescript", "javascript", "tsx", "python"]>, z.ZodArray<z.ZodEnum<["typescript", "javascript", "tsx", "python"]>, "many">]>;
|
|
6
|
+
severity: z.ZodEnum<["error", "warning", "info"]>;
|
|
7
|
+
message: z.ZodString;
|
|
8
|
+
messageKo: z.ZodOptional<z.ZodString>;
|
|
9
|
+
docs: z.ZodOptional<z.ZodString>;
|
|
10
|
+
query: z.ZodString;
|
|
11
|
+
}, "strip", z.ZodTypeAny, {
|
|
12
|
+
language: "typescript" | "javascript" | "tsx" | "python" | ("typescript" | "javascript" | "tsx" | "python")[];
|
|
13
|
+
id: string;
|
|
14
|
+
message: string;
|
|
15
|
+
severity: "error" | "warning" | "info";
|
|
16
|
+
query: string;
|
|
17
|
+
messageKo?: string | undefined;
|
|
18
|
+
docs?: string | undefined;
|
|
19
|
+
}, {
|
|
20
|
+
language: "typescript" | "javascript" | "tsx" | "python" | ("typescript" | "javascript" | "tsx" | "python")[];
|
|
21
|
+
id: string;
|
|
22
|
+
message: string;
|
|
23
|
+
severity: "error" | "warning" | "info";
|
|
24
|
+
query: string;
|
|
25
|
+
messageKo?: string | undefined;
|
|
26
|
+
docs?: string | undefined;
|
|
27
|
+
}>;
|
|
28
|
+
export type YamlRuleInput = z.infer<typeof yamlRuleSchema>;
|
|
29
|
+
export declare function parseYamlRule(source: string): PatternRule;
|
|
30
|
+
export {};
|
|
31
|
+
//# sourceMappingURL=yaml-rule.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"yaml-rule.d.ts","sourceRoot":"","sources":["../../src/matcher/yaml-rule.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAMvD,QAAA,MAAM,cAAc;;;;;;;;;;;;;;;;;;;;;;;;EAQlB,CAAC;AAEH,MAAM,MAAM,aAAa,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,cAAc,CAAC,CAAC;AAE3D,wBAAgB,aAAa,CAAC,MAAM,EAAE,MAAM,GAAG,WAAW,CAezD"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
import { parse as parseYaml } from 'yaml';
|
|
3
|
+
const languageSchema = z.enum(['typescript', 'javascript', 'tsx', 'python']);
|
|
4
|
+
const severitySchema = z.enum(['error', 'warning', 'info']);
|
|
5
|
+
const yamlRuleSchema = z.object({
|
|
6
|
+
id: z.string().min(1),
|
|
7
|
+
language: z.union([languageSchema, z.array(languageSchema).min(1)]),
|
|
8
|
+
severity: severitySchema,
|
|
9
|
+
message: z.string().min(1),
|
|
10
|
+
messageKo: z.string().optional(),
|
|
11
|
+
docs: z.string().url().optional(),
|
|
12
|
+
query: z.string().min(1),
|
|
13
|
+
});
|
|
14
|
+
export function parseYamlRule(source) {
|
|
15
|
+
const parsed = yamlRuleSchema.parse(parseYaml(source));
|
|
16
|
+
const rule = {
|
|
17
|
+
kind: 'pattern',
|
|
18
|
+
id: parsed.id,
|
|
19
|
+
language: parsed.language,
|
|
20
|
+
severity: parsed.severity,
|
|
21
|
+
message: parsed.message,
|
|
22
|
+
query: parsed.query,
|
|
23
|
+
};
|
|
24
|
+
return parsed.messageKo !== undefined
|
|
25
|
+
? { ...rule, messageKo: parsed.messageKo }
|
|
26
|
+
: parsed.docs !== undefined
|
|
27
|
+
? { ...rule, docs: parsed.docs }
|
|
28
|
+
: rule;
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=yaml-rule.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"yaml-rule.js","sourceRoot":"","sources":["../../src/matcher/yaml-rule.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,KAAK,IAAI,SAAS,EAAE,MAAM,MAAM,CAAC;AAI1C,MAAM,cAAc,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,YAAY,EAAE,YAAY,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC;AAC7E,MAAM,cAAc,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,SAAS,EAAE,MAAM,CAAC,CAAC,CAAC;AAE5D,MAAM,cAAc,GAAG,CAAC,CAAC,MAAM,CAAC;IAC9B,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IACrB,QAAQ,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,cAAc,EAAE,CAAC,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACnE,QAAQ,EAAE,cAAc;IACxB,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IAC1B,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAChC,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE;IACjC,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;CACzB,CAAC,CAAC;AAIH,MAAM,UAAU,aAAa,CAAC,MAAc;IAC1C,MAAM,MAAM,GAAG,cAAc,CAAC,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC;IACvD,MAAM,IAAI,GAAgB;QACxB,IAAI,EAAE,SAAS;QACf,EAAE,EAAE,MAAM,CAAC,EAAE;QACb,QAAQ,EAAE,MAAM,CAAC,QAA0C;QAC3D,QAAQ,EAAE,MAAM,CAAC,QAAoB;QACrC,OAAO,EAAE,MAAM,CAAC,OAAO;QACvB,KAAK,EAAE,MAAM,CAAC,KAAK;KACpB,CAAC;IACF,OAAO,MAAM,CAAC,SAAS,KAAK,SAAS;QACnC,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,SAAS,EAAE,MAAM,CAAC,SAAS,EAAE;QAC1C,CAAC,CAAC,MAAM,CAAC,IAAI,KAAK,SAAS;YACzB,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE;YAChC,CAAC,CAAC,IAAI,CAAC;AACb,CAAC"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
import type { Rule } from '@aicqtools/rule-sdk';
|
|
3
|
+
export declare const checkSnippetInputSchema: z.ZodObject<{
|
|
4
|
+
source: z.ZodString;
|
|
5
|
+
language: z.ZodEnum<["typescript", "javascript", "tsx", "python"]>;
|
|
6
|
+
filePath: z.ZodOptional<z.ZodString>;
|
|
7
|
+
}, "strip", z.ZodTypeAny, {
|
|
8
|
+
language: "typescript" | "javascript" | "tsx" | "python";
|
|
9
|
+
source: string;
|
|
10
|
+
filePath?: string | undefined;
|
|
11
|
+
}, {
|
|
12
|
+
language: "typescript" | "javascript" | "tsx" | "python";
|
|
13
|
+
source: string;
|
|
14
|
+
filePath?: string | undefined;
|
|
15
|
+
}>;
|
|
16
|
+
export type CheckSnippetInput = z.infer<typeof checkSnippetInputSchema>;
|
|
17
|
+
export interface CheckSnippetResult {
|
|
18
|
+
readonly diagnostics: ReadonlyArray<{
|
|
19
|
+
readonly ruleId: string;
|
|
20
|
+
readonly severity: string;
|
|
21
|
+
readonly message: string;
|
|
22
|
+
readonly line: number;
|
|
23
|
+
readonly column: number;
|
|
24
|
+
}>;
|
|
25
|
+
}
|
|
26
|
+
export declare function handleCheckSnippet(input: unknown, rules: readonly Rule[]): CheckSnippetResult;
|
|
27
|
+
export interface ListRulesResult {
|
|
28
|
+
readonly rules: ReadonlyArray<{
|
|
29
|
+
readonly id: string;
|
|
30
|
+
readonly severity: string;
|
|
31
|
+
readonly languages: readonly string[];
|
|
32
|
+
readonly message: string;
|
|
33
|
+
}>;
|
|
34
|
+
}
|
|
35
|
+
export declare function handleListRules(rules: readonly Rule[]): ListRulesResult;
|
|
36
|
+
//# sourceMappingURL=handlers.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handlers.d.ts","sourceRoot":"","sources":["../../src/mcp/handlers.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAExB,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,qBAAqB,CAAC;AAKhD,eAAO,MAAM,uBAAuB;;;;;;;;;;;;EAIlC,CAAC;AAEH,MAAM,MAAM,iBAAiB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,uBAAuB,CAAC,CAAC;AAExE,MAAM,WAAW,kBAAkB;IACjC,QAAQ,CAAC,WAAW,EAAE,aAAa,CAAC;QAClC,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;QACxB,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;QAC1B,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;QACzB,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;QACtB,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;KACzB,CAAC,CAAC;CACJ;AAED,wBAAgB,kBAAkB,CAAC,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,SAAS,IAAI,EAAE,GAAG,kBAAkB,CAiB7F;AAED,MAAM,WAAW,eAAe;IAC9B,QAAQ,CAAC,KAAK,EAAE,aAAa,CAAC;QAC5B,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC;QACpB,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;QAC1B,QAAQ,CAAC,SAAS,EAAE,SAAS,MAAM,EAAE,CAAC;QACtC,QAAQ,CAAC,OAAO,EAAE,MAAM,CAAC;KAC1B,CAAC,CAAC;CACJ;AAED,wBAAgB,eAAe,CAAC,KAAK,EAAE,SAAS,IAAI,EAAE,GAAG,eAAe,CASvE"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { z } from 'zod';
|
|
2
|
+
import { runFileWithSource } from '../runner/run-file.js';
|
|
3
|
+
const languageSchema = z.enum(['typescript', 'javascript', 'tsx', 'python']);
|
|
4
|
+
export const checkSnippetInputSchema = z.object({
|
|
5
|
+
source: z.string(),
|
|
6
|
+
language: languageSchema,
|
|
7
|
+
filePath: z.string().optional(),
|
|
8
|
+
});
|
|
9
|
+
export function handleCheckSnippet(input, rules) {
|
|
10
|
+
const parsed = checkSnippetInputSchema.parse(input ?? {});
|
|
11
|
+
const result = runFileWithSource(parsed.filePath ?? '<snippet>', parsed.source, parsed.language, rules);
|
|
12
|
+
return {
|
|
13
|
+
diagnostics: result.diagnostics.map((d) => ({
|
|
14
|
+
ruleId: d.ruleId,
|
|
15
|
+
severity: d.severity,
|
|
16
|
+
message: d.messageKo ?? d.message,
|
|
17
|
+
line: d.range.start.line,
|
|
18
|
+
column: d.range.start.column,
|
|
19
|
+
})),
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
export function handleListRules(rules) {
|
|
23
|
+
return {
|
|
24
|
+
rules: rules.map((r) => ({
|
|
25
|
+
id: r.id,
|
|
26
|
+
severity: r.severity,
|
|
27
|
+
languages: Array.isArray(r.language) ? [...r.language] : [r.language],
|
|
28
|
+
message: r.message,
|
|
29
|
+
})),
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=handlers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"handlers.js","sourceRoot":"","sources":["../../src/mcp/handlers.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAGxB,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAE1D,MAAM,cAAc,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,YAAY,EAAE,YAAY,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC;AAE7E,MAAM,CAAC,MAAM,uBAAuB,GAAG,CAAC,CAAC,MAAM,CAAC;IAC9C,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE;IAClB,QAAQ,EAAE,cAAc;IACxB,QAAQ,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;CAChC,CAAC,CAAC;AAcH,MAAM,UAAU,kBAAkB,CAAC,KAAc,EAAE,KAAsB;IACvE,MAAM,MAAM,GAAG,uBAAuB,CAAC,KAAK,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC;IAC1D,MAAM,MAAM,GAAG,iBAAiB,CAC9B,MAAM,CAAC,QAAQ,IAAI,WAAW,EAC9B,MAAM,CAAC,MAAM,EACb,MAAM,CAAC,QAAoB,EAC3B,KAAK,CACN,CAAC;IACF,OAAO;QACL,WAAW,EAAE,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YAC1C,MAAM,EAAE,CAAC,CAAC,MAAM;YAChB,QAAQ,EAAE,CAAC,CAAC,QAAQ;YACpB,OAAO,EAAE,CAAC,CAAC,SAAS,IAAI,CAAC,CAAC,OAAO;YACjC,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI;YACxB,MAAM,EAAE,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,MAAM;SAC7B,CAAC,CAAC;KACJ,CAAC;AACJ,CAAC;AAWD,MAAM,UAAU,eAAe,CAAC,KAAsB;IACpD,OAAO;QACL,KAAK,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YACvB,EAAE,EAAE,CAAC,CAAC,EAAE;YACR,QAAQ,EAAE,CAAC,CAAC,QAAQ;YACpB,SAAS,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC;YACrE,OAAO,EAAE,CAAC,CAAC,OAAO;SACnB,CAAC,CAAC;KACJ,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export { buildMcpServer } from './server.js';
|
|
2
|
+
export type { BuildMcpServerOptions } from './server.js';
|
|
3
|
+
export { startStdio } from './stdio.js';
|
|
4
|
+
export { handleCheckSnippet, handleListRules, checkSnippetInputSchema, } from './handlers.js';
|
|
5
|
+
export type { CheckSnippetInput, CheckSnippetResult, ListRulesResult, } from './handlers.js';
|
|
6
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/mcp/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,YAAY,EAAE,qBAAqB,EAAE,MAAM,aAAa,CAAC;AACzD,OAAO,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AACxC,OAAO,EACL,kBAAkB,EAClB,eAAe,EACf,uBAAuB,GACxB,MAAM,eAAe,CAAC;AACvB,YAAY,EACV,iBAAiB,EACjB,kBAAkB,EAClB,eAAe,GAChB,MAAM,eAAe,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/mcp/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAE7C,OAAO,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AACxC,OAAO,EACL,kBAAkB,EAClB,eAAe,EACf,uBAAuB,GACxB,MAAM,eAAe,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { Server } from '@modelcontextprotocol/sdk/server/index.js';
|
|
2
|
+
import type { Rule } from '@aicqtools/rule-sdk';
|
|
3
|
+
export interface BuildMcpServerOptions {
|
|
4
|
+
readonly rules?: readonly Rule[];
|
|
5
|
+
readonly name?: string;
|
|
6
|
+
readonly version?: string;
|
|
7
|
+
}
|
|
8
|
+
export declare function buildMcpServer(opts?: BuildMcpServerOptions): Promise<Server>;
|
|
9
|
+
//# sourceMappingURL=server.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../../src/mcp/server.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,2CAA2C,CAAC;AAKnE,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,qBAAqB,CAAC;AAIhD,MAAM,WAAW,qBAAqB;IACpC,QAAQ,CAAC,KAAK,CAAC,EAAE,SAAS,IAAI,EAAE,CAAC;IACjC,QAAQ,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,OAAO,CAAC,EAAE,MAAM,CAAC;CAC3B;AAED,wBAAsB,cAAc,CAAC,IAAI,GAAE,qBAA0B,GAAG,OAAO,CAAC,MAAM,CAAC,CAuDtF"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { Server } from '@modelcontextprotocol/sdk/server/index.js';
|
|
2
|
+
import { CallToolRequestSchema, ListToolsRequestSchema, } from '@modelcontextprotocol/sdk/types.js';
|
|
3
|
+
import { loadAllBuiltinRules } from '../rules-default/index.js';
|
|
4
|
+
import { handleCheckSnippet, handleListRules } from './handlers.js';
|
|
5
|
+
export async function buildMcpServer(opts = {}) {
|
|
6
|
+
const rules = opts.rules ?? (await loadAllBuiltinRules());
|
|
7
|
+
const server = new Server({
|
|
8
|
+
name: opts.name ?? 'aicq-guardrail',
|
|
9
|
+
version: opts.version ?? '0.0.0',
|
|
10
|
+
}, {
|
|
11
|
+
capabilities: { tools: {} },
|
|
12
|
+
});
|
|
13
|
+
server.setRequestHandler(ListToolsRequestSchema, () => ({
|
|
14
|
+
tools: [
|
|
15
|
+
{
|
|
16
|
+
name: 'checkSnippet',
|
|
17
|
+
description: 'Validate a code snippet against AICQ guardrail rules. Returns diagnostics with rule id, severity, message, line, and column.',
|
|
18
|
+
inputSchema: {
|
|
19
|
+
type: 'object',
|
|
20
|
+
properties: {
|
|
21
|
+
source: { type: 'string', description: 'Source code to check' },
|
|
22
|
+
language: {
|
|
23
|
+
type: 'string',
|
|
24
|
+
enum: ['typescript', 'javascript', 'tsx', 'python'],
|
|
25
|
+
},
|
|
26
|
+
filePath: { type: 'string', description: 'Optional file path for context' },
|
|
27
|
+
},
|
|
28
|
+
required: ['source', 'language'],
|
|
29
|
+
},
|
|
30
|
+
},
|
|
31
|
+
{
|
|
32
|
+
name: 'listRules',
|
|
33
|
+
description: 'List all loaded guardrail rules with their metadata.',
|
|
34
|
+
inputSchema: { type: 'object', properties: {} },
|
|
35
|
+
},
|
|
36
|
+
],
|
|
37
|
+
}));
|
|
38
|
+
server.setRequestHandler(CallToolRequestSchema, async (req) => {
|
|
39
|
+
const name = req.params.name;
|
|
40
|
+
const args = req.params.arguments;
|
|
41
|
+
if (name === 'checkSnippet') {
|
|
42
|
+
const result = handleCheckSnippet(args, rules);
|
|
43
|
+
return { content: [{ type: 'text', text: JSON.stringify(result, null, 2) }] };
|
|
44
|
+
}
|
|
45
|
+
if (name === 'listRules') {
|
|
46
|
+
const result = handleListRules(rules);
|
|
47
|
+
return { content: [{ type: 'text', text: JSON.stringify(result, null, 2) }] };
|
|
48
|
+
}
|
|
49
|
+
throw new Error(`Unknown tool: ${name}`);
|
|
50
|
+
});
|
|
51
|
+
return server;
|
|
52
|
+
}
|
|
53
|
+
//# sourceMappingURL=server.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"server.js","sourceRoot":"","sources":["../../src/mcp/server.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,2CAA2C,CAAC;AACnE,OAAO,EACL,qBAAqB,EACrB,sBAAsB,GACvB,MAAM,oCAAoC,CAAC;AAE5C,OAAO,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAChE,OAAO,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAQpE,MAAM,CAAC,KAAK,UAAU,cAAc,CAAC,OAA8B,EAAE;IACnE,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,IAAI,CAAC,MAAM,mBAAmB,EAAE,CAAC,CAAC;IAE1D,MAAM,MAAM,GAAG,IAAI,MAAM,CACvB;QACE,IAAI,EAAE,IAAI,CAAC,IAAI,IAAI,gBAAgB;QACnC,OAAO,EAAE,IAAI,CAAC,OAAO,IAAI,OAAO;KACjC,EACD;QACE,YAAY,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE;KAC5B,CACF,CAAC;IAEF,MAAM,CAAC,iBAAiB,CAAC,sBAAsB,EAAE,GAAG,EAAE,CAAC,CAAC;QACtD,KAAK,EAAE;YACL;gBACE,IAAI,EAAE,cAAc;gBACpB,WAAW,EACT,8HAA8H;gBAChI,WAAW,EAAE;oBACX,IAAI,EAAE,QAAQ;oBACd,UAAU,EAAE;wBACV,MAAM,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,sBAAsB,EAAE;wBAC/D,QAAQ,EAAE;4BACR,IAAI,EAAE,QAAQ;4BACd,IAAI,EAAE,CAAC,YAAY,EAAE,YAAY,EAAE,KAAK,EAAE,QAAQ,CAAC;yBACpD;wBACD,QAAQ,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,gCAAgC,EAAE;qBAC5E;oBACD,QAAQ,EAAE,CAAC,QAAQ,EAAE,UAAU,CAAC;iBACjC;aACF;YACD;gBACE,IAAI,EAAE,WAAW;gBACjB,WAAW,EAAE,sDAAsD;gBACnE,WAAW,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,UAAU,EAAE,EAAE,EAAE;aAChD;SACF;KACF,CAAC,CAAC,CAAC;IAEJ,MAAM,CAAC,iBAAiB,CAAC,qBAAqB,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE;QAC5D,MAAM,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC;QAC7B,MAAM,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC,SAAS,CAAC;QAClC,IAAI,IAAI,KAAK,cAAc,EAAE,CAAC;YAC5B,MAAM,MAAM,GAAG,kBAAkB,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;YAC/C,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC;QAChF,CAAC;QACD,IAAI,IAAI,KAAK,WAAW,EAAE,CAAC;YACzB,MAAM,MAAM,GAAG,eAAe,CAAC,KAAK,CAAC,CAAC;YACtC,OAAO,EAAE,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC;QAChF,CAAC;QACD,MAAM,IAAI,KAAK,CAAC,iBAAiB,IAAI,EAAE,CAAC,CAAC;IAC3C,CAAC,CAAC,CAAC;IAEH,OAAO,MAAM,CAAC;AAChB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stdio.d.ts","sourceRoot":"","sources":["../../src/mcp/stdio.ts"],"names":[],"mappings":"AACA,OAAO,EAAkB,KAAK,qBAAqB,EAAE,MAAM,aAAa,CAAC;AAEzE,wBAAsB,UAAU,CAAC,IAAI,GAAE,qBAA0B,GAAG,OAAO,CAAC,IAAI,CAAC,CAIhF"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { StdioServerTransport } from '@modelcontextprotocol/sdk/server/stdio.js';
|
|
2
|
+
import { buildMcpServer } from './server.js';
|
|
3
|
+
export async function startStdio(opts = {}) {
|
|
4
|
+
const server = await buildMcpServer(opts);
|
|
5
|
+
const transport = new StdioServerTransport();
|
|
6
|
+
await server.connect(transport);
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=stdio.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stdio.js","sourceRoot":"","sources":["../../src/mcp/stdio.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,2CAA2C,CAAC;AACjF,OAAO,EAAE,cAAc,EAA8B,MAAM,aAAa,CAAC;AAEzE,MAAM,CAAC,KAAK,UAAU,UAAU,CAAC,OAA8B,EAAE;IAC/D,MAAM,MAAM,GAAG,MAAM,cAAc,CAAC,IAAI,CAAC,CAAC;IAC1C,MAAM,SAAS,GAAG,IAAI,oBAAoB,EAAE,CAAC;IAC7C,MAAM,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;AAClC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ai-explainability-metadata.d.ts","sourceRoot":"","sources":["../../src/rules-default/ai-explainability-metadata.ts"],"names":[],"mappings":";AAiBA,wBAqBG"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { defineRule } from '@aicqtools/rule-sdk';
|
|
2
|
+
/**
|
|
3
|
+
* FSC AI guideline: when AI-derived results are surfaced to users, the
|
|
4
|
+
* response should include explainability metadata (reasoning / sources /
|
|
5
|
+
* model). Detect `res.json(...)` / `res.send(...)` payloads that look
|
|
6
|
+
* AI-derived (variable name contains `ai`/`model`/`completion`) but lack
|
|
7
|
+
* an explainability key.
|
|
8
|
+
*
|
|
9
|
+
* Limitation: name-based detection misses payloads built from generic
|
|
10
|
+
* variables. Severity is `info` so existing services don't break.
|
|
11
|
+
*/
|
|
12
|
+
const AI_VAR = /\b(aiResult|aiResponse|completion|prediction|inference|llmResult)\b/;
|
|
13
|
+
const EXPLAIN_KEYS = /\b(reasoning|sources|model|modelVersion|explanation|references)\b/;
|
|
14
|
+
export default defineRule({
|
|
15
|
+
id: 'ai-explainability-metadata',
|
|
16
|
+
language: ['typescript', 'tsx'],
|
|
17
|
+
severity: 'info',
|
|
18
|
+
message: 'AI-derived response is missing explainability metadata (reasoning/sources/model) — FSC AI guideline — explainability.',
|
|
19
|
+
messageKo: 'AI 응답에 설명가능성 메타데이터(reasoning/sources/model) 누락 (금감원 AI 가이드라인 — 설명가능성).',
|
|
20
|
+
docs: 'https://github.com/aicqtools/aicqtools/blob/main/docs/rules/ai-explainability-metadata.md',
|
|
21
|
+
visitors: {
|
|
22
|
+
call_expression(node, ctx) {
|
|
23
|
+
const fnNode = node.childForFieldName('function');
|
|
24
|
+
if (!fnNode)
|
|
25
|
+
return;
|
|
26
|
+
const fnText = ctx.textOf(fnNode);
|
|
27
|
+
if (!/\b(res|reply)\.(json|send)$/.test(fnText))
|
|
28
|
+
return;
|
|
29
|
+
const args = node.childForFieldName('arguments');
|
|
30
|
+
if (!args)
|
|
31
|
+
return;
|
|
32
|
+
const argsText = ctx.textOf(args);
|
|
33
|
+
if (!AI_VAR.test(argsText))
|
|
34
|
+
return;
|
|
35
|
+
if (EXPLAIN_KEYS.test(argsText))
|
|
36
|
+
return;
|
|
37
|
+
ctx.report({ node });
|
|
38
|
+
},
|
|
39
|
+
},
|
|
40
|
+
});
|
|
41
|
+
//# sourceMappingURL=ai-explainability-metadata.js.map
|