cedar-mcp-server 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (215) hide show
  1. package/.editorconfig +12 -0
  2. package/.github/workflows/ci.yml +31 -0
  3. package/.github/workflows/release.yml +42 -0
  4. package/.nvmrc +1 -0
  5. package/CHANGELOG.md +241 -0
  6. package/CONTRIBUTING.md +83 -0
  7. package/LICENSE +182 -0
  8. package/README.md +1635 -0
  9. package/SECURITY.md +37 -0
  10. package/dist/http-server.d.ts +61 -0
  11. package/dist/http-server.d.ts.map +1 -0
  12. package/dist/http-server.js +194 -0
  13. package/dist/http-server.js.map +1 -0
  14. package/dist/index.d.ts +32 -0
  15. package/dist/index.d.ts.map +1 -0
  16. package/dist/index.js +270 -0
  17. package/dist/index.js.map +1 -0
  18. package/dist/parser/policy-ast.d.ts +49 -0
  19. package/dist/parser/policy-ast.d.ts.map +1 -0
  20. package/dist/parser/policy-ast.js +311 -0
  21. package/dist/parser/policy-ast.js.map +1 -0
  22. package/dist/prompts/index.d.ts +38 -0
  23. package/dist/prompts/index.d.ts.map +1 -0
  24. package/dist/prompts/index.js +172 -0
  25. package/dist/prompts/index.js.map +1 -0
  26. package/dist/resources/ref-resolver.d.ts +23 -0
  27. package/dist/resources/ref-resolver.d.ts.map +1 -0
  28. package/dist/resources/ref-resolver.js +128 -0
  29. package/dist/resources/ref-resolver.js.map +1 -0
  30. package/dist/resources/store-manager.d.ts +64 -0
  31. package/dist/resources/store-manager.d.ts.map +1 -0
  32. package/dist/resources/store-manager.js +221 -0
  33. package/dist/resources/store-manager.js.map +1 -0
  34. package/dist/server.d.ts +18 -0
  35. package/dist/server.d.ts.map +1 -0
  36. package/dist/server.js +539 -0
  37. package/dist/server.js.map +1 -0
  38. package/dist/tools/advise/avp-rules.d.ts +49 -0
  39. package/dist/tools/advise/avp-rules.d.ts.map +1 -0
  40. package/dist/tools/advise/avp-rules.js +59 -0
  41. package/dist/tools/advise/avp-rules.js.map +1 -0
  42. package/dist/tools/advise/cedar-patterns.d.ts +24 -0
  43. package/dist/tools/advise/cedar-patterns.d.ts.map +1 -0
  44. package/dist/tools/advise/cedar-patterns.js +57 -0
  45. package/dist/tools/advise/cedar-patterns.js.map +1 -0
  46. package/dist/tools/advise/context-builder.d.ts +28 -0
  47. package/dist/tools/advise/context-builder.d.ts.map +1 -0
  48. package/dist/tools/advise/context-builder.js +89 -0
  49. package/dist/tools/advise/context-builder.js.map +1 -0
  50. package/dist/tools/advise/gotchas.d.ts +15 -0
  51. package/dist/tools/advise/gotchas.d.ts.map +1 -0
  52. package/dist/tools/advise/gotchas.js +83 -0
  53. package/dist/tools/advise/gotchas.js.map +1 -0
  54. package/dist/tools/advise.d.ts +96 -0
  55. package/dist/tools/advise.d.ts.map +1 -0
  56. package/dist/tools/advise.js +258 -0
  57. package/dist/tools/advise.js.map +1 -0
  58. package/dist/tools/authorize-batch.d.ts +35 -0
  59. package/dist/tools/authorize-batch.d.ts.map +1 -0
  60. package/dist/tools/authorize-batch.js +262 -0
  61. package/dist/tools/authorize-batch.js.map +1 -0
  62. package/dist/tools/authorize.d.ts +115 -0
  63. package/dist/tools/authorize.d.ts.map +1 -0
  64. package/dist/tools/authorize.js +373 -0
  65. package/dist/tools/authorize.js.map +1 -0
  66. package/dist/tools/check-change.d.ts +19 -0
  67. package/dist/tools/check-change.d.ts.map +1 -0
  68. package/dist/tools/check-change.js +91 -0
  69. package/dist/tools/check-change.js.map +1 -0
  70. package/dist/tools/diff-schema.d.ts +103 -0
  71. package/dist/tools/diff-schema.d.ts.map +1 -0
  72. package/dist/tools/diff-schema.js +379 -0
  73. package/dist/tools/diff-schema.js.map +1 -0
  74. package/dist/tools/diff-stores.d.ts +45 -0
  75. package/dist/tools/diff-stores.d.ts.map +1 -0
  76. package/dist/tools/diff-stores.js +222 -0
  77. package/dist/tools/diff-stores.js.map +1 -0
  78. package/dist/tools/explain.d.ts +80 -0
  79. package/dist/tools/explain.d.ts.map +1 -0
  80. package/dist/tools/explain.js +187 -0
  81. package/dist/tools/explain.js.map +1 -0
  82. package/dist/tools/format.d.ts +11 -0
  83. package/dist/tools/format.d.ts.map +1 -0
  84. package/dist/tools/format.js +20 -0
  85. package/dist/tools/format.js.map +1 -0
  86. package/dist/tools/generate-sample.d.ts +28 -0
  87. package/dist/tools/generate-sample.d.ts.map +1 -0
  88. package/dist/tools/generate-sample.js +568 -0
  89. package/dist/tools/generate-sample.js.map +1 -0
  90. package/dist/tools/link-template.d.ts +17 -0
  91. package/dist/tools/link-template.d.ts.map +1 -0
  92. package/dist/tools/link-template.js +78 -0
  93. package/dist/tools/link-template.js.map +1 -0
  94. package/dist/tools/list-template-links.d.ts +16 -0
  95. package/dist/tools/list-template-links.d.ts.map +1 -0
  96. package/dist/tools/list-template-links.js +22 -0
  97. package/dist/tools/list-template-links.js.map +1 -0
  98. package/dist/tools/list-templates.d.ts +16 -0
  99. package/dist/tools/list-templates.d.ts.map +1 -0
  100. package/dist/tools/list-templates.js +36 -0
  101. package/dist/tools/list-templates.js.map +1 -0
  102. package/dist/tools/translate.d.ts +11 -0
  103. package/dist/tools/translate.d.ts.map +1 -0
  104. package/dist/tools/translate.js +53 -0
  105. package/dist/tools/translate.js.map +1 -0
  106. package/dist/tools/validate-entities.d.ts +19 -0
  107. package/dist/tools/validate-entities.d.ts.map +1 -0
  108. package/dist/tools/validate-entities.js +88 -0
  109. package/dist/tools/validate-entities.js.map +1 -0
  110. package/dist/tools/validate-schema.d.ts +22 -0
  111. package/dist/tools/validate-schema.d.ts.map +1 -0
  112. package/dist/tools/validate-schema.js +89 -0
  113. package/dist/tools/validate-schema.js.map +1 -0
  114. package/dist/tools/validate-template.d.ts +18 -0
  115. package/dist/tools/validate-template.d.ts.map +1 -0
  116. package/dist/tools/validate-template.js +59 -0
  117. package/dist/tools/validate-template.js.map +1 -0
  118. package/dist/tools/validate.d.ts +90 -0
  119. package/dist/tools/validate.d.ts.map +1 -0
  120. package/dist/tools/validate.js +351 -0
  121. package/dist/tools/validate.js.map +1 -0
  122. package/dist/utils/format-detector.d.ts +49 -0
  123. package/dist/utils/format-detector.d.ts.map +1 -0
  124. package/dist/utils/format-detector.js +298 -0
  125. package/dist/utils/format-detector.js.map +1 -0
  126. package/examples/README.md +36 -0
  127. package/examples/abac-multi-tenant/README.md +150 -0
  128. package/examples/abac-multi-tenant/entities/users-and-docs.json +33 -0
  129. package/examples/abac-multi-tenant/policies/member-read-internal.cedar +9 -0
  130. package/examples/abac-multi-tenant/policies/owner-full-access.cedar +9 -0
  131. package/examples/abac-multi-tenant/policies/premium-share-guard.cedar +9 -0
  132. package/examples/abac-multi-tenant/policies/private-doc-guard.cedar +13 -0
  133. package/examples/abac-multi-tenant/run.ts +92 -0
  134. package/examples/abac-multi-tenant/schema.json +60 -0
  135. package/examples/api-gateway-path-routing/README.md +154 -0
  136. package/examples/api-gateway-path-routing/entities/users-and-roles.json +20 -0
  137. package/examples/api-gateway-path-routing/policies/admin-full-access.cedar +6 -0
  138. package/examples/api-gateway-path-routing/policies/developer-projects.cedar +14 -0
  139. package/examples/api-gateway-path-routing/policies/viewer-readonly.cedar +10 -0
  140. package/examples/api-gateway-path-routing/run.ts +108 -0
  141. package/examples/api-gateway-path-routing/schema.json +54 -0
  142. package/examples/rbac-document-management/README.md +167 -0
  143. package/examples/rbac-document-management/entities/users-and-docs.json +43 -0
  144. package/examples/rbac-document-management/policies/admin.cedar +6 -0
  145. package/examples/rbac-document-management/policies/editor.cedar +6 -0
  146. package/examples/rbac-document-management/policies/top-secret-forbid.cedar +13 -0
  147. package/examples/rbac-document-management/policies/viewer.cedar +6 -0
  148. package/examples/rbac-document-management/run.ts +87 -0
  149. package/examples/rbac-document-management/schema.json +57 -0
  150. package/package.json +50 -0
  151. package/src/http-server.ts +239 -0
  152. package/src/index.ts +294 -0
  153. package/src/parser/policy-ast.ts +345 -0
  154. package/src/prompts/README.md +3 -0
  155. package/src/prompts/index.ts +217 -0
  156. package/src/resources/ref-resolver.ts +134 -0
  157. package/src/resources/store-manager.ts +248 -0
  158. package/src/server.ts +711 -0
  159. package/src/tools/advise/avp-rules.ts +70 -0
  160. package/src/tools/advise/cedar-patterns.ts +73 -0
  161. package/src/tools/advise/context-builder.ts +109 -0
  162. package/src/tools/advise/gotchas.ts +92 -0
  163. package/src/tools/advise.ts +366 -0
  164. package/src/tools/authorize-batch.ts +345 -0
  165. package/src/tools/authorize.ts +464 -0
  166. package/src/tools/check-change.ts +119 -0
  167. package/src/tools/diff-schema.ts +510 -0
  168. package/src/tools/diff-stores.ts +298 -0
  169. package/src/tools/explain.ts +278 -0
  170. package/src/tools/format.ts +33 -0
  171. package/src/tools/generate-sample.ts +665 -0
  172. package/src/tools/link-template.ts +109 -0
  173. package/src/tools/list-template-links.ts +41 -0
  174. package/src/tools/list-templates.ts +55 -0
  175. package/src/tools/translate.ts +66 -0
  176. package/src/tools/validate-entities.ts +125 -0
  177. package/src/tools/validate-schema.ts +128 -0
  178. package/src/tools/validate-template.ts +72 -0
  179. package/src/tools/validate.ts +459 -0
  180. package/src/utils/format-detector.ts +356 -0
  181. package/test/fixtures/docmgmt.ts +121 -0
  182. package/test/fixtures/multitenant.ts +163 -0
  183. package/test/index.test.ts +96 -0
  184. package/test/integration/e2e/behavior.test.ts +359 -0
  185. package/test/integration/e2e/edge-cases.test.ts +365 -0
  186. package/test/integration/e2e/failure-modes.test.ts +266 -0
  187. package/test/integration/e2e/protocol.test.ts +252 -0
  188. package/test/integration/http-smoke.test.ts +588 -0
  189. package/test/integration/smoke.test.ts +475 -0
  190. package/test/prompts/prompts.test.ts +173 -0
  191. package/test/property/properties.test.ts +234 -0
  192. package/test/resources/ref-resolver.test.ts +186 -0
  193. package/test/resources/store-manager.test.ts +344 -0
  194. package/test/setup.test.ts +7 -0
  195. package/test/tools/advise/avp-rules.test.ts +76 -0
  196. package/test/tools/advise.test.ts +339 -0
  197. package/test/tools/authorize-batch.test.ts +459 -0
  198. package/test/tools/authorize.test.ts +682 -0
  199. package/test/tools/check-change.test.ts +104 -0
  200. package/test/tools/cross-fixture.test.ts +170 -0
  201. package/test/tools/diff-schema.test.ts +355 -0
  202. package/test/tools/diff-stores.test.ts +291 -0
  203. package/test/tools/explain.test.ts +221 -0
  204. package/test/tools/format.test.ts +33 -0
  205. package/test/tools/generate-sample.test.ts +480 -0
  206. package/test/tools/link-template.test.ts +90 -0
  207. package/test/tools/list-templates.test.ts +151 -0
  208. package/test/tools/translate.test.ts +89 -0
  209. package/test/tools/validate-entities.test.ts +178 -0
  210. package/test/tools/validate-schema.test.ts +86 -0
  211. package/test/tools/validate-template.test.ts +89 -0
  212. package/test/tools/validate.test.ts +331 -0
  213. package/test/utils/format-detector.test.ts +518 -0
  214. package/tsconfig.json +17 -0
  215. package/vitest.config.ts +13 -0
