@likec4/language-server 1.43.0 → 1.45.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 (301) hide show
  1. package/browser/package.json +1 -1
  2. package/browser-worker/package.json +1 -1
  3. package/dist/LikeC4LanguageServices.d.ts +13 -34
  4. package/dist/LikeC4LanguageServices.js +152 -0
  5. package/dist/Rpc.js +257 -0
  6. package/dist/ast.d.ts +5 -1
  7. package/dist/ast.js +257 -0
  8. package/dist/browser-worker.js +4 -0
  9. package/dist/browser.js +35 -0
  10. package/dist/bundled.js +44 -0
  11. package/dist/bundled.mjs +3568 -3900
  12. package/dist/documentation/documentation-provider.js +51 -0
  13. package/dist/documentation/index.js +1 -0
  14. package/dist/empty.js +2 -0
  15. package/dist/filesystem/ChokidarWatcher.d.ts +2 -0
  16. package/dist/filesystem/ChokidarWatcher.js +108 -0
  17. package/dist/filesystem/FileSystemWatcher.js +14 -0
  18. package/dist/filesystem/LikeC4FileSystem.d.ts +1 -2
  19. package/dist/filesystem/LikeC4FileSystem.js +126 -0
  20. package/dist/filesystem/index.d.ts +26 -0
  21. package/dist/filesystem/index.js +29 -0
  22. package/dist/formatting/LikeC4Formatter.js +637 -0
  23. package/dist/formatting/utils.js +18 -0
  24. package/dist/generated/ast.js +2155 -0
  25. package/dist/generated/{grammar.mjs → grammar.js} +6 -2
  26. package/dist/generated/module.d.ts +6 -1
  27. package/dist/generated/module.js +27 -0
  28. package/dist/generated-lib/{icons.mjs → icons.js} +11 -7
  29. package/dist/index.d.ts +10 -1
  30. package/dist/index.js +55 -0
  31. package/dist/{likec4lib.mjs → likec4lib.js} +3 -3
  32. package/dist/logger.js +81 -0
  33. package/dist/lsp/CodeActionProvider.d.ts +14 -0
  34. package/dist/lsp/CodeActionProvider.js +33 -0
  35. package/dist/lsp/CodeLensProvider.js +44 -0
  36. package/dist/lsp/CompletionProvider.d.ts +3 -1
  37. package/dist/lsp/CompletionProvider.js +200 -0
  38. package/dist/lsp/DocumentHighlightProvider.js +10 -0
  39. package/dist/lsp/DocumentLinkProvider.js +58 -0
  40. package/dist/lsp/DocumentSymbolProvider.js +306 -0
  41. package/dist/lsp/HoverProvider.js +106 -0
  42. package/dist/lsp/RenameProvider.js +6 -0
  43. package/dist/lsp/SemanticTokenProvider.js +257 -0
  44. package/dist/lsp/index.d.ts +1 -0
  45. package/dist/lsp/index.js +9 -0
  46. package/dist/mcp/MCPServerFactory.js +73 -0
  47. package/dist/mcp/NoopLikeC4MCPServer.js +17 -0
  48. package/dist/mcp/interfaces.js +5 -0
  49. package/dist/mcp/server/StdioLikeC4MCPServer.js +51 -0
  50. package/dist/mcp/server/StreamableLikeC4MCPServer.js +145 -0
  51. package/dist/mcp/server/WithMCPServer.js +56 -0
  52. package/dist/mcp/tools/_common.d.ts +8 -7
  53. package/dist/mcp/tools/_common.js +49 -0
  54. package/dist/mcp/tools/find-relationships.d.ts +7 -8
  55. package/dist/mcp/tools/find-relationships.js +150 -0
  56. package/dist/mcp/tools/list-projects.d.ts +3 -3
  57. package/dist/mcp/tools/list-projects.js +62 -0
  58. package/dist/mcp/tools/open-view.d.ts +6 -7
  59. package/dist/mcp/tools/open-view.js +52 -0
  60. package/dist/mcp/tools/read-deployment.d.ts +6 -7
  61. package/dist/mcp/tools/read-deployment.js +132 -0
  62. package/dist/mcp/tools/read-element.d.ts +6 -7
  63. package/dist/mcp/tools/read-element.js +194 -0
  64. package/dist/mcp/tools/read-project-summary.d.ts +5 -6
  65. package/dist/mcp/tools/read-project-summary.js +176 -0
  66. package/dist/mcp/tools/read-view.d.ts +6 -7
  67. package/dist/mcp/tools/read-view.js +203 -0
  68. package/dist/mcp/tools/search-element.d.ts +3 -3
  69. package/dist/mcp/tools/search-element.js +177 -0
  70. package/dist/mcp/utils.d.ts +2 -2
  71. package/dist/mcp/utils.js +48 -0
  72. package/dist/model/builder/MergedExtends.js +74 -0
  73. package/dist/model/builder/MergedSpecification.js +175 -0
  74. package/dist/model/builder/buildModel.js +176 -0
  75. package/dist/model/deployments-index.js +102 -0
  76. package/dist/model/fqn-index.d.ts +1 -2
  77. package/dist/model/fqn-index.js +247 -0
  78. package/dist/model/index.js +6 -0
  79. package/dist/model/model-builder.d.ts +13 -11
  80. package/dist/model/model-builder.js +232 -0
  81. package/dist/model/model-locator.d.ts +6 -5
  82. package/dist/model/model-locator.js +240 -0
  83. package/dist/model/model-parser-where.js +81 -0
  84. package/dist/model/model-parser.d.ts +309 -304
  85. package/dist/model/model-parser.js +126 -0
  86. package/dist/model/parser/Base.d.ts +2 -2
  87. package/dist/model/parser/Base.js +367 -0
  88. package/dist/model/parser/DeploymentModelParser.d.ts +2 -2
  89. package/dist/model/parser/DeploymentModelParser.js +176 -0
  90. package/dist/model/parser/DeploymentViewParser.d.ts +3 -3
  91. package/dist/model/parser/DeploymentViewParser.js +86 -0
  92. package/dist/model/parser/FqnRefParser.d.ts +2 -2
  93. package/dist/model/parser/FqnRefParser.js +382 -0
  94. package/dist/model/parser/GlobalsParser.d.ts +6 -6
  95. package/dist/model/parser/GlobalsParser.js +84 -0
  96. package/dist/model/parser/ImportsParser.d.ts +11 -12
  97. package/dist/model/parser/ImportsParser.js +24 -0
  98. package/dist/model/parser/ModelParser.d.ts +2 -2
  99. package/dist/model/parser/ModelParser.js +165 -0
  100. package/dist/model/parser/PredicatesParser.d.ts +2 -2
  101. package/dist/model/parser/PredicatesParser.js +45 -0
  102. package/dist/model/parser/SpecificationParser.d.ts +2 -2
  103. package/dist/model/parser/SpecificationParser.js +113 -0
  104. package/dist/model/parser/ValueConverter.js +12 -0
  105. package/dist/model/parser/ViewsParser.d.ts +3 -3
  106. package/dist/model/parser/ViewsParser.js +479 -0
  107. package/dist/model-change/ModelChanges.d.ts +8 -5
  108. package/dist/model-change/ModelChanges.js +129 -0
  109. package/dist/model-change/changeElementStyle.js +134 -0
  110. package/dist/model-change/changeViewLayout.d.ts +2 -2
  111. package/dist/model-change/changeViewLayout.js +28 -0
  112. package/dist/model-change/removeManualLayoutV1.d.ts +7 -0
  113. package/dist/model-change/removeManualLayoutV1.js +27 -0
  114. package/dist/module.d.ts +10 -5
  115. package/dist/module.js +143 -0
  116. package/dist/protocol.d.ts +34 -27
  117. package/dist/protocol.js +123 -0
  118. package/dist/references/index.js +3 -0
  119. package/dist/references/name-provider.js +37 -0
  120. package/dist/references/scope-computation.js +288 -0
  121. package/dist/references/scope-provider.d.ts +3 -3
  122. package/dist/references/scope-provider.js +242 -0
  123. package/dist/shared/NodeKindProvider.js +57 -0
  124. package/dist/shared/{WorkspaceSymbolProvider.mjs → WorkspaceSymbolProvider.js} +1 -1
  125. package/dist/shared/index.js +2 -0
  126. package/dist/test/index.js +1 -0
  127. package/dist/test/testServices.d.ts +16 -16
  128. package/dist/test/testServices.js +210 -0
  129. package/dist/utils/disposable.js +26 -0
  130. package/dist/utils/elementRef.d.ts +1 -1
  131. package/dist/utils/elementRef.js +27 -0
  132. package/dist/utils/fqnRef.js +63 -0
  133. package/dist/utils/index.js +35 -0
  134. package/dist/utils/printDocs.js +1 -0
  135. package/dist/utils/projectId.js +16 -0
  136. package/dist/utils/stringHash.js +5 -0
  137. package/dist/validation/DocumentValidator.js +17 -0
  138. package/dist/validation/_shared.js +26 -0
  139. package/dist/validation/deployment-checks.js +140 -0
  140. package/dist/validation/dynamic-view.js +67 -0
  141. package/dist/validation/element-ref.js +12 -0
  142. package/dist/validation/element.js +49 -0
  143. package/dist/validation/imports.js +46 -0
  144. package/dist/validation/index.d.ts +1 -1
  145. package/dist/validation/index.js +157 -0
  146. package/dist/validation/property-checks.js +108 -0
  147. package/dist/validation/relation.js +55 -0
  148. package/dist/validation/specification.js +190 -0
  149. package/dist/validation/view-predicates/fqn-expr-with.js +43 -0
  150. package/dist/validation/view-predicates/fqn-ref-expr.js +51 -0
  151. package/dist/validation/view-predicates/incoming.js +16 -0
  152. package/dist/validation/view-predicates/index.js +6 -0
  153. package/dist/validation/view-predicates/outgoing.js +20 -0
  154. package/dist/validation/view-predicates/relation-expr.js +46 -0
  155. package/dist/validation/view-predicates/relation-with.js +16 -0
  156. package/dist/validation/view.d.ts +1 -1
  157. package/dist/validation/view.js +42 -0
  158. package/dist/view-utils/assignNavigateTo.js +27 -0
  159. package/dist/view-utils/index.d.ts +1 -0
  160. package/dist/view-utils/index.js +2 -0
  161. package/dist/view-utils/manual-layout.d.ts +6 -0
  162. package/dist/view-utils/manual-layout.js +149 -0
  163. package/dist/views/ConfigurableLayouter.js +51 -0
  164. package/dist/views/LikeC4ManualLayouts.d.ts +42 -0
  165. package/dist/views/LikeC4ManualLayouts.js +209 -0
  166. package/dist/views/{likec4-views.d.ts → LikeC4Views.d.ts} +32 -10
  167. package/dist/views/LikeC4Views.js +216 -0
  168. package/dist/views/index.d.ts +4 -1
  169. package/dist/views/index.js +11 -0
  170. package/dist/workspace/AstNodeDescriptionProvider.js +18 -0
  171. package/dist/workspace/IndexManager.js +21 -0
  172. package/dist/workspace/LangiumDocuments.d.ts +4 -3
  173. package/dist/workspace/LangiumDocuments.js +72 -0
  174. package/dist/workspace/ProjectsManager.d.ts +25 -16
  175. package/dist/workspace/ProjectsManager.js +469 -0
  176. package/dist/workspace/WorkspaceManager.d.ts +3 -2
  177. package/dist/workspace/WorkspaceManager.js +98 -0
  178. package/dist/workspace/index.js +5 -0
  179. package/likec4lib/package.json +1 -1
  180. package/package.json +30 -28
  181. package/protocol/package.json +1 -1
  182. package/dist/LikeC4LanguageServices.mjs +0 -197
  183. package/dist/Rpc.mjs +0 -296
  184. package/dist/ast.mjs +0 -221
  185. package/dist/browser-worker.mjs +0 -2
  186. package/dist/browser.mjs +0 -32
  187. package/dist/documentation/documentation-provider.mjs +0 -48
  188. package/dist/documentation/index.mjs +0 -1
  189. package/dist/empty.mjs +0 -1
  190. package/dist/filesystem/ChokidarWatcher.mjs +0 -68
  191. package/dist/filesystem/FileSystemWatcher.mjs +0 -11
  192. package/dist/filesystem/LikeC4FileSystem.mjs +0 -64
  193. package/dist/filesystem/index.mjs +0 -19
  194. package/dist/formatting/LikeC4Formatter.mjs +0 -511
  195. package/dist/formatting/utils.mjs +0 -15
  196. package/dist/generated/ast.mjs +0 -2150
  197. package/dist/generated/module.mjs +0 -23
  198. package/dist/index.mjs +0 -50
  199. package/dist/logger.mjs +0 -82
  200. package/dist/lsp/CodeLensProvider.mjs +0 -42
  201. package/dist/lsp/CompletionProvider.mjs +0 -208
  202. package/dist/lsp/DocumentHighlightProvider.mjs +0 -10
  203. package/dist/lsp/DocumentLinkProvider.mjs +0 -53
  204. package/dist/lsp/DocumentSymbolProvider.mjs +0 -287
  205. package/dist/lsp/HoverProvider.mjs +0 -104
  206. package/dist/lsp/RenameProvider.mjs +0 -6
  207. package/dist/lsp/SemanticTokenProvider.mjs +0 -276
  208. package/dist/lsp/index.mjs +0 -7
  209. package/dist/mcp/MCPServerFactory.mjs +0 -70
  210. package/dist/mcp/NoopLikeC4MCPServer.mjs +0 -17
  211. package/dist/mcp/interfaces.mjs +0 -4
  212. package/dist/mcp/server/StdioLikeC4MCPServer.mjs +0 -46
  213. package/dist/mcp/server/StreamableLikeC4MCPServer.mjs +0 -153
  214. package/dist/mcp/server/WithMCPServer.mjs +0 -58
  215. package/dist/mcp/tools/_common.mjs +0 -42
  216. package/dist/mcp/tools/find-relationships.mjs +0 -151
  217. package/dist/mcp/tools/list-projects.mjs +0 -62
  218. package/dist/mcp/tools/open-view.mjs +0 -52
  219. package/dist/mcp/tools/read-deployment.mjs +0 -130
  220. package/dist/mcp/tools/read-element.mjs +0 -198
  221. package/dist/mcp/tools/read-project-summary.mjs +0 -178
  222. package/dist/mcp/tools/read-view.mjs +0 -205
  223. package/dist/mcp/tools/search-element.mjs +0 -171
  224. package/dist/mcp/utils.mjs +0 -47
  225. package/dist/model/builder/MergedExtends.mjs +0 -76
  226. package/dist/model/builder/MergedSpecification.mjs +0 -205
  227. package/dist/model/builder/assignTagColors.d.ts +0 -7
  228. package/dist/model/builder/assignTagColors.mjs +0 -51
  229. package/dist/model/builder/buildModel.mjs +0 -226
  230. package/dist/model/deployments-index.mjs +0 -100
  231. package/dist/model/fqn-index.mjs +0 -243
  232. package/dist/model/index.mjs +0 -6
  233. package/dist/model/model-builder.mjs +0 -285
  234. package/dist/model/model-locator.mjs +0 -239
  235. package/dist/model/model-parser-where.mjs +0 -81
  236. package/dist/model/model-parser.mjs +0 -127
  237. package/dist/model/parser/Base.mjs +0 -376
  238. package/dist/model/parser/DeploymentModelParser.mjs +0 -212
  239. package/dist/model/parser/DeploymentViewParser.mjs +0 -95
  240. package/dist/model/parser/FqnRefParser.mjs +0 -398
  241. package/dist/model/parser/GlobalsParser.mjs +0 -82
  242. package/dist/model/parser/ImportsParser.mjs +0 -28
  243. package/dist/model/parser/ModelParser.mjs +0 -190
  244. package/dist/model/parser/PredicatesParser.mjs +0 -45
  245. package/dist/model/parser/SpecificationParser.mjs +0 -120
  246. package/dist/model/parser/ValueConverter.mjs +0 -12
  247. package/dist/model/parser/ViewsParser.mjs +0 -490
  248. package/dist/model-change/ModelChanges.mjs +0 -89
  249. package/dist/model-change/changeElementStyle.mjs +0 -143
  250. package/dist/model-change/changeViewLayout.mjs +0 -32
  251. package/dist/model-change/saveManualLayout.d.ts +0 -11
  252. package/dist/model-change/saveManualLayout.mjs +0 -27
  253. package/dist/module.mjs +0 -180
  254. package/dist/protocol.mjs +0 -65
  255. package/dist/references/index.mjs +0 -3
  256. package/dist/references/name-provider.mjs +0 -39
  257. package/dist/references/scope-computation.mjs +0 -312
  258. package/dist/references/scope-provider.mjs +0 -239
  259. package/dist/shared/NodeKindProvider.mjs +0 -110
  260. package/dist/shared/index.mjs +0 -2
  261. package/dist/test/index.mjs +0 -1
  262. package/dist/test/testServices.mjs +0 -200
  263. package/dist/utils/disposable.mjs +0 -25
  264. package/dist/utils/elementRef.mjs +0 -20
  265. package/dist/utils/fqnRef.mjs +0 -57
  266. package/dist/utils/index.mjs +0 -33
  267. package/dist/utils/printDocs.mjs +0 -1
  268. package/dist/utils/projectId.mjs +0 -16
  269. package/dist/utils/stringHash.mjs +0 -5
  270. package/dist/validation/DocumentValidator.mjs +0 -16
  271. package/dist/validation/_shared.mjs +0 -25
  272. package/dist/validation/deployment-checks.mjs +0 -146
  273. package/dist/validation/dynamic-view.mjs +0 -67
  274. package/dist/validation/element-ref.mjs +0 -12
  275. package/dist/validation/element.mjs +0 -50
  276. package/dist/validation/imports.mjs +0 -25
  277. package/dist/validation/index.mjs +0 -180
  278. package/dist/validation/property-checks.mjs +0 -107
  279. package/dist/validation/relation.mjs +0 -53
  280. package/dist/validation/specification.mjs +0 -173
  281. package/dist/validation/view-predicates/fqn-expr-with.mjs +0 -43
  282. package/dist/validation/view-predicates/fqn-ref-expr.mjs +0 -53
  283. package/dist/validation/view-predicates/incoming.mjs +0 -16
  284. package/dist/validation/view-predicates/index.mjs +0 -6
  285. package/dist/validation/view-predicates/outgoing.mjs +0 -20
  286. package/dist/validation/view-predicates/relation-expr.mjs +0 -39
  287. package/dist/validation/view-predicates/relation-with.mjs +0 -16
  288. package/dist/validation/view.mjs +0 -25
  289. package/dist/view-utils/assignNavigateTo.mjs +0 -25
  290. package/dist/view-utils/index.mjs +0 -1
  291. package/dist/view-utils/manual-layout.mjs +0 -99
  292. package/dist/views/configurable-layouter.mjs +0 -51
  293. package/dist/views/index.mjs +0 -1
  294. package/dist/views/likec4-views.mjs +0 -166
  295. package/dist/workspace/AstNodeDescriptionProvider.mjs +0 -17
  296. package/dist/workspace/IndexManager.mjs +0 -17
  297. package/dist/workspace/LangiumDocuments.mjs +0 -53
  298. package/dist/workspace/ProjectsManager.mjs +0 -360
  299. package/dist/workspace/WorkspaceManager.mjs +0 -83
  300. package/dist/workspace/index.mjs +0 -5
  301. /package/dist/views/{configurable-layouter.d.ts → ConfigurableLayouter.d.ts} +0 -0
