guardlink 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 (172) hide show
  1. package/CHANGELOG.md +30 -0
  2. package/LICENSE +21 -0
  3. package/README.md +344 -0
  4. package/dist/agents/config.d.ts +46 -0
  5. package/dist/agents/config.d.ts.map +1 -0
  6. package/dist/agents/config.js +189 -0
  7. package/dist/agents/config.js.map +1 -0
  8. package/dist/agents/index.d.ts +24 -0
  9. package/dist/agents/index.d.ts.map +1 -0
  10. package/dist/agents/index.js +42 -0
  11. package/dist/agents/index.js.map +1 -0
  12. package/dist/agents/launcher.d.ts +54 -0
  13. package/dist/agents/launcher.d.ts.map +1 -0
  14. package/dist/agents/launcher.js +152 -0
  15. package/dist/agents/launcher.js.map +1 -0
  16. package/dist/agents/prompts.d.ts +14 -0
  17. package/dist/agents/prompts.d.ts.map +1 -0
  18. package/dist/agents/prompts.js +120 -0
  19. package/dist/agents/prompts.js.map +1 -0
  20. package/dist/analyze/index.d.ts +80 -0
  21. package/dist/analyze/index.d.ts.map +1 -0
  22. package/dist/analyze/index.js +306 -0
  23. package/dist/analyze/index.js.map +1 -0
  24. package/dist/analyze/llm.d.ts +52 -0
  25. package/dist/analyze/llm.d.ts.map +1 -0
  26. package/dist/analyze/llm.js +295 -0
  27. package/dist/analyze/llm.js.map +1 -0
  28. package/dist/analyze/prompts.d.ts +14 -0
  29. package/dist/analyze/prompts.d.ts.map +1 -0
  30. package/dist/analyze/prompts.js +205 -0
  31. package/dist/analyze/prompts.js.map +1 -0
  32. package/dist/analyzer/index.d.ts +5 -0
  33. package/dist/analyzer/index.d.ts.map +1 -0
  34. package/dist/analyzer/index.js +5 -0
  35. package/dist/analyzer/index.js.map +1 -0
  36. package/dist/analyzer/sarif.d.ts +84 -0
  37. package/dist/analyzer/sarif.d.ts.map +1 -0
  38. package/dist/analyzer/sarif.js +149 -0
  39. package/dist/analyzer/sarif.js.map +1 -0
  40. package/dist/cli/index.d.ts +25 -0
  41. package/dist/cli/index.d.ts.map +1 -0
  42. package/dist/cli/index.js +821 -0
  43. package/dist/cli/index.js.map +1 -0
  44. package/dist/dashboard/data.d.ts +52 -0
  45. package/dist/dashboard/data.d.ts.map +1 -0
  46. package/dist/dashboard/data.js +93 -0
  47. package/dist/dashboard/data.js.map +1 -0
  48. package/dist/dashboard/diagrams.d.ts +25 -0
  49. package/dist/dashboard/diagrams.d.ts.map +1 -0
  50. package/dist/dashboard/diagrams.js +243 -0
  51. package/dist/dashboard/diagrams.js.map +1 -0
  52. package/dist/dashboard/generate.d.ts +17 -0
  53. package/dist/dashboard/generate.d.ts.map +1 -0
  54. package/dist/dashboard/generate.js +1258 -0
  55. package/dist/dashboard/generate.js.map +1 -0
  56. package/dist/dashboard/index.d.ts +7 -0
  57. package/dist/dashboard/index.d.ts.map +1 -0
  58. package/dist/dashboard/index.js +7 -0
  59. package/dist/dashboard/index.js.map +1 -0
  60. package/dist/diff/engine.d.ts +51 -0
  61. package/dist/diff/engine.d.ts.map +1 -0
  62. package/dist/diff/engine.js +153 -0
  63. package/dist/diff/engine.js.map +1 -0
  64. package/dist/diff/format.d.ts +10 -0
  65. package/dist/diff/format.d.ts.map +1 -0
  66. package/dist/diff/format.js +111 -0
  67. package/dist/diff/format.js.map +1 -0
  68. package/dist/diff/git.d.ts +24 -0
  69. package/dist/diff/git.d.ts.map +1 -0
  70. package/dist/diff/git.js +85 -0
  71. package/dist/diff/git.js.map +1 -0
  72. package/dist/diff/index.d.ts +7 -0
  73. package/dist/diff/index.d.ts.map +1 -0
  74. package/dist/diff/index.js +7 -0
  75. package/dist/diff/index.js.map +1 -0
  76. package/dist/index.d.ts +20 -0
  77. package/dist/index.d.ts.map +1 -0
  78. package/dist/index.js +17 -0
  79. package/dist/index.js.map +1 -0
  80. package/dist/init/detect.d.ts +42 -0
  81. package/dist/init/detect.d.ts.map +1 -0
  82. package/dist/init/detect.js +185 -0
  83. package/dist/init/detect.js.map +1 -0
  84. package/dist/init/index.d.ts +39 -0
  85. package/dist/init/index.d.ts.map +1 -0
  86. package/dist/init/index.js +228 -0
  87. package/dist/init/index.js.map +1 -0
  88. package/dist/init/picker.d.ts +32 -0
  89. package/dist/init/picker.d.ts.map +1 -0
  90. package/dist/init/picker.js +105 -0
  91. package/dist/init/picker.js.map +1 -0
  92. package/dist/init/templates.d.ts +25 -0
  93. package/dist/init/templates.d.ts.map +1 -0
  94. package/dist/init/templates.js +263 -0
  95. package/dist/init/templates.js.map +1 -0
  96. package/dist/mcp/index.d.ts +12 -0
  97. package/dist/mcp/index.d.ts.map +1 -0
  98. package/dist/mcp/index.js +18 -0
  99. package/dist/mcp/index.js.map +1 -0
  100. package/dist/mcp/lookup.d.ts +27 -0
  101. package/dist/mcp/lookup.d.ts.map +1 -0
  102. package/dist/mcp/lookup.js +282 -0
  103. package/dist/mcp/lookup.js.map +1 -0
  104. package/dist/mcp/server.d.ts +41 -0
  105. package/dist/mcp/server.d.ts.map +1 -0
  106. package/dist/mcp/server.js +388 -0
  107. package/dist/mcp/server.js.map +1 -0
  108. package/dist/mcp/suggest.d.ts +35 -0
  109. package/dist/mcp/suggest.d.ts.map +1 -0
  110. package/dist/mcp/suggest.js +268 -0
  111. package/dist/mcp/suggest.js.map +1 -0
  112. package/dist/parser/comment-strip.d.ts +15 -0
  113. package/dist/parser/comment-strip.d.ts.map +1 -0
  114. package/dist/parser/comment-strip.js +76 -0
  115. package/dist/parser/comment-strip.js.map +1 -0
  116. package/dist/parser/index.d.ts +10 -0
  117. package/dist/parser/index.d.ts.map +1 -0
  118. package/dist/parser/index.js +9 -0
  119. package/dist/parser/index.js.map +1 -0
  120. package/dist/parser/normalize.d.ts +22 -0
  121. package/dist/parser/normalize.d.ts.map +1 -0
  122. package/dist/parser/normalize.js +42 -0
  123. package/dist/parser/normalize.js.map +1 -0
  124. package/dist/parser/parse-file.d.ts +18 -0
  125. package/dist/parser/parse-file.d.ts.map +1 -0
  126. package/dist/parser/parse-file.js +68 -0
  127. package/dist/parser/parse-file.js.map +1 -0
  128. package/dist/parser/parse-line.d.ts +21 -0
  129. package/dist/parser/parse-line.d.ts.map +1 -0
  130. package/dist/parser/parse-line.js +230 -0
  131. package/dist/parser/parse-line.js.map +1 -0
  132. package/dist/parser/parse-project.d.ts +31 -0
  133. package/dist/parser/parse-project.d.ts.map +1 -0
  134. package/dist/parser/parse-project.js +281 -0
  135. package/dist/parser/parse-project.js.map +1 -0
  136. package/dist/report/index.d.ts +6 -0
  137. package/dist/report/index.d.ts.map +1 -0
  138. package/dist/report/index.js +6 -0
  139. package/dist/report/index.js.map +1 -0
  140. package/dist/report/mermaid.d.ts +15 -0
  141. package/dist/report/mermaid.d.ts.map +1 -0
  142. package/dist/report/mermaid.js +260 -0
  143. package/dist/report/mermaid.js.map +1 -0
  144. package/dist/report/report.d.ts +16 -0
  145. package/dist/report/report.d.ts.map +1 -0
  146. package/dist/report/report.js +211 -0
  147. package/dist/report/report.js.map +1 -0
  148. package/dist/tui/commands.d.ts +42 -0
  149. package/dist/tui/commands.d.ts.map +1 -0
  150. package/dist/tui/commands.js +1216 -0
  151. package/dist/tui/commands.js.map +1 -0
  152. package/dist/tui/config.d.ts +27 -0
  153. package/dist/tui/config.d.ts.map +1 -0
  154. package/dist/tui/config.js +27 -0
  155. package/dist/tui/config.js.map +1 -0
  156. package/dist/tui/format.d.ts +63 -0
  157. package/dist/tui/format.d.ts.map +1 -0
  158. package/dist/tui/format.js +253 -0
  159. package/dist/tui/format.js.map +1 -0
  160. package/dist/tui/index.d.ts +18 -0
  161. package/dist/tui/index.d.ts.map +1 -0
  162. package/dist/tui/index.js +470 -0
  163. package/dist/tui/index.js.map +1 -0
  164. package/dist/tui/input.d.ts +63 -0
  165. package/dist/tui/input.d.ts.map +1 -0
  166. package/dist/tui/input.js +454 -0
  167. package/dist/tui/input.js.map +1 -0
  168. package/dist/types/index.d.ts +254 -0
  169. package/dist/types/index.d.ts.map +1 -0
  170. package/dist/types/index.js +6 -0
  171. package/dist/types/index.js.map +1 -0
  172. package/package.json +97 -0