@@ -0,0 +1,103 @@
1
+ export interface DiffSchemaInput {
2
+ blue: string;
3
+ green: string;
4
+ }
5
+ type Risk = "safe" | "review" | "breaking";
6
+ export interface AttributeChange {
7
+ attr: string;
8
+ change: "added" | "removed" | "type_changed" | "optional_to_required" | "required_to_optional";
9
+ old_type?: string;
10
+ new_type?: string;
11
+ risk: Risk;
12
+ reason: string;
13
+ }
14
+ export interface EntityTypeModification {
15
+ namespace: string;
16
+ name: string;
17
+ member_of_changes?: {
18
+ added: string[];
19
+ removed: string[];
20
+ risk: Risk;
21
+ reason: string;
22
+ };
23
+ attribute_changes?: AttributeChange[];
24
+ }
25
+ export interface ContextChange {
26
+ attr: string;
27
+ change: "added" | "removed" | "type_changed";
28
+ old_type?: string;
29
+ new_type?: string;
30
+ risk: Risk;
31
+ reason: string;
32
+ }
33
+ export interface ActionModification {
34
+ namespace: string;
35
+ name: string;
36
+ principal_types?: {
37
+ added: string[];
38
+ removed: string[];
39
+ risk: Risk;
40
+ reason: string;
41
+ };
42
+ resource_types?: {
43
+ added: string[];
44
+ removed: string[];
45
+ risk: Risk;
46
+ reason: string;
47
+ };
48
+ context_changes?: ContextChange[];
49
+ }
50
+ export interface SchemaDiff {
51
+ namespaces_added: string[];
52
+ namespaces_removed: string[];
53
+ entity_types: {
54
+ added: Array<{
55
+ namespace: string;
56
+ name: string;
57
+ }>;
58
+ removed: Array<{
59
+ namespace: string;
60
+ name: string;
61
+ risk: Risk;
62
+ reason: string;
63
+ }>;
64
+ modified: EntityTypeModification[];
65
+ };
66
+ actions: {
67
+ added: Array<{
68
+ namespace: string;
69
+ name: string;
70
+ }>;
71
+ removed: Array<{
72
+ namespace: string;
73
+ name: string;
74
+ risk: Risk;
75
+ reason: string;
76
+ }>;
77
+ modified: ActionModification[];
78
+ };
79
+ common_types: {
80
+ added: Array<{
81
+ namespace: string;
82
+ name: string;
83
+ }>;
84
+ removed: Array<{
85
+ namespace: string;
86
+ name: string;
87
+ risk: Risk;
88
+ reason: string;
89
+ }>;
90
+ modified: Array<{
91
+ namespace: string;
92
+ name: string;
93
+ risk: Risk;
94
+ reason: string;
95
+ }>;
96
+ };
97
+ summary: string;
98
+ risk_level: Risk;
99
+ error?: string;
100
+ }
101
+ export declare function handleDiffSchema(input: DiffSchemaInput): Promise<SchemaDiff>;
102
+ export {};
103
+ //# sourceMappingURL=diff-schema.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"diff-schema.d.ts","sourceRoot":"","sources":["../../src/tools/diff-schema.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,379 @@
1
+ import { schemaToText, schemaToJsonWithResolvedTypes } from "@cedar-policy/cedar-wasm/nodejs";
2
+ function stripCedarPrefix(value) {
3
+ if (typeof value === "string")
4
+ return value.replace(/^__cedar::/, "");
5
+ if (Array.isArray(value))
6
+ return value.map(stripCedarPrefix);
7
+ if (value && typeof value === "object") {
8
+ const out = {};
9
+ for (const [k, v] of Object.entries(value)) {
10
+ out[k] = k === "type" && typeof v === "string" ? v.replace(/^__cedar::/, "") : stripCedarPrefix(v);
11
+ }
12
+ return out;
13
+ }
14
+ return value;
15
+ }
16
+ function normalizeToCanonical(schemaStr) {
17
+ let asText;
18
+ // 1. Detect JSON vs cedarschema text
19
+ let parsedJson = null;
20
+ try {
21
+ parsedJson = JSON.parse(schemaStr);
22
+ }
23
+ catch {
24
+ parsedJson = null;
25
+ }
26
+ if (parsedJson !== null && typeof parsedJson === "object" && !Array.isArray(parsedJson)) {
27
+ const textAns = schemaToText(parsedJson);
28
+ if (textAns.type !== "success") {
29
+ throw new Error("Failed to convert JSON schema to text form: " + (textAns.errors?.[0]?.message ?? "unknown error"));
30
+ }
31
+ asText = textAns.text;
32
+ }
33
+ else {
34
+ asText = schemaStr;
35
+ }
36
+ // 2. Always normalize via schemaToJsonWithResolvedTypes (text input only — per spike findings)
37
+ const ans = schemaToJsonWithResolvedTypes(asText);
38
+ if (ans.type !== "success") {
39
+ throw new Error("Failed to parse schema: " + (ans.errors?.[0]?.message ?? "unknown error"));
40
+ }
41
+ return stripCedarPrefix(ans.json);
42
+ }
43
+ function attrType(attr) {
44
+ if (!attr)
45
+ return "unknown";
46
+ return attr.type;
47
+ }
48
+ function attrRequired(attr) {
49
+ return attr.required !== false;
50
+ }
51
+ function setDiff(blue, green) {
52
+ const blueSet = new Set(blue);
53
+ const greenSet = new Set(green);
54
+ return {
55
+ added: green.filter((x) => !blueSet.has(x)),
56
+ removed: blue.filter((x) => !greenSet.has(x)),
57
+ };
58
+ }
59
+ function diffAttributes(blueAttrs, greenAttrs, contextLabel) {
60
+ const b = blueAttrs ?? {};
61
+ const g = greenAttrs ?? {};
62
+ const changes = [];
63
+ for (const [name, gAttr] of Object.entries(g)) {
64
+ if (!(name in b)) {
65
+ const required = attrRequired(gAttr);
66
+ changes.push({
67
+ attr: name,
68
+ change: "added",
69
+ new_type: attrType(gAttr),
70
+ risk: required ? "breaking" : "safe",
71
+ reason: required
72
+ ? `Required ${contextLabel} added: existing entities/requests without this field will fail validation.`
73
+ : `Optional ${contextLabel} added: existing policies do not reference it; safe to deploy.`,
74
+ });
75
+ }
76
+ }
77
+ for (const [name, bAttr] of Object.entries(b)) {
78
+ if (!(name in g)) {
79
+ changes.push({
80
+ attr: name,
81
+ change: "removed",
82
+ old_type: attrType(bAttr),
83
+ risk: "breaking",
84
+ reason: `${contextLabel[0].toUpperCase() + contextLabel.slice(1)} removed: policies referencing it will fail validation.`,
85
+ });
86
+ continue;
87
+ }
88
+ const gAttr = g[name];
89
+ if (attrType(bAttr) !== attrType(gAttr)) {
90
+ changes.push({
91
+ attr: name,
92
+ change: "type_changed",
93
+ old_type: attrType(bAttr),
94
+ new_type: attrType(gAttr),
95
+ risk: "breaking",
96
+ reason: `Type changed (${attrType(bAttr)} → ${attrType(gAttr)}): policies expecting the old type will fail evaluation.`,
97
+ });
98
+ continue;
99
+ }
100
+ const bReq = attrRequired(bAttr);
101
+ const gReq = attrRequired(gAttr);
102
+ if (bReq !== gReq) {
103
+ changes.push({
104
+ attr: name,
105
+ change: bReq ? "required_to_optional" : "optional_to_required",
106
+ risk: bReq ? "safe" : "breaking",
107
+ reason: bReq
108
+ ? "Attribute changed from required to optional; all existing entities still satisfy the constraint."
109
+ : "Attribute changed from optional to required; existing entities without this field will fail validation.",
110
+ });
111
+ }
112
+ }
113
+ return changes;
114
+ }
115
+ function diffEntityTypes(blue, green, diff, removedNamespaces, addedNamespaces) {
116
+ const allNamespaces = new Set([...Object.keys(blue), ...Object.keys(green)]);
117
+ for (const ns of allNamespaces) {
118
+ const bEnts = blue[ns]?.entityTypes ?? {};
119
+ const gEnts = green[ns]?.entityTypes ?? {};
120
+ for (const [name, gEnt] of Object.entries(gEnts)) {
121
+ if (!(name in bEnts)) {
122
+ diff.entity_types.added.push({ namespace: ns, name });
123
+ }
124
+ else {
125
+ const bEnt = bEnts[name];
126
+ const mod = { namespace: ns, name };
127
+ const bMember = bEnt.memberOfTypes ?? [];
128
+ const gMember = gEnt.memberOfTypes ?? [];
129
+ const memberD = setDiff(bMember, gMember);
130
+ if (memberD.added.length > 0 || memberD.removed.length > 0) {
131
+ const breaking = memberD.removed.length > 0;
132
+ mod.member_of_changes = {
133
+ added: memberD.added,
134
+ removed: memberD.removed,
135
+ risk: breaking ? "breaking" : "review",
136
+ reason: breaking
137
+ ? "Parent types removed: policies using `in` against removed parents will fail validation."
138
+ : "Parent types added: hierarchy widened; policies using `in` may match more entities than before.",
139
+ };
140
+ }
141
+ const attrChanges = diffAttributes(bEnt.shape?.attributes, gEnt.shape?.attributes, "attribute");
142
+ if (attrChanges.length > 0)
143
+ mod.attribute_changes = attrChanges;
144
+ if (mod.member_of_changes || mod.attribute_changes) {
145
+ diff.entity_types.modified.push(mod);
146
+ }
147
+ }
148
+ }
149
+ for (const [name, bEnt] of Object.entries(bEnts)) {
150
+ if (!(name in gEnts)) {
151
+ diff.entity_types.removed.push({
152
+ namespace: ns,
153
+ name,
154
+ risk: "breaking",
155
+ reason: removedNamespaces.has(ns)
156
+ ? `Namespace ${ns} removed; entity type removed transitively. Policies referencing it will fail.`
157
+ : "Entity type removed: policies referencing it will fail validation; runtime requests for it will fail.",
158
+ });
159
+ void bEnt;
160
+ }
161
+ }
162
+ void addedNamespaces;
163
+ }
164
+ }
165
+ function diffActions(blue, green, diff) {
166
+ const allNamespaces = new Set([...Object.keys(blue), ...Object.keys(green)]);
167
+ for (const ns of allNamespaces) {
168
+ const bActs = blue[ns]?.actions ?? {};
169
+ const gActs = green[ns]?.actions ?? {};
170
+ for (const [name, gAct] of Object.entries(gActs)) {
171
+ if (!(name in bActs)) {
172
+ diff.actions.added.push({ namespace: ns, name });
173
+ }
174
+ else {
175
+ const bAct = bActs[name];
176
+ const mod = { namespace: ns, name };
177
+ const bPrin = bAct.appliesTo?.principalTypes ?? [];
178
+ const gPrin = gAct.appliesTo?.principalTypes ?? [];
179
+ const prinD = setDiff(bPrin, gPrin);
180
+ if (prinD.added.length > 0 || prinD.removed.length > 0) {
181
+ const breaking = prinD.removed.length > 0;
182
+ mod.principal_types = {
183
+ added: prinD.added,
184
+ removed: prinD.removed,
185
+ risk: breaking ? "breaking" : "review",
186
+ reason: breaking
187
+ ? "Principal types narrowed: existing policies for the removed type will fail validation."
188
+ : "Principal types widened: action applies to more principal types; policy effect may change.",
189
+ };
190
+ }
191
+ const bRes = bAct.appliesTo?.resourceTypes ?? [];
192
+ const gRes = gAct.appliesTo?.resourceTypes ?? [];
193
+ const resD = setDiff(bRes, gRes);
194
+ if (resD.added.length > 0 || resD.removed.length > 0) {
195
+ const breaking = resD.removed.length > 0;
196
+ mod.resource_types = {
197
+ added: resD.added,
198
+ removed: resD.removed,
199
+ risk: breaking ? "breaking" : "review",
200
+ reason: breaking
201
+ ? "Resource types narrowed: existing policies for the removed type will fail validation."
202
+ : "Resource types widened: action applies to more resource types; policy effect may change.",
203
+ };
204
+ }
205
+ const ctxChanges = diffAttributes(bAct.appliesTo?.context?.attributes, gAct.appliesTo?.context?.attributes, "context attribute");
206
+ if (ctxChanges.length > 0) {
207
+ mod.context_changes = ctxChanges.map((c) => ({
208
+ attr: c.attr,
209
+ change: c.change,
210
+ ...(c.old_type !== undefined ? { old_type: c.old_type } : {}),
211
+ ...(c.new_type !== undefined ? { new_type: c.new_type } : {}),
212
+ risk: c.risk,
213
+ reason: c.reason,
214
+ }));
215
+ }
216
+ if (mod.principal_types || mod.resource_types || mod.context_changes) {
217
+ diff.actions.modified.push(mod);
218
+ }
219
+ }
220
+ }
221
+ for (const name of Object.keys(bActs)) {
222
+ if (!(name in gActs)) {
223
+ diff.actions.removed.push({
224
+ namespace: ns,
225
+ name,
226
+ risk: "breaking",
227
+ reason: "Action removed: policies referencing it become invalid; runtime requests for it will fail.",
228
+ });
229
+ }
230
+ }
231
+ }
232
+ }
233
+ function diffCommonTypes(blue, green, diff) {
234
+ const allNamespaces = new Set([...Object.keys(blue), ...Object.keys(green)]);
235
+ for (const ns of allNamespaces) {
236
+ const bCt = blue[ns]?.commonTypes ?? {};
237
+ const gCt = green[ns]?.commonTypes ?? {};
238
+ for (const name of Object.keys(gCt)) {
239
+ if (!(name in bCt))
240
+ diff.common_types.added.push({ namespace: ns, name });
241
+ }
242
+ for (const name of Object.keys(bCt)) {
243
+ if (!(name in gCt)) {
244
+ diff.common_types.removed.push({
245
+ namespace: ns,
246
+ name,
247
+ risk: "review",
248
+ reason: "Common type removed: any entity or action referencing it will cause policies to fail validation.",
249
+ });
250
+ }
251
+ else if (JSON.stringify(bCt[name]) !== JSON.stringify(gCt[name])) {
252
+ diff.common_types.modified.push({
253
+ namespace: ns,
254
+ name,
255
+ risk: "review",
256
+ reason: "Common type definition changed: review every entity/action that references it.",
257
+ });
258
+ }
259
+ }
260
+ }
261
+ }
262
+ function computeRiskLevel(diff) {
263
+ const allRisks = [];
264
+ diff.entity_types.removed.forEach((e) => allRisks.push(e.risk));
265
+ diff.entity_types.modified.forEach((m) => {
266
+ if (m.member_of_changes)
267
+ allRisks.push(m.member_of_changes.risk);
268
+ m.attribute_changes?.forEach((c) => allRisks.push(c.risk));
269
+ });
270
+ diff.actions.removed.forEach((a) => allRisks.push(a.risk));
271
+ diff.actions.modified.forEach((m) => {
272
+ if (m.principal_types)
273
+ allRisks.push(m.principal_types.risk);
274
+ if (m.resource_types)
275
+ allRisks.push(m.resource_types.risk);
276
+ m.context_changes?.forEach((c) => allRisks.push(c.risk));
277
+ });
278
+ diff.common_types.removed.forEach((c) => allRisks.push(c.risk));
279
+ diff.common_types.modified.forEach((c) => allRisks.push(c.risk));
280
+ if (allRisks.includes("breaking"))
281
+ return "breaking";
282
+ if (allRisks.includes("review"))
283
+ return "review";
284
+ return "safe";
285
+ }
286
+ function computeSummary(diff) {
287
+ const parts = [];
288
+ const breakingCount = diff.entity_types.removed.length +
289
+ diff.actions.removed.length +
290
+ diff.entity_types.modified.reduce((acc, m) => {
291
+ const memberBreaking = m.member_of_changes?.risk === "breaking" ? 1 : 0;
292
+ const attrsBreaking = (m.attribute_changes ?? []).filter((c) => c.risk === "breaking").length;
293
+ return acc + memberBreaking + attrsBreaking;
294
+ }, 0) +
295
+ diff.actions.modified.reduce((acc, m) => {
296
+ const pBreak = m.principal_types?.risk === "breaking" ? 1 : 0;
297
+ const rBreak = m.resource_types?.risk === "breaking" ? 1 : 0;
298
+ const cBreak = (m.context_changes ?? []).filter((c) => c.risk === "breaking").length;
299
+ return acc + pBreak + rBreak + cBreak;
300
+ }, 0);
301
+ if (diff.namespaces_added.length)
302
+ parts.push(`${diff.namespaces_added.length} namespace(s) added`);
303
+ if (diff.namespaces_removed.length)
304
+ parts.push(`${diff.namespaces_removed.length} namespace(s) removed`);
305
+ if (diff.entity_types.added.length)
306
+ parts.push(`${diff.entity_types.added.length} entity type(s) added`);
307
+ if (diff.entity_types.removed.length)
308
+ parts.push(`${diff.entity_types.removed.length} entity type(s) removed`);
309
+ if (diff.entity_types.modified.length)
310
+ parts.push(`${diff.entity_types.modified.length} entity type(s) modified`);
311
+ if (diff.actions.added.length)
312
+ parts.push(`${diff.actions.added.length} action(s) added`);
313
+ if (diff.actions.removed.length)
314
+ parts.push(`${diff.actions.removed.length} action(s) removed`);
315
+ if (diff.actions.modified.length)
316
+ parts.push(`${diff.actions.modified.length} action(s) modified`);
317
+ if (diff.common_types.added.length)
318
+ parts.push(`${diff.common_types.added.length} common type(s) added`);
319
+ if (diff.common_types.removed.length)
320
+ parts.push(`${diff.common_types.removed.length} common type(s) removed`);
321
+ if (diff.common_types.modified.length)
322
+ parts.push(`${diff.common_types.modified.length} common type(s) modified`);
323
+ if (parts.length === 0)
324
+ return "No schema changes detected.";
325
+ const breaking = breakingCount > 0 ? ` (${breakingCount} BREAKING)` : "";
326
+ return `Schema diff: ${parts.join(", ")}${breaking}.`;
327
+ }
328
+ export async function handleDiffSchema(input) {
329
+ let blueJson;
330
+ let greenJson;
331
+ try {
332
+ blueJson = normalizeToCanonical(input.blue);
333
+ }
334
+ catch (e) {
335
+ return errorResult(`blue schema: ${e instanceof Error ? e.message : String(e)}`);
336
+ }
337
+ try {
338
+ greenJson = normalizeToCanonical(input.green);
339
+ }
340
+ catch (e) {
341
+ return errorResult(`green schema: ${e instanceof Error ? e.message : String(e)}`);
342
+ }
343
+ const diff = {
344
+ namespaces_added: [],
345
+ namespaces_removed: [],
346
+ entity_types: { added: [], removed: [], modified: [] },
347
+ actions: { added: [], removed: [], modified: [] },
348
+ common_types: { added: [], removed: [], modified: [] },
349
+ summary: "",
350
+ risk_level: "safe",
351
+ };
352
+ const blueNs = new Set(Object.keys(blueJson));
353
+ const greenNs = new Set(Object.keys(greenJson));
354
+ for (const ns of greenNs)
355
+ if (!blueNs.has(ns))
356
+ diff.namespaces_added.push(ns);
357
+ for (const ns of blueNs)
358
+ if (!greenNs.has(ns))
359
+ diff.namespaces_removed.push(ns);
360
+ diffEntityTypes(blueJson, greenJson, diff, new Set(diff.namespaces_removed), new Set(diff.namespaces_added));
361
+ diffActions(blueJson, greenJson, diff);
362
+ diffCommonTypes(blueJson, greenJson, diff);
363
+ diff.summary = computeSummary(diff);
364
+ diff.risk_level = computeRiskLevel(diff);
365
+ return diff;
366
+ }
367
+ function errorResult(error) {
368
+ return {
369
+ namespaces_added: [],
370
+ namespaces_removed: [],
371
+ entity_types: { added: [], removed: [], modified: [] },
372
+ actions: { added: [], removed: [], modified: [] },
373
+ common_types: { added: [], removed: [], modified: [] },
374
+ summary: "",
375
+ risk_level: "safe",
376
+ error,
377
+ };
378
+ }
379
+ //# sourceMappingURL=diff-schema.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"diff-schema.js","sourceRoot":"","sources":["../../src/tools/diff-schema.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,45 @@
1
+ import type { StoreManager } from "../resources/store-manager.js";
2
+ import { type SchemaDiff } from "./diff-schema.js";
3
+ export interface DiffStoresInput {
4
+ blue: string;
5
+ green: string;
6
+ behavioral_test_requests?: string;
7
+ }
8
+ export interface PolicyChangeInfo {
9
+ policy_id: string;
10
+ can_update_in_place: boolean;
11
+ changes: Array<{
12
+ field: string;
13
+ in_place_allowed: boolean;
14
+ reason: string;
15
+ }>;
16
+ recommendation: string;
17
+ }
18
+ export interface BehavioralDriftEntry {
19
+ principal: string;
20
+ action: string;
21
+ resource: string;
22
+ blue_decision: "Allow" | "Deny" | "Error";
23
+ green_decision: "Allow" | "Deny" | "Error";
24
+ drifted: boolean;
25
+ error?: string;
26
+ }
27
+ export interface DiffStoresResult {
28
+ blue: string;
29
+ green: string;
30
+ policies_added: Array<{
31
+ policy_id: string;
32
+ content: string;
33
+ }>;
34
+ policies_removed: Array<{
35
+ policy_id: string;
36
+ content: string;
37
+ }>;
38
+ policies_modified: PolicyChangeInfo[];
39
+ schema_diff: SchemaDiff;
40
+ behavioral_diff?: BehavioralDriftEntry[];
41
+ summary: string;
42
+ error?: string;
43
+ }
44
+ export declare function handleDiffStores(input: DiffStoresInput, manager: StoreManager): Promise<DiffStoresResult>;
45
+ //# sourceMappingURL=diff-stores.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"diff-stores.d.ts","sourceRoot":"","sources":["../../src/tools/diff-stores.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAElE,OAAO,EAAoB,KAAK,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAIrE,MAAM,WAAW,eAAe;IAC9B,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,wBAAwB,CAAC,EAAE,MAAM,CAAC;CACnC;AAED,MAAM,WAAW,gBAAgB;IAC/B,SAAS,EAAE,MAAM,CAAC;IAClB,mBAAmB,EAAE,OAAO,CAAC;IAC7B,OAAO,EAAE,KAAK,CAAC;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,gBAAgB,EAAE,OAAO,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAC7E,cAAc,EAAE,MAAM,CAAC;CACxB;AAED,MAAM,WAAW,oBAAoB;IACnC,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;IACjB,aAAa,EAAE,OAAO,GAAG,MAAM,GAAG,OAAO,CAAC;IAC1C,cAAc,EAAE,OAAO,GAAG,MAAM,GAAG,OAAO,CAAC;IAC3C,OAAO,EAAE,OAAO,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,cAAc,EAAE,KAAK,CAAC;QAAE,SAAS,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAC9D,gBAAgB,EAAE,KAAK,CAAC;QAAE,SAAS,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAChE,iBAAiB,EAAE,gBAAgB,EAAE,CAAC;IACtC,WAAW,EAAE,UAAU,CAAC;IACxB,eAAe,CAAC,EAAE,oBAAoB,EAAE,CAAC;IACzC,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,wBAAsB,gBAAgB,CACpC,KAAK,EAAE,eAAe,EACtB,OAAO,EAAE,YAAY,GACpB,OAAO,CAAC,gBAAgB,CAAC,CAiI3B"}