@@ -0,0 +1,194 @@
1
+ import { invariant } from '@likec4/core';
2
+ import * as z from 'zod/v3';
3
+ import { likec4Tool } from '../utils';
4
+ import { includedInViews, includedInViewsSchema, locationSchema, mkLocate, projectIdSchema } from './_common';
5
+ export const readElement = likec4Tool({
6
+ name: 'read-element',
7
+ description: `
8
+ Read detailed information about a LikeC4 element.
9
+
10
+ Request:
11
+ - id: string — element id (FQN)
12
+ - project: string (optional) — project id. Defaults to "default" if omitted.
13
+
14
+ Response (JSON object):
15
+ - id: string — element id (FQN)
16
+ - name: string — element name
17
+ - kind: string — element kind
18
+ - title: string — human-readable title
19
+ - description: string|null — optional description
20
+ - technology: string|null — optional technology
21
+ - tags: string[] — assigned tags
22
+ - project: string — project id this element belongs to
23
+ - metadata: Record<string, string> — element metadata
24
+ - shape: string — rendered shape
25
+ - color: string — rendered color
26
+ - children: string[] — ids (FQNs) of direct child elements
27
+ - defaultView: string|null — default view name if set
28
+ - includedInViews: View[] — views that include this element
29
+ - relationships: object — relationships of this element (direct and indirect)
30
+ - incoming: Array<{ source: { id: string, title: string, kind: string }, kind: string|null, target: string, title: string|null, description: string|null, technology: string|null, tags: string[] }>
31
+ - outgoing: Array<{ source: string, target: { id: string, title: string, kind: string }, kind: string|null, title: string|null, description: string|null, technology: string|null, tags: string[] }>
32
+ - deployedInstances: string[] — deployed instance ids (Deployment FQNs)
33
+ - sourceLocation: { path: string, range: { start: { line: number, character: number }, end: { line: number, character: number } } } | null — source location if available
34
+
35
+ View (object) fields:
36
+ - id: string — view identifier
37
+ - title: string — view title
38
+ - type: "element" | "deployment" | "dynamic"
39
+
40
+ Notes:
41
+ - Read-only, idempotent, no side effects.
42
+ - Safe to call repeatedly.
43
+
44
+ Example response:
45
+ {
46
+ "id": "shop.frontend",
47
+ "name": "frontend",
48
+ "kind": "container",
49
+ "title": "Frontend",
50
+ "description": "User-facing web app",
51
+ "technology": "React",
52
+ "tags": ["public"],
53
+ "project": "default",
54
+ "metadata": { "owner": "web" },
55
+ "shape": "rounded-rectangle",
56
+ "color": "#2F80ED",
57
+ "children": ["shop.frontend.auth"],
58
+ "defaultView": "frontend-overview",
59
+ "includedInViews": [
60
+ {
61
+ "id": "frontend-overview",
62
+ "title": "Frontend Overview",
63
+ "type": "element"
64
+ }
65
+ ],
66
+ "relationships": {
67
+ "incoming": [
68
+ {
69
+ "source": { "id": "shop.api", "title": "API", "kind": "container" },
70
+ "kind": "uses",
71
+ "target": "shop.frontend",
72
+ "title": "Calls",
73
+ "description": null,
74
+ "technology": "HTTPS",
75
+ "tags": []
76
+ }
77
+ ],
78
+ "outgoing": []
79
+ },
80
+ "deployedInstances": ["k8s.cluster.frontend"],
81
+ "sourceLocation": {
82
+ "path": "/abs/path/project/model.c4",
83
+ "range": { "start": { "line": 10, "character": 0 }, "end": { "line": 25, "character": 0 } }
84
+ }
85
+ }
86
+ `,
87
+ annotations: {
88
+ readOnlyHint: true,
89
+ idempotentHint: true,
90
+ title: 'Read element',
91
+ },
92
+ inputSchema: {
93
+ id: z.string().describe('Element id (FQN)'),
94
+ project: projectIdSchema,
95
+ },
96
+ outputSchema: {
97
+ id: z.string().describe('Element id (FQN)'),
98
+ kind: z.string().describe('Element kind'),
99
+ name: z.string().describe('Element name'),
100
+ title: z.string(),
101
+ description: z.string().nullable(),
102
+ technology: z.string().nullable(),
103
+ tags: z.array(z.string()),
104
+ project: z.string(),
105
+ metadata: z.record(z.union([z.string(), z.array(z.string())])),
106
+ shape: z.string(),
107
+ color: z.string(),
108
+ children: z.array(z.string()).describe('Children of this element (Array of FQNs)'),
109
+ defaultView: z.string().nullable().describe('Name of the default view of this element'),
110
+ includedInViews: includedInViewsSchema.describe('Views that include this element'),
111
+ relationships: z.object({
112
+ incoming: z.array(z.object({
113
+ source: z.object({
114
+ id: z.string(),
115
+ title: z.string(),
116
+ kind: z.string(),
117
+ }).describe('Source element of this relationship'),
118
+ kind: z.string().nullable().describe('Relationship kind'),
119
+ target: z.string().describe('Target element id (FQN), either this element or nested element, if relationship is indirect'),
120
+ title: z.string().nullable().describe('Relationship title'),
121
+ description: z.string().nullable().describe('Relationship description'),
122
+ technology: z.string().nullable().describe('Relationship technology'),
123
+ tags: z.array(z.string()).describe('Relationship tags'),
124
+ })).describe('Incoming relationships of this element (direct and indirect, incoming to nested elements)'),
125
+ outgoing: z.array(z.object({
126
+ source: z.string().describe('Source element id (FQN), either this element or nested element, if relationship is indirect'),
127
+ target: z.object({
128
+ id: z.string(),
129
+ title: z.string(),
130
+ kind: z.string(),
131
+ }).describe('Target element of this relationship'),
132
+ kind: z.string().nullable().describe('Relationship kind'),
133
+ title: z.string().nullable().describe('Relationship title'),
134
+ description: z.string().nullable().describe('Relationship description'),
135
+ technology: z.string().nullable().describe('Relationship technology'),
136
+ tags: z.array(z.string()).describe('Relationship tags'),
137
+ })).describe('Outgoing relationships of this element (direct and indirect, outgoing from nested elements)'),
138
+ }).describe('Relationships of this element'),
139
+ deployedInstances: z.array(z.string()).describe('Deployed instances of this element (Array of Deployment FQNs)'),
140
+ sourceLocation: locationSchema,
141
+ },
142
+ }, async (languageServices, args) => {
143
+ const projectId = languageServices.projectsManager.ensureProjectId(args.project);
144
+ const model = await languageServices.computedModel(projectId);
145
+ const element = model.findElement(args.id);
146
+ invariant(element, `Element "${args.id}" not found in project "${projectId}"`);
147
+ const locate = mkLocate(languageServices, projectId);
148
+ return {
149
+ id: element.id,
150
+ name: element.name,
151
+ kind: element.kind,
152
+ title: element.title,
153
+ description: element.description.text,
154
+ technology: element.technology,
155
+ tags: [...element.tags],
156
+ project: projectId,
157
+ metadata: element.getMetadata(),
158
+ shape: element.shape,
159
+ color: element.color,
160
+ children: [...element.children()].map(c => c.id),
161
+ defaultView: element.defaultView?.id || null,
162
+ includedInViews: includedInViews(element.views()),
163
+ relationships: {
164
+ incoming: [...element.incoming()].map(r => ({
165
+ source: {
166
+ id: r.source.id,
167
+ title: r.source.title,
168
+ kind: r.source.kind,
169
+ },
170
+ kind: r.kind,
171
+ target: r.target.id,
172
+ title: r.title,
173
+ description: r.description.text,
174
+ technology: r.technology,
175
+ tags: [...r.tags],
176
+ })),
177
+ outgoing: [...element.outgoing()].map(r => ({
178
+ source: r.source.id,
179
+ target: {
180
+ id: r.target.id,
181
+ title: r.target.title,
182
+ kind: r.target.kind,
183
+ },
184
+ kind: r.kind,
185
+ title: r.title,
186
+ description: r.description.text,
187
+ technology: r.technology,
188
+ tags: [...r.tags],
189
+ })),
190
+ },
191
+ deployedInstances: [...element.deployments()].map(i => i.id),
192
+ sourceLocation: locate({ element: element.id }),
193
+ };
194
+ });
@@ -1,9 +1,8 @@
1
- import z from 'zod';
1
+ import * as z from 'zod/v3';
2
2
  export declare const readProjectSummary: (languageServices: import("../..").LikeC4LanguageServices) => [string, {
3
3
  inputSchema?: {
4
- project: z.ZodDefault<z.ZodOptional<z.ZodEffects<z.ZodString, ProjectId, string>>>;
5
- } | undefined;
4
+ project: z.ZodDefault<z.ZodOptional<z.ZodEffects<z.ZodString, import("@likec4/core").ProjectId, string>>>;
5
+ };
6
6
  }, (args: {
7
- [x: string]: any;
8
- project?: unknown;
9
- }, extra: import("@modelcontextprotocol/sdk/shared/protocol").RequestHandlerExtra<import("@modelcontextprotocol/sdk/types").ServerRequest, import("@modelcontextprotocol/sdk/types").ServerNotification>) => import("@modelcontextprotocol/sdk/types").CallToolResult | Promise<import("@modelcontextprotocol/sdk/types").CallToolResult>];
7
+ project: string & import("type-fest/source/tagged").Tag<"ProjectID", never>;
8
+ }, extra: import("@modelcontextprotocol/sdk/shared/protocol.js").RequestHandlerExtra<import("@modelcontextprotocol/sdk/types.js").ServerRequest, import("@modelcontextprotocol/sdk/types.js").ServerNotification>) => import("@modelcontextprotocol/sdk/types.js").CallToolResult | Promise<import("@modelcontextprotocol/sdk/types.js").CallToolResult>];
@@ -0,0 +1,176 @@
1
+ import { keys } from 'remeda';
2
+ import * as z from 'zod/v3';
3
+ import { likec4Tool } from '../utils';
4
+ import { projectIdSchema } from './_common';
5
+ export const readProjectSummary = likec4Tool({
6
+ name: 'read-project-summary',
7
+ annotations: {
8
+ readOnlyHint: true,
9
+ idempotentHint: true,
10
+ title: 'Read project summary',
11
+ },
12
+ description: `
13
+ Request:
14
+ - project: string (optional) — project id. Defaults to "default" if omitted.
15
+
16
+ Response (JSON object):
17
+ - title: string — human-readable project title
18
+ - folder: string — absolute path to the project root
19
+ - sources: string[] — absolute file paths of model documents
20
+ - specification: object
21
+ - elementKinds: string[] — all element kinds
22
+ - relationshipKinds: string[] — all relationship kinds
23
+ - deploymentKinds: string[] — all deployment kinds
24
+ - tags: string[] — all tags
25
+ - metadataKeys: string[] — used metadata keys
26
+ - elements: Element[] — list of elements
27
+ - deployments: Deployment[] — list of deployment entities
28
+ - views: View[] — list of views defined in the model
29
+
30
+ Element (object) fields:
31
+ - id: string — element id (FQN)
32
+ - kind: string — element kind
33
+ - title: string — element title
34
+ - tags: string[] — element tags
35
+
36
+ Deployment (object) fields:
37
+ - type = "deployment-node": { id: string, kind: string, title: string, tags: string[] }
38
+ - type = "deployed-instance": { id: string, title: string, tags: string[], referencedElementId: string }
39
+
40
+ View (object) fields:
41
+ - id: string — view identifier
42
+ - title: string — view title
43
+ - type: "element" | "deployment" | "dynamic"
44
+
45
+ Notes:
46
+ - Read-only, idempotent, no side effects.
47
+ - Safe to call repeatedly.
48
+
49
+ Example response:
50
+ {
51
+ "title": "Cloud Boutique",
52
+ "folder": "/abs/path/to/workspace/examples/cloud-system",
53
+ "sources": [
54
+ "/abs/path/to/workspace/examples/cloud-system/model.c4"
55
+ ],
56
+ "specification": {
57
+ "elementKinds": ["system", "container", "component"],
58
+ "relationshipKinds": ["uses", "depends-on"],
59
+ "deploymentKinds": ["node", "cluster"],
60
+ "tags": ["public", "internal"],
61
+ "metadataKeys": ["owner", "tier"]
62
+ },
63
+ "elements": [
64
+ {
65
+ "id": "shop.frontend",
66
+ "kind": "component",
67
+ "title": "Frontend",
68
+ "tags": ["public"]
69
+ }
70
+ ],
71
+ "deployments": [
72
+ {
73
+ "type": "deployment-node",
74
+ "id": "k8s.shop.frontend",
75
+ "kind": "cluster",
76
+ "title": "Frontend",
77
+ "tags": []
78
+ }
79
+ ],
80
+ "views": [
81
+ {
82
+ "name": "system-overview",
83
+ "title": "System Overview",
84
+ "type": "element"
85
+ }
86
+ ]
87
+ }
88
+ `,
89
+ inputSchema: {
90
+ project: projectIdSchema,
91
+ },
92
+ outputSchema: {
93
+ title: z.string(),
94
+ folder: z.string(),
95
+ sources: z.array(z.string()),
96
+ specification: z.object({
97
+ elementKinds: z.array(z.string()),
98
+ relationshipKinds: z.array(z.string()),
99
+ deploymentKinds: z.array(z.string()),
100
+ tags: z.array(z.string()),
101
+ metadataKeys: z.array(z.string()),
102
+ }),
103
+ elements: z.array(z.object({
104
+ id: z.string(),
105
+ kind: z.string(),
106
+ title: z.string(),
107
+ tags: z.array(z.string()),
108
+ })).describe('List of elements in the project'),
109
+ deployments: z.array(z.discriminatedUnion('type', [
110
+ z.object({
111
+ type: z.literal('deployment-node'),
112
+ id: z.string().describe('Node ID'),
113
+ kind: z.string().describe('Deployment node kind'),
114
+ title: z.string().describe('Node title'),
115
+ tags: z.array(z.string()),
116
+ }),
117
+ z.object({
118
+ type: z.literal('deployed-instance'),
119
+ id: z.string().describe('Node ID'),
120
+ title: z.string().describe('Node title'),
121
+ tags: z.array(z.string()),
122
+ referencedElementId: z.string().describe('Element ID (FQN)'),
123
+ }),
124
+ ])).describe('List of deployment nodes and deployed instances in the project'),
125
+ views: z.array(z.object({
126
+ id: z.string(),
127
+ title: z.string(),
128
+ type: z.enum(['element', 'deployment', 'dynamic']),
129
+ })),
130
+ },
131
+ }, async (languageServices, args) => {
132
+ const projectId = languageServices.projectsManager.ensureProjectId(args.project);
133
+ const project = languageServices.project(projectId);
134
+ const model = await languageServices.computedModel(projectId);
135
+ return {
136
+ title: project.title,
137
+ folder: project.folder.fsPath,
138
+ specification: {
139
+ elementKinds: keys(model.specification.elements),
140
+ relationshipKinds: keys(model.specification.relationships),
141
+ deploymentKinds: keys(model.specification.deployments),
142
+ tags: [...model.tags],
143
+ metadataKeys: model.specification.metadataKeys ?? [],
144
+ },
145
+ elements: [...model.elements()].filter(e => !e.imported).map(e => ({
146
+ id: e.id,
147
+ kind: e.kind,
148
+ title: e.title,
149
+ tags: [...e.tags],
150
+ })),
151
+ deployments: [...model.deployment.elements()].map(d => {
152
+ if (d.isInstance()) {
153
+ return ({
154
+ type: 'deployed-instance',
155
+ id: d.id,
156
+ title: d.title,
157
+ tags: [...d.tags],
158
+ referencedElementId: d.element.id,
159
+ });
160
+ }
161
+ return ({
162
+ type: 'deployment-node',
163
+ id: d.id,
164
+ kind: d.kind,
165
+ title: d.title,
166
+ tags: [...d.tags],
167
+ });
168
+ }),
169
+ views: [...model.views()].map(v => ({
170
+ id: v.id,
171
+ title: v.titleOrId,
172
+ type: v.$view._type,
173
+ })),
174
+ sources: project.documents?.map(d => d.fsPath) ?? [],
175
+ };
176
+ });
@@ -1,11 +1,10 @@
1
- import z from 'zod';
1
+ import * as z from 'zod/v3';
2
2
  export declare const readView: (languageServices: import("../..").LikeC4LanguageServices) => [string, {
3
3
  inputSchema?: {
4
4
  viewId: z.ZodString;
5
- project: z.ZodDefault<z.ZodOptional<z.ZodEffects<z.ZodString, ProjectId, string>>>;
6
- } | undefined;
5
+ project: z.ZodDefault<z.ZodOptional<z.ZodEffects<z.ZodString, import("@likec4/core").ProjectId, string>>>;
6
+ };
7
7
  }, (args: {
8
- [x: string]: any;
9
- viewId?: unknown;
10
- project?: unknown;
11
- }, extra: import("@modelcontextprotocol/sdk/shared/protocol").RequestHandlerExtra<import("@modelcontextprotocol/sdk/types").ServerRequest, import("@modelcontextprotocol/sdk/types").ServerNotification>) => import("@modelcontextprotocol/sdk/types").CallToolResult | Promise<import("@modelcontextprotocol/sdk/types").CallToolResult>];
8
+ project: string & import("type-fest/source/tagged").Tag<"ProjectID", never>;
9
+ viewId: string;
10
+ }, extra: import("@modelcontextprotocol/sdk/shared/protocol.js").RequestHandlerExtra<import("@modelcontextprotocol/sdk/types.js").ServerRequest, import("@modelcontextprotocol/sdk/types.js").ServerNotification>) => import("@modelcontextprotocol/sdk/types.js").CallToolResult | Promise<import("@modelcontextprotocol/sdk/types.js").CallToolResult>];
@@ -0,0 +1,203 @@
1
+ import * as z from 'zod/v3';
2
+ import { likec4Tool } from '../utils';
3
+ import { locationSchema, mkLocate, projectIdSchema } from './_common';
4
+ const modelRef = (node) => {
5
+ if (node.hasElement()) {
6
+ return node.element.id;
7
+ }
8
+ if (node.hasDeployment()) {
9
+ return node.deployment.id;
10
+ }
11
+ return null;
12
+ };
13
+ const nodeSchema = z.discriminatedUnion('type', [
14
+ z.object({
15
+ type: z.literal('element'),
16
+ id: z.string().describe('Node ID'),
17
+ elementId: z.string().describe('Element ID (FQN)'),
18
+ kind: z.string().describe('Element kind'),
19
+ title: z.string().describe('Node title'),
20
+ description: z.string().nullable(),
21
+ technology: z.string().nullable(),
22
+ children: z.array(z.string()).describe('Children nodes, array of node IDs'),
23
+ shape: z.string().describe('Rendered shape'),
24
+ color: z.string().describe('Rendered color'),
25
+ tags: z.array(z.string()),
26
+ }),
27
+ z.object({
28
+ type: z.literal('deployment-node'),
29
+ id: z.string().describe('Node ID'),
30
+ deploymentId: z.string().describe('Deployment entity ID (FQN)'),
31
+ kind: z.string().describe('Deployment kind'),
32
+ title: z.string().describe('Node title'),
33
+ description: z.string().nullable(),
34
+ technology: z.string().nullable(),
35
+ children: z.array(z.string()).describe('Children nodes, array of node IDs'),
36
+ shape: z.string().describe('Rendered shape'),
37
+ color: z.string().describe('Rendered color'),
38
+ tags: z.array(z.string()),
39
+ }),
40
+ z.object({
41
+ type: z.literal('deployed-instance'),
42
+ id: z.string().describe('Node ID'),
43
+ deploymentId: z.string().describe('Deployment entity ID (FQN)'),
44
+ title: z.string().describe('Node title'),
45
+ description: z.string().nullable(),
46
+ technology: z.string().nullable(),
47
+ referencedElement: z.object({
48
+ id: z.string().describe('Element ID (FQN)'),
49
+ kind: z.string().describe('Element kind'),
50
+ title: z.string().describe('Element title'),
51
+ }),
52
+ shape: z.string().describe('Rendered shape'),
53
+ color: z.string().describe('Rendered color'),
54
+ tags: z.array(z.string()),
55
+ }),
56
+ ]);
57
+ export const readView = likec4Tool({
58
+ name: 'read-view',
59
+ description: `
60
+ Read detailed information about a LikeC4 view.
61
+
62
+ Request:
63
+ - viewId: string — view id (name)
64
+ - project: string (optional) — project id. Defaults to "default" if omitted.
65
+
66
+ Response (JSON object):
67
+ - id: string — view id
68
+ - type: "element" | "deployment" | "dynamic" — view type
69
+ - title: string — view title (falls back to id if not set)
70
+ - description: string|null — optional description
71
+ - tags: string[] — view tags
72
+ - project: string — project id this view belongs to
73
+ - nodes: Node[] — nodes included in the view
74
+ - edges: Edge[] — relationships between nodes
75
+ - sourceLocation: { path: string, range: { start: { line: number, character: number }, end: { line: number, character: number } } } | null — source location if available
76
+
77
+ Node (discriminated union by "type"):
78
+ - type = "element": { id: string, elementId: string, kind: string, title: string, description: string|null, technology: string|null, children: string[], shape: string, color: string, tags: string[] }
79
+ - type = "deployment-node": { id: string, deploymentId: string, kind: string, title: string, description: string|null, technology: string|null, children: string[], shape: string, color: string, tags: string[] }
80
+ - type = "deployed-instance": { id: string, deploymentId: string, title: string, description: string|null, technology: string|null, referencedElement: { id: string, kind: string, title: string }, shape: string, color: string, tags: string[] }
81
+
82
+ Edge object:
83
+ - { source: string, target: string, label: string|null, description: string|null, technology: string|null, tags: string[] }
84
+
85
+ Notes:
86
+ - Read-only, idempotent, no side effects.
87
+
88
+ Example response:
89
+ {
90
+ "id": "system-overview",
91
+ "type": "element",
92
+ "title": "System Overview",
93
+ "description": null,
94
+ "tags": [],
95
+ "project": "default",
96
+ "nodes": [
97
+ { "type": "logical", "id": "n1", "elementId": "shop.frontend", "kind": "container", "title": "Frontend", "description": null, "technology": "React", "children": [], "shape": "rounded-rectangle", "color": "#2F80ED", "tags": [] }
98
+ ],
99
+ "edges": [
100
+ { "source": "n1", "target": "n2", "label": "calls", "description": null, "technology": "HTTPS", "tags": [] }
101
+ ],
102
+ "sourceLocation": {
103
+ "path": "/abs/path/project/model.c4",
104
+ "range": { "start": { "line": 10, "character": 0 }, "end": { "line": 30, "character": 0 } }
105
+ }
106
+ }
107
+ `,
108
+ annotations: {
109
+ readOnlyHint: true,
110
+ idempotentHint: true,
111
+ title: 'Read view',
112
+ },
113
+ inputSchema: {
114
+ viewId: z.string().describe('View id (name)'),
115
+ project: projectIdSchema,
116
+ },
117
+ outputSchema: {
118
+ id: z.string(),
119
+ type: z.enum(['element', 'deployment', 'dynamic']).describe('View type'),
120
+ title: z.string(),
121
+ description: z.string().nullable(),
122
+ tags: z.array(z.string()),
123
+ project: z.string(),
124
+ nodes: z.array(nodeSchema),
125
+ edges: z.array(z.object({
126
+ source: z.string().describe('Source node'),
127
+ target: z.string().describe('Target node'),
128
+ label: z.string().nullable(),
129
+ description: z.string().nullable(),
130
+ technology: z.string().nullable(),
131
+ tags: z.array(z.string()),
132
+ })).describe('Edge represents relationship between nodes'),
133
+ sourceLocation: locationSchema,
134
+ },
135
+ }, async (languageServices, args) => {
136
+ const projectId = languageServices.projectsManager.ensureProjectId(args.project);
137
+ const project = languageServices.project(projectId);
138
+ const model = await languageServices.computedModel(projectId);
139
+ const view = model.findView(args.viewId);
140
+ if (!view) {
141
+ throw new Error(`View with ID '${args.viewId}' not found in project ${project.id}`);
142
+ }
143
+ const locate = mkLocate(languageServices, project.id);
144
+ return {
145
+ id: view.id,
146
+ type: view.$view._type,
147
+ title: view.title ?? view.id,
148
+ description: view.description.text,
149
+ tags: [...view.tags],
150
+ project: project.id,
151
+ nodes: [...view.nodes()].flatMap((node) => {
152
+ const base = {
153
+ id: node.id,
154
+ title: node.title,
155
+ description: node.description.text,
156
+ technology: node.technology,
157
+ shape: node.shape,
158
+ color: node.color,
159
+ tags: [...node.tags],
160
+ };
161
+ if (node.hasDeployedInstance()) {
162
+ return {
163
+ ...base,
164
+ type: 'deployed-instance',
165
+ deploymentId: node.deployment.id,
166
+ referencedElement: {
167
+ id: node.deployment.element.id,
168
+ kind: node.deployment.element.kind,
169
+ title: node.deployment.element.title,
170
+ },
171
+ };
172
+ }
173
+ if (node.hasDeployment()) {
174
+ return {
175
+ ...base,
176
+ type: 'deployment-node',
177
+ kind: node.deployment.kind,
178
+ deploymentId: node.deployment.id,
179
+ children: [...node.children()].map(c => c.id),
180
+ };
181
+ }
182
+ if (node.hasElement()) {
183
+ return {
184
+ ...base,
185
+ type: 'element',
186
+ elementId: node.element.id,
187
+ kind: node.element.kind,
188
+ children: [...node.children()].flatMap(c => modelRef(c) ?? []),
189
+ };
190
+ }
191
+ return [];
192
+ }),
193
+ edges: [...view.edges()].map(r => ({
194
+ source: r.source.id,
195
+ target: r.target.id,
196
+ label: r.label,
197
+ description: r.description.text,
198
+ technology: r.technology,
199
+ tags: [...r.tags],
200
+ })),
201
+ sourceLocation: locate({ view: view.id }),
202
+ };
203
+ });
@@ -1,8 +1,8 @@
1
- import z from 'zod';
1
+ import * as z from 'zod/v3';
2
2
  export declare const searchElement: (languageServices: import("../..").LikeC4LanguageServices) => [string, {
3
3
  inputSchema?: {
4
4
  search: z.ZodString;
5
- } | undefined;
5
+ };
6
6
  }, (args: {
7
7
  search: string;
8
- }, extra: import("@modelcontextprotocol/sdk/shared/protocol").RequestHandlerExtra<import("@modelcontextprotocol/sdk/types").ServerRequest, import("@modelcontextprotocol/sdk/types").ServerNotification>) => import("@modelcontextprotocol/sdk/types").CallToolResult | Promise<import("@modelcontextprotocol/sdk/types").CallToolResult>];
8
+ }, extra: import("@modelcontextprotocol/sdk/shared/protocol.js").RequestHandlerExtra<import("@modelcontextprotocol/sdk/types.js").ServerRequest, import("@modelcontextprotocol/sdk/types.js").ServerNotification>) => import("@modelcontextprotocol/sdk/types.js").CallToolResult | Promise<import("@modelcontextprotocol/sdk/types.js").CallToolResult>];