@memberjunction/db-auto-doc 2.117.0 → 2.118.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 (251) hide show
  1. package/README.md +652 -165
  2. package/bin/run.js +7 -0
  3. package/dist/api/DBAutoDocAPI.d.ts +252 -0
  4. package/dist/api/DBAutoDocAPI.d.ts.map +1 -0
  5. package/dist/api/DBAutoDocAPI.js +530 -0
  6. package/dist/api/DBAutoDocAPI.js.map +1 -0
  7. package/dist/api/index.d.ts +7 -0
  8. package/dist/api/index.d.ts.map +1 -0
  9. package/dist/api/index.js +10 -0
  10. package/dist/api/index.js.map +1 -0
  11. package/dist/commands/analyze.d.ts +6 -4
  12. package/dist/commands/analyze.d.ts.map +1 -1
  13. package/dist/commands/analyze.js +58 -71
  14. package/dist/commands/analyze.js.map +1 -1
  15. package/dist/commands/export.d.ts +14 -4
  16. package/dist/commands/export.d.ts.map +1 -1
  17. package/dist/commands/export.js +156 -61
  18. package/dist/commands/export.js.map +1 -1
  19. package/dist/commands/init.d.ts +3 -4
  20. package/dist/commands/init.d.ts.map +1 -1
  21. package/dist/commands/init.js +155 -146
  22. package/dist/commands/init.js.map +1 -1
  23. package/dist/commands/reset.d.ts +4 -1
  24. package/dist/commands/reset.d.ts.map +1 -1
  25. package/dist/commands/reset.js +33 -19
  26. package/dist/commands/reset.js.map +1 -1
  27. package/dist/commands/status.d.ts +10 -0
  28. package/dist/commands/status.d.ts.map +1 -0
  29. package/dist/commands/status.js +66 -0
  30. package/dist/commands/status.js.map +1 -0
  31. package/dist/core/AnalysisEngine.d.ts +108 -0
  32. package/dist/core/AnalysisEngine.d.ts.map +1 -0
  33. package/dist/core/AnalysisEngine.js +716 -0
  34. package/dist/core/AnalysisEngine.js.map +1 -0
  35. package/dist/core/AnalysisOrchestrator.d.ts +37 -0
  36. package/dist/core/AnalysisOrchestrator.d.ts.map +1 -0
  37. package/dist/core/AnalysisOrchestrator.js +294 -0
  38. package/dist/core/AnalysisOrchestrator.js.map +1 -0
  39. package/dist/core/BackpropagationEngine.d.ts +32 -0
  40. package/dist/core/BackpropagationEngine.d.ts.map +1 -0
  41. package/dist/core/BackpropagationEngine.js +121 -0
  42. package/dist/core/BackpropagationEngine.js.map +1 -0
  43. package/dist/core/ConvergenceDetector.d.ts +27 -0
  44. package/dist/core/ConvergenceDetector.d.ts.map +1 -0
  45. package/dist/core/ConvergenceDetector.js +92 -0
  46. package/dist/core/ConvergenceDetector.js.map +1 -0
  47. package/dist/core/GuardrailsManager.d.ts +78 -0
  48. package/dist/core/GuardrailsManager.d.ts.map +1 -0
  49. package/dist/core/GuardrailsManager.js +367 -0
  50. package/dist/core/GuardrailsManager.js.map +1 -0
  51. package/dist/core/index.d.ts +7 -0
  52. package/dist/core/index.d.ts.map +1 -0
  53. package/dist/core/index.js +13 -0
  54. package/dist/core/index.js.map +1 -0
  55. package/dist/database/Database.d.ts +56 -0
  56. package/dist/database/Database.d.ts.map +1 -0
  57. package/dist/database/Database.js +172 -0
  58. package/dist/database/Database.js.map +1 -0
  59. package/dist/database/TopologicalSorter.d.ts +25 -0
  60. package/dist/database/TopologicalSorter.d.ts.map +1 -0
  61. package/dist/database/TopologicalSorter.js +150 -0
  62. package/dist/database/TopologicalSorter.js.map +1 -0
  63. package/dist/database/index.d.ts +6 -0
  64. package/dist/database/index.d.ts.map +1 -0
  65. package/dist/database/index.js +14 -0
  66. package/dist/database/index.js.map +1 -0
  67. package/dist/discovery/ColumnStatsCache.d.ts +91 -0
  68. package/dist/discovery/ColumnStatsCache.d.ts.map +1 -0
  69. package/dist/discovery/ColumnStatsCache.js +231 -0
  70. package/dist/discovery/ColumnStatsCache.js.map +1 -0
  71. package/dist/discovery/DiscoveryEngine.d.ts +100 -0
  72. package/dist/discovery/DiscoveryEngine.d.ts.map +1 -0
  73. package/dist/discovery/DiscoveryEngine.js +726 -0
  74. package/dist/discovery/DiscoveryEngine.js.map +1 -0
  75. package/dist/discovery/DiscoveryTriggerAnalyzer.d.ts +57 -0
  76. package/dist/discovery/DiscoveryTriggerAnalyzer.d.ts.map +1 -0
  77. package/dist/discovery/DiscoveryTriggerAnalyzer.js +186 -0
  78. package/dist/discovery/DiscoveryTriggerAnalyzer.js.map +1 -0
  79. package/dist/discovery/FKDetector.d.ts +47 -0
  80. package/dist/discovery/FKDetector.d.ts.map +1 -0
  81. package/dist/discovery/FKDetector.js +317 -0
  82. package/dist/discovery/FKDetector.js.map +1 -0
  83. package/dist/discovery/LLMDiscoveryValidator.d.ts +64 -0
  84. package/dist/discovery/LLMDiscoveryValidator.d.ts.map +1 -0
  85. package/dist/discovery/LLMDiscoveryValidator.js +431 -0
  86. package/dist/discovery/LLMDiscoveryValidator.js.map +1 -0
  87. package/dist/discovery/LLMSanityChecker.d.ts +38 -0
  88. package/dist/discovery/LLMSanityChecker.d.ts.map +1 -0
  89. package/dist/discovery/LLMSanityChecker.js +156 -0
  90. package/dist/discovery/LLMSanityChecker.js.map +1 -0
  91. package/dist/discovery/PKDetector.d.ts +62 -0
  92. package/dist/discovery/PKDetector.d.ts.map +1 -0
  93. package/dist/discovery/PKDetector.js +436 -0
  94. package/dist/discovery/PKDetector.js.map +1 -0
  95. package/dist/discovery/index.d.ts +9 -0
  96. package/dist/discovery/index.d.ts.map +1 -0
  97. package/dist/discovery/index.js +25 -0
  98. package/dist/discovery/index.js.map +1 -0
  99. package/dist/drivers/BaseAutoDocDriver.d.ts +132 -0
  100. package/dist/drivers/BaseAutoDocDriver.d.ts.map +1 -0
  101. package/dist/drivers/BaseAutoDocDriver.js +121 -0
  102. package/dist/drivers/BaseAutoDocDriver.js.map +1 -0
  103. package/dist/drivers/MySQLDriver.d.ts +61 -0
  104. package/dist/drivers/MySQLDriver.d.ts.map +1 -0
  105. package/dist/drivers/MySQLDriver.js +668 -0
  106. package/dist/drivers/MySQLDriver.js.map +1 -0
  107. package/dist/drivers/PostgreSQLDriver.d.ts +65 -0
  108. package/dist/drivers/PostgreSQLDriver.d.ts.map +1 -0
  109. package/dist/drivers/PostgreSQLDriver.js +704 -0
  110. package/dist/drivers/PostgreSQLDriver.js.map +1 -0
  111. package/dist/drivers/SQLServerDriver.d.ts +61 -0
  112. package/dist/drivers/SQLServerDriver.d.ts.map +1 -0
  113. package/dist/drivers/SQLServerDriver.js +667 -0
  114. package/dist/drivers/SQLServerDriver.js.map +1 -0
  115. package/dist/generators/CSVGenerator.d.ts +35 -0
  116. package/dist/generators/CSVGenerator.d.ts.map +1 -0
  117. package/dist/generators/CSVGenerator.js +154 -0
  118. package/dist/generators/CSVGenerator.js.map +1 -0
  119. package/dist/generators/HTMLGenerator.d.ts +29 -0
  120. package/dist/generators/HTMLGenerator.d.ts.map +1 -0
  121. package/dist/generators/HTMLGenerator.js +710 -0
  122. package/dist/generators/HTMLGenerator.js.map +1 -0
  123. package/dist/generators/MarkdownGenerator.d.ts +27 -0
  124. package/dist/generators/MarkdownGenerator.d.ts.map +1 -0
  125. package/dist/generators/MarkdownGenerator.js +361 -0
  126. package/dist/generators/MarkdownGenerator.js.map +1 -0
  127. package/dist/generators/MermaidGenerator.d.ts +35 -0
  128. package/dist/generators/MermaidGenerator.d.ts.map +1 -0
  129. package/dist/generators/MermaidGenerator.js +321 -0
  130. package/dist/generators/MermaidGenerator.js.map +1 -0
  131. package/dist/generators/ReportGenerator.d.ts +22 -0
  132. package/dist/generators/ReportGenerator.d.ts.map +1 -0
  133. package/dist/generators/ReportGenerator.js +176 -0
  134. package/dist/generators/ReportGenerator.js.map +1 -0
  135. package/dist/generators/SQLGenerator.d.ts +31 -0
  136. package/dist/generators/SQLGenerator.d.ts.map +1 -0
  137. package/dist/generators/SQLGenerator.js +168 -0
  138. package/dist/generators/SQLGenerator.js.map +1 -0
  139. package/dist/generators/index.d.ts +10 -0
  140. package/dist/generators/index.d.ts.map +1 -0
  141. package/dist/generators/index.js +19 -0
  142. package/dist/generators/index.js.map +1 -0
  143. package/dist/index.d.ts +11 -20
  144. package/dist/index.d.ts.map +1 -1
  145. package/dist/index.js +19 -20
  146. package/dist/index.js.map +1 -1
  147. package/dist/prompts/PromptEngine.d.ts +65 -0
  148. package/dist/prompts/PromptEngine.d.ts.map +1 -0
  149. package/dist/prompts/PromptEngine.js +282 -0
  150. package/dist/prompts/PromptEngine.js.map +1 -0
  151. package/dist/prompts/PromptFileLoader.d.ts +21 -0
  152. package/dist/prompts/PromptFileLoader.d.ts.map +1 -0
  153. package/dist/prompts/PromptFileLoader.js +74 -0
  154. package/dist/prompts/PromptFileLoader.js.map +1 -0
  155. package/dist/prompts/index.d.ts +6 -0
  156. package/dist/prompts/index.d.ts.map +1 -0
  157. package/dist/prompts/index.js +11 -0
  158. package/dist/prompts/index.js.map +1 -0
  159. package/dist/state/IterationTracker.d.ts +64 -0
  160. package/dist/state/IterationTracker.d.ts.map +1 -0
  161. package/dist/state/IterationTracker.js +136 -0
  162. package/dist/state/IterationTracker.js.map +1 -0
  163. package/dist/state/StateManager.d.ts +79 -0
  164. package/dist/state/StateManager.d.ts.map +1 -0
  165. package/dist/state/StateManager.js +348 -0
  166. package/dist/state/StateManager.js.map +1 -0
  167. package/dist/state/StateValidator.d.ts +24 -0
  168. package/dist/state/StateValidator.d.ts.map +1 -0
  169. package/dist/state/StateValidator.js +147 -0
  170. package/dist/state/StateValidator.js.map +1 -0
  171. package/dist/state/index.d.ts +7 -0
  172. package/dist/state/index.d.ts.map +1 -0
  173. package/dist/state/index.js +13 -0
  174. package/dist/state/index.js.map +1 -0
  175. package/dist/types/analysis.d.ts +76 -0
  176. package/dist/types/analysis.d.ts.map +1 -0
  177. package/dist/types/analysis.js +6 -0
  178. package/dist/types/analysis.js.map +1 -0
  179. package/dist/types/config.d.ts +132 -0
  180. package/dist/types/config.d.ts.map +1 -0
  181. package/dist/types/config.js +7 -0
  182. package/dist/types/config.js.map +1 -0
  183. package/dist/types/discovery.d.ts +277 -0
  184. package/dist/types/discovery.d.ts.map +1 -0
  185. package/dist/types/discovery.js +7 -0
  186. package/dist/types/discovery.js.map +1 -0
  187. package/dist/types/driver.d.ts +148 -0
  188. package/dist/types/driver.d.ts.map +1 -0
  189. package/dist/types/driver.js +7 -0
  190. package/dist/types/driver.js.map +1 -0
  191. package/dist/types/index.d.ts +8 -0
  192. package/dist/types/index.d.ts.map +1 -0
  193. package/dist/types/index.js +24 -0
  194. package/dist/types/index.js.map +1 -0
  195. package/dist/types/prompts.d.ts +158 -0
  196. package/dist/types/prompts.d.ts.map +1 -0
  197. package/dist/types/prompts.js +6 -0
  198. package/dist/types/prompts.js.map +1 -0
  199. package/dist/types/state.d.ts +278 -0
  200. package/dist/types/state.d.ts.map +1 -0
  201. package/dist/types/state.js +7 -0
  202. package/dist/types/state.js.map +1 -0
  203. package/dist/utils/config-loader.d.ts +29 -0
  204. package/dist/utils/config-loader.d.ts.map +1 -0
  205. package/dist/utils/config-loader.js +163 -0
  206. package/dist/utils/config-loader.js.map +1 -0
  207. package/dist/utils/index.d.ts +5 -0
  208. package/dist/utils/index.d.ts.map +1 -0
  209. package/dist/utils/index.js +9 -0
  210. package/dist/utils/index.js.map +1 -0
  211. package/package.json +24 -3
  212. package/dist/ai/simple-ai-client.d.ts +0 -70
  213. package/dist/ai/simple-ai-client.d.ts.map +0 -1
  214. package/dist/ai/simple-ai-client.js +0 -181
  215. package/dist/ai/simple-ai-client.js.map +0 -1
  216. package/dist/analyzers/analyzer.d.ts +0 -23
  217. package/dist/analyzers/analyzer.d.ts.map +0 -1
  218. package/dist/analyzers/analyzer.js +0 -127
  219. package/dist/analyzers/analyzer.js.map +0 -1
  220. package/dist/cli-old/cli.d.ts +0 -3
  221. package/dist/cli-old/cli.d.ts.map +0 -1
  222. package/dist/cli-old/cli.js +0 -388
  223. package/dist/cli-old/cli.js.map +0 -1
  224. package/dist/commands/review.d.ts +0 -11
  225. package/dist/commands/review.d.ts.map +0 -1
  226. package/dist/commands/review.js +0 -82
  227. package/dist/commands/review.js.map +0 -1
  228. package/dist/database/connection.d.ts +0 -40
  229. package/dist/database/connection.d.ts.map +0 -1
  230. package/dist/database/connection.js +0 -136
  231. package/dist/database/connection.js.map +0 -1
  232. package/dist/database/introspection.d.ts +0 -59
  233. package/dist/database/introspection.d.ts.map +0 -1
  234. package/dist/database/introspection.js +0 -124
  235. package/dist/database/introspection.js.map +0 -1
  236. package/dist/generators/markdown-generator.d.ts +0 -8
  237. package/dist/generators/markdown-generator.d.ts.map +0 -1
  238. package/dist/generators/markdown-generator.js +0 -106
  239. package/dist/generators/markdown-generator.js.map +0 -1
  240. package/dist/generators/sql-generator.d.ts +0 -20
  241. package/dist/generators/sql-generator.d.ts.map +0 -1
  242. package/dist/generators/sql-generator.js +0 -83
  243. package/dist/generators/sql-generator.js.map +0 -1
  244. package/dist/state/state-manager.d.ts +0 -95
  245. package/dist/state/state-manager.d.ts.map +0 -1
  246. package/dist/state/state-manager.js +0 -236
  247. package/dist/state/state-manager.js.map +0 -1
  248. package/dist/types/state-file.d.ts +0 -124
  249. package/dist/types/state-file.d.ts.map +0 -1
  250. package/dist/types/state-file.js +0 -79
  251. package/dist/types/state-file.js.map +0 -1
