@jingyi0605/codingns 0.8.1 → 0.8.5

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 (249) hide show
  1. package/bin/codingns.mjs +180 -0
  2. package/dist/public/assets/{AdaptiveButlerPage-b7s6F_sd.js → AdaptiveButlerPage-CJw8Ae62.js} +3 -3
  3. package/dist/public/assets/App-BOHBGFOd.js +30 -0
  4. package/dist/public/assets/{BootstrapPage-jFfl7KNK.js → BootstrapPage-BxHQT4nA.js} +1 -1
  5. package/dist/public/assets/{ConversationPage-sj_rn4q0.js → ConversationPage-DWFsF6BB.js} +6 -6
  6. package/dist/public/assets/{DesktopDetachPreviewPage-C5c88SOX.js → DesktopDetachPreviewPage-DOgEjYEf.js} +1 -1
  7. package/dist/public/assets/DesktopModal-D_A8sgQU.js +1 -0
  8. package/dist/public/assets/DesktopWindowPage-DK7L7osV.js +2 -0
  9. package/dist/public/assets/FileContextPanel-BdCoubcJ.js +1 -0
  10. package/dist/public/assets/GitSidebar-BeZ0hj7A.js +6 -0
  11. package/dist/public/assets/MobileCreateSessionSheet-DfLMVu8q.js +1 -0
  12. package/dist/public/assets/MobileSheet-5kZ-w-gU.js +1 -0
  13. package/dist/public/assets/{MobileTopHeaderFrame-_I0t7cC_.js → MobileTopHeaderFrame-lcp2GscV.js} +1 -1
  14. package/dist/public/assets/MobileWorkspaceSwitcherHeader-C6JMiOq_.js +1 -0
  15. package/dist/public/assets/PluginAccessOverview-DGcKAMQl.js +1 -0
  16. package/dist/public/assets/PluginContainerPage-BlY-xJDh.js +1 -0
  17. package/dist/public/assets/PluginDetailPage-CAJ7LFpD.js +1 -0
  18. package/dist/public/assets/PluginsListPage-BxZG1NyT.js +1 -0
  19. package/dist/public/assets/{RelayConnectEntryPage-CMtDWyGS.js → RelayConnectEntryPage-CfNO_TIl.js} +1 -1
  20. package/dist/public/assets/ServerSettingsModal-by36Z_5k.js +1 -0
  21. package/dist/public/assets/SessionIndexPage-DkBp9Mqz.js +1 -0
  22. package/dist/public/assets/SettingsPage-C-ASmJAG.js +2 -0
  23. package/dist/public/assets/TerminalManagerPanel-NVZRxxmH.js +1 -0
  24. package/dist/public/assets/{TerminalPage-CBIKHI33.js → TerminalPage-C4LNoPBp.js} +3 -3
  25. package/dist/public/assets/TerminalRuntimeFallbackModal-Bzum5nZ0.js +1 -0
  26. package/dist/public/assets/ToolFilesPage-47zbdgTW.js +1 -0
  27. package/dist/public/assets/ToolGitPage-Fuk_b_jg.js +1 -0
  28. package/dist/public/assets/ToolProcessesPage-sWSMWD-9.js +1 -0
  29. package/dist/public/assets/ToolsHomePage-R1mZlbZi.js +1 -0
  30. package/dist/public/assets/WorkbenchLandingPage-CqmiFH2u.js +1 -0
  31. package/dist/public/assets/WorkbenchLayout-OFi6CWgH.js +244 -0
  32. package/dist/public/assets/WorkbenchModal-C7qoQElW.js +1 -0
  33. package/dist/public/assets/WorkbenchShellRoute-BAQe_E0O.js +1 -0
  34. package/dist/public/assets/WorkspaceDebugDetailPage-DhKa6e9y.js +1 -0
  35. package/dist/public/assets/WorkspaceDetailPage-BPsrFffw.js +1 -0
  36. package/dist/public/assets/WorkspaceHomePage-KAtqZOAb.js +1 -0
  37. package/dist/public/assets/{client-runtime-manager-CdJP7nUp.js → client-runtime-manager-wmCJZKYd.js} +1 -1
  38. package/dist/public/assets/file-tree-icon-Mg1DiBRX.js +590 -0
  39. package/dist/public/assets/{index-VVxfF0s5.css → index-C4t-vvqk.css} +1 -1
  40. package/dist/public/assets/index-CL97fwWB.js +42 -0
  41. package/dist/public/assets/{login-direct-candidate-resolver-C-mo698r.js → login-direct-candidate-resolver-BOAgTuUf.js} +1 -1
  42. package/dist/public/assets/plugin-permission-copy-Cq99cnzV.js +1 -0
  43. package/dist/public/assets/plugins-api-BQTV5DOp.js +1 -0
  44. package/dist/public/assets/{preferences-service-CnaTvZq2.js → preferences-service-DJxbEEeg.js} +1 -1
  45. package/dist/public/assets/realtime-client-CLafKzzJ.js +1 -0
  46. package/dist/public/assets/{relay-entry-D7OgZZN-.js → relay-entry-D-LfvdiX.js} +1 -1
  47. package/dist/public/assets/{terminal-runtime-meta-BCtAYB0E.js → terminal-runtime-meta-BJmy8dyK.js} +1 -1
  48. package/dist/public/assets/useRegisteredDebugTemplates-DQAWVdCo.js +1 -0
  49. package/dist/public/assets/workbench-navigation-MEzCSmsK.js +1 -0
  50. package/dist/public/index.html +2 -2
  51. package/dist/server/config/env.d.ts +1 -0
  52. package/dist/server/config/env.js +4 -0
  53. package/dist/server/config/env.js.map +1 -1
  54. package/dist/server/helpers/wechat-claw-runtime/modules/runtime-state-store.js +1 -1
  55. package/dist/server/helpers/wechat-claw-runtime/modules/runtime-state-store.js.map +1 -1
  56. package/dist/server/modules/channels/wechat-claw-client.d.ts +51 -0
  57. package/dist/server/modules/channels/wechat-claw-client.js +245 -0
  58. package/dist/server/modules/channels/wechat-claw-client.js.map +1 -0
  59. package/dist/server/modules/file/file-access-guard.d.ts +2 -0
  60. package/dist/server/modules/file/file-access-guard.js +24 -2
  61. package/dist/server/modules/file/file-access-guard.js.map +1 -1
  62. package/dist/server/modules/file/file-controller.d.ts +153 -1
  63. package/dist/server/modules/file/file-controller.js +215 -1
  64. package/dist/server/modules/file/file-controller.js.map +1 -1
  65. package/dist/server/modules/file/file-preview-link-service.d.ts +2 -0
  66. package/dist/server/modules/file/file-preview-link-service.js +5 -1
  67. package/dist/server/modules/file/file-preview-link-service.js.map +1 -1
  68. package/dist/server/modules/file/runtime/codingns-workspace-bridge.js +911 -0
  69. package/dist/server/modules/file/workspace-file-bridge-service.d.ts +126 -0
  70. package/dist/server/modules/file/workspace-file-bridge-service.js +471 -0
  71. package/dist/server/modules/file/workspace-file-bridge-service.js.map +1 -0
  72. package/dist/server/modules/file/workspace-file-bridge-watch-service.d.ts +42 -0
  73. package/dist/server/modules/file/workspace-file-bridge-watch-service.js +304 -0
  74. package/dist/server/modules/file/workspace-file-bridge-watch-service.js.map +1 -0
  75. package/dist/server/modules/model-switch/cc-switch-adapter.js +1 -1
  76. package/dist/server/modules/model-switch/cc-switch-adapter.js.map +1 -1
  77. package/dist/server/modules/plugins/plugin-controller.d.ts +131 -0
  78. package/dist/server/modules/plugins/plugin-controller.js +277 -0
  79. package/dist/server/modules/plugins/plugin-controller.js.map +1 -0
  80. package/dist/server/modules/plugins/plugin-file-gateway-service.d.ts +38 -0
  81. package/dist/server/modules/plugins/plugin-file-gateway-service.js +178 -0
  82. package/dist/server/modules/plugins/plugin-file-gateway-service.js.map +1 -0
  83. package/dist/server/modules/plugins/plugin-manifest.d.ts +8 -0
  84. package/dist/server/modules/plugins/plugin-manifest.js +420 -0
  85. package/dist/server/modules/plugins/plugin-manifest.js.map +1 -0
  86. package/dist/server/modules/plugins/plugin-permission-service.d.ts +49 -0
  87. package/dist/server/modules/plugins/plugin-permission-service.js +267 -0
  88. package/dist/server/modules/plugins/plugin-permission-service.js.map +1 -0
  89. package/dist/server/modules/plugins/plugin-process-runner.d.ts +21 -0
  90. package/dist/server/modules/plugins/plugin-process-runner.js +127 -0
  91. package/dist/server/modules/plugins/plugin-process-runner.js.map +1 -0
  92. package/dist/server/modules/plugins/plugin-registry-service.d.ts +41 -0
  93. package/dist/server/modules/plugins/plugin-registry-service.js +238 -0
  94. package/dist/server/modules/plugins/plugin-registry-service.js.map +1 -0
  95. package/dist/server/modules/plugins/plugin-runtime-service.d.ts +55 -0
  96. package/dist/server/modules/plugins/plugin-runtime-service.js +252 -0
  97. package/dist/server/modules/plugins/plugin-runtime-service.js.map +1 -0
  98. package/dist/server/modules/plugins/plugin-runtime-session-service.d.ts +21 -0
  99. package/dist/server/modules/plugins/plugin-runtime-session-service.js +83 -0
  100. package/dist/server/modules/plugins/plugin-runtime-session-service.js.map +1 -0
  101. package/dist/server/modules/plugins/plugin-scheduler-service.d.ts +31 -0
  102. package/dist/server/modules/plugins/plugin-scheduler-service.js +232 -0
  103. package/dist/server/modules/plugins/plugin-scheduler-service.js.map +1 -0
  104. package/dist/server/modules/plugins/plugin-static-service.d.ts +11 -0
  105. package/dist/server/modules/plugins/plugin-static-service.js +145 -0
  106. package/dist/server/modules/plugins/plugin-static-service.js.map +1 -0
  107. package/dist/server/modules/presentation/presentation-controller.d.ts +3 -0
  108. package/dist/server/modules/presentation/presentation-controller.js +11 -0
  109. package/dist/server/modules/presentation/presentation-controller.js.map +1 -1
  110. package/dist/server/modules/presentation/presentation-export-task-service.d.ts +6 -0
  111. package/dist/server/modules/presentation/presentation-export-task-service.js +52 -8
  112. package/dist/server/modules/presentation/presentation-export-task-service.js.map +1 -1
  113. package/dist/server/modules/presentation/presentation-pptx-export-service.js +200 -14
  114. package/dist/server/modules/presentation/presentation-pptx-export-service.js.map +1 -1
  115. package/dist/server/modules/presentation/presentation-renderer.d.ts +50 -0
  116. package/dist/server/modules/presentation/presentation-renderer.js +450 -37
  117. package/dist/server/modules/presentation/presentation-renderer.js.map +1 -1
  118. package/dist/server/modules/tasks/task-types.d.ts +2 -0
  119. package/dist/server/modules/tasks/task-types.js +2 -0
  120. package/dist/server/modules/tasks/task-types.js.map +1 -1
  121. package/dist/server/modules/terminal/runtime/terminal-log-writer-process.js +1 -1
  122. package/dist/server/modules/terminal/runtime/terminal-log-writer-process.js.map +1 -1
  123. package/dist/server/routes/files.js +40 -0
  124. package/dist/server/routes/files.js.map +1 -1
  125. package/dist/server/routes/plugins-public.d.ts +3 -0
  126. package/dist/server/routes/plugins-public.js +5 -0
  127. package/dist/server/routes/plugins-public.js.map +1 -0
  128. package/dist/server/routes/plugins.d.ts +3 -0
  129. package/dist/server/routes/plugins.js +19 -0
  130. package/dist/server/routes/plugins.js.map +1 -0
  131. package/dist/server/routes/presentation.js +1 -0
  132. package/dist/server/routes/presentation.js.map +1 -1
  133. package/dist/server/server/create-server.d.ts +20 -0
  134. package/dist/server/server/create-server.js +47 -1
  135. package/dist/server/server/create-server.js.map +1 -1
  136. package/dist/server/shared/http/error-handler.js +10 -6
  137. package/dist/server/shared/http/error-handler.js.map +1 -1
  138. package/dist/server/shared/runtime/better-sqlite3.d.ts +5 -0
  139. package/dist/server/shared/runtime/better-sqlite3.js +6 -0
  140. package/dist/server/shared/runtime/better-sqlite3.js.map +1 -0
  141. package/dist/server/storage/repositories/plugin-audit-event-repository.d.ts +8 -0
  142. package/dist/server/storage/repositories/plugin-audit-event-repository.js +49 -0
  143. package/dist/server/storage/repositories/plugin-audit-event-repository.js.map +1 -0
  144. package/dist/server/storage/repositories/plugin-definition-repository.d.ts +10 -0
  145. package/dist/server/storage/repositories/plugin-definition-repository.js +84 -0
  146. package/dist/server/storage/repositories/plugin-definition-repository.js.map +1 -0
  147. package/dist/server/storage/repositories/plugin-enablement-repository.d.ts +9 -0
  148. package/dist/server/storage/repositories/plugin-enablement-repository.js +74 -0
  149. package/dist/server/storage/repositories/plugin-enablement-repository.js.map +1 -0
  150. package/dist/server/storage/repositories/plugin-permission-grant-repository.d.ts +12 -0
  151. package/dist/server/storage/repositories/plugin-permission-grant-repository.js +142 -0
  152. package/dist/server/storage/repositories/plugin-permission-grant-repository.js.map +1 -0
  153. package/dist/server/storage/repositories/plugin-run-repository.d.ts +10 -0
  154. package/dist/server/storage/repositories/plugin-run-repository.js +111 -0
  155. package/dist/server/storage/repositories/plugin-run-repository.js.map +1 -0
  156. package/dist/server/storage/repositories/plugin-runtime-session-repository.d.ts +10 -0
  157. package/dist/server/storage/repositories/plugin-runtime-session-repository.js +86 -0
  158. package/dist/server/storage/repositories/plugin-runtime-session-repository.js.map +1 -0
  159. package/dist/server/storage/sqlite/client.d.ts +2 -2
  160. package/dist/server/storage/sqlite/client.js +250 -1
  161. package/dist/server/storage/sqlite/client.js.map +1 -1
  162. package/dist/server/storage/sqlite/schema.sql +140 -0
  163. package/dist/server/types/domain.d.ts +122 -0
  164. package/package.json +10 -3
  165. package/scripts/postinstall.mjs +248 -11
  166. package/vendor/better-sqlite3-win32-x64-node22/LICENSE +21 -0
  167. package/vendor/better-sqlite3-win32-x64-node22/README.md +12 -0
  168. package/vendor/better-sqlite3-win32-x64-node22/README.upstream.md +99 -0
  169. package/vendor/better-sqlite3-win32-x64-node22/binding.gyp +38 -0
  170. package/vendor/better-sqlite3-win32-x64-node22/build/Release/better_sqlite3.node +0 -0
  171. package/vendor/better-sqlite3-win32-x64-node22/deps/common.gypi +68 -0
  172. package/vendor/better-sqlite3-win32-x64-node22/deps/copy.js +31 -0
  173. package/vendor/better-sqlite3-win32-x64-node22/deps/defines.gypi +41 -0
  174. package/vendor/better-sqlite3-win32-x64-node22/deps/download.sh +122 -0
  175. package/vendor/better-sqlite3-win32-x64-node22/deps/patches/1208.patch +15 -0
  176. package/vendor/better-sqlite3-win32-x64-node22/deps/sqlite3/sqlite3.c +265994 -0
  177. package/vendor/better-sqlite3-win32-x64-node22/deps/sqlite3/sqlite3.h +13968 -0
  178. package/vendor/better-sqlite3-win32-x64-node22/deps/sqlite3/sqlite3ext.h +730 -0
  179. package/vendor/better-sqlite3-win32-x64-node22/deps/sqlite3.gyp +80 -0
  180. package/vendor/better-sqlite3-win32-x64-node22/deps/test_extension.c +21 -0
  181. package/vendor/better-sqlite3-win32-x64-node22/lib/database.js +90 -0
  182. package/vendor/better-sqlite3-win32-x64-node22/lib/index.js +3 -0
  183. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/aggregate.js +43 -0
  184. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/backup.js +67 -0
  185. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/function.js +31 -0
  186. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/inspect.js +7 -0
  187. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/pragma.js +12 -0
  188. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/serialize.js +16 -0
  189. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/table.js +189 -0
  190. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/transaction.js +78 -0
  191. package/vendor/better-sqlite3-win32-x64-node22/lib/methods/wrappers.js +54 -0
  192. package/vendor/better-sqlite3-win32-x64-node22/lib/sqlite-error.js +20 -0
  193. package/vendor/better-sqlite3-win32-x64-node22/lib/util.js +12 -0
  194. package/vendor/better-sqlite3-win32-x64-node22/package.json +38 -0
  195. package/vendor/better-sqlite3-win32-x64-node22/scripts/verify-runtime.cjs +42 -0
  196. package/vendor/better-sqlite3-win32-x64-node22/src/addon.cpp +47 -0
  197. package/vendor/better-sqlite3-win32-x64-node22/src/better_sqlite3.cpp +74 -0
  198. package/vendor/better-sqlite3-win32-x64-node22/src/objects/backup.cpp +120 -0
  199. package/vendor/better-sqlite3-win32-x64-node22/src/objects/backup.hpp +36 -0
  200. package/vendor/better-sqlite3-win32-x64-node22/src/objects/database.cpp +417 -0
  201. package/vendor/better-sqlite3-win32-x64-node22/src/objects/database.hpp +103 -0
  202. package/vendor/better-sqlite3-win32-x64-node22/src/objects/statement-iterator.cpp +113 -0
  203. package/vendor/better-sqlite3-win32-x64-node22/src/objects/statement-iterator.hpp +50 -0
  204. package/vendor/better-sqlite3-win32-x64-node22/src/objects/statement.cpp +383 -0
  205. package/vendor/better-sqlite3-win32-x64-node22/src/objects/statement.hpp +58 -0
  206. package/vendor/better-sqlite3-win32-x64-node22/src/util/bind-map.cpp +73 -0
  207. package/vendor/better-sqlite3-win32-x64-node22/src/util/binder.cpp +193 -0
  208. package/vendor/better-sqlite3-win32-x64-node22/src/util/constants.cpp +172 -0
  209. package/vendor/better-sqlite3-win32-x64-node22/src/util/custom-aggregate.cpp +121 -0
  210. package/vendor/better-sqlite3-win32-x64-node22/src/util/custom-function.cpp +59 -0
  211. package/vendor/better-sqlite3-win32-x64-node22/src/util/custom-table.cpp +409 -0
  212. package/vendor/better-sqlite3-win32-x64-node22/src/util/data-converter.cpp +17 -0
  213. package/vendor/better-sqlite3-win32-x64-node22/src/util/data.cpp +194 -0
  214. package/vendor/better-sqlite3-win32-x64-node22/src/util/helpers.cpp +109 -0
  215. package/vendor/better-sqlite3-win32-x64-node22/src/util/macros.cpp +83 -0
  216. package/vendor/better-sqlite3-win32-x64-node22/src/util/query-macros.cpp +71 -0
  217. package/vendor/better-sqlite3-win32-x64-node22/src/util/row-builder.cpp +49 -0
  218. package/vendor/node-pty-fork/README.md +1 -0
  219. package/vendor/node-pty-fork/scripts/runtime-install-context.cjs +24 -0
  220. package/vendor/node-pty-fork/scripts/verify-runtime.cjs +8 -0
  221. package/vendor/node-pty-fork/scripts/verify-runtime.test.cjs +30 -0
  222. package/vendor-src/better-sqlite3-win32-x64-node22/README.md +12 -0
  223. package/dist/public/assets/App-B0q8uDA-.js +0 -30
  224. package/dist/public/assets/DesktopWindowPage-BdKUZrKG.js +0 -2
  225. package/dist/public/assets/FileContextPanel-lM5mBcfn.js +0 -1
  226. package/dist/public/assets/GitSidebar-CmXAhyjo.js +0 -6
  227. package/dist/public/assets/MobileCreateSessionSheet-CceV0-AH.js +0 -1
  228. package/dist/public/assets/MobileWorkspaceSwitcherHeader-DhaM9fgx.js +0 -1
  229. package/dist/public/assets/ServerSettingsModal-Rkgn3jft.js +0 -1
  230. package/dist/public/assets/SessionIndexPage-BOumP3ij.js +0 -1
  231. package/dist/public/assets/SettingsPage-vx_c-00-.js +0 -2
  232. package/dist/public/assets/TerminalManagerPanel-D9JHCS6d.js +0 -1
  233. package/dist/public/assets/TerminalRuntimeFallbackModal-W5NjqFEz.js +0 -1
  234. package/dist/public/assets/ToolFilesPage-DWtpaN_7.js +0 -1
  235. package/dist/public/assets/ToolGitPage-MpGXsw4_.js +0 -1
  236. package/dist/public/assets/ToolProcessesPage-B1jHQKhZ.js +0 -1
  237. package/dist/public/assets/ToolsHomePage-CJrn8ZFl.js +0 -1
  238. package/dist/public/assets/WorkbenchLandingPage-CJQ1V5U-.js +0 -1
  239. package/dist/public/assets/WorkbenchLayout-D48i71PU.js +0 -244
  240. package/dist/public/assets/WorkbenchModal-BYNuMIoV.js +0 -1
  241. package/dist/public/assets/WorkbenchShellRoute-CGKjy4J-.js +0 -1
  242. package/dist/public/assets/WorkspaceDebugDetailPage-DCAYgays.js +0 -1
  243. package/dist/public/assets/WorkspaceDetailPage-D5v-nUIi.js +0 -1
  244. package/dist/public/assets/WorkspaceHomePage-I5G1p5SR.js +0 -1
  245. package/dist/public/assets/file-tree-icon-BFwaPxKs.js +0 -590
  246. package/dist/public/assets/index-CjewzOUG.js +0 -42
  247. package/dist/public/assets/model-switch-api-Br0ivfe5.js +0 -1
  248. package/dist/public/assets/realtime-client-BlQRqVmm.js +0 -1
  249. package/dist/public/assets/useRegisteredDebugTemplates-CXmxu69X.js +0 -1
