fdb2 1.0.6 → 1.0.8

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 (193) hide show
  1. package/.vscodeignore +45 -0
  2. package/README.md +24 -85
  3. package/dist/package.json +115 -0
  4. package/dist/pnpm-lock.yaml +7447 -0
  5. package/dist/public/explorer.css +244 -111
  6. package/dist/public/explorer.js +523 -278
  7. package/dist/scripts/preinstall.js +112 -0
  8. package/dist/server/index.d.ts.map +1 -1
  9. package/dist/server/index.js +4 -9
  10. package/dist/server/index.js.map +1 -1
  11. package/dist/server/index.ts +5 -10
  12. package/dist/server/service/connection.service.d.ts.map +1 -1
  13. package/dist/server/service/connection.service.js +1 -0
  14. package/dist/server/service/connection.service.js.map +1 -1
  15. package/dist/server/service/connection.service.ts +1 -0
  16. package/dist/server/service/database/base.service.d.ts +4 -0
  17. package/dist/server/service/database/base.service.d.ts.map +1 -1
  18. package/dist/server/service/database/base.service.js +3 -3
  19. package/dist/server/service/database/base.service.js.map +1 -1
  20. package/dist/server/service/database/base.service.ts +8 -3
  21. package/dist/server/service/database/cockroachdb.service.d.ts +5 -0
  22. package/dist/server/service/database/cockroachdb.service.d.ts.map +1 -1
  23. package/dist/server/service/database/cockroachdb.service.js +112 -0
  24. package/dist/server/service/database/cockroachdb.service.js.map +1 -1
  25. package/dist/server/service/database/cockroachdb.service.ts +123 -0
  26. package/dist/server/service/database/database.service.d.ts +4 -0
  27. package/dist/server/service/database/database.service.d.ts.map +1 -1
  28. package/dist/server/service/database/database.service.js +8 -0
  29. package/dist/server/service/database/database.service.js.map +1 -1
  30. package/dist/server/service/database/database.service.ts +9 -0
  31. package/dist/server/service/database/mongodb.service.d.ts +6 -0
  32. package/dist/server/service/database/mongodb.service.d.ts.map +1 -1
  33. package/dist/server/service/database/mongodb.service.js +8 -0
  34. package/dist/server/service/database/mongodb.service.js.map +1 -1
  35. package/dist/server/service/database/mongodb.service.ts +9 -0
  36. package/dist/server/service/database/mssql.service.d.ts +4 -0
  37. package/dist/server/service/database/mssql.service.d.ts.map +1 -1
  38. package/dist/server/service/database/mssql.service.js +105 -0
  39. package/dist/server/service/database/mssql.service.js.map +1 -1
  40. package/dist/server/service/database/mssql.service.ts +118 -0
  41. package/dist/server/service/database/mysql.service.d.ts +4 -0
  42. package/dist/server/service/database/mysql.service.d.ts.map +1 -1
  43. package/dist/server/service/database/mysql.service.js +116 -0
  44. package/dist/server/service/database/mysql.service.js.map +1 -1
  45. package/dist/server/service/database/mysql.service.ts +130 -0
  46. package/dist/server/service/database/oracle.service.d.ts +4 -0
  47. package/dist/server/service/database/oracle.service.d.ts.map +1 -1
  48. package/dist/server/service/database/oracle.service.js +114 -0
  49. package/dist/server/service/database/oracle.service.js.map +1 -1
  50. package/dist/server/service/database/oracle.service.ts +128 -0
  51. package/dist/server/service/database/postgres.service.d.ts +4 -0
  52. package/dist/server/service/database/postgres.service.d.ts.map +1 -1
  53. package/dist/server/service/database/postgres.service.js +120 -0
  54. package/dist/server/service/database/postgres.service.js.map +1 -1
  55. package/dist/server/service/database/postgres.service.ts +131 -0
  56. package/dist/server/service/database/sap.service.d.ts +4 -0
  57. package/dist/server/service/database/sap.service.d.ts.map +1 -1
  58. package/dist/server/service/database/sap.service.js +107 -0
  59. package/dist/server/service/database/sap.service.js.map +1 -1
  60. package/dist/server/service/database/sap.service.ts +120 -0
  61. package/dist/server/service/database/sqlite.service.d.ts +5 -0
  62. package/dist/server/service/database/sqlite.service.d.ts.map +1 -1
  63. package/dist/server/service/database/sqlite.service.js +133 -0
  64. package/dist/server/service/database/sqlite.service.js.map +1 -1
  65. package/dist/server/service/database/sqlite.service.ts +150 -0
  66. package/fdb2.server.pid +1 -0
  67. package/package.json +18 -9
  68. package/packages/vscode/.vscodeignore +44 -0
  69. package/packages/vscode/README.md +62 -0
  70. package/packages/vscode/out/database-services/base.service.js +236 -0
  71. package/packages/vscode/out/database-services/base.service.js.map +1 -0
  72. package/packages/vscode/out/database-services/cockroachdb.service.js +634 -0
  73. package/packages/vscode/out/database-services/cockroachdb.service.js.map +1 -0
  74. package/packages/vscode/out/database-services/connection.service.js +346 -0
  75. package/packages/vscode/out/database-services/connection.service.js.map +1 -0
  76. package/packages/vscode/out/database-services/database.service.js +571 -0
  77. package/packages/vscode/out/database-services/database.service.js.map +1 -0
  78. package/packages/vscode/out/database-services/index.js +18 -0
  79. package/packages/vscode/out/database-services/index.js.map +1 -0
  80. package/packages/vscode/out/database-services/model/connection.entity.js +11 -0
  81. package/packages/vscode/out/database-services/model/connection.entity.js.map +1 -0
  82. package/packages/vscode/out/database-services/model/database.entity.js +35 -0
  83. package/packages/vscode/out/database-services/model/database.entity.js.map +1 -0
  84. package/packages/vscode/out/database-services/mongodb.service.js +458 -0
  85. package/packages/vscode/out/database-services/mongodb.service.js.map +1 -0
  86. package/packages/vscode/out/database-services/mssql.service.js +694 -0
  87. package/packages/vscode/out/database-services/mssql.service.js.map +1 -0
  88. package/packages/vscode/out/database-services/mysql.service.js +735 -0
  89. package/packages/vscode/out/database-services/mysql.service.js.map +1 -0
  90. package/packages/vscode/out/database-services/oracle.service.js +787 -0
  91. package/packages/vscode/out/database-services/oracle.service.js.map +1 -0
  92. package/packages/vscode/out/database-services/postgres.service.js +696 -0
  93. package/packages/vscode/out/database-services/postgres.service.js.map +1 -0
  94. package/packages/vscode/out/database-services/sap.service.js +695 -0
  95. package/packages/vscode/out/database-services/sap.service.js.map +1 -0
  96. package/packages/vscode/out/database-services/sqlite.service.js +532 -0
  97. package/packages/vscode/out/database-services/sqlite.service.js.map +1 -0
  98. package/packages/vscode/out/extension.js +93 -0
  99. package/packages/vscode/out/extension.js.map +1 -0
  100. package/packages/vscode/out/provider/DatabaseTreeProvider.js +159 -0
  101. package/packages/vscode/out/provider/DatabaseTreeProvider.js.map +1 -0
  102. package/packages/vscode/out/provider/WebViewProvider.js +259 -0
  103. package/packages/vscode/out/provider/WebViewProvider.js.map +1 -0
  104. package/packages/vscode/out/service/ConnectionManager.js +105 -0
  105. package/packages/vscode/out/service/ConnectionManager.js.map +1 -0
  106. package/packages/vscode/out/service/DatabaseServiceBridge.js +395 -0
  107. package/packages/vscode/out/service/DatabaseServiceBridge.js.map +1 -0
  108. package/packages/vscode/out/typings/connection.js +3 -0
  109. package/packages/vscode/out/typings/connection.js.map +1 -0
  110. package/packages/vscode/package.json +142 -0
  111. package/packages/vscode/resources/icon.svg +5 -0
  112. package/packages/vscode/resources/webview/_plugin-vue_export-helper.js +6529 -0
  113. package/packages/vscode/resources/webview/_plugin-vue_export-helper.js.map +1 -0
  114. package/packages/vscode/resources/webview/connection.css +69 -0
  115. package/packages/vscode/resources/webview/connection.js +228 -0
  116. package/packages/vscode/resources/webview/connection.js.map +1 -0
  117. package/packages/vscode/resources/webview/database.css +259 -0
  118. package/packages/vscode/resources/webview/database.js +275 -0
  119. package/packages/vscode/resources/webview/database.js.map +1 -0
  120. package/packages/vscode/resources/webview/favicon.ico +0 -0
  121. package/packages/vscode/resources/webview/index.html +9 -0
  122. package/packages/vscode/resources/webview/modules/header.tpl +14 -0
  123. package/packages/vscode/resources/webview/modules/initial_state.tpl +55 -0
  124. package/packages/vscode/resources/webview/query.css +162 -0
  125. package/packages/vscode/resources/webview/query.js +198 -0
  126. package/packages/vscode/resources/webview/query.js.map +1 -0
  127. package/packages/vscode/src/database-services/base.service.js.map +1 -0
  128. package/packages/vscode/src/database-services/base.service.ts +363 -0
  129. package/packages/vscode/src/database-services/cockroachdb.service.js.map +1 -0
  130. package/packages/vscode/src/database-services/cockroachdb.service.ts +659 -0
  131. package/packages/vscode/src/database-services/connection.service.ts +341 -0
  132. package/packages/vscode/src/database-services/database.service.ts +630 -0
  133. package/packages/vscode/src/database-services/index.ts +7 -0
  134. package/packages/vscode/src/database-services/model/connection.entity.js +11 -0
  135. package/packages/vscode/src/database-services/model/connection.entity.js.map +1 -0
  136. package/packages/vscode/src/database-services/model/connection.entity.ts +66 -0
  137. package/packages/vscode/src/database-services/model/database.entity.js +35 -0
  138. package/packages/vscode/src/database-services/model/database.entity.js.map +1 -0
  139. package/packages/vscode/src/database-services/model/database.entity.ts +246 -0
  140. package/packages/vscode/src/database-services/mongodb.service.js.map +1 -0
  141. package/packages/vscode/src/database-services/mongodb.service.ts +454 -0
  142. package/packages/vscode/src/database-services/mssql.service.js.map +1 -0
  143. package/packages/vscode/src/database-services/mssql.service.ts +723 -0
  144. package/packages/vscode/src/database-services/mysql.service.js.map +1 -0
  145. package/packages/vscode/src/database-services/mysql.service.ts +761 -0
  146. package/packages/vscode/src/database-services/oracle.service.js.map +1 -0
  147. package/packages/vscode/src/database-services/oracle.service.ts +832 -0
  148. package/packages/vscode/src/database-services/postgres.service.js.map +1 -0
  149. package/packages/vscode/src/database-services/postgres.service.ts +741 -0
  150. package/packages/vscode/src/database-services/sap.service.js.map +1 -0
  151. package/packages/vscode/src/database-services/sap.service.ts +713 -0
  152. package/packages/vscode/src/database-services/sqlite.service.js.map +1 -0
  153. package/packages/vscode/src/database-services/sqlite.service.ts +559 -0
  154. package/packages/vscode/src/extension.ts +76 -0
  155. package/packages/vscode/src/provider/DatabaseTreeProvider.ts +167 -0
  156. package/packages/vscode/src/provider/WebViewProvider.ts +277 -0
  157. package/packages/vscode/src/service/DatabaseServiceBridge.ts +414 -0
  158. package/packages/vscode/src/typings/connection.ts +90 -0
  159. package/packages/vscode/tsconfig.json +21 -0
  160. package/public/fdb2.png +0 -0
  161. package/server/backups/db_ai_breakout_2026-03-11T08-38-48-677Z.sql +0 -0
  162. package/server/index.ts +5 -10
  163. package/server/model/connection.entity.js +11 -0
  164. package/server/model/connection.entity.js.map +1 -0
  165. package/server/model/database.entity.js +35 -0
  166. package/server/model/database.entity.js.map +1 -0
  167. package/server/service/connection.service.ts +1 -0
  168. package/server/service/database/base.service.ts +8 -3
  169. package/server/service/database/cockroachdb.service.ts +123 -0
  170. package/server/service/database/database.service.ts +9 -0
  171. package/server/service/database/mongodb.service.ts +9 -0
  172. package/server/service/database/mssql.service.ts +118 -0
  173. package/server/service/database/mysql.service.ts +130 -0
  174. package/server/service/database/oracle.service.ts +128 -0
  175. package/server/service/database/postgres.service.ts +131 -0
  176. package/server/service/database/sap.service.ts +120 -0
  177. package/server/service/database/sqlite.service.ts +150 -0
  178. package/server/tsconfig.json +20 -0
  179. package/src/components/connection-editor/index.vue +0 -1
  180. package/src/platform/database/components/db-tools.vue +414 -174
  181. package/src/platform/database/components/table-detail.vue +3 -2
  182. package/src/platform/database/components/table-editor.vue +245 -18
  183. package/src/platform/vscode/bridge.ts +121 -0
  184. package/src/platform/vscode/components/ConnectionPanel.vue +272 -0
  185. package/src/platform/vscode/components/DatabasePanel.vue +532 -0
  186. package/src/platform/vscode/components/QueryPanel.vue +371 -0
  187. package/src/platform/vscode/entry/connection.ts +13 -0
  188. package/src/platform/vscode/entry/database.ts +13 -0
  189. package/src/platform/vscode/entry/query.ts +13 -0
  190. package/src/platform/vscode/index.ts +5 -0
  191. package/src/service/database.ts +2 -6
  192. package/vite.config.ts +46 -6
  193. package/vite.config.vscode.ts +47 -0