@@ -0,0 +1,321 @@
1
+ "use strict";
2
+ /**
3
+ * Generates standalone Mermaid diagram files for ERD
4
+ */
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.MermaidGenerator = void 0;
7
+ class MermaidGenerator {
8
+ /**
9
+ * Generate Mermaid ERD diagram
10
+ */
11
+ generate(state, options = {}) {
12
+ const lines = [];
13
+ // Header comments
14
+ if (options.includeComments !== false) {
15
+ lines.push(`%% Entity Relationship Diagram`);
16
+ lines.push(`%% Database: ${state.database.name}`);
17
+ lines.push(`%% Server: ${state.database.server}`);
18
+ lines.push(`%% Generated: ${new Date().toISOString()}`);
19
+ lines.push(`%% Total Schemas: ${state.schemas.length}`);
20
+ lines.push(`%% Total Tables: ${state.summary.totalTables}`);
21
+ lines.push(`%% Total Columns: ${state.summary.totalColumns}`);
22
+ lines.push('');
23
+ }
24
+ // Start ERD
25
+ lines.push('erDiagram');
26
+ lines.push('');
27
+ // Process each schema
28
+ for (const schema of state.schemas) {
29
+ if (options.includeComments !== false) {
30
+ lines.push(` %% Schema: ${schema.name}`);
31
+ if (schema.description) {
32
+ lines.push(` %% ${schema.description}`);
33
+ }
34
+ lines.push('');
35
+ }
36
+ // Process all tables
37
+ this.appendSchemaEntities(lines, schema, options);
38
+ }
39
+ lines.push('');
40
+ // Add relationships
41
+ if (options.includeComments !== false) {
42
+ lines.push(` %% Relationships`);
43
+ lines.push('');
44
+ }
45
+ this.appendRelationships(lines, state, options);
46
+ return lines.join('\n');
47
+ }
48
+ /**
49
+ * Append entity definitions for a schema
50
+ */
51
+ appendSchemaEntities(lines, schema, options) {
52
+ for (const table of schema.tables) {
53
+ // Check filters
54
+ if (options.approvedOnly && !table.userApproved) {
55
+ continue;
56
+ }
57
+ if (options.confidenceThreshold && table.descriptionIterations.length > 0) {
58
+ const latest = table.descriptionIterations[table.descriptionIterations.length - 1];
59
+ if ((latest.confidence || 0) < options.confidenceThreshold) {
60
+ continue;
61
+ }
62
+ }
63
+ lines.push(` ${table.name} {`);
64
+ for (const column of table.columns) {
65
+ const type = column.dataType.replace(/\s+/g, '_');
66
+ const constraints = [];
67
+ if (column.isPrimaryKey)
68
+ constraints.push('PK');
69
+ if (column.isForeignKey)
70
+ constraints.push('FK');
71
+ if (!column.isNullable)
72
+ constraints.push('NOT_NULL');
73
+ const constraintStr = constraints.length > 0 ? ` "${constraints.join(',')}"` : '';
74
+ // Include description as comment if available
75
+ if (options.includeComments !== false && column.description) {
76
+ const description = column.description.replace(/"/g, '\\"').substring(0, 60);
77
+ lines.push(` ${type} ${column.name}${constraintStr} %% ${description}`);
78
+ }
79
+ else {
80
+ lines.push(` ${type} ${column.name}${constraintStr}`);
81
+ }
82
+ }
83
+ lines.push(' }');
84
+ lines.push('');
85
+ }
86
+ }
87
+ /**
88
+ * Append relationship definitions
89
+ */
90
+ appendRelationships(lines, state, options) {
91
+ const relationships = new Set();
92
+ for (const schema of state.schemas) {
93
+ for (const table of schema.tables) {
94
+ // Check filters
95
+ if (options.approvedOnly && !table.userApproved) {
96
+ continue;
97
+ }
98
+ if (options.confidenceThreshold && table.descriptionIterations.length > 0) {
99
+ const latest = table.descriptionIterations[table.descriptionIterations.length - 1];
100
+ if ((latest.confidence || 0) < options.confidenceThreshold) {
101
+ continue;
102
+ }
103
+ }
104
+ if (table.dependsOn && table.dependsOn.length > 0) {
105
+ for (const dep of table.dependsOn) {
106
+ // Check if dependent table passes filters
107
+ if (this.tablePassesFilters(state, dep.schema, dep.table, options)) {
108
+ const key = `${dep.table}||--o{${table.name}`;
109
+ if (!relationships.has(key)) {
110
+ relationships.add(key);
111
+ lines.push(` ${dep.table} ||--o{ ${table.name} : "has"`);
112
+ }
113
+ }
114
+ }
115
+ }
116
+ }
117
+ }
118
+ // Add comments for complex relationships
119
+ if (options.includeComments !== false && relationships.size > 0) {
120
+ lines.push('');
121
+ lines.push(` %% Relationship Notation:`);
122
+ lines.push(` %% Parent ||--o{ Child : "describes"`);
123
+ lines.push(` %% One Parent can have zero or more Children`);
124
+ }
125
+ }
126
+ /**
127
+ * Check if a table passes the configured filters
128
+ */
129
+ tablePassesFilters(state, schemaName, tableName, options) {
130
+ const schema = state.schemas.find(s => s.name === schemaName);
131
+ if (!schema)
132
+ return false;
133
+ const table = schema.tables.find(t => t.name === tableName);
134
+ if (!table)
135
+ return false;
136
+ if (options.approvedOnly && !table.userApproved) {
137
+ return false;
138
+ }
139
+ if (options.confidenceThreshold && table.descriptionIterations.length > 0) {
140
+ const latest = table.descriptionIterations[table.descriptionIterations.length - 1];
141
+ if ((latest.confidence || 0) < options.confidenceThreshold) {
142
+ return false;
143
+ }
144
+ }
145
+ return true;
146
+ }
147
+ /**
148
+ * Generate an HTML-wrapped version of the Mermaid diagram
149
+ * Useful for standalone rendering
150
+ */
151
+ generateHtml(state, options = {}) {
152
+ const mermaidDiagram = this.generate(state, options);
153
+ return `<!DOCTYPE html>
154
+ <html lang="en">
155
+ <head>
156
+ <meta charset="UTF-8">
157
+ <meta name="viewport" content="width=device-width, initial-scale=1.0">
158
+ <title>Database ERD - ${this.escapeHtml(state.database.name)}</title>
159
+ <script src="https://cdn.jsdelivr.net/npm/mermaid/dist/mermaid.min.js"><\/script>
160
+ <style>
161
+ * {
162
+ margin: 0;
163
+ padding: 0;
164
+ box-sizing: border-box;
165
+ }
166
+
167
+ body {
168
+ font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
169
+ background-color: #f5f7fa;
170
+ color: #333;
171
+ padding: 2rem;
172
+ }
173
+
174
+ .container {
175
+ max-width: 1400px;
176
+ margin: 0 auto;
177
+ background: white;
178
+ border-radius: 8px;
179
+ padding: 2rem;
180
+ box-shadow: 0 2px 8px rgba(0,0,0,0.1);
181
+ }
182
+
183
+ h1 {
184
+ color: #667eea;
185
+ margin-bottom: 0.5rem;
186
+ }
187
+
188
+ .metadata {
189
+ color: #666;
190
+ font-size: 0.95rem;
191
+ margin-bottom: 2rem;
192
+ padding: 1rem;
193
+ background-color: #f9f9f9;
194
+ border-radius: 4px;
195
+ }
196
+
197
+ .metadata p {
198
+ margin: 0.3rem 0;
199
+ }
200
+
201
+ .mermaid {
202
+ background-color: #f9f9f9;
203
+ border: 1px solid #e0e0e0;
204
+ border-radius: 6px;
205
+ padding: 1rem;
206
+ margin: 2rem 0;
207
+ overflow: auto;
208
+ }
209
+
210
+ .mermaid svg {
211
+ max-width: 100%;
212
+ height: auto;
213
+ }
214
+
215
+ .controls {
216
+ margin-bottom: 2rem;
217
+ display: flex;
218
+ gap: 1rem;
219
+ flex-wrap: wrap;
220
+ }
221
+
222
+ button {
223
+ padding: 0.6rem 1.2rem;
224
+ background-color: #667eea;
225
+ color: white;
226
+ border: none;
227
+ border-radius: 4px;
228
+ cursor: pointer;
229
+ font-size: 0.95rem;
230
+ transition: background-color 0.2s;
231
+ }
232
+
233
+ button:hover {
234
+ background-color: #764ba2;
235
+ }
236
+
237
+ .download-link {
238
+ display: inline-block;
239
+ padding: 0.6rem 1.2rem;
240
+ background-color: #667eea;
241
+ color: white;
242
+ text-decoration: none;
243
+ border-radius: 4px;
244
+ transition: background-color 0.2s;
245
+ }
246
+
247
+ .download-link:hover {
248
+ background-color: #764ba2;
249
+ }
250
+
251
+ @media print {
252
+ body {
253
+ background: white;
254
+ padding: 0;
255
+ }
256
+
257
+ .container {
258
+ box-shadow: none;
259
+ padding: 0;
260
+ }
261
+
262
+ .controls {
263
+ display: none;
264
+ }
265
+ }
266
+ </style>
267
+ </head>
268
+ <body>
269
+ <div class="container">
270
+ <h1>Database Entity Relationship Diagram</h1>
271
+ <div class="metadata">
272
+ <p><strong>Database:</strong> ${this.escapeHtml(state.database.name)}</p>
273
+ <p><strong>Server:</strong> ${this.escapeHtml(state.database.server)}</p>
274
+ <p><strong>Generated:</strong> ${new Date().toLocaleString()}</p>
275
+ <p><strong>Tables:</strong> ${state.summary.totalTables} | <strong>Columns:</strong> ${state.summary.totalColumns}</p>
276
+ </div>
277
+
278
+ <div class="controls">
279
+ <button onclick="downloadMmd()">Download .mmd File</button>
280
+ <button onclick="window.print()">Print / Save as PDF</button>
281
+ </div>
282
+
283
+ <div class="mermaid">
284
+ ${mermaidDiagram}
285
+ </div>
286
+ </div>
287
+
288
+ <script>
289
+ mermaid.initialize({ startOnLoad: true, theme: "default", securityLevel: "loose" });
290
+ mermaid.contentLoaded();
291
+
292
+ function downloadMmd() {
293
+ const content = \`${this.escapeLiteral(mermaidDiagram)}\`;
294
+ const element = document.createElement('a');
295
+ element.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(content));
296
+ element.setAttribute('download', '${state.database.name.replace(/\\s+/g, '_')}_erd.mmd');
297
+ element.style.display = 'none';
298
+ document.body.appendChild(element);
299
+ element.click();
300
+ document.body.removeChild(element);
301
+ }
302
+ </script>
303
+ </body>
304
+ </html>`;
305
+ }
306
+ escapeHtml(text) {
307
+ const map = {
308
+ '&': '&amp;',
309
+ '<': '&lt;',
310
+ '>': '&gt;',
311
+ '"': '&quot;',
312
+ "'": '&#039;'
313
+ };
314
+ return text.replace(/[&<>"']/g, (char) => map[char]);
315
+ }
316
+ escapeLiteral(text) {
317
+ return text.replace(/`/g, '\\`').replace(/\$/g, '\\$');
318
+ }
319
+ }
320
+ exports.MermaidGenerator = MermaidGenerator;
321
+ //# sourceMappingURL=MermaidGenerator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MermaidGenerator.js","sourceRoot":"","sources":["../../src/generators/MermaidGenerator.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,22 @@
1
+ /**
2
+ * Generates analysis reports
3
+ */
4
+ import { DatabaseDocumentation } from '../types/state.js';
5
+ import { StateManager } from '../state/StateManager.js';
6
+ export declare class ReportGenerator {
7
+ private stateManager;
8
+ constructor(stateManager: StateManager);
9
+ /**
10
+ * Generate analysis report
11
+ */
12
+ generate(state: DatabaseDocumentation): string;
13
+ /**
14
+ * Calculate overall statistics
15
+ */
16
+ private calculateStatistics;
17
+ /**
18
+ * Calculate confidence statistics
19
+ */
20
+ private calculateConfidenceStats;
21
+ }
22
+ //# sourceMappingURL=ReportGenerator.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ReportGenerator.d.ts","sourceRoot":"","sources":["../../src/generators/ReportGenerator.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAExD,qBAAa,eAAe;IACd,OAAO,CAAC,YAAY;gBAAZ,YAAY,EAAE,YAAY;IAE9C;;OAEG;IACI,QAAQ,CAAC,KAAK,EAAE,qBAAqB,GAAG,MAAM;IAiIrD;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAuB3B;;OAEG;IACH,OAAO,CAAC,wBAAwB;CAuCjC"}
@@ -0,0 +1,176 @@
1
+ "use strict";
2
+ /**
3
+ * Generates analysis reports
4
+ */
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.ReportGenerator = void 0;
7
+ class ReportGenerator {
8
+ constructor(stateManager) {
9
+ this.stateManager = stateManager;
10
+ }
11
+ /**
12
+ * Generate analysis report
13
+ */
14
+ generate(state) {
15
+ const lines = [];
16
+ lines.push('# Database Documentation Analysis Report');
17
+ lines.push('');
18
+ lines.push(`**Database**: ${state.database.name}`);
19
+ lines.push(`**Server**: ${state.database.server}`);
20
+ lines.push(`**Generated**: ${new Date().toISOString()}`);
21
+ lines.push('');
22
+ // Overall statistics
23
+ const stats = this.calculateStatistics(state);
24
+ lines.push('## Overall Statistics');
25
+ lines.push('');
26
+ lines.push(`- **Schemas**: ${stats.schemaCount}`);
27
+ lines.push(`- **Tables**: ${stats.tableCount}`);
28
+ lines.push(`- **Columns**: ${stats.columnCount}`);
29
+ lines.push(`- **Total Iterations**: ${state.summary.totalIterations}`);
30
+ lines.push(`- **Analysis Runs**: ${state.phases.descriptionGeneration.length}`);
31
+ lines.push('');
32
+ // Latest run details
33
+ if (state.phases.descriptionGeneration.length > 0) {
34
+ const lastRun = state.phases.descriptionGeneration[state.phases.descriptionGeneration.length - 1];
35
+ lines.push('## Latest Analysis Run');
36
+ lines.push('');
37
+ lines.push(`- **Run ID**: ${lastRun.runId}`);
38
+ lines.push(`- **Status**: ${lastRun.status}`);
39
+ lines.push(`- **Started**: ${lastRun.startedAt}`);
40
+ if (lastRun.completedAt) {
41
+ lines.push(`- **Completed**: ${lastRun.completedAt}`);
42
+ }
43
+ lines.push(`- **Model**: ${lastRun.modelUsed}`);
44
+ lines.push(`- **Iterations**: ${lastRun.iterationsPerformed}`);
45
+ lines.push(`- **Levels Processed**: ${lastRun.levelsProcessed}`);
46
+ lines.push(`- **Backpropagations**: ${lastRun.backpropagationCount}`);
47
+ lines.push(`- **Total Tokens**: ${lastRun.totalTokensUsed.toLocaleString()}`);
48
+ lines.push(`- **Estimated Cost**: $${lastRun.estimatedCost.toFixed(2)}`);
49
+ lines.push('');
50
+ if (lastRun.converged) {
51
+ lines.push(`**Convergence**: ${lastRun.convergenceReason}`);
52
+ lines.push('');
53
+ }
54
+ // Warnings
55
+ if (lastRun.warnings.length > 0) {
56
+ lines.push('### Warnings');
57
+ lines.push('');
58
+ for (const warning of lastRun.warnings) {
59
+ lines.push(`- ${warning}`);
60
+ }
61
+ lines.push('');
62
+ }
63
+ // Errors
64
+ if (lastRun.errors.length > 0) {
65
+ lines.push('### Errors');
66
+ lines.push('');
67
+ for (const error of lastRun.errors) {
68
+ lines.push(`- ${error}`);
69
+ }
70
+ lines.push('');
71
+ }
72
+ }
73
+ // Confidence distribution
74
+ const confidenceStats = this.calculateConfidenceStats(state);
75
+ lines.push('## Confidence Distribution');
76
+ lines.push('');
77
+ lines.push(`- **Average Confidence**: ${(confidenceStats.average * 100).toFixed(1)}%`);
78
+ lines.push(`- **High (>= 0.9)**: ${confidenceStats.high} tables`);
79
+ lines.push(`- **Medium (0.7 - 0.9)**: ${confidenceStats.medium} tables`);
80
+ lines.push(`- **Low (< 0.7)**: ${confidenceStats.low} tables`);
81
+ lines.push('');
82
+ // Low confidence tables
83
+ const lowConfidence = this.stateManager.getLowConfidenceTables(state, 0.7);
84
+ if (lowConfidence.length > 0) {
85
+ lines.push('### Low Confidence Tables');
86
+ lines.push('');
87
+ lines.push('| Schema | Table | Confidence | Description |');
88
+ lines.push('|--------|-------|------------|-------------|');
89
+ for (const item of lowConfidence) {
90
+ const descPreview = item.description.substring(0, 100);
91
+ lines.push(`| ${item.schema} | ${item.table} | ${(item.confidence * 100).toFixed(0)}% | ${descPreview}... |`);
92
+ }
93
+ lines.push('');
94
+ }
95
+ // Unprocessed tables
96
+ const unprocessed = this.stateManager.getUnprocessedTables(state);
97
+ if (unprocessed.length > 0) {
98
+ lines.push('### Unprocessed Tables');
99
+ lines.push('');
100
+ lines.push('| Schema | Table |');
101
+ lines.push('|--------|-------|');
102
+ for (const item of unprocessed) {
103
+ lines.push(`| ${item.schema} | ${item.table} |`);
104
+ }
105
+ lines.push('');
106
+ }
107
+ // Iteration history
108
+ if (state.phases.descriptionGeneration.length > 1) {
109
+ lines.push('## Iteration History');
110
+ lines.push('');
111
+ lines.push('| Run | Status | Iterations | Tokens | Cost | Converged |');
112
+ lines.push('|-----|--------|------------|--------|------|-----------|');
113
+ for (const run of state.phases.descriptionGeneration) {
114
+ lines.push(`| ${run.runId} | ${run.status} | ${run.iterationsPerformed} | ${run.totalTokensUsed.toLocaleString()} | $${run.estimatedCost.toFixed(2)} | ${run.converged ? 'Yes' : 'No'} |`);
115
+ }
116
+ lines.push('');
117
+ }
118
+ return lines.join('\n');
119
+ }
120
+ /**
121
+ * Calculate overall statistics
122
+ */
123
+ calculateStatistics(state) {
124
+ let tableCount = 0;
125
+ let columnCount = 0;
126
+ for (const schema of state.schemas) {
127
+ tableCount += schema.tables.length;
128
+ for (const table of schema.tables) {
129
+ columnCount += table.columns.length;
130
+ }
131
+ }
132
+ return {
133
+ schemaCount: state.schemas.length,
134
+ tableCount,
135
+ columnCount
136
+ };
137
+ }
138
+ /**
139
+ * Calculate confidence statistics
140
+ */
141
+ calculateConfidenceStats(state) {
142
+ let total = 0;
143
+ let count = 0;
144
+ let high = 0;
145
+ let medium = 0;
146
+ let low = 0;
147
+ for (const schema of state.schemas) {
148
+ for (const table of schema.tables) {
149
+ if (table.descriptionIterations.length > 0) {
150
+ const latest = table.descriptionIterations[table.descriptionIterations.length - 1];
151
+ if (latest.confidence !== undefined) {
152
+ total += latest.confidence;
153
+ count++;
154
+ if (latest.confidence >= 0.9) {
155
+ high++;
156
+ }
157
+ else if (latest.confidence >= 0.7) {
158
+ medium++;
159
+ }
160
+ else {
161
+ low++;
162
+ }
163
+ }
164
+ }
165
+ }
166
+ }
167
+ return {
168
+ average: count > 0 ? total / count : 0,
169
+ high,
170
+ medium,
171
+ low
172
+ };
173
+ }
174
+ }
175
+ exports.ReportGenerator = ReportGenerator;
176
+ //# sourceMappingURL=ReportGenerator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ReportGenerator.js","sourceRoot":"","sources":["../../src/generators/ReportGenerator.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,31 @@
1
+ /**
2
+ * Generates SQL scripts with sp_addextendedproperty statements
3
+ */
4
+ import { DatabaseDocumentation } from '../types/state.js';
5
+ export interface SQLGeneratorOptions {
6
+ approvedOnly?: boolean;
7
+ confidenceThreshold?: number;
8
+ }
9
+ export declare class SQLGenerator {
10
+ /**
11
+ * Generate SQL script
12
+ */
13
+ generate(state: DatabaseDocumentation, options?: SQLGeneratorOptions): string;
14
+ /**
15
+ * Generate schema description statement
16
+ */
17
+ private generateSchemaDescription;
18
+ /**
19
+ * Generate table description statement
20
+ */
21
+ private generateTableDescription;
22
+ /**
23
+ * Generate column description statement
24
+ */
25
+ private generateColumnDescription;
26
+ /**
27
+ * Escape string for SQL
28
+ */
29
+ private escapeString;
30
+ }
31
+ //# sourceMappingURL=SQLGenerator.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SQLGenerator.d.ts","sourceRoot":"","sources":["../../src/generators/SQLGenerator.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAC;AAE1D,MAAM,WAAW,mBAAmB;IAClC,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,mBAAmB,CAAC,EAAE,MAAM,CAAC;CAC9B;AAED,qBAAa,YAAY;IACvB;;OAEG;IACI,QAAQ,CACb,KAAK,EAAE,qBAAqB,EAC5B,OAAO,GAAE,mBAAwB,GAChC,MAAM;IAqET;;OAEG;IACH,OAAO,CAAC,yBAAyB;IAyBjC;;OAEG;IACH,OAAO,CAAC,wBAAwB;IAoChC;;OAEG;IACH,OAAO,CAAC,yBAAyB;IA0CjC;;OAEG;IACH,OAAO,CAAC,YAAY;CAGrB"}