@simplysm/sd-claude 14.0.50 → 14.0.52

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 (318) hide show
  1. package/claude/references/sd-frontend-design.md +10 -9
  2. package/claude/references/sd-simplysm-v14/angular/README.md +497 -0
  3. package/claude/references/sd-simplysm-v14/angular/bootstrap/provide-sd-angular.md +37 -0
  4. package/claude/references/sd-simplysm-v14/angular/bootstrap/sd-angular-config-provider.md +16 -0
  5. package/claude/references/sd-simplysm-v14/angular/directives/sd-command-directive.md +27 -0
  6. package/claude/references/sd-simplysm-v14/angular/directives/sd-events.md +25 -0
  7. package/claude/references/sd-simplysm-v14/angular/directives/sd-intersection-directive.md +36 -0
  8. package/claude/references/sd-simplysm-v14/angular/directives/sd-invalid.md +24 -0
  9. package/claude/references/sd-simplysm-v14/angular/directives/sd-resize-directive.md +42 -0
  10. package/claude/references/sd-simplysm-v14/angular/directives/sd-ripple.md +23 -0
  11. package/claude/references/sd-simplysm-v14/angular/directives/sd-router-link.md +38 -0
  12. package/claude/references/sd-simplysm-v14/angular/directives/sd-show-effect.md +18 -0
  13. package/claude/references/sd-simplysm-v14/angular/directives/sd-typed-template.md +69 -0
  14. package/claude/references/sd-simplysm-v14/angular/features/sd-address-search-modal.md +50 -0
  15. package/claude/references/sd-simplysm-v14/angular/features/sd-permission-table.md +20 -0
  16. package/claude/references/sd-simplysm-v14/angular/features/sd-shared-data-components.md +158 -0
  17. package/claude/references/sd-simplysm-v14/angular/features/sd-tiptap-editor.md +26 -0
  18. package/claude/references/sd-simplysm-v14/angular/pipes/format-pipe.md +41 -0
  19. package/claude/references/sd-simplysm-v14/angular/plugins/sd-global-error-handler.md +23 -0
  20. package/claude/references/sd-simplysm-v14/angular/plugins/sd-option-event-plugin.md +34 -0
  21. package/claude/references/sd-simplysm-v14/angular/provider-types/sd-menu.md +65 -0
  22. package/claude/references/sd-simplysm-v14/angular/provider-types/sd-modal-content-def.md +148 -0
  23. package/claude/references/sd-simplysm-v14/angular/provider-types/sd-toast-content-def.md +73 -0
  24. package/claude/references/sd-simplysm-v14/angular/provider-types/shared-data-base.md +59 -0
  25. package/claude/references/sd-simplysm-v14/angular/providers/sd-activated-modal-provider.md +34 -0
  26. package/claude/references/sd-simplysm-v14/angular/providers/sd-app-structure-provider.md +81 -0
  27. package/claude/references/sd-simplysm-v14/angular/providers/sd-busy-provider.md +18 -0
  28. package/claude/references/sd-simplysm-v14/angular/providers/sd-file-dialog-provider.md +40 -0
  29. package/claude/references/sd-simplysm-v14/angular/providers/sd-local-storage-provider.md +20 -0
  30. package/claude/references/sd-simplysm-v14/angular/providers/sd-modal-provider.md +67 -0
  31. package/claude/references/sd-simplysm-v14/angular/providers/sd-navigate-window-provider.md +18 -0
  32. package/claude/references/sd-simplysm-v14/angular/providers/sd-print-provider.md +25 -0
  33. package/claude/references/sd-simplysm-v14/angular/providers/sd-service-client-factory-provider.md +43 -0
  34. package/claude/references/sd-simplysm-v14/angular/providers/sd-shared-data-provider.md +64 -0
  35. package/claude/references/sd-simplysm-v14/angular/providers/sd-system-config-provider.md +46 -0
  36. package/claude/references/sd-simplysm-v14/angular/providers/sd-system-log-provider.md +18 -0
  37. package/claude/references/sd-simplysm-v14/angular/providers/sd-theme-provider.md +38 -0
  38. package/claude/references/sd-simplysm-v14/angular/providers/sd-toast-provider.md +65 -0
  39. package/claude/references/sd-simplysm-v14/angular/recipes/_common-rules.md +336 -0
  40. package/claude/references/sd-simplysm-v14/angular/recipes/crud-detail/extension-a-edit-save.md +191 -0
  41. package/claude/references/sd-simplysm-v14/angular/recipes/crud-detail/extension-b-delete-restore.md +103 -0
  42. package/claude/references/sd-simplysm-v14/angular/recipes/crud-detail/extension-c-modal-view.md +198 -0
  43. package/claude/references/sd-simplysm-v14/angular/recipes/crud-detail/extension-d-control-view.md +109 -0
  44. package/claude/references/sd-simplysm-v14/angular/recipes/crud-detail/extension-e-auxiliary.md +87 -0
  45. package/claude/references/sd-simplysm-v14/angular/recipes/crud-detail/extension-f-complex-detail.md +202 -0
  46. package/claude/references/sd-simplysm-v14/angular/recipes/crud-detail.md +280 -0
  47. package/claude/references/sd-simplysm-v14/angular/recipes/crud-list/extension-a-inline-edit.md +386 -0
  48. package/claude/references/sd-simplysm-v14/angular/recipes/crud-list/extension-b-selection.md +215 -0
  49. package/claude/references/sd-simplysm-v14/angular/recipes/crud-list/extension-c-inline-delete.md +64 -0
  50. package/claude/references/sd-simplysm-v14/angular/recipes/crud-list/extension-d-select-modal.md +193 -0
  51. package/claude/references/sd-simplysm-v14/angular/recipes/crud-list/extension-e-readonly-modal.md +140 -0
  52. package/claude/references/sd-simplysm-v14/angular/recipes/crud-list/extension-f-modal-edit.md +123 -0
  53. package/claude/references/sd-simplysm-v14/angular/recipes/crud-list/extension-g-excel.md +145 -0
  54. package/claude/references/sd-simplysm-v14/angular/recipes/crud-list.md +377 -0
  55. package/claude/references/sd-simplysm-v14/angular/recipes/data-select-button.md +368 -0
  56. package/claude/references/sd-simplysm-v14/angular/recipes/page-modal-container.md +238 -0
  57. package/claude/references/sd-simplysm-v14/angular/styling/classes.md +149 -0
  58. package/claude/references/sd-simplysm-v14/angular/styling/mixins.md +100 -0
  59. package/claude/references/sd-simplysm-v14/angular/styling/themes.md +35 -0
  60. package/claude/references/sd-simplysm-v14/angular/styling/variables.md +147 -0
  61. package/claude/references/sd-simplysm-v14/angular/type-utilities/directive-input-signals.md +232 -0
  62. package/claude/references/sd-simplysm-v14/angular/ui-data/sd-list.md +37 -0
  63. package/claude/references/sd-simplysm-v14/angular/ui-data/sd-sheet.md +212 -0
  64. package/claude/references/sd-simplysm-v14/angular/ui-form/sd-additional-button.md +26 -0
  65. package/claude/references/sd-simplysm-v14/angular/ui-form/sd-anchor.md +31 -0
  66. package/claude/references/sd-simplysm-v14/angular/ui-form/sd-button.md +103 -0
  67. package/claude/references/sd-simplysm-v14/angular/ui-form/sd-checkbox-group.md +39 -0
  68. package/claude/references/sd-simplysm-v14/angular/ui-form/sd-checkbox.md +81 -0
  69. package/claude/references/sd-simplysm-v14/angular/ui-form/sd-date-range-picker.md +27 -0
  70. package/claude/references/sd-simplysm-v14/angular/ui-form/sd-form.md +89 -0
  71. package/claude/references/sd-simplysm-v14/angular/ui-form/sd-modal-select-button.md +54 -0
  72. package/claude/references/sd-simplysm-v14/angular/ui-form/sd-numpad.md +26 -0
  73. package/claude/references/sd-simplysm-v14/angular/ui-form/sd-range.md +26 -0
  74. package/claude/references/sd-simplysm-v14/angular/ui-form/sd-select.md +68 -0
  75. package/claude/references/sd-simplysm-v14/angular/ui-form/sd-shared-data-select.md +52 -0
  76. package/claude/references/sd-simplysm-v14/angular/ui-form/sd-state-preset.md +37 -0
  77. package/claude/references/sd-simplysm-v14/angular/ui-form/sd-switch.md +27 -0
  78. package/claude/references/sd-simplysm-v14/angular/ui-form/sd-textarea.md +33 -0
  79. package/claude/references/sd-simplysm-v14/angular/ui-form/sd-textfield.md +145 -0
  80. package/claude/references/sd-simplysm-v14/angular/ui-layout/sd-dock-container.md +64 -0
  81. package/claude/references/sd-simplysm-v14/angular/ui-layout/sd-dock.md +37 -0
  82. package/claude/references/sd-simplysm-v14/angular/ui-layout/sd-gap.md +26 -0
  83. package/claude/references/sd-simplysm-v14/angular/ui-layout/sd-kanban-board.md +96 -0
  84. package/claude/references/sd-simplysm-v14/angular/ui-layout/sd-kanban-lane.md +34 -0
  85. package/claude/references/sd-simplysm-v14/angular/ui-layout/sd-kanban.md +29 -0
  86. package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-collapse.md +35 -0
  87. package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-pagination.md +26 -0
  88. package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-sidebar-container.md +49 -0
  89. package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-sidebar-menu.md +22 -0
  90. package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-sidebar-user.md +43 -0
  91. package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-tab.md +51 -0
  92. package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-topbar-container.md +97 -0
  93. package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-topbar-menu.md +23 -0
  94. package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-topbar-user.md +38 -0
  95. package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-topbar.md +30 -0
  96. package/claude/references/sd-simplysm-v14/angular/ui-overlay/sd-busy-container.md +69 -0
  97. package/claude/references/sd-simplysm-v14/angular/ui-overlay/sd-confirm-modal.md +30 -0
  98. package/claude/references/sd-simplysm-v14/angular/ui-overlay/sd-dropdown.md +40 -0
  99. package/claude/references/sd-simplysm-v14/angular/ui-overlay/sd-modal.md +34 -0
  100. package/claude/references/sd-simplysm-v14/angular/ui-overlay/sd-prompt-modal.md +30 -0
  101. package/claude/references/sd-simplysm-v14/angular/ui-overlay/sd-toast.md +35 -0
  102. package/claude/references/sd-simplysm-v14/angular/ui-visual/sd-barcode.md +36 -0
  103. package/claude/references/sd-simplysm-v14/angular/ui-visual/sd-calendar.md +34 -0
  104. package/claude/references/sd-simplysm-v14/angular/ui-visual/sd-echarts.md +32 -0
  105. package/claude/references/sd-simplysm-v14/angular/ui-visual/sd-label.md +24 -0
  106. package/claude/references/sd-simplysm-v14/angular/ui-visual/sd-note.md +23 -0
  107. package/claude/references/sd-simplysm-v14/angular/ui-visual/sd-progress.md +23 -0
  108. package/claude/references/sd-simplysm-v14/angular/utils/inject-routing-signals.md +161 -0
  109. package/claude/references/sd-simplysm-v14/angular/utils/inject-sd-system-config-resource.md +35 -0
  110. package/claude/references/sd-simplysm-v14/angular/utils/mark.md +43 -0
  111. package/claude/references/sd-simplysm-v14/angular/utils/selection-managers.md +96 -0
  112. package/claude/references/sd-simplysm-v14/angular/utils/set-safe-style.md +19 -0
  113. package/claude/references/sd-simplysm-v14/angular/utils/setup-functions.md +93 -0
  114. package/claude/references/sd-simplysm-v14/capacitor-plugin-auto-update/README.md +38 -0
  115. package/claude/references/sd-simplysm-v14/capacitor-plugin-auto-update/apk-installer/apk-installer.md +115 -0
  116. package/claude/references/sd-simplysm-v14/capacitor-plugin-auto-update/auto-update/auto-update.md +113 -0
  117. package/claude/references/sd-simplysm-v14/capacitor-plugin-file-system/README.md +197 -0
  118. package/claude/references/sd-simplysm-v14/capacitor-plugin-intent/README.md +235 -0
  119. package/claude/references/sd-simplysm-v14/capacitor-plugin-usb-storage/README.md +251 -0
  120. package/claude/references/sd-simplysm-v14/core-browser/README.md +52 -0
  121. package/claude/references/sd-simplysm-v14/core-browser/extensions/copy-paste.md +59 -0
  122. package/claude/references/sd-simplysm-v14/core-browser/extensions/element-prototype-extensions.md +137 -0
  123. package/claude/references/sd-simplysm-v14/core-browser/extensions/get-bounds.md +84 -0
  124. package/claude/references/sd-simplysm-v14/core-browser/utils/download-blob.md +59 -0
  125. package/claude/references/sd-simplysm-v14/core-browser/utils/fetch-url-bytes.md +91 -0
  126. package/claude/references/sd-simplysm-v14/core-browser/utils/indexed-db-store.md +131 -0
  127. package/claude/references/sd-simplysm-v14/core-browser/utils/indexed-db-virtual-fs.md +121 -0
  128. package/claude/references/sd-simplysm-v14/core-browser/utils/open-file-dialog.md +60 -0
  129. package/claude/references/sd-simplysm-v14/core-common/README.md +179 -0
  130. package/claude/references/sd-simplysm-v14/core-common/errors/argument-error.md +26 -0
  131. package/claude/references/sd-simplysm-v14/core-common/errors/not-implemented-error.md +33 -0
  132. package/claude/references/sd-simplysm-v14/core-common/errors/sd-error.md +38 -0
  133. package/claude/references/sd-simplysm-v14/core-common/errors/timeout-error.md +36 -0
  134. package/claude/references/sd-simplysm-v14/core-common/extensions/array.md +125 -0
  135. package/claude/references/sd-simplysm-v14/core-common/extensions/map.md +43 -0
  136. package/claude/references/sd-simplysm-v14/core-common/extensions/set.md +35 -0
  137. package/claude/references/sd-simplysm-v14/core-common/features/debounce-queue.md +48 -0
  138. package/claude/references/sd-simplysm-v14/core-common/features/event-emitter.md +52 -0
  139. package/claude/references/sd-simplysm-v14/core-common/features/serial-queue.md +44 -0
  140. package/claude/references/sd-simplysm-v14/core-common/type-utils/common-types.md +100 -0
  141. package/claude/references/sd-simplysm-v14/core-common/type-utils/env.md +42 -0
  142. package/claude/references/sd-simplysm-v14/core-common/types/date-only.md +86 -0
  143. package/claude/references/sd-simplysm-v14/core-common/types/date-time.md +106 -0
  144. package/claude/references/sd-simplysm-v14/core-common/types/lazy-gc-map.md +59 -0
  145. package/claude/references/sd-simplysm-v14/core-common/types/time.md +62 -0
  146. package/claude/references/sd-simplysm-v14/core-common/types/uuid.md +41 -0
  147. package/claude/references/sd-simplysm-v14/core-common/utils/bytes.md +36 -0
  148. package/claude/references/sd-simplysm-v14/core-common/utils/dt.md +60 -0
  149. package/claude/references/sd-simplysm-v14/core-common/utils/err.md +26 -0
  150. package/claude/references/sd-simplysm-v14/core-common/utils/json.md +58 -0
  151. package/claude/references/sd-simplysm-v14/core-common/utils/num.md +56 -0
  152. package/claude/references/sd-simplysm-v14/core-common/utils/obj.md +107 -0
  153. package/claude/references/sd-simplysm-v14/core-common/utils/path.md +30 -0
  154. package/claude/references/sd-simplysm-v14/core-common/utils/primitive.md +28 -0
  155. package/claude/references/sd-simplysm-v14/core-common/utils/str.md +63 -0
  156. package/claude/references/sd-simplysm-v14/core-common/utils/template-strings.md +49 -0
  157. package/claude/references/sd-simplysm-v14/core-common/utils/transfer.md +35 -0
  158. package/claude/references/sd-simplysm-v14/core-common/utils/wait.md +35 -0
  159. package/claude/references/sd-simplysm-v14/core-common/utils/xml.md +49 -0
  160. package/claude/references/sd-simplysm-v14/core-common/utils/zip-archive.md +77 -0
  161. package/claude/references/sd-simplysm-v14/core-node/README.md +59 -0
  162. package/claude/references/sd-simplysm-v14/core-node/features/fs-watcher.md +110 -0
  163. package/claude/references/sd-simplysm-v14/core-node/logging/create-file-reporter.md +78 -0
  164. package/claude/references/sd-simplysm-v14/core-node/logging/pretty-reporter.md +38 -0
  165. package/claude/references/sd-simplysm-v14/core-node/logging/setup-consola.md +77 -0
  166. package/claude/references/sd-simplysm-v14/core-node/utils/cpx.md +128 -0
  167. package/claude/references/sd-simplysm-v14/core-node/utils/fsx.md +168 -0
  168. package/claude/references/sd-simplysm-v14/core-node/utils/pathx.md +73 -0
  169. package/claude/references/sd-simplysm-v14/core-node/worker/create-worker.md +85 -0
  170. package/claude/references/sd-simplysm-v14/core-node/worker/worker.md +160 -0
  171. package/claude/references/sd-simplysm-v14/excel/README.md +66 -0
  172. package/claude/references/sd-simplysm-v14/excel/core-classes/excel-cell.md +79 -0
  173. package/claude/references/sd-simplysm-v14/excel/core-classes/excel-col.md +36 -0
  174. package/claude/references/sd-simplysm-v14/excel/core-classes/excel-row.md +34 -0
  175. package/claude/references/sd-simplysm-v14/excel/core-classes/excel-workbook.md +93 -0
  176. package/claude/references/sd-simplysm-v14/excel/core-classes/excel-worksheet.md +147 -0
  177. package/claude/references/sd-simplysm-v14/excel/types/excel-address-point.md +33 -0
  178. package/claude/references/sd-simplysm-v14/excel/types/excel-style-options.md +57 -0
  179. package/claude/references/sd-simplysm-v14/excel/types/excel-value-type.md +28 -0
  180. package/claude/references/sd-simplysm-v14/excel/types/excel-xml-content-type-data.md +23 -0
  181. package/claude/references/sd-simplysm-v14/excel/types/excel-xml-drawing-data.md +29 -0
  182. package/claude/references/sd-simplysm-v14/excel/types/excel-xml-relationship-data.md +39 -0
  183. package/claude/references/sd-simplysm-v14/excel/types/excel-xml-shared-string-data.md +42 -0
  184. package/claude/references/sd-simplysm-v14/excel/types/excel-xml-style-data.md +97 -0
  185. package/claude/references/sd-simplysm-v14/excel/types/excel-xml-workbook-data.md +22 -0
  186. package/claude/references/sd-simplysm-v14/excel/types/excel-xml-worksheet-data.md +68 -0
  187. package/claude/references/sd-simplysm-v14/excel/types/excel-xml.md +15 -0
  188. package/claude/references/sd-simplysm-v14/excel/utilities/excel-utils.md +101 -0
  189. package/claude/references/sd-simplysm-v14/excel/wrapper/excel-wrapper.md +108 -0
  190. package/claude/references/sd-simplysm-v14/lint/README.md +183 -0
  191. package/claude/references/sd-simplysm-v14/orm-common/README.md +156 -0
  192. package/claude/references/sd-simplysm-v14/orm-common/core/db-context.md +208 -0
  193. package/claude/references/sd-simplysm-v14/orm-common/core/db-transaction-error.md +64 -0
  194. package/claude/references/sd-simplysm-v14/orm-common/expression/expr-unit.md +62 -0
  195. package/claude/references/sd-simplysm-v14/orm-common/expression/expr.md +198 -0
  196. package/claude/references/sd-simplysm-v14/orm-common/models/migration.md +37 -0
  197. package/claude/references/sd-simplysm-v14/orm-common/query-builder/create-query-builder.md +80 -0
  198. package/claude/references/sd-simplysm-v14/orm-common/queryable-executable/executable.md +54 -0
  199. package/claude/references/sd-simplysm-v14/orm-common/queryable-executable/parse-search-query.md +75 -0
  200. package/claude/references/sd-simplysm-v14/orm-common/queryable-executable/queryable.md +238 -0
  201. package/claude/references/sd-simplysm-v14/orm-common/schema-builders/column-builder.md +63 -0
  202. package/claude/references/sd-simplysm-v14/orm-common/schema-builders/foreign-key-builder.md +137 -0
  203. package/claude/references/sd-simplysm-v14/orm-common/schema-builders/index-builder.md +54 -0
  204. package/claude/references/sd-simplysm-v14/orm-common/schema-builders/procedure.md +67 -0
  205. package/claude/references/sd-simplysm-v14/orm-common/schema-builders/table.md +95 -0
  206. package/claude/references/sd-simplysm-v14/orm-common/schema-builders/view.md +71 -0
  207. package/claude/references/sd-simplysm-v14/orm-common/types/data-type.md +146 -0
  208. package/claude/references/sd-simplysm-v14/orm-common/types/dialect.md +151 -0
  209. package/claude/references/sd-simplysm-v14/orm-common/types/expr.md +175 -0
  210. package/claude/references/sd-simplysm-v14/orm-common/types/parse-query-result.md +58 -0
  211. package/claude/references/sd-simplysm-v14/orm-common/types/query-def.md +224 -0
  212. package/claude/references/sd-simplysm-v14/orm-node/README.md +65 -0
  213. package/claude/references/sd-simplysm-v14/orm-node/connections/mssql-db-conn.md +85 -0
  214. package/claude/references/sd-simplysm-v14/orm-node/connections/mysql-db-conn.md +83 -0
  215. package/claude/references/sd-simplysm-v14/orm-node/connections/postgresql-db-conn.md +86 -0
  216. package/claude/references/sd-simplysm-v14/orm-node/core/create-db-conn.md +62 -0
  217. package/claude/references/sd-simplysm-v14/orm-node/core/create-orm.md +107 -0
  218. package/claude/references/sd-simplysm-v14/orm-node/core/node-db-context-executor.md +50 -0
  219. package/claude/references/sd-simplysm-v14/orm-node/types/db-conn-config.md +91 -0
  220. package/claude/references/sd-simplysm-v14/orm-node/types/db-conn-constants.md +33 -0
  221. package/claude/references/sd-simplysm-v14/orm-node/types/db-conn.md +60 -0
  222. package/claude/references/sd-simplysm-v14/orm-node/types/get-dialect-from-config.md +17 -0
  223. package/{README.md → claude/references/sd-simplysm-v14/sd-claude/README.md} +85 -84
  224. package/{docs → claude/references/sd-simplysm-v14/sd-claude}/assets.md +2 -2
  225. package/{docs → claude/references/sd-simplysm-v14/sd-claude}/hooks.md +15 -1
  226. package/claude/references/sd-simplysm-v14/sd-cli/README.md +138 -0
  227. package/claude/references/sd-simplysm-v14/sd-cli/angular-vite-plugin/sd-angular-plugin.md +60 -0
  228. package/claude/references/sd-simplysm-v14/sd-cli/config/build-target.md +31 -0
  229. package/claude/references/sd-simplysm-v14/sd-cli/config/npm-config.md +27 -0
  230. package/claude/references/sd-simplysm-v14/sd-cli/config/sd-browser-support-config.md +19 -0
  231. package/claude/references/sd-simplysm-v14/sd-cli/config/sd-build-package-config.md +21 -0
  232. package/claude/references/sd-simplysm-v14/sd-cli/config/sd-capacitor-config.md +109 -0
  233. package/claude/references/sd-simplysm-v14/sd-cli/config/sd-client-package-config.md +33 -0
  234. package/claude/references/sd-simplysm-v14/sd-cli/config/sd-config.md +78 -0
  235. package/claude/references/sd-simplysm-v14/sd-cli/config/sd-electron-config.md +27 -0
  236. package/claude/references/sd-simplysm-v14/sd-cli/config/sd-package-config.md +18 -0
  237. package/claude/references/sd-simplysm-v14/sd-cli/config/sd-post-publish-script-config.md +19 -0
  238. package/claude/references/sd-simplysm-v14/sd-cli/config/sd-publish-config.md +72 -0
  239. package/claude/references/sd-simplysm-v14/sd-cli/config/sd-pwa-config.md +41 -0
  240. package/claude/references/sd-simplysm-v14/sd-cli/config/sd-scripts-package-config.md +19 -0
  241. package/claude/references/sd-simplysm-v14/sd-cli/config/sd-server-package-config.md +32 -0
  242. package/claude/references/sd-simplysm-v14/sd-cli/config/sd-watch-hook-config.md +19 -0
  243. package/claude/references/sd-simplysm-v14/sd-cli/ts-compiler/sd-ts-compiler.md +158 -0
  244. package/claude/references/sd-simplysm-v14/service-client/README.md +74 -0
  245. package/claude/references/sd-simplysm-v14/service-client/features/event-client.md +93 -0
  246. package/claude/references/sd-simplysm-v14/service-client/features/file-client.md +63 -0
  247. package/claude/references/sd-simplysm-v14/service-client/features/orm-client-connector.md +89 -0
  248. package/claude/references/sd-simplysm-v14/service-client/features/orm-client-db-context-executor.md +31 -0
  249. package/claude/references/sd-simplysm-v14/service-client/main/service-client.md +206 -0
  250. package/claude/references/sd-simplysm-v14/service-client/protocol/client-protocol-wrapper.md +64 -0
  251. package/claude/references/sd-simplysm-v14/service-client/transport/service-transport.md +68 -0
  252. package/claude/references/sd-simplysm-v14/service-client/transport/socket-provider.md +100 -0
  253. package/claude/references/sd-simplysm-v14/service-client/types/blob-input.md +7 -0
  254. package/claude/references/sd-simplysm-v14/service-client/types/browser-worker.md +47 -0
  255. package/claude/references/sd-simplysm-v14/service-client/types/file-collection.md +21 -0
  256. package/claude/references/sd-simplysm-v14/service-client/types/service-connection-options.md +22 -0
  257. package/claude/references/sd-simplysm-v14/service-client/types/service-progress.md +39 -0
  258. package/claude/references/sd-simplysm-v14/service-common/README.md +161 -0
  259. package/claude/references/sd-simplysm-v14/service-common/app-structure/app-structure-item.md +107 -0
  260. package/claude/references/sd-simplysm-v14/service-common/app-structure/get-flat-permissions.md +57 -0
  261. package/claude/references/sd-simplysm-v14/service-common/app-structure/is-usable-modules-chain.md +23 -0
  262. package/claude/references/sd-simplysm-v14/service-common/app-structure/is-usable-modules.md +42 -0
  263. package/claude/references/sd-simplysm-v14/service-common/events/define-event.md +68 -0
  264. package/claude/references/sd-simplysm-v14/service-common/protocol/create-service-protocol.md +93 -0
  265. package/claude/references/sd-simplysm-v14/service-common/protocol/protocol-config.md +21 -0
  266. package/claude/references/sd-simplysm-v14/service-common/protocol/service-add-event-listener-message.md +23 -0
  267. package/claude/references/sd-simplysm-v14/service-common/protocol/service-auth-message.md +17 -0
  268. package/claude/references/sd-simplysm-v14/service-common/protocol/service-emit-event-message.md +21 -0
  269. package/claude/references/sd-simplysm-v14/service-common/protocol/service-error-message.md +29 -0
  270. package/claude/references/sd-simplysm-v14/service-common/protocol/service-event-message.md +21 -0
  271. package/claude/references/sd-simplysm-v14/service-common/protocol/service-get-event-listener-infos-message.md +19 -0
  272. package/claude/references/sd-simplysm-v14/service-common/protocol/service-message.md +52 -0
  273. package/claude/references/sd-simplysm-v14/service-common/protocol/service-progress-message.md +21 -0
  274. package/claude/references/sd-simplysm-v14/service-common/protocol/service-remove-event-listener-message.md +19 -0
  275. package/claude/references/sd-simplysm-v14/service-common/protocol/service-request-message.md +17 -0
  276. package/claude/references/sd-simplysm-v14/service-common/protocol/service-response-message.md +17 -0
  277. package/claude/references/sd-simplysm-v14/service-common/service-types/app-structure-service.md +15 -0
  278. package/claude/references/sd-simplysm-v14/service-common/service-types/auto-update-service.md +20 -0
  279. package/claude/references/sd-simplysm-v14/service-common/service-types/orm-service.md +61 -0
  280. package/claude/references/sd-simplysm-v14/service-common/types/service-upload-result.md +19 -0
  281. package/claude/references/sd-simplysm-v14/service-server/README.md +162 -0
  282. package/claude/references/sd-simplysm-v14/service-server/auth/auth-token-payload.md +18 -0
  283. package/claude/references/sd-simplysm-v14/service-server/auth/sign-jwt.md +30 -0
  284. package/claude/references/sd-simplysm-v14/service-server/auth/verify-jwt.md +35 -0
  285. package/claude/references/sd-simplysm-v14/service-server/core/auth.md +64 -0
  286. package/claude/references/sd-simplysm-v14/service-server/core/define-service.md +81 -0
  287. package/claude/references/sd-simplysm-v14/service-server/core/execute-service-method.md +43 -0
  288. package/claude/references/sd-simplysm-v14/service-server/core/service-context.md +79 -0
  289. package/claude/references/sd-simplysm-v14/service-server/legacy/handle-v1-connection.md +25 -0
  290. package/claude/references/sd-simplysm-v14/service-server/main/create-service-server.md +32 -0
  291. package/claude/references/sd-simplysm-v14/service-server/main/service-server.md +113 -0
  292. package/claude/references/sd-simplysm-v14/service-server/protocol/server-protocol-wrapper.md +35 -0
  293. package/claude/references/sd-simplysm-v14/service-server/services/app-structure-service.md +59 -0
  294. package/claude/references/sd-simplysm-v14/service-server/services/auto-update-service.md +34 -0
  295. package/claude/references/sd-simplysm-v14/service-server/services/orm-service.md +43 -0
  296. package/claude/references/sd-simplysm-v14/service-server/transport-http/handle-http-request.md +33 -0
  297. package/claude/references/sd-simplysm-v14/service-server/transport-http/handle-static-file.md +29 -0
  298. package/claude/references/sd-simplysm-v14/service-server/transport-http/handle-upload.md +33 -0
  299. package/claude/references/sd-simplysm-v14/service-server/transport-socket/service-socket.md +64 -0
  300. package/claude/references/sd-simplysm-v14/service-server/transport-socket/websocket-handler.md +57 -0
  301. package/claude/references/sd-simplysm-v14/service-server/types/service-server-options.md +36 -0
  302. package/claude/references/sd-simplysm-v14/service-server/utils/get-config.md +29 -0
  303. package/claude/references/sd-simplysm-v14/storage/README.md +99 -0
  304. package/claude/references/sd-simplysm-v14/storage/clients/ftp-storage-client.md +99 -0
  305. package/claude/references/sd-simplysm-v14/storage/clients/sftp-storage-client.md +108 -0
  306. package/claude/references/sd-simplysm-v14/storage/factory/storage-factory.md +114 -0
  307. package/claude/references/sd-simplysm-v14/storage/types/file-info.md +32 -0
  308. package/claude/references/sd-simplysm-v14/storage/types/storage-client.md +55 -0
  309. package/claude/references/sd-simplysm-v14/storage/types/storage-conn-config.md +34 -0
  310. package/claude/rules/sd-claude-rules.md +8 -8
  311. package/claude/rules/sd-simplysm-v14.md +33 -0
  312. package/claude/skills/sd-claude-docs/SKILL.md +41 -24
  313. package/claude/skills/sd-claude-docs/references/package-docs.md +240 -116
  314. package/claude/skills/sd-inner-debug/SKILL.md +1 -1
  315. package/claude/skills/sd-inner-review/SKILL.md +4 -2
  316. package/package.json +2 -3
  317. /package/{docs → claude/references/sd-simplysm-v14/sd-claude}/cli.md +0 -0
  318. /package/{docs → claude/references/sd-simplysm-v14/sd-claude}/scripts.md +0 -0