@@ -0,0 +1,167 @@
1
+ import * as vscode from 'vscode';
2
+ import { DatabaseServiceBridge } from '../service/DatabaseServiceBridge';
3
+ import { DatabaseConnection, DatabaseInfo, TableInfo } from '../typings/connection';
4
+
5
+ /**
6
+ * 树形视图项目类型
7
+ */
8
+ type TreeItemContext =
9
+ | 'connection' // 数据库连接
10
+ | 'database' // 数据库
11
+ | 'table' // 表
12
+ | 'view' // 视图
13
+ | 'table-actions'; // 表操作
14
+
15
+ /**
16
+ * 树形视图项目
17
+ */
18
+ class DatabaseItem extends vscode.TreeItem {
19
+ constructor(
20
+ public readonly label: string,
21
+ public readonly collapsibleState: vscode.TreeItemCollapsibleState,
22
+ public readonly contextValue: TreeItemContext,
23
+ public readonly connection?: DatabaseConnection,
24
+ public readonly database?: DatabaseInfo,
25
+ public readonly table?: TableInfo
26
+ ) {
27
+ super(label, collapsibleState);
28
+
29
+ // 设置图标
30
+ this.iconPath = this.getIconPath(contextValue);
31
+
32
+ // 设置描述
33
+ if (contextValue === 'connection' && connection) {
34
+ this.description = `${connection.host}:${connection.port}`;
35
+ } else if (contextValue === 'table' && table) {
36
+ this.description = table.type;
37
+ }
38
+ }
39
+
40
+ private getIconPath(contextValue: TreeItemContext): vscode.ThemeIcon {
41
+ switch (contextValue) {
42
+ case 'connection':
43
+ return new vscode.ThemeIcon('database');
44
+ case 'database':
45
+ return new vscode.ThemeIcon('server');
46
+ case 'table':
47
+ return new vscode.ThemeIcon('table');
48
+ case 'view':
49
+ return new vscode.ThemeIcon('preview');
50
+ case 'table-actions':
51
+ return new vscode.ThemeIcon('ellipsis');
52
+ default:
53
+ return new vscode.ThemeIcon('circle-outline');
54
+ }
55
+ }
56
+ }
57
+
58
+ /**
59
+ * 数据库树形视图提供者
60
+ * 提供侧边栏的数据库连接和结构树
61
+ */
62
+ export class DatabaseTreeProvider implements vscode.TreeDataProvider<DatabaseItem> {
63
+ private _onDidChangeTreeData = new vscode.EventEmitter<DatabaseItem | undefined>();
64
+ readonly onDidChangeTreeData = this._onDidChangeTreeData.event;
65
+
66
+ constructor(
67
+ private context: vscode.ExtensionContext,
68
+ private dbBridge: DatabaseServiceBridge
69
+ ) {}
70
+
71
+ refresh(): void {
72
+ this._onDidChangeTreeData.fire(undefined);
73
+ }
74
+
75
+ getTreeItem(element: DatabaseItem): vscode.TreeItem {
76
+ return element;
77
+ }
78
+
79
+ async getChildren(element?: DatabaseItem): Promise<DatabaseItem[]> {
80
+ if (!element) {
81
+ // 根节点:显示所有连接
82
+ const connections = await this.dbBridge.connection.getAllConnections();
83
+ return connections.map((conn: any) => {
84
+ const item = new DatabaseItem(
85
+ conn.name,
86
+ vscode.TreeItemCollapsibleState.Collapsed,
87
+ 'connection',
88
+ conn
89
+ );
90
+ item.command = {
91
+ command: 'fdb2.openDatabasePanel',
92
+ title: '打开数据库',
93
+ arguments: [conn]
94
+ };
95
+ return item;
96
+ });
97
+ }
98
+
99
+ if (element.contextValue === 'connection') {
100
+ // 连接节点:显示数据库列表(SQLite 不显示)
101
+ if (element.connection?.type === 'sqlite') {
102
+ return await this.getTables(element.connection, '');
103
+ }
104
+ return await this.getDatabases(element.connection);
105
+ }
106
+
107
+ if (element.contextValue === 'database') {
108
+ // 数据库节点:显示表列表
109
+ return await this.getTables(element.connection, element.database?.name || '');
110
+ }
111
+
112
+ if (element.contextValue === 'table' || element.contextValue === 'view') {
113
+ // 表节点:显示操作按钮
114
+ return [
115
+ new DatabaseItem('查看数据', vscode.TreeItemCollapsibleState.None, 'table-actions'),
116
+ new DatabaseItem('查看结构', vscode.TreeItemCollapsibleState.None, 'table-actions'),
117
+ new DatabaseItem('导出数据', vscode.TreeItemCollapsibleState.None, 'table-actions')
118
+ ];
119
+ }
120
+
121
+ return [];
122
+ }
123
+
124
+ /**
125
+ * 获取数据库列表
126
+ */
127
+ private async getDatabases(connection: DatabaseConnection): Promise<DatabaseItem[]> {
128
+ if (!connection) return [];
129
+ try {
130
+ const databases = await this.dbBridge.database.getDatabases(connection.id);
131
+ return databases.map(db =>
132
+ new DatabaseItem(
133
+ db,
134
+ vscode.TreeItemCollapsibleState.Collapsed,
135
+ 'database',
136
+ connection,
137
+ db
138
+ )
139
+ );
140
+ } catch (error: any) {
141
+ vscode.window.showErrorMessage(`获取数据库列表失败: ${error.message}`);
142
+ return [];
143
+ }
144
+ }
145
+
146
+ /**
147
+ * 获取表列表
148
+ */
149
+ private async getTables(connection: DatabaseConnection, databaseName: string): Promise<DatabaseItem[]> {
150
+ try {
151
+ const tables = await this.dbBridge.database.getTables(connection.id, databaseName);
152
+ return tables.map(table =>
153
+ new DatabaseItem(
154
+ table.name,
155
+ vscode.TreeItemCollapsibleState.Collapsed,
156
+ table.type === 'view' ? 'view' : 'table',
157
+ connection,
158
+ undefined,
159
+ table
160
+ )
161
+ );
162
+ } catch (error: any) {
163
+ vscode.window.showErrorMessage(`获取表列表失败: ${error.message}`);
164
+ return [];
165
+ }
166
+ }
167
+ }
@@ -0,0 +1,277 @@
1
+ import * as vscode from 'vscode';
2
+ import * as path from 'path';
3
+ import { DatabaseServiceBridge } from '../service/DatabaseServiceBridge';
4
+
5
+ /**
6
+ * WebView 提供者
7
+ * 负责创建和管理 WebView 面板
8
+ */
9
+ export class WebViewProvider {
10
+ private panels: Map<string, vscode.WebviewPanel> = new Map();
11
+
12
+ constructor(
13
+ private context: vscode.ExtensionContext,
14
+ private dbBridge: DatabaseServiceBridge
15
+ ) {}
16
+
17
+ /**
18
+ * 显示查询面板
19
+ */
20
+ async showQueryPanel(): Promise<void> {
21
+ const panel = vscode.window.createWebviewPanel(
22
+ 'fdb2.query',
23
+ 'SQL 查询',
24
+ vscode.ViewColumn.One,
25
+ {
26
+ enableScripts: true,
27
+ retainContextWhenHidden: true,
28
+ localResourceRoots: [
29
+ vscode.Uri.file(path.join(this.context.extensionPath, 'resources', 'webview'))
30
+ ]
31
+ }
32
+ );
33
+
34
+ panel.webview.html = this.getWebviewContent(panel.webview, 'query');
35
+ this.setupMessageHandler(panel, 'query');
36
+
37
+ this.panels.set('query', panel);
38
+
39
+ // 发送连接列表
40
+ this.sendConnections(panel);
41
+ }
42
+
43
+ /**
44
+ * 显示数据库管理面板
45
+ */
46
+ async showDatabasePanel(connection?: any): Promise<void> {
47
+ const panel = vscode.window.createWebviewPanel(
48
+ 'fdb2.database',
49
+ '数据库管理',
50
+ vscode.ViewColumn.One,
51
+ {
52
+ enableScripts: true,
53
+ retainContextWhenHidden: true,
54
+ localResourceRoots: [
55
+ vscode.Uri.file(path.join(this.context.extensionPath, 'resources', 'webview'))
56
+ ]
57
+ }
58
+ );
59
+
60
+ panel.webview.html = this.getWebviewContent(panel.webview, 'database');
61
+ this.setupMessageHandler(panel, 'database');
62
+
63
+ this.panels.set('database', panel);
64
+
65
+ // 如果指定了连接,发送连接信息
66
+ if (connection) {
67
+ panel.webview.postMessage({ command: 'selectConnection', data: connection });
68
+ }
69
+ }
70
+
71
+ /**
72
+ * 显示添加连接面板
73
+ */
74
+ async showAddConnectionPanel(): Promise<void> {
75
+ const panel = vscode.window.createWebviewPanel(
76
+ 'fdb2.connection',
77
+ '添加数据库连接',
78
+ vscode.ViewColumn.One,
79
+ {
80
+ enableScripts: true,
81
+ retainContextWhenHidden: true
82
+ }
83
+ );
84
+
85
+ panel.webview.html = this.getWebviewContent(panel.webview, 'connection');
86
+ this.setupMessageHandler(panel, 'connection');
87
+
88
+ panel.onDidDispose(() => {
89
+ // 面板关闭后刷新树形视图
90
+ vscode.commands.executeCommand('fdb2.refreshConnections');
91
+ });
92
+ }
93
+
94
+ /**
95
+ * 显示编辑连接面板
96
+ */
97
+ async showEditConnectionPanel(connection: any): Promise<void> {
98
+ const panel = vscode.window.createWebviewPanel(
99
+ 'fdb2.connection',
100
+ '编辑数据库连接',
101
+ vscode.ViewColumn.One,
102
+ {
103
+ enableScripts: true,
104
+ retainContextWhenHidden: true
105
+ }
106
+ );
107
+
108
+ panel.webview.html = this.getWebviewContent(panel.webview, 'connection');
109
+ this.setupMessageHandler(panel, 'connection');
110
+
111
+ // 发送连接数据用于编辑
112
+ setTimeout(() => {
113
+ panel.webview.postMessage({ command: 'editConnection', data: connection });
114
+ }, 100);
115
+
116
+ panel.onDidDispose(() => {
117
+ vscode.commands.executeCommand('fdb2.refreshConnections');
118
+ });
119
+ }
120
+
121
+ /**
122
+ * 获取 WebView 内容
123
+ */
124
+ private getWebviewContent(webview: vscode.Webview, type: string): string {
125
+ const scriptPath = path.join(this.context.extensionPath, 'resources', 'webview', `${type}.js`);
126
+ const stylePath = path.join(this.context.extensionPath, 'resources', 'webview', `${type}.css`);
127
+
128
+ const scriptUri = webview.asWebviewUri(vscode.Uri.file(scriptPath));
129
+ const styleUri = webview.asWebviewUri(vscode.Uri.file(stylePath));
130
+
131
+ // 获取数据库类型列表
132
+ const databaseTypes = this.getDatabaseTypes();
133
+
134
+ return `<!DOCTYPE html>
135
+ <html lang="zh-CN">
136
+ <head>
137
+ <meta charset="UTF-8">
138
+ <meta name="viewport" content="width=device-width, initial-scale=1.0">
139
+ <title>Database Tool</title>
140
+ <link rel="stylesheet" href="${styleUri}">
141
+ <style>
142
+ body {
143
+ margin: 0;
144
+ padding: 0;
145
+ font-family: var(--vscode-font-family);
146
+ color: var(--vscode-foreground);
147
+ background-color: var(--vscode-editor-background);
148
+ }
149
+ #app {
150
+ height: 100vh;
151
+ overflow: auto;
152
+ }
153
+ </style>
154
+ </head>
155
+ <body>
156
+ <div id="app"></div>
157
+ <script>
158
+ // VSCode API
159
+ const vscode = acquireVsCodeApi();
160
+
161
+ // 数据库类型配置
162
+ window.DATABASE_TYPES = ${JSON.stringify(databaseTypes)};
163
+ </script>
164
+ <script src="${scriptUri}"></script>
165
+ </body>
166
+ </html>`;
167
+ }
168
+
169
+ /**
170
+ * 设置消息处理器
171
+ */
172
+ private setupMessageHandler(panel: vscode.WebviewPanel, type: string): void {
173
+ panel.webview.onDidReceiveMessage(
174
+ async message => {
175
+ await this.handleMessage(panel, message);
176
+ },
177
+ undefined,
178
+ this.context.subscriptions
179
+ );
180
+
181
+ panel.onDidDispose(() => {
182
+ this.panels.delete(type);
183
+ });
184
+ }
185
+
186
+ /**
187
+ * 处理来自 WebView 的消息
188
+ */
189
+ private async handleMessage(panel: vscode.WebviewPanel, message: any): Promise<void> {
190
+ try {
191
+ switch (message.command) {
192
+ case 'getConnections':
193
+ this.sendConnections(panel);
194
+ break;
195
+
196
+ case 'addConnection':
197
+ await this.dbBridge.connection.addConnection(message.data);
198
+ panel.webview.postMessage({ command: 'connectionAdded', data: message.data });
199
+ vscode.window.showInformationMessage('连接添加成功');
200
+ break;
201
+
202
+ case 'updateConnection':
203
+ await this.dbBridge.connection.updateConnection(message.data.id, message.data);
204
+ panel.webview.postMessage({ command: 'connectionUpdated', data: message.data });
205
+ vscode.window.showInformationMessage('连接更新成功');
206
+ break;
207
+
208
+ case 'testConnection':
209
+ const success = await this.dbBridge.connection.testConnection(message.data);
210
+ panel.webview.postMessage({ command: 'testResult', data: { success } });
211
+ if (success) {
212
+ vscode.window.showInformationMessage('连接测试成功');
213
+ } else {
214
+ vscode.window.showErrorMessage('连接测试失败');
215
+ }
216
+ break;
217
+
218
+ case 'executeQuery':
219
+ const queryResult = await this.dbBridge.database.executeQuery(message.data.connectionId, message.data.sql, message.data.database);
220
+ panel.webview.postMessage({
221
+ command: 'queryResult',
222
+ data: queryResult
223
+ });
224
+ break;
225
+
226
+ case 'getTables':
227
+ const tables = await this.dbBridge.database.getTables(message.data.connectionId, message.data.database);
228
+ panel.webview.postMessage({
229
+ command: 'tables',
230
+ data: tables
231
+ });
232
+ break;
233
+
234
+ case 'getDatabases':
235
+ const databases = await this.dbBridge.database.getDatabases(message.data.connectionId);
236
+ panel.webview.postMessage({
237
+ command: 'databases',
238
+ data: databases
239
+ });
240
+ break;
241
+
242
+ default:
243
+ console.warn('Unknown command:', message.command);
244
+ }
245
+ } catch (error: any) {
246
+ vscode.window.showErrorMessage(`操作失败: ${error.message}`);
247
+ panel.webview.postMessage({
248
+ command: 'error',
249
+ data: error.message
250
+ });
251
+ }
252
+ }
253
+
254
+ /**
255
+ * 发送连接列表到 WebView
256
+ */
257
+ private async sendConnections(panel: vscode.WebviewPanel): Promise<void> {
258
+ const connections = await this.dbBridge.connection.getAllConnections();
259
+ panel.webview.postMessage({ command: 'connections', data: connections });
260
+ }
261
+
262
+ /**
263
+ * 获取数据库类型列表
264
+ */
265
+ private getDatabaseTypes(): any[] {
266
+ return [
267
+ { type: 'mysql', name: 'MySQL', defaultPort: 3306 },
268
+ { type: 'postgresql', name: 'PostgreSQL', defaultPort: 5432 },
269
+ { type: 'sqlite', name: 'SQLite', defaultPort: 0 },
270
+ { type: 'sqlserver', name: 'SQL Server', defaultPort: 1433 },
271
+ { type: 'oracle', name: 'Oracle', defaultPort: 1521 },
272
+ { type: 'cockroachdb', name: 'CockroachDB', defaultPort: 26257 },
273
+ { type: 'mongodb', name: 'MongoDB', defaultPort: 27017 },
274
+ { type: 'sap_hana', name: 'SAP HANA', defaultPort: 39013 }
275
+ ];
276
+ }
277
+ }