@@ -0,0 +1,254 @@
1
+ /**
2
+ * GuardLink — Core type definitions
3
+ * Mirrors the canonical schema from §5 of the specification.
4
+ */
5
+ export type Severity = 'critical' | 'high' | 'medium' | 'low';
6
+ export type SeverityAlias = 'P0' | 'P1' | 'P2' | 'P3';
7
+ export type DataClassification = 'pii' | 'phi' | 'financial' | 'secrets' | 'internal' | 'public';
8
+ export type AnnotationVerb = 'asset' | 'threat' | 'control' | 'mitigates' | 'exposes' | 'accepts' | 'transfers' | 'flows' | 'boundary' | 'validates' | 'audit' | 'owns' | 'handles' | 'assumes' | 'comment' | 'shield' | 'shield:begin' | 'shield:end';
9
+ export interface SourceLocation {
10
+ file: string;
11
+ line: number;
12
+ end_line?: number | null;
13
+ parent_symbol?: string | null;
14
+ }
15
+ export interface BaseAnnotation {
16
+ verb: AnnotationVerb;
17
+ location: SourceLocation;
18
+ description?: string;
19
+ raw: string;
20
+ }
21
+ export interface AssetAnnotation extends BaseAnnotation {
22
+ verb: 'asset';
23
+ path: string;
24
+ id?: string;
25
+ }
26
+ export interface ThreatAnnotation extends BaseAnnotation {
27
+ verb: 'threat';
28
+ name: string;
29
+ canonical_name: string;
30
+ id?: string;
31
+ severity?: Severity;
32
+ external_refs: string[];
33
+ }
34
+ export interface ControlAnnotation extends BaseAnnotation {
35
+ verb: 'control';
36
+ name: string;
37
+ canonical_name: string;
38
+ id?: string;
39
+ }
40
+ export interface MitigatesAnnotation extends BaseAnnotation {
41
+ verb: 'mitigates';
42
+ asset: string;
43
+ threat: string;
44
+ control?: string;
45
+ }
46
+ export interface ExposesAnnotation extends BaseAnnotation {
47
+ verb: 'exposes';
48
+ asset: string;
49
+ threat: string;
50
+ severity?: Severity;
51
+ external_refs: string[];
52
+ }
53
+ export interface AcceptsAnnotation extends BaseAnnotation {
54
+ verb: 'accepts';
55
+ threat: string;
56
+ asset: string;
57
+ }
58
+ export interface TransfersAnnotation extends BaseAnnotation {
59
+ verb: 'transfers';
60
+ threat: string;
61
+ source: string;
62
+ target: string;
63
+ }
64
+ export interface FlowsAnnotation extends BaseAnnotation {
65
+ verb: 'flows';
66
+ source: string;
67
+ target: string;
68
+ mechanism?: string;
69
+ }
70
+ export interface BoundaryAnnotation extends BaseAnnotation {
71
+ verb: 'boundary';
72
+ asset_a: string;
73
+ asset_b: string;
74
+ id?: string;
75
+ }
76
+ export interface ValidatesAnnotation extends BaseAnnotation {
77
+ verb: 'validates';
78
+ control: string;
79
+ asset: string;
80
+ }
81
+ export interface AuditAnnotation extends BaseAnnotation {
82
+ verb: 'audit';
83
+ asset: string;
84
+ }
85
+ export interface OwnsAnnotation extends BaseAnnotation {
86
+ verb: 'owns';
87
+ owner: string;
88
+ asset: string;
89
+ }
90
+ export interface HandlesAnnotation extends BaseAnnotation {
91
+ verb: 'handles';
92
+ classification: DataClassification;
93
+ asset: string;
94
+ }
95
+ export interface AssumesAnnotation extends BaseAnnotation {
96
+ verb: 'assumes';
97
+ asset: string;
98
+ }
99
+ export interface ShieldAnnotation extends BaseAnnotation {
100
+ verb: 'shield' | 'shield:begin' | 'shield:end';
101
+ }
102
+ export interface CommentAnnotation extends BaseAnnotation {
103
+ verb: 'comment';
104
+ }
105
+ export type Annotation = AssetAnnotation | ThreatAnnotation | ControlAnnotation | MitigatesAnnotation | ExposesAnnotation | AcceptsAnnotation | TransfersAnnotation | FlowsAnnotation | BoundaryAnnotation | ValidatesAnnotation | AuditAnnotation | OwnsAnnotation | HandlesAnnotation | AssumesAnnotation | CommentAnnotation | ShieldAnnotation;
106
+ export interface ThreatModel {
107
+ version: '1.0.0';
108
+ project: string;
109
+ generated_at: string;
110
+ source_files: number;
111
+ annotations_parsed: number;
112
+ assets: ThreatModelAsset[];
113
+ threats: ThreatModelThreat[];
114
+ controls: ThreatModelControl[];
115
+ mitigations: ThreatModelMitigation[];
116
+ exposures: ThreatModelExposure[];
117
+ acceptances: ThreatModelAcceptance[];
118
+ transfers: ThreatModelTransfer[];
119
+ flows: ThreatModelFlow[];
120
+ boundaries: ThreatModelBoundary[];
121
+ validations: ThreatModelValidation[];
122
+ audits: ThreatModelAudit[];
123
+ ownership: ThreatModelOwnership[];
124
+ data_handling: ThreatModelDataHandling[];
125
+ assumptions: ThreatModelAssumption[];
126
+ shields: ThreatModelShield[];
127
+ comments: ThreatModelComment[];
128
+ coverage: CoverageStats;
129
+ }
130
+ export interface ThreatModelAsset {
131
+ path: string[];
132
+ id?: string;
133
+ description?: string;
134
+ location: SourceLocation;
135
+ }
136
+ export interface ThreatModelThreat {
137
+ name: string;
138
+ canonical_name: string;
139
+ id?: string;
140
+ severity?: Severity;
141
+ external_refs: string[];
142
+ description?: string;
143
+ location: SourceLocation;
144
+ }
145
+ export interface ThreatModelControl {
146
+ name: string;
147
+ canonical_name: string;
148
+ id?: string;
149
+ description?: string;
150
+ location: SourceLocation;
151
+ }
152
+ export interface ThreatModelMitigation {
153
+ asset: string;
154
+ threat: string;
155
+ control?: string;
156
+ description?: string;
157
+ location: SourceLocation;
158
+ }
159
+ export interface ThreatModelExposure {
160
+ asset: string;
161
+ threat: string;
162
+ severity?: Severity;
163
+ external_refs: string[];
164
+ description?: string;
165
+ location: SourceLocation;
166
+ }
167
+ export interface ThreatModelAcceptance {
168
+ threat: string;
169
+ asset: string;
170
+ description?: string;
171
+ location: SourceLocation;
172
+ }
173
+ export interface ThreatModelTransfer {
174
+ threat: string;
175
+ source: string;
176
+ target: string;
177
+ description?: string;
178
+ location: SourceLocation;
179
+ }
180
+ export interface ThreatModelFlow {
181
+ source: string;
182
+ target: string;
183
+ mechanism?: string;
184
+ description?: string;
185
+ location: SourceLocation;
186
+ }
187
+ export interface ThreatModelBoundary {
188
+ asset_a: string;
189
+ asset_b: string;
190
+ id?: string;
191
+ description?: string;
192
+ location: SourceLocation;
193
+ }
194
+ export interface ThreatModelValidation {
195
+ control: string;
196
+ asset: string;
197
+ description?: string;
198
+ location: SourceLocation;
199
+ }
200
+ export interface ThreatModelAudit {
201
+ asset: string;
202
+ description?: string;
203
+ location: SourceLocation;
204
+ }
205
+ export interface ThreatModelOwnership {
206
+ owner: string;
207
+ asset: string;
208
+ description?: string;
209
+ location: SourceLocation;
210
+ }
211
+ export interface ThreatModelDataHandling {
212
+ classification: DataClassification;
213
+ asset: string;
214
+ description?: string;
215
+ location: SourceLocation;
216
+ }
217
+ export interface ThreatModelAssumption {
218
+ asset: string;
219
+ description?: string;
220
+ location: SourceLocation;
221
+ }
222
+ export interface ThreatModelShield {
223
+ reason?: string;
224
+ location: SourceLocation;
225
+ }
226
+ export interface ThreatModelComment {
227
+ description?: string;
228
+ location: SourceLocation;
229
+ }
230
+ export interface CoverageStats {
231
+ total_symbols: number;
232
+ annotated_symbols: number;
233
+ coverage_percent: number;
234
+ unannotated_critical: UnannotatedSymbol[];
235
+ }
236
+ export interface UnannotatedSymbol {
237
+ file: string;
238
+ line: number;
239
+ kind: string;
240
+ name: string;
241
+ }
242
+ export interface ParseDiagnostic {
243
+ level: 'error' | 'warning';
244
+ message: string;
245
+ file: string;
246
+ line: number;
247
+ raw?: string;
248
+ }
249
+ export interface ParseResult {
250
+ annotations: Annotation[];
251
+ diagnostics: ParseDiagnostic[];
252
+ files_parsed: number;
253
+ }
254
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ /**
2
+ * GuardLink — Core type definitions
3
+ * Mirrors the canonical schema from §5 of the specification.
4
+ */
5
+ export {};
6
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAAA;;;GAGG"}
package/package.json ADDED
@@ -0,0 +1,97 @@
1
+ {
2
+ "name": "guardlink",
3
+ "version": "1.0.0",
4
+ "description": "GuardLink — Security annotations for code. Threat modeling that lives in your codebase.",
5
+ "type": "module",
6
+ "bin": {
7
+ "guardlink": "./dist/cli/index.js",
8
+ "guardlink-mcp": "./dist/mcp/index.js"
9
+ },
10
+ "main": "./dist/index.js",
11
+ "types": "./dist/index.d.ts",
12
+ "files": [
13
+ "dist",
14
+ "LICENSE",
15
+ "README.md",
16
+ "CHANGELOG.md"
17
+ ],
18
+ "exports": {
19
+ ".": {
20
+ "import": "./dist/index.js",
21
+ "types": "./dist/index.d.ts"
22
+ },
23
+ "./parser": {
24
+ "import": "./dist/parser/index.js",
25
+ "types": "./dist/parser/index.d.ts"
26
+ },
27
+ "./init": {
28
+ "import": "./dist/init/index.js",
29
+ "types": "./dist/init/index.d.ts"
30
+ },
31
+ "./report": {
32
+ "import": "./dist/report/index.js",
33
+ "types": "./dist/report/index.d.ts"
34
+ },
35
+ "./diff": {
36
+ "import": "./dist/diff/index.js",
37
+ "types": "./dist/diff/index.d.ts"
38
+ },
39
+ "./analyzer": {
40
+ "import": "./dist/analyzer/index.js",
41
+ "types": "./dist/analyzer/index.d.ts"
42
+ },
43
+ "./mcp": {
44
+ "import": "./dist/mcp/index.js",
45
+ "types": "./dist/mcp/index.d.ts"
46
+ }
47
+ },
48
+ "scripts": {
49
+ "build": "tsc",
50
+ "dev": "tsc --watch",
51
+ "test": "vitest run",
52
+ "test:watch": "vitest",
53
+ "lint": "eslint src/",
54
+ "cli": "tsx src/cli/index.ts",
55
+ "prepublishOnly": "npm run build"
56
+ },
57
+ "keywords": [
58
+ "guardlink",
59
+ "security",
60
+ "threat-modeling",
61
+ "annotations",
62
+ "sast",
63
+ "sarif",
64
+ "devsecops",
65
+ "mcp",
66
+ "appsec",
67
+ "code-annotations",
68
+ "threat-model"
69
+ ],
70
+ "author": "BugB Technologies (https://bugb.io)",
71
+ "license": "MIT",
72
+ "repository": {
73
+ "type": "git",
74
+ "url": "https://github.com/Bugb-Technologies/guardlink.git"
75
+ },
76
+ "bugs": {
77
+ "url": "https://github.com/Bugb-Technologies/guardlink/issues"
78
+ },
79
+ "homepage": "https://github.com/Bugb-Technologies/guardlink#readme",
80
+ "engines": {
81
+ "node": ">=18"
82
+ },
83
+ "devDependencies": {
84
+ "@types/gradient-string": "^1.1.6",
85
+ "@types/node": "^22.0.0",
86
+ "tsx": "^4.0.0",
87
+ "typescript": "^5.7.0",
88
+ "vitest": "^3.0.0"
89
+ },
90
+ "dependencies": {
91
+ "@modelcontextprotocol/sdk": "^1.26.0",
92
+ "chalk": "^5.4.0",
93
+ "commander": "^13.0.0",
94
+ "fast-glob": "^3.3.0",
95
+ "gradient-string": "^3.0.0"
96
+ }
97
+ }