@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.
- package/claude/references/sd-frontend-design.md +10 -9
- package/claude/references/sd-simplysm-v14/angular/README.md +497 -0
- package/claude/references/sd-simplysm-v14/angular/bootstrap/provide-sd-angular.md +37 -0
- package/claude/references/sd-simplysm-v14/angular/bootstrap/sd-angular-config-provider.md +16 -0
- package/claude/references/sd-simplysm-v14/angular/directives/sd-command-directive.md +27 -0
- package/claude/references/sd-simplysm-v14/angular/directives/sd-events.md +25 -0
- package/claude/references/sd-simplysm-v14/angular/directives/sd-intersection-directive.md +36 -0
- package/claude/references/sd-simplysm-v14/angular/directives/sd-invalid.md +24 -0
- package/claude/references/sd-simplysm-v14/angular/directives/sd-resize-directive.md +42 -0
- package/claude/references/sd-simplysm-v14/angular/directives/sd-ripple.md +23 -0
- package/claude/references/sd-simplysm-v14/angular/directives/sd-router-link.md +38 -0
- package/claude/references/sd-simplysm-v14/angular/directives/sd-show-effect.md +18 -0
- package/claude/references/sd-simplysm-v14/angular/directives/sd-typed-template.md +69 -0
- package/claude/references/sd-simplysm-v14/angular/features/sd-address-search-modal.md +50 -0
- package/claude/references/sd-simplysm-v14/angular/features/sd-permission-table.md +20 -0
- package/claude/references/sd-simplysm-v14/angular/features/sd-shared-data-components.md +158 -0
- package/claude/references/sd-simplysm-v14/angular/features/sd-tiptap-editor.md +26 -0
- package/claude/references/sd-simplysm-v14/angular/pipes/format-pipe.md +41 -0
- package/claude/references/sd-simplysm-v14/angular/plugins/sd-global-error-handler.md +23 -0
- package/claude/references/sd-simplysm-v14/angular/plugins/sd-option-event-plugin.md +34 -0
- package/claude/references/sd-simplysm-v14/angular/provider-types/sd-menu.md +65 -0
- package/claude/references/sd-simplysm-v14/angular/provider-types/sd-modal-content-def.md +148 -0
- package/claude/references/sd-simplysm-v14/angular/provider-types/sd-toast-content-def.md +73 -0
- package/claude/references/sd-simplysm-v14/angular/provider-types/shared-data-base.md +59 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-activated-modal-provider.md +34 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-app-structure-provider.md +81 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-busy-provider.md +18 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-file-dialog-provider.md +40 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-local-storage-provider.md +20 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-modal-provider.md +67 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-navigate-window-provider.md +18 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-print-provider.md +25 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-service-client-factory-provider.md +43 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-shared-data-provider.md +64 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-system-config-provider.md +46 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-system-log-provider.md +18 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-theme-provider.md +38 -0
- package/claude/references/sd-simplysm-v14/angular/providers/sd-toast-provider.md +65 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/_common-rules.md +336 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-detail/extension-a-edit-save.md +191 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-detail/extension-b-delete-restore.md +103 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-detail/extension-c-modal-view.md +198 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-detail/extension-d-control-view.md +109 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-detail/extension-e-auxiliary.md +87 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-detail/extension-f-complex-detail.md +202 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-detail.md +280 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-list/extension-a-inline-edit.md +386 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-list/extension-b-selection.md +215 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-list/extension-c-inline-delete.md +64 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-list/extension-d-select-modal.md +193 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-list/extension-e-readonly-modal.md +140 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-list/extension-f-modal-edit.md +123 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-list/extension-g-excel.md +145 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/crud-list.md +377 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/data-select-button.md +368 -0
- package/claude/references/sd-simplysm-v14/angular/recipes/page-modal-container.md +238 -0
- package/claude/references/sd-simplysm-v14/angular/styling/classes.md +149 -0
- package/claude/references/sd-simplysm-v14/angular/styling/mixins.md +100 -0
- package/claude/references/sd-simplysm-v14/angular/styling/themes.md +35 -0
- package/claude/references/sd-simplysm-v14/angular/styling/variables.md +147 -0
- package/claude/references/sd-simplysm-v14/angular/type-utilities/directive-input-signals.md +232 -0
- package/claude/references/sd-simplysm-v14/angular/ui-data/sd-list.md +37 -0
- package/claude/references/sd-simplysm-v14/angular/ui-data/sd-sheet.md +212 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-additional-button.md +26 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-anchor.md +31 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-button.md +103 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-checkbox-group.md +39 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-checkbox.md +81 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-date-range-picker.md +27 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-form.md +89 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-modal-select-button.md +54 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-numpad.md +26 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-range.md +26 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-select.md +68 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-shared-data-select.md +52 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-state-preset.md +37 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-switch.md +27 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-textarea.md +33 -0
- package/claude/references/sd-simplysm-v14/angular/ui-form/sd-textfield.md +145 -0
- package/claude/references/sd-simplysm-v14/angular/ui-layout/sd-dock-container.md +64 -0
- package/claude/references/sd-simplysm-v14/angular/ui-layout/sd-dock.md +37 -0
- package/claude/references/sd-simplysm-v14/angular/ui-layout/sd-gap.md +26 -0
- package/claude/references/sd-simplysm-v14/angular/ui-layout/sd-kanban-board.md +96 -0
- package/claude/references/sd-simplysm-v14/angular/ui-layout/sd-kanban-lane.md +34 -0
- package/claude/references/sd-simplysm-v14/angular/ui-layout/sd-kanban.md +29 -0
- package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-collapse.md +35 -0
- package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-pagination.md +26 -0
- package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-sidebar-container.md +49 -0
- package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-sidebar-menu.md +22 -0
- package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-sidebar-user.md +43 -0
- package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-tab.md +51 -0
- package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-topbar-container.md +97 -0
- package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-topbar-menu.md +23 -0
- package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-topbar-user.md +38 -0
- package/claude/references/sd-simplysm-v14/angular/ui-navigation/sd-topbar.md +30 -0
- package/claude/references/sd-simplysm-v14/angular/ui-overlay/sd-busy-container.md +69 -0
- package/claude/references/sd-simplysm-v14/angular/ui-overlay/sd-confirm-modal.md +30 -0
- package/claude/references/sd-simplysm-v14/angular/ui-overlay/sd-dropdown.md +40 -0
- package/claude/references/sd-simplysm-v14/angular/ui-overlay/sd-modal.md +34 -0
- package/claude/references/sd-simplysm-v14/angular/ui-overlay/sd-prompt-modal.md +30 -0
- package/claude/references/sd-simplysm-v14/angular/ui-overlay/sd-toast.md +35 -0
- package/claude/references/sd-simplysm-v14/angular/ui-visual/sd-barcode.md +36 -0
- package/claude/references/sd-simplysm-v14/angular/ui-visual/sd-calendar.md +34 -0
- package/claude/references/sd-simplysm-v14/angular/ui-visual/sd-echarts.md +32 -0
- package/claude/references/sd-simplysm-v14/angular/ui-visual/sd-label.md +24 -0
- package/claude/references/sd-simplysm-v14/angular/ui-visual/sd-note.md +23 -0
- package/claude/references/sd-simplysm-v14/angular/ui-visual/sd-progress.md +23 -0
- package/claude/references/sd-simplysm-v14/angular/utils/inject-routing-signals.md +161 -0
- package/claude/references/sd-simplysm-v14/angular/utils/inject-sd-system-config-resource.md +35 -0
- package/claude/references/sd-simplysm-v14/angular/utils/mark.md +43 -0
- package/claude/references/sd-simplysm-v14/angular/utils/selection-managers.md +96 -0
- package/claude/references/sd-simplysm-v14/angular/utils/set-safe-style.md +19 -0
- package/claude/references/sd-simplysm-v14/angular/utils/setup-functions.md +93 -0
- package/claude/references/sd-simplysm-v14/capacitor-plugin-auto-update/README.md +38 -0
- package/claude/references/sd-simplysm-v14/capacitor-plugin-auto-update/apk-installer/apk-installer.md +115 -0
- package/claude/references/sd-simplysm-v14/capacitor-plugin-auto-update/auto-update/auto-update.md +113 -0
- package/claude/references/sd-simplysm-v14/capacitor-plugin-file-system/README.md +197 -0
- package/claude/references/sd-simplysm-v14/capacitor-plugin-intent/README.md +235 -0
- package/claude/references/sd-simplysm-v14/capacitor-plugin-usb-storage/README.md +251 -0
- package/claude/references/sd-simplysm-v14/core-browser/README.md +52 -0
- package/claude/references/sd-simplysm-v14/core-browser/extensions/copy-paste.md +59 -0
- package/claude/references/sd-simplysm-v14/core-browser/extensions/element-prototype-extensions.md +137 -0
- package/claude/references/sd-simplysm-v14/core-browser/extensions/get-bounds.md +84 -0
- package/claude/references/sd-simplysm-v14/core-browser/utils/download-blob.md +59 -0
- package/claude/references/sd-simplysm-v14/core-browser/utils/fetch-url-bytes.md +91 -0
- package/claude/references/sd-simplysm-v14/core-browser/utils/indexed-db-store.md +131 -0
- package/claude/references/sd-simplysm-v14/core-browser/utils/indexed-db-virtual-fs.md +121 -0
- package/claude/references/sd-simplysm-v14/core-browser/utils/open-file-dialog.md +60 -0
- package/claude/references/sd-simplysm-v14/core-common/README.md +179 -0
- package/claude/references/sd-simplysm-v14/core-common/errors/argument-error.md +26 -0
- package/claude/references/sd-simplysm-v14/core-common/errors/not-implemented-error.md +33 -0
- package/claude/references/sd-simplysm-v14/core-common/errors/sd-error.md +38 -0
- package/claude/references/sd-simplysm-v14/core-common/errors/timeout-error.md +36 -0
- package/claude/references/sd-simplysm-v14/core-common/extensions/array.md +125 -0
- package/claude/references/sd-simplysm-v14/core-common/extensions/map.md +43 -0
- package/claude/references/sd-simplysm-v14/core-common/extensions/set.md +35 -0
- package/claude/references/sd-simplysm-v14/core-common/features/debounce-queue.md +48 -0
- package/claude/references/sd-simplysm-v14/core-common/features/event-emitter.md +52 -0
- package/claude/references/sd-simplysm-v14/core-common/features/serial-queue.md +44 -0
- package/claude/references/sd-simplysm-v14/core-common/type-utils/common-types.md +100 -0
- package/claude/references/sd-simplysm-v14/core-common/type-utils/env.md +42 -0
- package/claude/references/sd-simplysm-v14/core-common/types/date-only.md +86 -0
- package/claude/references/sd-simplysm-v14/core-common/types/date-time.md +106 -0
- package/claude/references/sd-simplysm-v14/core-common/types/lazy-gc-map.md +59 -0
- package/claude/references/sd-simplysm-v14/core-common/types/time.md +62 -0
- package/claude/references/sd-simplysm-v14/core-common/types/uuid.md +41 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/bytes.md +36 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/dt.md +60 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/err.md +26 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/json.md +58 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/num.md +56 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/obj.md +107 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/path.md +30 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/primitive.md +28 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/str.md +63 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/template-strings.md +49 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/transfer.md +35 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/wait.md +35 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/xml.md +49 -0
- package/claude/references/sd-simplysm-v14/core-common/utils/zip-archive.md +77 -0
- package/claude/references/sd-simplysm-v14/core-node/README.md +59 -0
- package/claude/references/sd-simplysm-v14/core-node/features/fs-watcher.md +110 -0
- package/claude/references/sd-simplysm-v14/core-node/logging/create-file-reporter.md +78 -0
- package/claude/references/sd-simplysm-v14/core-node/logging/pretty-reporter.md +38 -0
- package/claude/references/sd-simplysm-v14/core-node/logging/setup-consola.md +77 -0
- package/claude/references/sd-simplysm-v14/core-node/utils/cpx.md +128 -0
- package/claude/references/sd-simplysm-v14/core-node/utils/fsx.md +168 -0
- package/claude/references/sd-simplysm-v14/core-node/utils/pathx.md +73 -0
- package/claude/references/sd-simplysm-v14/core-node/worker/create-worker.md +85 -0
- package/claude/references/sd-simplysm-v14/core-node/worker/worker.md +160 -0
- package/claude/references/sd-simplysm-v14/excel/README.md +66 -0
- package/claude/references/sd-simplysm-v14/excel/core-classes/excel-cell.md +79 -0
- package/claude/references/sd-simplysm-v14/excel/core-classes/excel-col.md +36 -0
- package/claude/references/sd-simplysm-v14/excel/core-classes/excel-row.md +34 -0
- package/claude/references/sd-simplysm-v14/excel/core-classes/excel-workbook.md +93 -0
- package/claude/references/sd-simplysm-v14/excel/core-classes/excel-worksheet.md +147 -0
- package/claude/references/sd-simplysm-v14/excel/types/excel-address-point.md +33 -0
- package/claude/references/sd-simplysm-v14/excel/types/excel-style-options.md +57 -0
- package/claude/references/sd-simplysm-v14/excel/types/excel-value-type.md +28 -0
- package/claude/references/sd-simplysm-v14/excel/types/excel-xml-content-type-data.md +23 -0
- package/claude/references/sd-simplysm-v14/excel/types/excel-xml-drawing-data.md +29 -0
- package/claude/references/sd-simplysm-v14/excel/types/excel-xml-relationship-data.md +39 -0
- package/claude/references/sd-simplysm-v14/excel/types/excel-xml-shared-string-data.md +42 -0
- package/claude/references/sd-simplysm-v14/excel/types/excel-xml-style-data.md +97 -0
- package/claude/references/sd-simplysm-v14/excel/types/excel-xml-workbook-data.md +22 -0
- package/claude/references/sd-simplysm-v14/excel/types/excel-xml-worksheet-data.md +68 -0
- package/claude/references/sd-simplysm-v14/excel/types/excel-xml.md +15 -0
- package/claude/references/sd-simplysm-v14/excel/utilities/excel-utils.md +101 -0
- package/claude/references/sd-simplysm-v14/excel/wrapper/excel-wrapper.md +108 -0
- package/claude/references/sd-simplysm-v14/lint/README.md +183 -0
- package/claude/references/sd-simplysm-v14/orm-common/README.md +156 -0
- package/claude/references/sd-simplysm-v14/orm-common/core/db-context.md +208 -0
- package/claude/references/sd-simplysm-v14/orm-common/core/db-transaction-error.md +64 -0
- package/claude/references/sd-simplysm-v14/orm-common/expression/expr-unit.md +62 -0
- package/claude/references/sd-simplysm-v14/orm-common/expression/expr.md +198 -0
- package/claude/references/sd-simplysm-v14/orm-common/models/migration.md +37 -0
- package/claude/references/sd-simplysm-v14/orm-common/query-builder/create-query-builder.md +80 -0
- package/claude/references/sd-simplysm-v14/orm-common/queryable-executable/executable.md +54 -0
- package/claude/references/sd-simplysm-v14/orm-common/queryable-executable/parse-search-query.md +75 -0
- package/claude/references/sd-simplysm-v14/orm-common/queryable-executable/queryable.md +238 -0
- package/claude/references/sd-simplysm-v14/orm-common/schema-builders/column-builder.md +63 -0
- package/claude/references/sd-simplysm-v14/orm-common/schema-builders/foreign-key-builder.md +137 -0
- package/claude/references/sd-simplysm-v14/orm-common/schema-builders/index-builder.md +54 -0
- package/claude/references/sd-simplysm-v14/orm-common/schema-builders/procedure.md +67 -0
- package/claude/references/sd-simplysm-v14/orm-common/schema-builders/table.md +95 -0
- package/claude/references/sd-simplysm-v14/orm-common/schema-builders/view.md +71 -0
- package/claude/references/sd-simplysm-v14/orm-common/types/data-type.md +146 -0
- package/claude/references/sd-simplysm-v14/orm-common/types/dialect.md +151 -0
- package/claude/references/sd-simplysm-v14/orm-common/types/expr.md +175 -0
- package/claude/references/sd-simplysm-v14/orm-common/types/parse-query-result.md +58 -0
- package/claude/references/sd-simplysm-v14/orm-common/types/query-def.md +224 -0
- package/claude/references/sd-simplysm-v14/orm-node/README.md +65 -0
- package/claude/references/sd-simplysm-v14/orm-node/connections/mssql-db-conn.md +85 -0
- package/claude/references/sd-simplysm-v14/orm-node/connections/mysql-db-conn.md +83 -0
- package/claude/references/sd-simplysm-v14/orm-node/connections/postgresql-db-conn.md +86 -0
- package/claude/references/sd-simplysm-v14/orm-node/core/create-db-conn.md +62 -0
- package/claude/references/sd-simplysm-v14/orm-node/core/create-orm.md +107 -0
- package/claude/references/sd-simplysm-v14/orm-node/core/node-db-context-executor.md +50 -0
- package/claude/references/sd-simplysm-v14/orm-node/types/db-conn-config.md +91 -0
- package/claude/references/sd-simplysm-v14/orm-node/types/db-conn-constants.md +33 -0
- package/claude/references/sd-simplysm-v14/orm-node/types/db-conn.md +60 -0
- package/claude/references/sd-simplysm-v14/orm-node/types/get-dialect-from-config.md +17 -0
- package/{README.md → claude/references/sd-simplysm-v14/sd-claude/README.md} +85 -84
- package/{docs → claude/references/sd-simplysm-v14/sd-claude}/assets.md +2 -2
- package/{docs → claude/references/sd-simplysm-v14/sd-claude}/hooks.md +15 -1
- package/claude/references/sd-simplysm-v14/sd-cli/README.md +138 -0
- package/claude/references/sd-simplysm-v14/sd-cli/angular-vite-plugin/sd-angular-plugin.md +60 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/build-target.md +31 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/npm-config.md +27 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-browser-support-config.md +19 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-build-package-config.md +21 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-capacitor-config.md +109 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-client-package-config.md +33 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-config.md +78 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-electron-config.md +27 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-package-config.md +18 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-post-publish-script-config.md +19 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-publish-config.md +72 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-pwa-config.md +41 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-scripts-package-config.md +19 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-server-package-config.md +32 -0
- package/claude/references/sd-simplysm-v14/sd-cli/config/sd-watch-hook-config.md +19 -0
- package/claude/references/sd-simplysm-v14/sd-cli/ts-compiler/sd-ts-compiler.md +158 -0
- package/claude/references/sd-simplysm-v14/service-client/README.md +74 -0
- package/claude/references/sd-simplysm-v14/service-client/features/event-client.md +93 -0
- package/claude/references/sd-simplysm-v14/service-client/features/file-client.md +63 -0
- package/claude/references/sd-simplysm-v14/service-client/features/orm-client-connector.md +89 -0
- package/claude/references/sd-simplysm-v14/service-client/features/orm-client-db-context-executor.md +31 -0
- package/claude/references/sd-simplysm-v14/service-client/main/service-client.md +206 -0
- package/claude/references/sd-simplysm-v14/service-client/protocol/client-protocol-wrapper.md +64 -0
- package/claude/references/sd-simplysm-v14/service-client/transport/service-transport.md +68 -0
- package/claude/references/sd-simplysm-v14/service-client/transport/socket-provider.md +100 -0
- package/claude/references/sd-simplysm-v14/service-client/types/blob-input.md +7 -0
- package/claude/references/sd-simplysm-v14/service-client/types/browser-worker.md +47 -0
- package/claude/references/sd-simplysm-v14/service-client/types/file-collection.md +21 -0
- package/claude/references/sd-simplysm-v14/service-client/types/service-connection-options.md +22 -0
- package/claude/references/sd-simplysm-v14/service-client/types/service-progress.md +39 -0
- package/claude/references/sd-simplysm-v14/service-common/README.md +161 -0
- package/claude/references/sd-simplysm-v14/service-common/app-structure/app-structure-item.md +107 -0
- package/claude/references/sd-simplysm-v14/service-common/app-structure/get-flat-permissions.md +57 -0
- package/claude/references/sd-simplysm-v14/service-common/app-structure/is-usable-modules-chain.md +23 -0
- package/claude/references/sd-simplysm-v14/service-common/app-structure/is-usable-modules.md +42 -0
- package/claude/references/sd-simplysm-v14/service-common/events/define-event.md +68 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/create-service-protocol.md +93 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/protocol-config.md +21 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/service-add-event-listener-message.md +23 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/service-auth-message.md +17 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/service-emit-event-message.md +21 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/service-error-message.md +29 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/service-event-message.md +21 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/service-get-event-listener-infos-message.md +19 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/service-message.md +52 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/service-progress-message.md +21 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/service-remove-event-listener-message.md +19 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/service-request-message.md +17 -0
- package/claude/references/sd-simplysm-v14/service-common/protocol/service-response-message.md +17 -0
- package/claude/references/sd-simplysm-v14/service-common/service-types/app-structure-service.md +15 -0
- package/claude/references/sd-simplysm-v14/service-common/service-types/auto-update-service.md +20 -0
- package/claude/references/sd-simplysm-v14/service-common/service-types/orm-service.md +61 -0
- package/claude/references/sd-simplysm-v14/service-common/types/service-upload-result.md +19 -0
- package/claude/references/sd-simplysm-v14/service-server/README.md +162 -0
- package/claude/references/sd-simplysm-v14/service-server/auth/auth-token-payload.md +18 -0
- package/claude/references/sd-simplysm-v14/service-server/auth/sign-jwt.md +30 -0
- package/claude/references/sd-simplysm-v14/service-server/auth/verify-jwt.md +35 -0
- package/claude/references/sd-simplysm-v14/service-server/core/auth.md +64 -0
- package/claude/references/sd-simplysm-v14/service-server/core/define-service.md +81 -0
- package/claude/references/sd-simplysm-v14/service-server/core/execute-service-method.md +43 -0
- package/claude/references/sd-simplysm-v14/service-server/core/service-context.md +79 -0
- package/claude/references/sd-simplysm-v14/service-server/legacy/handle-v1-connection.md +25 -0
- package/claude/references/sd-simplysm-v14/service-server/main/create-service-server.md +32 -0
- package/claude/references/sd-simplysm-v14/service-server/main/service-server.md +113 -0
- package/claude/references/sd-simplysm-v14/service-server/protocol/server-protocol-wrapper.md +35 -0
- package/claude/references/sd-simplysm-v14/service-server/services/app-structure-service.md +59 -0
- package/claude/references/sd-simplysm-v14/service-server/services/auto-update-service.md +34 -0
- package/claude/references/sd-simplysm-v14/service-server/services/orm-service.md +43 -0
- package/claude/references/sd-simplysm-v14/service-server/transport-http/handle-http-request.md +33 -0
- package/claude/references/sd-simplysm-v14/service-server/transport-http/handle-static-file.md +29 -0
- package/claude/references/sd-simplysm-v14/service-server/transport-http/handle-upload.md +33 -0
- package/claude/references/sd-simplysm-v14/service-server/transport-socket/service-socket.md +64 -0
- package/claude/references/sd-simplysm-v14/service-server/transport-socket/websocket-handler.md +57 -0
- package/claude/references/sd-simplysm-v14/service-server/types/service-server-options.md +36 -0
- package/claude/references/sd-simplysm-v14/service-server/utils/get-config.md +29 -0
- package/claude/references/sd-simplysm-v14/storage/README.md +99 -0
- package/claude/references/sd-simplysm-v14/storage/clients/ftp-storage-client.md +99 -0
- package/claude/references/sd-simplysm-v14/storage/clients/sftp-storage-client.md +108 -0
- package/claude/references/sd-simplysm-v14/storage/factory/storage-factory.md +114 -0
- package/claude/references/sd-simplysm-v14/storage/types/file-info.md +32 -0
- package/claude/references/sd-simplysm-v14/storage/types/storage-client.md +55 -0
- package/claude/references/sd-simplysm-v14/storage/types/storage-conn-config.md +34 -0
- package/claude/rules/sd-claude-rules.md +8 -8
- package/claude/rules/sd-simplysm-v14.md +33 -0
- package/claude/skills/sd-claude-docs/SKILL.md +41 -24
- package/claude/skills/sd-claude-docs/references/package-docs.md +240 -116
- package/claude/skills/sd-inner-debug/SKILL.md +1 -1
- package/claude/skills/sd-inner-review/SKILL.md +4 -2
- package/package.json +2 -3
- /package/{docs → claude/references/sd-simplysm-v14/sd-claude}/cli.md +0 -0
- /package/{docs → claude/references/sd-simplysm-v14/sd-claude}/scripts.md +0 -0
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
# `createOrm`
|
|
2
|
+
|
|
3
|
+
Node.js ORM 팩토리 함수. `DbContext` 서브클래스와 DB 연결 설정을 받아 트랜잭션을 관리하는 [`Orm<T>`](#orm) 인스턴스를 반환한다.
|
|
4
|
+
|
|
5
|
+
## When to use
|
|
6
|
+
|
|
7
|
+
- ✅ DbContext 기반 ORM 쿼리를 실행할 때 — 트랜잭션 관리가 자동으로 이루어진다.
|
|
8
|
+
- ❌ 생 SQL만 실행할 때 → [`createDbConn`](./create-db-conn.md)이 더 적절하다.
|
|
9
|
+
|
|
10
|
+
## Signature
|
|
11
|
+
|
|
12
|
+
```typescript
|
|
13
|
+
function createOrm<T extends DbContext>(
|
|
14
|
+
DbClass: new (executor: DbContextExecutor, opt: { database: string; schema?: string }) => T,
|
|
15
|
+
config: DbConnConfig,
|
|
16
|
+
options?: OrmOptions,
|
|
17
|
+
): Orm<T>;
|
|
18
|
+
```
|
|
19
|
+
|
|
20
|
+
## Parameters
|
|
21
|
+
|
|
22
|
+
| Param | Type | Description |
|
|
23
|
+
|-------|------|-------------|
|
|
24
|
+
| `DbClass` | constructor | `DbContext`를 상속한 클래스 생성자 |
|
|
25
|
+
| `config` | `DbConnConfig` | DB 연결 설정 |
|
|
26
|
+
| `options` | `OrmOptions?` | ORM 옵션. `config`보다 우선 적용된다 |
|
|
27
|
+
|
|
28
|
+
## Returns
|
|
29
|
+
|
|
30
|
+
`Orm<T>` — `connect()`와 `connectWithoutTransaction()`을 제공하는 ORM 인스턴스.
|
|
31
|
+
|
|
32
|
+
`options.database` / `options.schema`는 `config`의 동일 필드보다 우선 적용된다. `database`는 필수이며, `config`와 `options` 양쪽 모두 `database`가 없으면 에러를 throw한다.
|
|
33
|
+
|
|
34
|
+
## Related Types
|
|
35
|
+
|
|
36
|
+
### `Orm`
|
|
37
|
+
|
|
38
|
+
`createOrm()`에서 반환하는 객체의 타입.
|
|
39
|
+
|
|
40
|
+
```typescript
|
|
41
|
+
interface Orm<T extends DbContext> {
|
|
42
|
+
readonly DbClass: new (
|
|
43
|
+
executor: DbContextExecutor,
|
|
44
|
+
opt: { database: string; schema?: string },
|
|
45
|
+
) => T;
|
|
46
|
+
readonly config: DbConnConfig;
|
|
47
|
+
readonly options?: OrmOptions;
|
|
48
|
+
connect<R>(callback: (conn: T) => Promise<R>, isolationLevel?: IsolationLevel): Promise<R>;
|
|
49
|
+
connectWithoutTransaction<R>(callback: (conn: T) => Promise<R>): Promise<R>;
|
|
50
|
+
}
|
|
51
|
+
```
|
|
52
|
+
|
|
53
|
+
| Field | Type | Description |
|
|
54
|
+
|-------|------|-------------|
|
|
55
|
+
| `DbClass` | constructor | DbContext 서브클래스 생성자 |
|
|
56
|
+
| `config` | `DbConnConfig` | DB 연결 설정 |
|
|
57
|
+
| `options` | `OrmOptions?` | ORM 옵션 |
|
|
58
|
+
| `connect(callback, isolationLevel?)` | method | 트랜잭션 내에서 콜백을 실행한다. 콜백 완료 후 자동 커밋, 예외 발생 시 자동 롤백 |
|
|
59
|
+
| `connectWithoutTransaction(callback)` | method | 트랜잭션 없이 콜백을 실행한다 |
|
|
60
|
+
|
|
61
|
+
### `OrmOptions`
|
|
62
|
+
|
|
63
|
+
`createOrm()`의 세 번째 인수로 전달하는 옵션. `DbConnConfig`의 동일 필드보다 우선 적용된다.
|
|
64
|
+
|
|
65
|
+
```typescript
|
|
66
|
+
interface OrmOptions {
|
|
67
|
+
database?: string;
|
|
68
|
+
schema?: string;
|
|
69
|
+
}
|
|
70
|
+
```
|
|
71
|
+
|
|
72
|
+
| Field | Type | Description |
|
|
73
|
+
|-------|------|-------------|
|
|
74
|
+
| `database` | `string?` | 데이터베이스 이름. `DbConnConfig`의 `database` 대신 사용된다 |
|
|
75
|
+
| `schema` | `string?` | 스키마 이름 (MSSQL: `dbo`, PostgreSQL: `public`). `DbConnConfig`의 `schema` 대신 사용된다 |
|
|
76
|
+
|
|
77
|
+
## Usage
|
|
78
|
+
|
|
79
|
+
```typescript
|
|
80
|
+
import { DbContext } from "@simplysm/orm-common";
|
|
81
|
+
import { createOrm } from "@simplysm/orm-node";
|
|
82
|
+
|
|
83
|
+
class MyDb extends DbContext {
|
|
84
|
+
user = this.queryable(User);
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
const orm = createOrm(MyDb, {
|
|
88
|
+
dialect: "mysql",
|
|
89
|
+
host: "localhost",
|
|
90
|
+
port: 3306,
|
|
91
|
+
username: "root",
|
|
92
|
+
password: "password",
|
|
93
|
+
database: "mydb",
|
|
94
|
+
});
|
|
95
|
+
|
|
96
|
+
// 트랜잭션 내에서 실행
|
|
97
|
+
await orm.connect(async (db) => {
|
|
98
|
+
const users = await db.user().execute();
|
|
99
|
+
return users;
|
|
100
|
+
});
|
|
101
|
+
|
|
102
|
+
// 트랜잭션 없이 실행
|
|
103
|
+
await orm.connectWithoutTransaction(async (db) => {
|
|
104
|
+
const users = await db.user().execute();
|
|
105
|
+
return users;
|
|
106
|
+
});
|
|
107
|
+
```
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
# `NodeDbContextExecutor`
|
|
2
|
+
|
|
3
|
+
`orm-common`의 `DbContextExecutor` 인터페이스를 구현하는 Node.js 환경용 실행자. `DbContext`에서 내부적으로 사용한다.
|
|
4
|
+
|
|
5
|
+
## When to use
|
|
6
|
+
|
|
7
|
+
- ✅ `createOrm()`이 내부적으로 생성하므로 직접 사용할 일은 거의 없다.
|
|
8
|
+
- ✅ 커스텀 DbContext 실행 파이프라인을 구성해야 하는 드문 경우에만 직접 인스턴스를 생성한다.
|
|
9
|
+
|
|
10
|
+
```typescript
|
|
11
|
+
class NodeDbContextExecutor implements DbContextExecutor {
|
|
12
|
+
constructor(config: DbConnConfig);
|
|
13
|
+
|
|
14
|
+
connect(): Promise<void>;
|
|
15
|
+
close(): Promise<void>;
|
|
16
|
+
beginTransaction(isolationLevel?: IsolationLevel): Promise<void>;
|
|
17
|
+
commitTransaction(): Promise<void>;
|
|
18
|
+
rollbackTransaction(): Promise<void>;
|
|
19
|
+
executeParametrized(query: string, params?: unknown[]): Promise<Record<string, unknown>[][]>;
|
|
20
|
+
bulkInsert(
|
|
21
|
+
tableName: string,
|
|
22
|
+
columnMetas: Record<string, ColumnMeta>,
|
|
23
|
+
records: DataRecord[],
|
|
24
|
+
): Promise<void>;
|
|
25
|
+
executeDefs<T = DataRecord>(
|
|
26
|
+
defs: QueryDef[],
|
|
27
|
+
resultMetas?: (ResultMeta | undefined)[],
|
|
28
|
+
): Promise<T[][]>;
|
|
29
|
+
}
|
|
30
|
+
```
|
|
31
|
+
|
|
32
|
+
## Members
|
|
33
|
+
|
|
34
|
+
| Member | Kind | Type | Description |
|
|
35
|
+
|--------|------|------|-------------|
|
|
36
|
+
| `connect()` | method | `Promise<void>` | `createDbConn()`으로 DB 연결을 생성하고 연결을 수립한다 |
|
|
37
|
+
| `close()` | method | `Promise<void>` | DB 연결을 종료한다 |
|
|
38
|
+
| `beginTransaction(isolationLevel?)` | method | `Promise<void>` | 트랜잭션을 시작한다 |
|
|
39
|
+
| `commitTransaction()` | method | `Promise<void>` | 트랜잭션을 커밋한다 |
|
|
40
|
+
| `rollbackTransaction()` | method | `Promise<void>` | 트랜잭션을 롤백한다 |
|
|
41
|
+
| `executeParametrized(query, params?)` | method | `Promise<Record<string, unknown>[][]>` | 파라미터화된 쿼리를 실행한다 |
|
|
42
|
+
| `bulkInsert(tableName, columnMetas, records)` | method | `Promise<void>` | 대량 데이터 삽입 |
|
|
43
|
+
| `executeDefs(defs, resultMetas?)` | method | `Promise<T[][]>` | QueryDef 배열을 SQL로 변환하여 실행한다 |
|
|
44
|
+
|
|
45
|
+
일반적으로 직접 사용하지 않는다. [`createOrm()`](./create-orm.md)이 내부적으로 이 클래스를 생성하여 `DbContext`에 전달한다.
|
|
46
|
+
|
|
47
|
+
## `executeDefs()` 처리 방식
|
|
48
|
+
|
|
49
|
+
- `resultMetas`가 모두 `undefined`이면 쿼리를 단일 문자열로 결합하여 한 번의 요청으로 실행한다 (결과 불필요 최적화).
|
|
50
|
+
- 그 외에는 각 def를 개별 실행하고 `ResultMeta`가 있으면 `parseQueryResult()`로 결과를 파싱한다.
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
# `DbConnConfig`
|
|
2
|
+
|
|
3
|
+
DB 연결 설정 discriminated union. `dialect` 필드로 구현체를 분기한다.
|
|
4
|
+
|
|
5
|
+
```typescript
|
|
6
|
+
type DbConnConfig = MysqlDbConnConfig | MssqlDbConnConfig | PostgresqlDbConnConfig;
|
|
7
|
+
```
|
|
8
|
+
|
|
9
|
+
## Related Types
|
|
10
|
+
|
|
11
|
+
### `MysqlDbConnConfig`
|
|
12
|
+
|
|
13
|
+
MySQL 연결 설정.
|
|
14
|
+
|
|
15
|
+
```typescript
|
|
16
|
+
interface MysqlDbConnConfig {
|
|
17
|
+
dialect: "mysql";
|
|
18
|
+
host: string;
|
|
19
|
+
port?: number;
|
|
20
|
+
username: string;
|
|
21
|
+
password: string;
|
|
22
|
+
database?: string;
|
|
23
|
+
defaultIsolationLevel?: IsolationLevel;
|
|
24
|
+
}
|
|
25
|
+
```
|
|
26
|
+
|
|
27
|
+
| Field | Type | Description |
|
|
28
|
+
|-------|------|-------------|
|
|
29
|
+
| `dialect` | `"mysql"` | Discriminant. 항상 `"mysql"` |
|
|
30
|
+
| `host` | `string` | 호스트 주소 |
|
|
31
|
+
| `port` | `number?` | 포트 (생략 시 mysql2 기본값 사용) |
|
|
32
|
+
| `username` | `string` | 사용자 이름 |
|
|
33
|
+
| `password` | `string` | 비밀번호 |
|
|
34
|
+
| `database` | `string?` | 데이터베이스 이름 |
|
|
35
|
+
| `defaultIsolationLevel` | `IsolationLevel?` | 기본 격리 수준 (미지정 시 `READ_UNCOMMITTED`) |
|
|
36
|
+
|
|
37
|
+
### `MssqlDbConnConfig`
|
|
38
|
+
|
|
39
|
+
MSSQL/Azure SQL 연결 설정.
|
|
40
|
+
|
|
41
|
+
```typescript
|
|
42
|
+
interface MssqlDbConnConfig {
|
|
43
|
+
dialect: "mssql" | "mssql-azure";
|
|
44
|
+
host: string;
|
|
45
|
+
port?: number;
|
|
46
|
+
username: string;
|
|
47
|
+
password: string;
|
|
48
|
+
database?: string;
|
|
49
|
+
schema?: string;
|
|
50
|
+
defaultIsolationLevel?: IsolationLevel;
|
|
51
|
+
}
|
|
52
|
+
```
|
|
53
|
+
|
|
54
|
+
| Field | Type | Description |
|
|
55
|
+
|-------|------|-------------|
|
|
56
|
+
| `dialect` | `"mssql" \| "mssql-azure"` | Discriminant. `"mssql-azure"`인 경우 암호화 연결(`encrypt: true`)을 사용한다 |
|
|
57
|
+
| `host` | `string` | 호스트 주소 |
|
|
58
|
+
| `port` | `number?` | 포트 |
|
|
59
|
+
| `username` | `string` | 사용자 이름 |
|
|
60
|
+
| `password` | `string` | 비밀번호 |
|
|
61
|
+
| `database` | `string?` | 데이터베이스 이름 |
|
|
62
|
+
| `schema` | `string?` | 스키마 이름 |
|
|
63
|
+
| `defaultIsolationLevel` | `IsolationLevel?` | 기본 격리 수준 (미지정 시 `READ_UNCOMMITTED`) |
|
|
64
|
+
|
|
65
|
+
### `PostgresqlDbConnConfig`
|
|
66
|
+
|
|
67
|
+
PostgreSQL 연결 설정.
|
|
68
|
+
|
|
69
|
+
```typescript
|
|
70
|
+
interface PostgresqlDbConnConfig {
|
|
71
|
+
dialect: "postgresql";
|
|
72
|
+
host: string;
|
|
73
|
+
port?: number;
|
|
74
|
+
username: string;
|
|
75
|
+
password: string;
|
|
76
|
+
database?: string;
|
|
77
|
+
schema?: string;
|
|
78
|
+
defaultIsolationLevel?: IsolationLevel;
|
|
79
|
+
}
|
|
80
|
+
```
|
|
81
|
+
|
|
82
|
+
| Field | Type | Description |
|
|
83
|
+
|-------|------|-------------|
|
|
84
|
+
| `dialect` | `"postgresql"` | Discriminant. 항상 `"postgresql"` |
|
|
85
|
+
| `host` | `string` | 호스트 주소 |
|
|
86
|
+
| `port` | `number?` | 포트 (미지정 시 `5432`) |
|
|
87
|
+
| `username` | `string` | 사용자 이름 |
|
|
88
|
+
| `password` | `string` | 비밀번호 |
|
|
89
|
+
| `database` | `string?` | 데이터베이스 이름 |
|
|
90
|
+
| `schema` | `string?` | 스키마 이름 |
|
|
91
|
+
| `defaultIsolationLevel` | `IsolationLevel?` | 기본 격리 수준 (미지정 시 `READ_UNCOMMITTED`) |
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
# `DB_CONN_CONNECT_TIMEOUT`
|
|
2
|
+
|
|
3
|
+
DB 연결 수립 타임아웃 (10초).
|
|
4
|
+
|
|
5
|
+
```typescript
|
|
6
|
+
const DB_CONN_CONNECT_TIMEOUT = 10 * 1000; // 10_000ms
|
|
7
|
+
```
|
|
8
|
+
|
|
9
|
+
## Related Types
|
|
10
|
+
|
|
11
|
+
### `DB_CONN_DEFAULT_TIMEOUT`
|
|
12
|
+
|
|
13
|
+
DB 쿼리 기본 타임아웃 (10분). 유휴 연결 자동 종료 타이머는 이 값의 2배 후 `close()`를 호출한다.
|
|
14
|
+
|
|
15
|
+
```typescript
|
|
16
|
+
const DB_CONN_DEFAULT_TIMEOUT = 10 * 60 * 1000; // 600_000ms
|
|
17
|
+
```
|
|
18
|
+
|
|
19
|
+
### `DB_CONN_ERRORS`
|
|
20
|
+
|
|
21
|
+
DB 연결 관련 오류 메시지 상수.
|
|
22
|
+
|
|
23
|
+
```typescript
|
|
24
|
+
const DB_CONN_ERRORS = {
|
|
25
|
+
NOT_CONNECTED: "'Connection'이 연결되어 있지 않습니다.",
|
|
26
|
+
ALREADY_CONNECTED: "'Connection'이 이미 연결되어 있습니다.",
|
|
27
|
+
} as const;
|
|
28
|
+
```
|
|
29
|
+
|
|
30
|
+
| Key | Value |
|
|
31
|
+
|-----|-------|
|
|
32
|
+
| `NOT_CONNECTED` | `"'Connection'이 연결되어 있지 않습니다."` |
|
|
33
|
+
| `ALREADY_CONNECTED` | `"'Connection'이 이미 연결되어 있습니다."` |
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
# `DbConn`
|
|
2
|
+
|
|
3
|
+
저수준 DB 연결 인터페이스. 각 DBMS 구현체(`MssqlDbConn`, `MysqlDbConn`, `PostgresqlDbConn`)가 이 인터페이스를 구현한다.
|
|
4
|
+
|
|
5
|
+
## When to use
|
|
6
|
+
|
|
7
|
+
- ✅ DBMS에 무관한 코드에서 연결 객체의 타입으로 사용할 때.
|
|
8
|
+
- ✅ 커스텀 DbConn 구현체를 만들 때 이 인터페이스를 구현한다.
|
|
9
|
+
|
|
10
|
+
```typescript
|
|
11
|
+
interface DbConn extends EventEmitter<{ close: void }> {
|
|
12
|
+
config: DbConnConfig;
|
|
13
|
+
isConnected: boolean;
|
|
14
|
+
isInTransaction: boolean;
|
|
15
|
+
connect(): Promise<void>;
|
|
16
|
+
close(): Promise<void>;
|
|
17
|
+
beginTransaction(isolationLevel?: IsolationLevel): Promise<void>;
|
|
18
|
+
commitTransaction(): Promise<void>;
|
|
19
|
+
rollbackTransaction(): Promise<void>;
|
|
20
|
+
execute(queries: string[]): Promise<Record<string, unknown>[][]>;
|
|
21
|
+
executeParametrized(query: string, params?: unknown[]): Promise<Record<string, unknown>[][]>;
|
|
22
|
+
bulkInsert(
|
|
23
|
+
tableName: string,
|
|
24
|
+
columnMetas: Record<string, ColumnMeta>,
|
|
25
|
+
records: Record<string, unknown>[],
|
|
26
|
+
): Promise<void>;
|
|
27
|
+
}
|
|
28
|
+
```
|
|
29
|
+
|
|
30
|
+
## Members
|
|
31
|
+
|
|
32
|
+
| Member | Kind | Type | Description |
|
|
33
|
+
|--------|------|------|-------------|
|
|
34
|
+
| `config` | property | `DbConnConfig` | 연결 설정 |
|
|
35
|
+
| `isConnected` | property | `boolean` | 연결 여부 |
|
|
36
|
+
| `isInTransaction` | property | `boolean` | 트랜잭션 진행 여부 |
|
|
37
|
+
| `connect()` | method | `Promise<void>` | DB 연결을 수립한다 |
|
|
38
|
+
| `close()` | method | `Promise<void>` | DB 연결을 종료한다 |
|
|
39
|
+
| `beginTransaction(isolationLevel?)` | method | `Promise<void>` | 트랜잭션을 시작한다 |
|
|
40
|
+
| `commitTransaction()` | method | `Promise<void>` | 트랜잭션을 커밋한다 |
|
|
41
|
+
| `rollbackTransaction()` | method | `Promise<void>` | 트랜잭션을 롤백한다 |
|
|
42
|
+
| `execute(queries)` | method | `Promise<Record<string, unknown>[][]>` | SQL 쿼리 배열을 실행한다 |
|
|
43
|
+
| `executeParametrized(query, params?)` | method | `Promise<Record<string, unknown>[][]>` | 파라미터화된 쿼리를 실행한다 |
|
|
44
|
+
| `bulkInsert(tableName, columnMetas, records)` | method | `Promise<void>` | 네이티브 bulk API를 사용하여 대량 삽입한다 |
|
|
45
|
+
|
|
46
|
+
`EventEmitter<{ close: void }>`를 상속하므로 연결 종료 시 `'close'` 이벤트를 수신할 수 있다.
|
|
47
|
+
|
|
48
|
+
## Usage
|
|
49
|
+
|
|
50
|
+
```typescript
|
|
51
|
+
conn.on("close", () => {
|
|
52
|
+
// 연결이 종료됨
|
|
53
|
+
});
|
|
54
|
+
|
|
55
|
+
await conn.connect();
|
|
56
|
+
await conn.beginTransaction();
|
|
57
|
+
await conn.execute(["INSERT INTO users (name) VALUES ('Alice')"]);
|
|
58
|
+
await conn.commitTransaction();
|
|
59
|
+
await conn.close();
|
|
60
|
+
```
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
# `getDialectFromConfig`
|
|
2
|
+
|
|
3
|
+
`DbConnConfig`에서 정규화된 `Dialect`를 추출한다.
|
|
4
|
+
|
|
5
|
+
```typescript
|
|
6
|
+
function getDialectFromConfig(config: DbConnConfig): Dialect;
|
|
7
|
+
```
|
|
8
|
+
|
|
9
|
+
## Parameters
|
|
10
|
+
|
|
11
|
+
| Param | Type | Description |
|
|
12
|
+
|-------|------|-------------|
|
|
13
|
+
| `config` | `DbConnConfig` | DB 연결 설정 |
|
|
14
|
+
|
|
15
|
+
## Returns
|
|
16
|
+
|
|
17
|
+
`Dialect` — 정규화된 dialect 값. `"mssql-azure"` → `"mssql"`로 변환하고, 나머지(`"mysql"`, `"mssql"`, `"postgresql"`)는 `config.dialect`를 그대로 반환한다.
|
|
@@ -1,84 +1,85 @@
|
|
|
1
|
-
# @simplysm/sd-claude
|
|
2
|
-
|
|
3
|
-
Claude Code 에셋을 소비 프로젝트의 `.claude/` 디렉토리에 자동 설치하는 패키지. 다수의 스킬(`sd-*` 접두어 포함), 2개 rules 파일, 참조 문서, 훅 스크립트를 포함한다. CLI(`sd-claude`)로 멀티 계정 전환 기능도 제공한다.
|
|
4
|
-
|
|
5
|
-
TypeScript 소스 없음. `scripts/`는 Node.js `.mjs` 스크립트이고, `claude/`는 배포 에셋 디렉토리다.
|
|
6
|
-
|
|
7
|
-
## Installation
|
|
8
|
-
|
|
9
|
-
```bash
|
|
10
|
-
npm install @simplysm/sd-claude
|
|
11
|
-
```
|
|
12
|
-
|
|
13
|
-
설치 시 `postinstall` 스크립트가 자동 실행되어, `claude/sd-*` 에셋과 `settings.json`을 프로젝트 루트 `.claude/`에 복사한다. `settings.json`은 훅이 미리 등록된 정적 파일이다.
|
|
14
|
-
|
|
15
|
-
## API Overview
|
|
16
|
-
|
|
17
|
-
### CLI Commands
|
|
18
|
-
|
|
19
|
-
| API | Type | Description |
|
|
20
|
-
|-----|------|-------------|
|
|
21
|
-
| `sd-claude auth save` | CLI command | 현재 Claude Code 계정의 Organization 이름과 refresh token을 `~/.claude/profiles.json`에 저장 |
|
|
22
|
-
| `sd-claude auth switch` | CLI command | 저장된 계정 목록을 표시하고 선택한 계정으로 전환 (TTY 필수) |
|
|
23
|
-
|
|
24
|
-
→ See [docs/cli.md](./
|
|
25
|
-
|
|
26
|
-
### Scripts (Internal)
|
|
27
|
-
|
|
28
|
-
| API | Type | Description |
|
|
29
|
-
|-----|------|-------------|
|
|
30
|
-
| `postinstall.mjs` | lifecycle script | `pnpm install` 후 `claude/sd-*` 및 `settings.json`을 소비 프로젝트 `.claude/`에 복사 |
|
|
31
|
-
| `sync.mjs` | lifecycle script | `prepack` 시 루트 `.claude/sd-*` 에셋을 `claude/`로 동기화 |
|
|
32
|
-
| `forEachSdEntry(dir, callback)` | function | 디렉토리에서 `sd-*` 항목을 2단계 깊이로 탐색하며 콜백 호출 |
|
|
33
|
-
| `collectSdEntries(dir)` | function | `forEachSdEntry`로 수집한 `sd-*` 항목의 상대 경로 배열 반환 |
|
|
34
|
-
|
|
35
|
-
→ See [docs/scripts.md](./
|
|
36
|
-
|
|
37
|
-
### Hooks
|
|
38
|
-
|
|
39
|
-
| API | Type | Description |
|
|
40
|
-
|-----|------|-------------|
|
|
41
|
-
| `sd-subagent-start.sh` | SubagentStart hook | subagent 시작 시 `CLAUDE.md` 내용을 출력하여 subagent가 프로젝트 지침을 참조하도록 안내 |
|
|
42
|
-
| `sd-check-write.py` | PreToolUse hook (Write) | 기존 파일에 Write 도구 사용 시 차단하고 Edit 도구 사용을 안내 |
|
|
43
|
-
| `sd-check-bash.py` | PreToolUse hook (Bash) | 금지된 명령어 차단 (git stash/checkout/restore/reset/clean, cd, npx tsc, npx eslint) |
|
|
44
|
-
| `sd-check-forbidden-files.py` | PreToolUse hook (Write/Edit) | `tsconfig.json`, `eslint.config.ts` 등 보호 파일 수정 차단 |
|
|
45
|
-
| `sd-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
| `claude/
|
|
55
|
-
| `claude/
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
pnpm
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
# .claude/
|
|
79
|
-
#
|
|
80
|
-
#
|
|
81
|
-
#
|
|
82
|
-
# sd
|
|
83
|
-
#
|
|
84
|
-
|
|
1
|
+
# @simplysm/sd-claude
|
|
2
|
+
|
|
3
|
+
Claude Code 에셋을 소비 프로젝트의 `.claude/` 디렉토리에 자동 설치하는 패키지. 다수의 스킬(`sd-*` 접두어 포함), 2개 rules 파일, 참조 문서, 6개 훅 스크립트를 포함한다. CLI(`sd-claude`)로 멀티 계정 전환 기능도 제공한다.
|
|
4
|
+
|
|
5
|
+
TypeScript 소스 없음. `scripts/`는 Node.js `.mjs` 스크립트이고, `claude/`는 배포 에셋 디렉토리다.
|
|
6
|
+
|
|
7
|
+
## Installation
|
|
8
|
+
|
|
9
|
+
```bash
|
|
10
|
+
npm install @simplysm/sd-claude
|
|
11
|
+
```
|
|
12
|
+
|
|
13
|
+
설치 시 `postinstall` 스크립트가 자동 실행되어, `claude/sd-*` 에셋과 `settings.json`을 프로젝트 루트 `.claude/`에 복사한다. `settings.json`은 훅이 미리 등록된 정적 파일이다.
|
|
14
|
+
|
|
15
|
+
## API Overview
|
|
16
|
+
|
|
17
|
+
### CLI Commands
|
|
18
|
+
|
|
19
|
+
| API | Type | Description |
|
|
20
|
+
|-----|------|-------------|
|
|
21
|
+
| `sd-claude auth save` | CLI command | 현재 Claude Code 계정의 Organization 이름과 refresh token을 `~/.claude/profiles.json`에 저장 |
|
|
22
|
+
| `sd-claude auth switch` | CLI command | 저장된 계정 목록을 표시하고 선택한 계정으로 전환 (TTY 필수) |
|
|
23
|
+
|
|
24
|
+
→ See [docs/cli.md](./cli.md) for details.
|
|
25
|
+
|
|
26
|
+
### Scripts (Internal)
|
|
27
|
+
|
|
28
|
+
| API | Type | Description |
|
|
29
|
+
|-----|------|-------------|
|
|
30
|
+
| `postinstall.mjs` | lifecycle script | `pnpm install` 후 `claude/sd-*` 및 `settings.json`을 소비 프로젝트 `.claude/`에 복사 |
|
|
31
|
+
| `sync.mjs` | lifecycle script | `prepack` 시 루트 `.claude/sd-*` 에셋을 `claude/`로 동기화 |
|
|
32
|
+
| `forEachSdEntry(dir, callback)` | function | 디렉토리에서 `sd-*` 항목을 2단계 깊이로 탐색하며 콜백 호출 |
|
|
33
|
+
| `collectSdEntries(dir)` | function | `forEachSdEntry`로 수집한 `sd-*` 항목의 상대 경로 배열 반환 |
|
|
34
|
+
|
|
35
|
+
→ See [docs/scripts.md](./scripts.md) for details.
|
|
36
|
+
|
|
37
|
+
### Hooks
|
|
38
|
+
|
|
39
|
+
| API | Type | Description |
|
|
40
|
+
|-----|------|-------------|
|
|
41
|
+
| `sd-subagent-start.sh` | SubagentStart hook | subagent 시작 시 `CLAUDE.md` 내용을 출력하여 subagent가 프로젝트 지침을 참조하도록 안내 |
|
|
42
|
+
| `sd-check-write.py` | PreToolUse hook (Write) | 기존 파일에 Write 도구 사용 시 차단하고 Edit 도구 사용을 안내 |
|
|
43
|
+
| `sd-check-bash.py` | PreToolUse hook (Bash) | 금지된 명령어 차단 (git stash/checkout/restore/reset/clean, cd, npx tsc, npx eslint) |
|
|
44
|
+
| `sd-check-forbidden-files.py` | PreToolUse hook (Write/Edit) | `tsconfig.json`, `eslint.config.ts` 등 보호 파일 수정 차단 |
|
|
45
|
+
| `sd-cache-read-hash.py` | PostToolUse hook (Read) | Read 후 파일 SHA-256 해시를 세션별 캐시에 저장 |
|
|
46
|
+
| `sd-statusline.py` | statusLine hook | 상태바에 `폴더 | 모델 | 컨텍스트% | 5h사용량 | 7d사용량 | $추가요금` 표시 |
|
|
47
|
+
|
|
48
|
+
→ See [docs/hooks.md](./hooks.md) for details.
|
|
49
|
+
|
|
50
|
+
### Asset Structure
|
|
51
|
+
|
|
52
|
+
| API | Type | Description |
|
|
53
|
+
|-----|------|-------------|
|
|
54
|
+
| `claude/skills/` | asset directory | 19개 sd-* 스킬 디렉토리 (각 스킬은 `SKILL.md` + 선택적 `SKILL.eval.md`와 `references/` 포함) |
|
|
55
|
+
| `claude/rules/` | asset directory | Claude Code 규칙 파일 (`sd-claude-rules.md`, `sd-options.md`) |
|
|
56
|
+
| `claude/references/` | asset directory | 스킬/규칙에서 참조하는 공유 문서 (`sd-frontend-design.md`) |
|
|
57
|
+
|
|
58
|
+
→ See [docs/assets.md](./assets.md) for details.
|
|
59
|
+
|
|
60
|
+
## Usage Examples
|
|
61
|
+
|
|
62
|
+
### 멀티 계정 관리
|
|
63
|
+
|
|
64
|
+
```bash
|
|
65
|
+
# 현재 계정을 저장
|
|
66
|
+
sd-claude auth save
|
|
67
|
+
|
|
68
|
+
# 저장된 계정 목록에서 선택하여 전환
|
|
69
|
+
sd-claude auth switch
|
|
70
|
+
```
|
|
71
|
+
|
|
72
|
+
### 소비 프로젝트에 설치
|
|
73
|
+
|
|
74
|
+
```bash
|
|
75
|
+
# pnpm install 시 자동으로 .claude/에 에셋 설치됨
|
|
76
|
+
pnpm add -D @simplysm/sd-claude
|
|
77
|
+
|
|
78
|
+
# 설치 후 .claude/ 디렉토리 구조:
|
|
79
|
+
# .claude/
|
|
80
|
+
# rules/sd-claude-rules.md
|
|
81
|
+
# skills/sd-commit/, sd-check/, ...
|
|
82
|
+
# references/sd-*.md
|
|
83
|
+
# sd-subagent-start.sh, sd-check-write.py, ...
|
|
84
|
+
# settings.json (훅 자동 등록)
|
|
85
|
+
```
|
|
@@ -9,8 +9,9 @@ claude/
|
|
|
9
9
|
├── references/ ← 스킬/규칙에서 참조하는 공유 문서
|
|
10
10
|
├── rules/ ← Claude Code 규칙 파일
|
|
11
11
|
├── skills/ ← 스킬 파일 디렉토리
|
|
12
|
+
├── sd-cache-read-hash.py ← 훅 스크립트
|
|
12
13
|
├── sd-check-bash.py ← 훅 스크립트
|
|
13
|
-
├── sd-check-forbidden-files.py
|
|
14
|
+
├── sd-check-forbidden-files.py ← 훅 스크립트
|
|
14
15
|
├── sd-check-write.py ← 훅 스크립트
|
|
15
16
|
├── sd-subagent-start.sh ← 훅 스크립트
|
|
16
17
|
└── sd-statusline.py ← 훅 스크립트
|
|
@@ -83,7 +84,6 @@ Claude Code 규칙 파일. 2개 파일.
|
|
|
83
84
|
| 파일 | Description |
|
|
84
85
|
|------|-------------|
|
|
85
86
|
| `sd-frontend-design.md` | 프론트엔드 UI 코드 작성 지침 |
|
|
86
|
-
| `sd-testing.md` | 테스트 작성 지침 |
|
|
87
87
|
|
|
88
88
|
## 소스 오브 트루스
|
|
89
89
|
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
# Hooks
|
|
2
2
|
|
|
3
|
-
`claude/` 디렉토리의 훅 스크립트 (총
|
|
3
|
+
`claude/` 디렉토리의 훅 스크립트 (총 6개). `postinstall`에 의해 `.claude/`에 설치되고, `settings.json`에 자동 등록되어 Claude Code 세션에서 실행된다.
|
|
4
4
|
|
|
5
5
|
## `sd-subagent-start.sh`
|
|
6
6
|
|
|
@@ -132,3 +132,17 @@ statusLine 훅. Claude Code 상태바에 `폴더 | 모델 | 컨텍스트% | 5h
|
|
|
132
132
|
|------|-------------|
|
|
133
133
|
| (없음) | 기본 모드: stdin에서 세션 정보를 읽고 상태바 문자열 출력 |
|
|
134
134
|
| `--fetch <version>` | 백그라운드 fetch 모드: API를 호출하여 캐시 갱신 |
|
|
135
|
+
|
|
136
|
+
## `sd-cache-read-hash.py`
|
|
137
|
+
|
|
138
|
+
PostToolUse 훅 (matcher: `Read`). Read 도구 실행 후 읽은 파일의 SHA-256 해시를 세션별 캐시 디렉토리에 저장한다. 파일 변경 감지에 활용된다.
|
|
139
|
+
|
|
140
|
+
입력: stdin JSON (`tool_input.file_path`, `session_id`)
|
|
141
|
+
|
|
142
|
+
동작:
|
|
143
|
+
1. `tool_input.file_path`에서 파일 경로를 읽는다
|
|
144
|
+
2. 파일이 존재하지 않으면 아무 동작 없이 종료한다
|
|
145
|
+
3. 파일 내용의 SHA-256 해시를 계산한다
|
|
146
|
+
4. 파일 경로의 SHA-256 해시를 키로 사용하여 `.tmp/read_hash/{session_id}/` 디렉토리에 해시 파일을 저장한다
|
|
147
|
+
|
|
148
|
+
캐시 경로: `.tmp/read_hash/{session_id}/{path_hash}` (내용: 파일 콘텐츠의 SHA-256 해시)
|