@@ -0,0 +1,54 @@
1
+ 'use strict';
2
+ const { cppdb } = require('../util');
3
+
4
+ exports.prepare = function prepare(sql) {
5
+ return this[cppdb].prepare(sql, this, false);
6
+ };
7
+
8
+ exports.exec = function exec(sql) {
9
+ this[cppdb].exec(sql);
10
+ return this;
11
+ };
12
+
13
+ exports.close = function close() {
14
+ this[cppdb].close();
15
+ return this;
16
+ };
17
+
18
+ exports.loadExtension = function loadExtension(...args) {
19
+ this[cppdb].loadExtension(...args);
20
+ return this;
21
+ };
22
+
23
+ exports.defaultSafeIntegers = function defaultSafeIntegers(...args) {
24
+ this[cppdb].defaultSafeIntegers(...args);
25
+ return this;
26
+ };
27
+
28
+ exports.unsafeMode = function unsafeMode(...args) {
29
+ this[cppdb].unsafeMode(...args);
30
+ return this;
31
+ };
32
+
33
+ exports.getters = {
34
+ name: {
35
+ get: function name() { return this[cppdb].name; },
36
+ enumerable: true,
37
+ },
38
+ open: {
39
+ get: function open() { return this[cppdb].open; },
40
+ enumerable: true,
41
+ },
42
+ inTransaction: {
43
+ get: function inTransaction() { return this[cppdb].inTransaction; },
44
+ enumerable: true,
45
+ },
46
+ readonly: {
47
+ get: function readonly() { return this[cppdb].readonly; },
48
+ enumerable: true,
49
+ },
50
+ memory: {
51
+ get: function memory() { return this[cppdb].memory; },
52
+ enumerable: true,
53
+ },
54
+ };
@@ -0,0 +1,20 @@
1
+ 'use strict';
2
+ const descriptor = { value: 'SqliteError', writable: true, enumerable: false, configurable: true };
3
+
4
+ function SqliteError(message, code) {
5
+ if (new.target !== SqliteError) {
6
+ return new SqliteError(message, code);
7
+ }
8
+ if (typeof code !== 'string') {
9
+ throw new TypeError('Expected second argument to be a string');
10
+ }
11
+ Error.call(this, message);
12
+ descriptor.value = '' + message;
13
+ Object.defineProperty(this, 'message', descriptor);
14
+ Error.captureStackTrace(this, SqliteError);
15
+ this.code = code;
16
+ }
17
+ Object.setPrototypeOf(SqliteError, Error);
18
+ Object.setPrototypeOf(SqliteError.prototype, Error.prototype);
19
+ Object.defineProperty(SqliteError.prototype, 'name', descriptor);
20
+ module.exports = SqliteError;
@@ -0,0 +1,12 @@
1
+ 'use strict';
2
+
3
+ exports.getBooleanOption = (options, key) => {
4
+ let value = false;
5
+ if (key in options && typeof (value = options[key]) !== 'boolean') {
6
+ throw new TypeError(`Expected the "${key}" option to be a boolean`);
7
+ }
8
+ return value;
9
+ };
10
+
11
+ exports.cppdb = Symbol();
12
+ exports.inspect = Symbol.for('nodejs.util.inspect.custom');
@@ -0,0 +1,38 @@
1
+ {
2
+ "name": "better-sqlite3",
3
+ "version": "12.8.0-cns.1",
4
+ "description": "CodingNS-maintained better-sqlite3 runtime bundle for Windows x64 + Node 22",
5
+ "license": "MIT",
6
+ "type": "commonjs",
7
+ "main": "./lib/index.js",
8
+ "files": [
9
+ "LICENSE",
10
+ "README.md",
11
+ "README.upstream.md",
12
+ "binding.gyp",
13
+ "lib",
14
+ "src",
15
+ "deps",
16
+ "build/Release",
17
+ "scripts"
18
+ ],
19
+ "os": [
20
+ "win32"
21
+ ],
22
+ "cpu": [
23
+ "x64"
24
+ ],
25
+ "engines": {
26
+ "node": "22.x"
27
+ },
28
+ "scripts": {
29
+ "install": "node ./scripts/verify-runtime.cjs",
30
+ "verify:runtime": "node ./scripts/verify-runtime.cjs"
31
+ },
32
+ "dependencies": {
33
+ "bindings": "^1.5.0"
34
+ },
35
+ "publishConfig": {
36
+ "access": "public"
37
+ }
38
+ }
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+
3
+ const fs = require("node:fs");
4
+ const path = require("node:path");
5
+
6
+ const packageRoot = path.resolve(__dirname, "..");
7
+ const releaseDir = path.join(packageRoot, "build", "Release");
8
+ const requiredFiles = [
9
+ path.join(packageRoot, "lib", "index.js"),
10
+ path.join(packageRoot, "binding.gyp")
11
+ ];
12
+
13
+ if (process.platform !== "win32") {
14
+ console.log("[codingns-better-sqlite3] 非 win32 环境,跳过运行时校验。");
15
+ process.exit(0);
16
+ }
17
+
18
+ if (process.arch !== "x64") {
19
+ console.error("[codingns-better-sqlite3] 当前仅支持 x64。");
20
+ process.exit(1);
21
+ }
22
+
23
+ const nodeMajor = Number((process.versions.node || "").split(".")[0]);
24
+ if (nodeMajor !== 22) {
25
+ console.error(`[codingns-better-sqlite3] 当前仅支持 Node 22,检测到 ${process.versions.node || "unknown"}。`);
26
+ process.exit(1);
27
+ }
28
+
29
+ for (const filePath of requiredFiles) {
30
+ if (!fs.existsSync(filePath)) {
31
+ console.error(`[codingns-better-sqlite3] 缺少关键文件:${filePath}`);
32
+ process.exit(1);
33
+ }
34
+ }
35
+
36
+ const binaryPath = path.join(releaseDir, "better_sqlite3.node");
37
+ if (!fs.existsSync(binaryPath)) {
38
+ console.error(`[codingns-better-sqlite3] 缺少预编译产物:${binaryPath}`);
39
+ process.exit(1);
40
+ }
41
+
42
+ console.log("[codingns-better-sqlite3] 运行时校验通过。");
@@ -0,0 +1,47 @@
1
+ struct Addon {
2
+ explicit Addon(v8::Isolate* isolate) :
3
+ privileged_info(NULL),
4
+ next_id(0),
5
+ cs(isolate) {}
6
+
7
+ static void Cleanup(void* ptr) {
8
+ Addon* addon = static_cast<Addon*>(ptr);
9
+ for (Database* db : addon->dbs) db->CloseHandles();
10
+ addon->dbs.clear();
11
+ delete addon;
12
+ }
13
+
14
+ inline sqlite3_uint64 NextId() {
15
+ return next_id++;
16
+ }
17
+
18
+ static void ConfigureURI() {
19
+ static std::once_flag init_flag;
20
+ std::call_once(init_flag, [](){
21
+ const char* env = getenv("SQLITE_USE_URI");
22
+ if (env != NULL) {
23
+ if (strcmp(env, "1") == 0) {
24
+ int status = sqlite3_config(SQLITE_CONFIG_URI, 1);
25
+ assert(status == SQLITE_OK); ((void)status);
26
+ } else if (strcmp(env, "0") == 0) {
27
+ int status = sqlite3_config(SQLITE_CONFIG_URI, 0);
28
+ assert(status == SQLITE_OK); ((void)status);
29
+ }
30
+ }
31
+ });
32
+ }
33
+
34
+ static NODE_METHOD(JS_setErrorConstructor) {
35
+ REQUIRE_ARGUMENT_FUNCTION(first, v8::Local<v8::Function> SqliteError);
36
+ OnlyAddon->SqliteError.Reset(OnlyIsolate, SqliteError);
37
+ }
38
+
39
+ v8::Global<v8::Function> Statement;
40
+ v8::Global<v8::Function> StatementIterator;
41
+ v8::Global<v8::Function> Backup;
42
+ v8::Global<v8::Function> SqliteError;
43
+ NODE_ARGUMENTS_POINTER privileged_info;
44
+ sqlite3_uint64 next_id;
45
+ CS cs;
46
+ std::set<Database*, Database::CompareDatabase> dbs;
47
+ };
@@ -0,0 +1,74 @@
1
+ #include <climits>
2
+ #include <cstdio>
3
+ #include <cstring>
4
+ #include <string>
5
+ #include <vector>
6
+ #include <set>
7
+ #include <unordered_map>
8
+ #include <algorithm>
9
+ #include <mutex>
10
+ #include <sqlite3.h>
11
+ #include <node.h>
12
+ #include <node_object_wrap.h>
13
+ #include <node_buffer.h>
14
+
15
+ struct Addon;
16
+ class Database;
17
+ class Statement;
18
+ class StatementIterator;
19
+ class Backup;
20
+
21
+ #include "util/macros.cpp"
22
+ #include "util/helpers.cpp"
23
+ #include "util/constants.cpp"
24
+ #include "util/bind-map.cpp"
25
+ #include "util/data-converter.cpp"
26
+ #include "util/data.cpp"
27
+ #if defined(NODE_MODULE_VERSION) && NODE_MODULE_VERSION >= 127
28
+ #include "util/row-builder.cpp"
29
+ #endif
30
+
31
+ #include "objects/backup.hpp"
32
+ #include "objects/statement.hpp"
33
+ #include "objects/database.hpp"
34
+ #include "addon.cpp"
35
+ #include "objects/statement-iterator.hpp"
36
+
37
+ #include "util/query-macros.cpp"
38
+ #include "util/custom-function.cpp"
39
+ #include "util/custom-aggregate.cpp"
40
+ #include "util/custom-table.cpp"
41
+ #include "util/binder.cpp"
42
+
43
+ #include "objects/backup.cpp"
44
+ #include "objects/statement.cpp"
45
+ #include "objects/database.cpp"
46
+ #include "objects/statement-iterator.cpp"
47
+
48
+ NODE_MODULE_INIT(/* exports, context */) {
49
+ #if defined(NODE_MODULE_VERSION) && NODE_MODULE_VERSION >= 140
50
+ // Use Isolate::GetCurrent as stated in deprecation message within v8_context.h 13.9.72320122
51
+ v8::Isolate* isolate = v8::Isolate::GetCurrent();
52
+ #else
53
+ v8::Isolate* isolate = context->GetIsolate();
54
+ #endif
55
+ v8::HandleScope scope(isolate);
56
+ Addon::ConfigureURI();
57
+
58
+ // Initialize addon instance.
59
+ Addon* addon = new Addon(isolate);
60
+ v8::Local<v8::External> data = v8::External::New(isolate, addon);
61
+ node::AddEnvironmentCleanupHook(isolate, Addon::Cleanup, addon);
62
+
63
+ // Create and export native-backed classes and functions.
64
+ exports->Set(context, InternalizedFromLatin1(isolate, "Database"), Database::Init(isolate, data)).FromJust();
65
+ exports->Set(context, InternalizedFromLatin1(isolate, "Statement"), Statement::Init(isolate, data)).FromJust();
66
+ exports->Set(context, InternalizedFromLatin1(isolate, "StatementIterator"), StatementIterator::Init(isolate, data)).FromJust();
67
+ exports->Set(context, InternalizedFromLatin1(isolate, "Backup"), Backup::Init(isolate, data)).FromJust();
68
+ exports->Set(context, InternalizedFromLatin1(isolate, "setErrorConstructor"), v8::FunctionTemplate::New(isolate, Addon::JS_setErrorConstructor, data)->GetFunction(context).ToLocalChecked()).FromJust();
69
+
70
+ // Store addon instance data.
71
+ addon->Statement.Reset(isolate, exports->Get(context, InternalizedFromLatin1(isolate, "Statement")).ToLocalChecked().As<v8::Function>());
72
+ addon->StatementIterator.Reset(isolate, exports->Get(context, InternalizedFromLatin1(isolate, "StatementIterator")).ToLocalChecked().As<v8::Function>());
73
+ addon->Backup.Reset(isolate, exports->Get(context, InternalizedFromLatin1(isolate, "Backup")).ToLocalChecked().As<v8::Function>());
74
+ }
@@ -0,0 +1,120 @@
1
+ Backup::Backup(
2
+ Database* db,
3
+ sqlite3* dest_handle,
4
+ sqlite3_backup* backup_handle,
5
+ sqlite3_uint64 id,
6
+ bool unlink
7
+ ) :
8
+ node::ObjectWrap(),
9
+ db(db),
10
+ dest_handle(dest_handle),
11
+ backup_handle(backup_handle),
12
+ id(id),
13
+ alive(true),
14
+ unlink(unlink) {
15
+ assert(db != NULL);
16
+ assert(dest_handle != NULL);
17
+ assert(backup_handle != NULL);
18
+ db->AddBackup(this);
19
+ }
20
+
21
+ Backup::~Backup() {
22
+ if (alive) db->RemoveBackup(this);
23
+ CloseHandles();
24
+ }
25
+
26
+ // Whenever this is used, db->RemoveBackup must be invoked beforehand.
27
+ void Backup::CloseHandles() {
28
+ if (alive) {
29
+ alive = false;
30
+ std::string filename(sqlite3_db_filename(dest_handle, "main"));
31
+ sqlite3_backup_finish(backup_handle);
32
+ int status = sqlite3_close(dest_handle);
33
+ assert(status == SQLITE_OK); ((void)status);
34
+ if (unlink) remove(filename.c_str());
35
+ }
36
+ }
37
+
38
+ INIT(Backup::Init) {
39
+ v8::Local<v8::FunctionTemplate> t = NewConstructorTemplate(isolate, data, JS_new, "Backup");
40
+ SetPrototypeMethod(isolate, data, t, "transfer", JS_transfer);
41
+ SetPrototypeMethod(isolate, data, t, "close", JS_close);
42
+ return t->GetFunction(OnlyContext).ToLocalChecked();
43
+ }
44
+
45
+ NODE_METHOD(Backup::JS_new) {
46
+ UseAddon;
47
+ if (!addon->privileged_info) return ThrowTypeError("Disabled constructor");
48
+ assert(info.IsConstructCall());
49
+ Database* db = Unwrap<Database>(addon->privileged_info->This());
50
+ REQUIRE_DATABASE_OPEN(db->GetState());
51
+ REQUIRE_DATABASE_NOT_BUSY(db->GetState());
52
+
53
+ v8::Local<v8::Object> database = (*addon->privileged_info)[0].As<v8::Object>();
54
+ v8::Local<v8::String> attachedName = (*addon->privileged_info)[1].As<v8::String>();
55
+ v8::Local<v8::String> destFile = (*addon->privileged_info)[2].As<v8::String>();
56
+ bool unlink = (*addon->privileged_info)[3].As<v8::Boolean>()->Value();
57
+
58
+ UseIsolate;
59
+ sqlite3* dest_handle;
60
+ v8::String::Utf8Value dest_file(isolate, destFile);
61
+ v8::String::Utf8Value attached_name(isolate, attachedName);
62
+ int mask = (SQLITE_OPEN_READWRITE | SQLITE_OPEN_CREATE);
63
+
64
+ if (sqlite3_open_v2(*dest_file, &dest_handle, mask, NULL) != SQLITE_OK) {
65
+ Database::ThrowSqliteError(addon, dest_handle);
66
+ int status = sqlite3_close(dest_handle);
67
+ assert(status == SQLITE_OK); ((void)status);
68
+ return;
69
+ }
70
+
71
+ sqlite3_extended_result_codes(dest_handle, 1);
72
+ sqlite3_limit(dest_handle, SQLITE_LIMIT_LENGTH, INT_MAX);
73
+ sqlite3_backup* backup_handle = sqlite3_backup_init(dest_handle, "main", db->GetHandle(), *attached_name);
74
+ if (backup_handle == NULL) {
75
+ Database::ThrowSqliteError(addon, dest_handle);
76
+ int status = sqlite3_close(dest_handle);
77
+ assert(status == SQLITE_OK); ((void)status);
78
+ return;
79
+ }
80
+
81
+ Backup* backup = new Backup(db, dest_handle, backup_handle, addon->NextId(), unlink);
82
+ backup->Wrap(info.This());
83
+ SetFrozen(isolate, OnlyContext, info.This(), addon->cs.database, database);
84
+
85
+ info.GetReturnValue().Set(info.This());
86
+ }
87
+
88
+ NODE_METHOD(Backup::JS_transfer) {
89
+ Backup* backup = Unwrap<Backup>(info.This());
90
+ REQUIRE_ARGUMENT_INT32(first, int pages);
91
+ REQUIRE_DATABASE_OPEN(backup->db->GetState());
92
+ assert(backup->db->GetState()->busy == false);
93
+ assert(backup->alive == true);
94
+
95
+ sqlite3_backup* backup_handle = backup->backup_handle;
96
+ int status = sqlite3_backup_step(backup_handle, pages) & 0xff;
97
+
98
+ Addon* addon = backup->db->GetAddon();
99
+ if (status == SQLITE_OK || status == SQLITE_DONE || status == SQLITE_BUSY) {
100
+ int total_pages = sqlite3_backup_pagecount(backup_handle);
101
+ int remaining_pages = sqlite3_backup_remaining(backup_handle);
102
+ UseIsolate;
103
+ UseContext;
104
+ v8::Local<v8::Object> result = v8::Object::New(isolate);
105
+ result->Set(ctx, addon->cs.totalPages.Get(isolate), v8::Int32::New(isolate, total_pages)).FromJust();
106
+ result->Set(ctx, addon->cs.remainingPages.Get(isolate), v8::Int32::New(isolate, remaining_pages)).FromJust();
107
+ info.GetReturnValue().Set(result);
108
+ if (status == SQLITE_DONE) backup->unlink = false;
109
+ } else {
110
+ Database::ThrowSqliteError(addon, sqlite3_errstr(status), status);
111
+ }
112
+ }
113
+
114
+ NODE_METHOD(Backup::JS_close) {
115
+ Backup* backup = Unwrap<Backup>(info.This());
116
+ assert(backup->db->GetState()->busy == false);
117
+ if (backup->alive) backup->db->RemoveBackup(backup);
118
+ backup->CloseHandles();
119
+ info.GetReturnValue().Set(info.This());
120
+ }
@@ -0,0 +1,36 @@
1
+ class Backup : public node::ObjectWrap {
2
+ public:
3
+
4
+ ~Backup();
5
+
6
+ // Whenever this is used, db->RemoveBackup must be invoked beforehand.
7
+ void CloseHandles();
8
+
9
+ // Used to support ordered containers.
10
+ static inline bool Compare(Backup const * const a, Backup const * const b) {
11
+ return a->id < b->id;
12
+ }
13
+
14
+ static INIT(Init);
15
+
16
+ private:
17
+
18
+ explicit Backup(
19
+ Database* db,
20
+ sqlite3* dest_handle,
21
+ sqlite3_backup* backup_handle,
22
+ sqlite3_uint64 id,
23
+ bool unlink
24
+ );
25
+
26
+ static NODE_METHOD(JS_new);
27
+ static NODE_METHOD(JS_transfer);
28
+ static NODE_METHOD(JS_close);
29
+
30
+ Database* const db;
31
+ sqlite3* const dest_handle;
32
+ sqlite3_backup* const backup_handle;
33
+ const sqlite3_uint64 id;
34
+ bool alive;
35
+ bool unlink;
36
+ };