@@ -0,0 +1,206 @@
1
+ # `ServiceClient`
2
+
3
+ WebSocket 기반 서비스 클라이언트의 최상위 파사드 클래스. 내부적으로 `SocketProvider`, `ClientProtocolWrapper`, `ServiceTransport`, `EventClient`, `FileClient`를 조합한다.
4
+
5
+ ## When to use
6
+
7
+ - ✅ `@simplysm/service-server`에 WebSocket으로 연결하여 RPC 호출, 이벤트, 파일, ORM 기능을 사용할 때
8
+ - ✅ 재연결/하트비트가 자동 관리되는 WebSocket 클라이언트가 필요할 때
9
+ - ❌ 서버 측 로직 구현 → `@simplysm/service-server`
10
+ - ❌ 단순 HTTP REST 호출만 필요한 경우 → `fetch` API 직접 사용
11
+
12
+ ## Signature
13
+
14
+ ```typescript
15
+ export class ServiceClient extends EventEmitter<ServiceClientEvents> {
16
+ constructor(
17
+ public readonly name: string,
18
+ public readonly options: ServiceConnectionOptions,
19
+ );
20
+ get connected(): boolean;
21
+ get hostUrl(): string;
22
+ getService<TService>(serviceName: string): ServiceProxy<TService>;
23
+ getEvent<TEventDef extends ServiceEventDef>(eventName: string): ClientEventProxy<TEventDef>;
24
+ connect(): Promise<void>;
25
+ close(): Promise<void>;
26
+ send(
27
+ serviceName: string,
28
+ methodName: string,
29
+ params: unknown[],
30
+ progress?: ServiceProgress,
31
+ ): Promise<unknown>;
32
+ auth(token: string): Promise<void>;
33
+ addListener<TEventDef extends ServiceEventDef>(
34
+ eventName: string,
35
+ info: TEventDef["$info"],
36
+ cb: (data: TEventDef["$data"]) => PromiseLike<void>,
37
+ ): Promise<string>;
38
+ removeListener(key: string): Promise<void>;
39
+ emitEvent<TEventDef extends ServiceEventDef>(
40
+ eventName: string,
41
+ infoSelector: (item: TEventDef["$info"]) => boolean,
42
+ data: TEventDef["$data"],
43
+ ): Promise<void>;
44
+ uploadFile(
45
+ files: File[] | FileCollection | { name: string; data: BlobInput }[],
46
+ ): Promise<ServiceUploadResult[]>;
47
+ downloadFileBuffer(relPath: string): Promise<Bytes>;
48
+ }
49
+ ```
50
+
51
+ ## Constructor Parameters
52
+
53
+ | Parameter | Type | Description |
54
+ |-----------|------|-------------|
55
+ | `name` | `string` | 클라이언트 식별자 (WebSocket URL 파라미터 및 HTTP 헤더로 전달됨) |
56
+ | `options` | [`ServiceConnectionOptions`](../types/service-connection-options.md) | 연결 옵션 |
57
+
58
+ ## Members
59
+
60
+ | Member | Kind | Type | Description |
61
+ |--------|------|------|-------------|
62
+ | `name` | property | `string` | 클라이언트 식별자 (읽기 전용) |
63
+ | `options` | property | `ServiceConnectionOptions` | 연결 옵션 (읽기 전용) |
64
+ | `connected` | getter | `boolean` | 현재 WebSocket 연결 상태 |
65
+ | `hostUrl` | getter | `string` | HTTP 기본 URL (`http(s)://host:port`) |
66
+ | `connect()` | method | `Promise<void>` | WebSocket 연결 시작 |
67
+ | `close()` | method | `Promise<void>` | WebSocket 연결 종료 및 protocol dispose |
68
+ | `auth(token)` | method | `Promise<void>` | 서버에 인증 토큰 전송. 재연결 시 자동 재인증됨 |
69
+ | `getService<TService>(serviceName)` | method | `ServiceProxy<TService>` | 타입 안전한 서비스 프록시 반환 |
70
+ | `getEvent<TEventDef>(eventName)` | method | `ClientEventProxy<TEventDef>` | 타입 안전한 이벤트 프록시 반환 |
71
+ | `send(serviceName, methodName, params, progress?)` | method | `Promise<unknown>` | 서비스 메서드 원격 호출 |
72
+ | `addListener(eventName, info, cb)` | method | `Promise<string>` | 서버 이벤트 구독. 연결 상태여야 함 |
73
+ | `removeListener(key)` | method | `Promise<void>` | 서버 이벤트 구독 해제 |
74
+ | `emitEvent(eventName, infoSelector, data)` | method | `Promise<void>` | 서버 이벤트 발행 |
75
+ | `uploadFile(files)` | method | `Promise<ServiceUploadResult[]>` | 파일 업로드. `auth()` 호출 후 사용해야 함 |
76
+ | `downloadFileBuffer(relPath)` | method | `Promise<Bytes>` | 파일 다운로드 (`Uint8Array` 반환) |
77
+
78
+ ## Events (EventEmitter)
79
+
80
+ `ServiceClient`는 `EventEmitter<ServiceClientEvents>`를 상속한다. `.on()`/`.off()`로 이벤트를 구독한다.
81
+
82
+ | Event | Data Type | Description |
83
+ |-------|-----------|-------------|
84
+ | `request-progress` | `ServiceProgressState` | 요청 전송 progress |
85
+ | `response-progress` | `ServiceProgressState` | 응답 수신 progress |
86
+ | `server-progress` | `ServiceProgressState` | 서버 내부 처리 progress |
87
+ | `state` | `"connected" \| "closed" \| "reconnecting"` | 연결 상태 변경 |
88
+
89
+ ## Related Types
90
+
91
+ ### `ServiceProxy`
92
+
93
+ `TService`의 모든 메서드 반환 타입을 `Promise`로 래핑하는 유틸리티 타입. `getService<TService>()`의 반환 타입으로 사용된다.
94
+
95
+ ```typescript
96
+ export type ServiceProxy<TService> = {
97
+ [K in keyof TService]: TService[K] extends (...args: infer P) => infer R
98
+ ? (...args: P) => Promise<Awaited<R>>
99
+ : never;
100
+ };
101
+ ```
102
+
103
+ 함수가 아닌 속성(`never`)은 타입에서 제외된다.
104
+
105
+ ## `createServiceClient`
106
+
107
+ `ServiceClient` 팩토리 함수. `new ServiceClient(name, options)`와 동일하다.
108
+
109
+ ```typescript
110
+ export function createServiceClient(name: string, options: ServiceConnectionOptions): ServiceClient;
111
+ ```
112
+
113
+ | Parameter | Type | Description |
114
+ |-----------|------|-------------|
115
+ | `name` | `string` | 클라이언트 식별자 |
116
+ | `options` | `ServiceConnectionOptions` | 연결 옵션 |
117
+
118
+ ## Usage
119
+
120
+ ### 최소 예제
121
+
122
+ ```typescript
123
+ import { ServiceClient } from "@simplysm/service-client";
124
+
125
+ const client = new ServiceClient("my-app", {
126
+ host: "localhost",
127
+ port: 3000,
128
+ });
129
+
130
+ await client.connect();
131
+ const userSvc = client.getService<UserService>("User");
132
+ const users = await userSvc.getList();
133
+ await client.close();
134
+ ```
135
+
136
+ ### 전형 예제
137
+
138
+ ```typescript
139
+ import { ServiceClient } from "@simplysm/service-client";
140
+
141
+ const client = new ServiceClient("my-app", {
142
+ host: "api.example.com",
143
+ port: 443,
144
+ ssl: true,
145
+ maxReconnectCount: 5, // 재연결 5회 시도 후 포기
146
+ });
147
+
148
+ // 연결 상태 모니터링
149
+ client.on("state", (state) => {
150
+ if (state === "reconnecting") {
151
+ // 재연결 시도 중 UI 피드백
152
+ }
153
+ });
154
+
155
+ await client.connect();
156
+ await client.auth("jwt-token"); // 재연결 시 자동 재인증됨
157
+
158
+ // 타입 안전한 서비스 호출
159
+ const userSvc = client.getService<UserService>("User");
160
+ const users = await userSvc.getList();
161
+
162
+ // 이벤트 구독 (getEvent 프록시 방식 권장)
163
+ const chatEvt = client.getEvent<typeof ChatEvent>("Chat");
164
+ const key = await chatEvt.addListener({ roomId: "room-1" }, async (data) => {
165
+ // 재연결 시 자동 재구독됨
166
+ });
167
+ await chatEvt.removeListener(key);
168
+
169
+ // 파일 업로드 (auth() 호출 후에만 가능)
170
+ const results = await client.uploadFile([{ name: "file.txt", data: "hello" }]);
171
+
172
+ // 파일 다운로드
173
+ const bytes = await client.downloadFileBuffer("/files/report.pdf");
174
+
175
+ await client.close();
176
+ ```
177
+
178
+ ## 🚫 Anti-patterns
179
+
180
+ ### auth() 없이 파일 업로드
181
+
182
+ ```typescript
183
+ // ❌ auth() 호출 전에 uploadFile() 호출
184
+ await client.connect();
185
+ await client.uploadFile([...]); // Error: "인증 토큰이 없습니다..."
186
+
187
+ // ✅ auth() 후 uploadFile() 호출
188
+ await client.connect();
189
+ await client.auth("token");
190
+ await client.uploadFile([...]);
191
+ ```
192
+
193
+ **근거**: `uploadFile()`은 내부적으로 `Authorization: Bearer {token}` 헤더를 사용하므로 인증 토큰이 필수이다.
194
+
195
+ ### 연결 안 됨 상태에서 addListener()
196
+
197
+ ```typescript
198
+ // ❌ connect() 전에 addListener()
199
+ const key = await client.addListener(...); // Error: "서버에 연결되지 않았습니다."
200
+
201
+ // ✅ connect() 후 addListener() 또는 getEvent() 프록시 사용
202
+ await client.connect();
203
+ const key = await client.addListener(...);
204
+ ```
205
+
206
+ **근거**: `addListener()`는 서버에 이벤트 등록 요청을 전송하므로 연결 상태여야 한다.
@@ -0,0 +1,64 @@
1
+ # `ClientProtocolWrapper`
2
+
3
+ 메시지 인코딩/디코딩 인터페이스. 데이터 크기가 30KB 이상이면 Web Worker로 처리를 오프로드한다. 팩토리 함수 `createClientProtocolWrapper`로 생성한다.
4
+
5
+ ## When to use
6
+
7
+ - ✅ 메시지 인코딩/디코딩을 직접 제어하거나 Worker 오프로드 동작을 커스터마이징할 때
8
+ - ❌ 일반적으로 `ServiceClient`가 내부적으로 생성·관리한다. 직접 생성은 커스텀 전송 계층 구현 시에만 필요하다.
9
+
10
+ ```typescript
11
+ export interface ClientProtocolWrapper {
12
+ encode(uuid: string, message: ServiceMessage): Promise<{ chunks: Bytes[]; totalSize: number }>;
13
+ decode(bytes: Bytes): Promise<ServiceMessageDecodeResult<ServiceMessage>>;
14
+ dispose(): void;
15
+ }
16
+ ```
17
+
18
+ ## Members
19
+
20
+ | Member | Kind | Type | Description |
21
+ |--------|------|------|-------------|
22
+ | `encode(uuid, message)` | method | `Promise<{ chunks: Bytes[]; totalSize: number }>` | 메시지를 바이너리 청크로 인코딩. 큰 데이터는 Worker로 오프로드 |
23
+ | `decode(bytes)` | method | `Promise<ServiceMessageDecodeResult<ServiceMessage>>` | 바이너리를 메시지로 디코딩. 큰 데이터는 Worker로 오프로드 (zero-copy 전송) |
24
+ | `dispose()` | method | `void` | 내부 `ServiceProtocol`과 Worker resolver 맵 정리 |
25
+
26
+ ## `createClientProtocolWrapper`
27
+
28
+ `ClientProtocolWrapper` 팩토리 함수.
29
+
30
+ ```typescript
31
+ export function createClientProtocolWrapper(protocol: ServiceProtocol): ClientProtocolWrapper;
32
+ ```
33
+
34
+ | Parameter | Type | Description |
35
+ |-----------|------|-------------|
36
+ | `protocol` | `ServiceProtocol` | `@simplysm/service-common`의 `createServiceProtocol()`로 생성한 프로토콜 인스턴스 |
37
+
38
+ 내부 동작:
39
+ - 임계값: 30KB (`30 * 1024` bytes)
40
+ - Worker가 지원되지 않는 환경에서는 메인 스레드에서 처리
41
+ - Worker는 모듈 스코프 싱글턴으로 공유됨 (`createClientProtocolWrapper` 여러 번 호출해도 Worker는 하나)
42
+ - Worker 작업은 60초 타임아웃 후 자동 reject (메모리 누수 방지)
43
+ - `decode` 시 Worker로 `ArrayBuffer` 소유권 이전 (zero-copy)
44
+
45
+ **Worker 생성 패턴 제약:**
46
+
47
+ Worker 생성 시 반드시 `new Worker(new URL("...", import.meta.url))` 직접 패턴을 사용해야 한다. sd-cli의 esbuild Worker 번들링 플러그인(`sd-worker-bundle`)이 AST에서 이 패턴만 인식하여 Worker 파일을 별도 번들로 분리한다. 래퍼 함수로 감싸면 플러그인이 인식하지 못하고 브라우저에서 404 에러가 발생한다.
48
+
49
+ ## Usage
50
+
51
+ ```typescript
52
+ import { createClientProtocolWrapper } from "@simplysm/service-client";
53
+ import { createServiceProtocol } from "@simplysm/service-common";
54
+
55
+ const protocol = createServiceProtocol();
56
+ const wrapper = createClientProtocolWrapper(protocol);
57
+
58
+ const { chunks, totalSize } = await wrapper.encode("uuid-1", { name: "User.getList", body: [] });
59
+ // chunks: Bytes[] — 전송할 청크 배열
60
+ // totalSize: number — 전체 크기 (progress 표시용)
61
+
62
+ // 사용 완료 후 반드시 정리
63
+ wrapper.dispose();
64
+ ```
@@ -0,0 +1,68 @@
1
+ # `ServiceTransport`
2
+
3
+ 요청-응답 매핑, progress 중계, 서버 이벤트 디스패치를 담당하는 인터페이스. 팩토리 함수 `createServiceTransport`로 생성한다.
4
+
5
+ ## When to use
6
+
7
+ - ✅ 요청-응답 매핑과 progress 중계를 직접 제어하는 커스텀 계층을 구현할 때
8
+ - ❌ 일반적으로 `ServiceClient`가 내부적으로 생성·관리한다. 직접 생성이 필요한 경우는 드물다.
9
+
10
+ ```typescript
11
+ export interface ServiceTransport {
12
+ on<K extends keyof ServiceTransportEvents & string>(
13
+ type: K,
14
+ listener: (data: ServiceTransportEvents[K]) => void,
15
+ ): void;
16
+ off<K extends keyof ServiceTransportEvents & string>(
17
+ type: K,
18
+ listener: (data: ServiceTransportEvents[K]) => void,
19
+ ): void;
20
+ send(message: ServiceClientMessage, progress?: ServiceProgress): Promise<unknown>;
21
+ }
22
+ ```
23
+
24
+ ## Members
25
+
26
+ | Member | Kind | Type | Description |
27
+ |--------|------|------|-------------|
28
+ | `on(type, listener)` | method | `void` | 이벤트 리스너 등록 |
29
+ | `off(type, listener)` | method | `void` | 이벤트 리스너 제거 |
30
+ | `send(message, progress?)` | method | `Promise<unknown>` | 서버에 메시지 전송하고 응답 대기 |
31
+
32
+ ## Related Types
33
+
34
+ ### `ServiceTransportEvents`
35
+
36
+ `ServiceTransport`에서 발생하는 이벤트 타입 맵.
37
+
38
+ ```typescript
39
+ export interface ServiceTransportEvents {
40
+ event: { keys: string[]; data: unknown };
41
+ }
42
+ ```
43
+
44
+ | Event | Type | Description |
45
+ |-------|------|-------------|
46
+ | `event` | `{ keys: string[]; data: unknown }` | 서버에서 발행된 이벤트 수신 |
47
+
48
+ ## `createServiceTransport`
49
+
50
+ `ServiceTransport` 팩토리 함수.
51
+
52
+ ```typescript
53
+ export function createServiceTransport(
54
+ socket: SocketProvider,
55
+ protocol: ClientProtocolWrapper,
56
+ ): ServiceTransport;
57
+ ```
58
+
59
+ | Parameter | Type | Description |
60
+ |-----------|------|-------------|
61
+ | `socket` | [`SocketProvider`](./socket-provider.md) | WebSocket 소켓 제공자 |
62
+ | `protocol` | [`ClientProtocolWrapper`](../protocol/client-protocol-wrapper.md) | 인코딩/디코딩 래퍼 |
63
+
64
+ 내부 동작:
65
+ - `uuid` 기반 요청-응답 `Map`으로 비동기 응답을 매핑
66
+ - 소켓 `closed`/`reconnecting` 상태 시 대기 중인 모든 요청을 reject
67
+ - 분할 메시지의 progress 상태를 추적하여 완료 시 100% 이벤트 전송
68
+ - 소켓 `message` 이벤트를 수신하여 `progress`, `response`, `error`, `evt:on` 타입으로 분기 처리
@@ -0,0 +1,100 @@
1
+ # `SocketProvider`
2
+
3
+ WebSocket 연결, 재연결, 하트비트를 관리하는 인터페이스. 팩토리 함수 `createSocketProvider`로 생성한다.
4
+
5
+ ## When to use
6
+
7
+ - ✅ WebSocket 연결/재연결/하트비트를 직접 제어하는 커스텀 전송 계층을 구현할 때
8
+ - ❌ 일반적으로 `ServiceClient`가 내부적으로 생성·관리한다. 직접 생성은 `ServiceClient` 없이 독립 WebSocket 통신이 필요한 경우에만 사용한다.
9
+
10
+ ```typescript
11
+ export interface SocketProvider {
12
+ readonly clientName: string;
13
+ readonly connected: boolean;
14
+ on<K extends keyof SocketProviderEvents & string>(
15
+ type: K,
16
+ listener: (data: SocketProviderEvents[K]) => void,
17
+ ): void;
18
+ off<K extends keyof SocketProviderEvents & string>(
19
+ type: K,
20
+ listener: (data: SocketProviderEvents[K]) => void,
21
+ ): void;
22
+ connect(): Promise<void>;
23
+ close(): Promise<void>;
24
+ send(data: Bytes): Promise<void>;
25
+ }
26
+ ```
27
+
28
+ ## Members
29
+
30
+ | Member | Kind | Type | Description |
31
+ |--------|------|------|-------------|
32
+ | `clientName` | property | `string` | 클라이언트 식별자 (읽기 전용) |
33
+ | `connected` | getter | `boolean` | 현재 연결 상태 |
34
+ | `on(type, listener)` | method | `void` | 이벤트 리스너 등록 |
35
+ | `off(type, listener)` | method | `void` | 이벤트 리스너 제거 |
36
+ | `connect()` | method | `Promise<void>` | WebSocket 연결 시작 |
37
+ | `close()` | method | `Promise<void>` | WebSocket 연결 종료 |
38
+ | `send(data)` | method | `Promise<void>` | 바이너리 데이터 전송. 연결 복구 대기 후 전송 |
39
+
40
+ ## Related Types
41
+
42
+ ### `SocketProviderEvents`
43
+
44
+ `SocketProvider`에서 발생하는 이벤트 타입 맵.
45
+
46
+ ```typescript
47
+ export interface SocketProviderEvents {
48
+ message: Bytes;
49
+ state: "connected" | "closed" | "reconnecting";
50
+ }
51
+ ```
52
+
53
+ | Event | Type | Description |
54
+ |-------|------|-------------|
55
+ | `message` | `Bytes` | 서버로부터 바이너리 메시지 수신 |
56
+ | `state` | `"connected" \| "closed" \| "reconnecting"` | 연결 상태 변경 |
57
+
58
+ ## `createSocketProvider`
59
+
60
+ `SocketProvider` 팩토리 함수.
61
+
62
+ ```typescript
63
+ export function createSocketProvider(
64
+ url: string,
65
+ clientName: string,
66
+ maxReconnectCount: number,
67
+ ): SocketProvider;
68
+ ```
69
+
70
+ | Parameter | Type | Description |
71
+ |-----------|------|-------------|
72
+ | `url` | `string` | WebSocket 서버 URL (`ws://` 또는 `wss://`) |
73
+ | `clientName` | `string` | 클라이언트 식별자 (URL 파라미터 `clientName`으로 전달됨) |
74
+ | `maxReconnectCount` | `number` | 최대 재연결 횟수. `0`이면 재연결 안 함 |
75
+
76
+ 내부 동작:
77
+ - 하트비트: 5초마다 ping 전송, 30초 응답 없으면 재연결 시도
78
+ - 재연결: 연결 끊김 시 3초 간격으로 `maxReconnectCount`회 재시도
79
+ - Node.js 환경에서 `globalThis.WebSocket`이 없으면 `ws` 패키지로 폴리필
80
+ - ping/pong은 1바이트 패킷(ping: `0x01`, pong: `0x02`)으로 처리
81
+
82
+ ## Usage
83
+
84
+ ```typescript
85
+ import { createSocketProvider } from "@simplysm/service-client";
86
+
87
+ const socket = createSocketProvider("ws://localhost:3000/ws", "my-app", 10);
88
+
89
+ socket.on("state", (state) => {
90
+ console.log("소켓 상태:", state); // "connected" | "closed" | "reconnecting"
91
+ });
92
+
93
+ socket.on("message", (bytes) => {
94
+ console.log("메시지 수신:", bytes.length, "bytes");
95
+ });
96
+
97
+ await socket.connect();
98
+ await socket.send(new Uint8Array([1, 2, 3]));
99
+ await socket.close();
100
+ ```
@@ -0,0 +1,7 @@
1
+ # BlobInput
2
+
3
+ Blob constructor가 허용하는 데이터 타입. DOM `BlobPart`를 대체하여 Node.js / 브라우저 양쪽에서 typecheck가 통과하도록 한다.
4
+
5
+ ```typescript
6
+ export type BlobInput = Blob | Uint8Array<ArrayBuffer> | ArrayBuffer | string;
7
+ ```
@@ -0,0 +1,47 @@
1
+ # BrowserWorker
2
+
3
+ Web Worker 최소 인터페이스. DOM lib 없이도 타입체크가 통과하도록 하는 추상 타입이다.
4
+
5
+ ```typescript
6
+ export interface BrowserWorker {
7
+ onmessage: ((event: MessageEvent) => void) | null;
8
+ onerror: ((event: Event) => void) | null;
9
+ postMessage(message: unknown, transfer?: unknown[]): void;
10
+ terminate(): void;
11
+ }
12
+ ```
13
+
14
+ ## Fields
15
+
16
+ | Field | Type | Description |
17
+ |-------|------|-------------|
18
+ | `onmessage` | `((event: MessageEvent) => void) \| null` | 메시지 수신 핸들러 |
19
+ | `onerror` | `((event: Event) => void) \| null` | 에러 핸들러 |
20
+ | `postMessage(message, transfer?)` | `void` | Worker에 메시지 전송 |
21
+ | `terminate()` | `void` | Worker 종료 |
22
+
23
+ ## Related Functions
24
+
25
+ ### `isBrowserWorkerSupported`
26
+
27
+ DOM Worker API 지원 여부를 확인한다. `"Worker" in globalThis`로 판별한다.
28
+
29
+ ```typescript
30
+ export function isBrowserWorkerSupported(): boolean;
31
+ ```
32
+
33
+ ### `isNodeWorkerSupported`
34
+
35
+ Node.js `worker_threads` 지원 여부를 확인한다. `process.versions.node` 존재 여부로 판별한다.
36
+
37
+ ```typescript
38
+ export function isNodeWorkerSupported(): boolean;
39
+ ```
40
+
41
+ ### `isWorkerSupported`
42
+
43
+ Worker 오프로딩 지원 여부를 확인한다. `isBrowserWorkerSupported() || isNodeWorkerSupported()`를 반환한다.
44
+
45
+ ```typescript
46
+ export function isWorkerSupported(): boolean;
47
+ ```
@@ -0,0 +1,21 @@
1
+ # FileCollection
2
+
3
+ File 컬렉션 인터페이스. DOM `FileList`를 대체하며 브라우저 `FileList`와 구조적으로 호환된다.
4
+
5
+ ```typescript
6
+ export interface FileCollection {
7
+ readonly length: number;
8
+ item(index: number): File | null;
9
+ [index: number]: File;
10
+ [Symbol.iterator](): IterableIterator<File>;
11
+ }
12
+ ```
13
+
14
+ ## Fields
15
+
16
+ | Field | Type | Description |
17
+ |-------|------|-------------|
18
+ | `length` | `number` | 파일 개수 (읽기 전용) |
19
+ | `item(index)` | `File \| null` | 인덱스로 File 반환 |
20
+ | `[index]` | `File` | 인덱스 접근자 |
21
+ | `[Symbol.iterator]()` | `IterableIterator<File>` | for-of 이터레이션 지원 |
@@ -0,0 +1,22 @@
1
+ # ServiceConnectionOptions
2
+
3
+ 서비스 서버에 연결할 때 사용하는 옵션 인터페이스.
4
+
5
+ ```typescript
6
+ export interface ServiceConnectionOptions {
7
+ port: number;
8
+ host: string;
9
+ ssl?: boolean;
10
+ /** 0으로 설정하면 재연결을 비활성화하고 즉시 연결을 끊음 */
11
+ maxReconnectCount?: number;
12
+ }
13
+ ```
14
+
15
+ ## Fields
16
+
17
+ | Field | Type | Required | Description |
18
+ |-------|------|----------|-------------|
19
+ | `port` | `number` | required | 서버 포트 번호 |
20
+ | `host` | `string` | required | 서버 호스트 주소 |
21
+ | `ssl` | `boolean` | optional | HTTPS/WSS 사용 여부. 기본값 `false` |
22
+ | `maxReconnectCount` | `number` | optional | 최대 재연결 횟수. `0`이면 재연결 비활성화. `ServiceClient` 기본값 `10` |
@@ -0,0 +1,39 @@
1
+ # ServiceProgress
2
+
3
+ 요청/응답/서버 단계별 progress 콜백을 담는 컨테이너 인터페이스.
4
+
5
+ ```typescript
6
+ export interface ServiceProgress {
7
+ request?: (s: ServiceProgressState) => void;
8
+ response?: (s: ServiceProgressState) => void;
9
+ server?: (s: ServiceProgressState) => void;
10
+ }
11
+ ```
12
+
13
+ ## Fields
14
+
15
+ | Field | Type | Required | Description |
16
+ |-------|------|----------|-------------|
17
+ | `request` | `(s: ServiceProgressState) => void` | optional | 클라이언트 → 서버 전송 progress |
18
+ | `response` | `(s: ServiceProgressState) => void` | optional | 서버 → 클라이언트 수신 progress |
19
+ | `server` | `(s: ServiceProgressState) => void` | optional | 서버 내부 처리 progress |
20
+
21
+ ## Related Types
22
+
23
+ ### `ServiceProgressState`
24
+
25
+ progress 콜백에 전달되는 상태 객체.
26
+
27
+ ```typescript
28
+ export interface ServiceProgressState {
29
+ uuid: string;
30
+ totalSize: number;
31
+ completedSize: number;
32
+ }
33
+ ```
34
+
35
+ | Field | Type | Description |
36
+ |-------|------|-------------|
37
+ | `uuid` | `string` | 요청 식별자 |
38
+ | `totalSize` | `number` | 전체 크기 (bytes) |
39
+ | `completedSize` | `number` | 완료된 크기 (bytes) |