@buenojs/bueno 0.8.10 → 0.8.11
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/dist/cache/index.d.ts +187 -0
- package/dist/cache/index.d.ts.map +1 -0
- package/dist/cache/index.js +595 -0
- package/dist/cache/index.js.map +1 -0
- package/dist/cli/bin.d.ts +8 -0
- package/dist/cli/bin.d.ts.map +1 -0
- package/dist/cli/bin.js +9 -9
- package/dist/cli/bin.js.map +1 -0
- package/dist/cli/commands/add-frontend.d.ts +7 -0
- package/dist/cli/commands/add-frontend.d.ts.map +1 -0
- package/dist/cli/commands/add-frontend.js +376 -0
- package/dist/cli/commands/add-frontend.js.map +1 -0
- package/dist/cli/commands/build.d.ts +7 -0
- package/dist/cli/commands/build.d.ts.map +1 -0
- package/dist/cli/commands/build.js +347 -0
- package/dist/cli/commands/build.js.map +1 -0
- package/dist/cli/commands/dev.d.ts +7 -0
- package/dist/cli/commands/dev.d.ts.map +1 -0
- package/dist/cli/commands/dev.js +205 -0
- package/dist/cli/commands/dev.js.map +1 -0
- package/dist/cli/commands/generate.d.ts +7 -0
- package/dist/cli/commands/generate.d.ts.map +1 -0
- package/dist/cli/commands/generate.js +491 -0
- package/dist/cli/commands/generate.js.map +1 -0
- package/dist/cli/commands/help.d.ts +7 -0
- package/dist/cli/commands/help.d.ts.map +1 -0
- package/dist/cli/commands/help.js +51 -0
- package/dist/cli/commands/help.js.map +1 -0
- package/dist/cli/commands/index.d.ts +59 -0
- package/dist/cli/commands/index.d.ts.map +1 -0
- package/dist/cli/commands/index.js +77 -0
- package/dist/cli/commands/index.js.map +1 -0
- package/dist/cli/commands/migration.d.ts +7 -0
- package/dist/cli/commands/migration.d.ts.map +1 -0
- package/dist/cli/commands/migration.js +295 -0
- package/dist/cli/commands/migration.js.map +1 -0
- package/dist/cli/commands/new.d.ts +7 -0
- package/dist/cli/commands/new.d.ts.map +1 -0
- package/dist/cli/commands/new.js +641 -0
- package/dist/cli/commands/new.js.map +1 -0
- package/dist/cli/commands/start.d.ts +7 -0
- package/dist/cli/commands/start.d.ts.map +1 -0
- package/dist/cli/commands/start.js +171 -0
- package/dist/cli/commands/start.js.map +1 -0
- package/dist/cli/core/args.d.ts +61 -0
- package/dist/cli/core/args.d.ts.map +1 -0
- package/dist/cli/core/args.js +224 -0
- package/dist/cli/core/args.js.map +1 -0
- package/dist/cli/core/console.d.ts +135 -0
- package/dist/cli/core/console.d.ts.map +1 -0
- package/dist/cli/core/console.js +268 -0
- package/dist/cli/core/console.js.map +1 -0
- package/dist/cli/core/index.d.ts +10 -0
- package/dist/cli/core/index.d.ts.map +1 -0
- package/dist/cli/core/index.js +10 -0
- package/dist/cli/core/index.js.map +1 -0
- package/dist/cli/core/prompt.d.ts +63 -0
- package/dist/cli/core/prompt.d.ts.map +1 -0
- package/dist/cli/core/prompt.js +338 -0
- package/dist/cli/core/prompt.js.map +1 -0
- package/dist/cli/core/spinner.d.ts +111 -0
- package/dist/cli/core/spinner.d.ts.map +1 -0
- package/dist/cli/core/spinner.js +208 -0
- package/dist/cli/core/spinner.js.map +1 -0
- package/dist/cli/index.d.ts +47 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +127 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/templates/database/index.d.ts +24 -0
- package/dist/cli/templates/database/index.d.ts.map +1 -0
- package/dist/cli/templates/database/index.js +49 -0
- package/dist/cli/templates/database/index.js.map +1 -0
- package/dist/cli/templates/database/mysql.d.ts +6 -0
- package/dist/cli/templates/database/mysql.d.ts.map +1 -0
- package/dist/cli/templates/database/mysql.js +12 -0
- package/dist/cli/templates/database/mysql.js.map +1 -0
- package/dist/cli/templates/database/none.d.ts +8 -0
- package/dist/cli/templates/database/none.d.ts.map +1 -0
- package/dist/cli/templates/database/none.js +14 -0
- package/dist/cli/templates/database/none.js.map +1 -0
- package/dist/cli/templates/database/postgresql.d.ts +6 -0
- package/dist/cli/templates/database/postgresql.d.ts.map +1 -0
- package/dist/cli/templates/database/postgresql.js +12 -0
- package/dist/cli/templates/database/postgresql.js.map +1 -0
- package/dist/cli/templates/database/sqlite.d.ts +6 -0
- package/dist/cli/templates/database/sqlite.d.ts.map +1 -0
- package/dist/cli/templates/database/sqlite.js +12 -0
- package/dist/cli/templates/database/sqlite.js.map +1 -0
- package/dist/cli/templates/deploy.d.ts +41 -0
- package/dist/cli/templates/deploy.d.ts.map +1 -0
- package/dist/cli/templates/deploy.js +278 -0
- package/dist/cli/templates/deploy.js.map +1 -0
- package/dist/cli/templates/docker.d.ts +30 -0
- package/dist/cli/templates/docker.d.ts.map +1 -0
- package/dist/cli/templates/docker.js +298 -0
- package/dist/cli/templates/docker.js.map +1 -0
- package/dist/cli/templates/frontend/index.d.ts +25 -0
- package/dist/cli/templates/frontend/index.d.ts.map +1 -0
- package/dist/cli/templates/frontend/index.js +40 -0
- package/dist/cli/templates/frontend/index.js.map +1 -0
- package/dist/cli/templates/frontend/none.d.ts +8 -0
- package/dist/cli/templates/frontend/none.d.ts.map +1 -0
- package/dist/cli/templates/frontend/none.js +15 -0
- package/dist/cli/templates/frontend/none.js.map +1 -0
- package/dist/cli/templates/frontend/react.d.ts +6 -0
- package/dist/cli/templates/frontend/react.d.ts.map +1 -0
- package/dist/cli/templates/frontend/react.js +139 -0
- package/dist/cli/templates/frontend/react.js.map +1 -0
- package/dist/cli/templates/frontend/solid.d.ts +6 -0
- package/dist/cli/templates/frontend/solid.d.ts.map +1 -0
- package/dist/cli/templates/frontend/solid.js +133 -0
- package/dist/cli/templates/frontend/solid.js.map +1 -0
- package/dist/cli/templates/frontend/svelte.d.ts +6 -0
- package/dist/cli/templates/frontend/svelte.d.ts.map +1 -0
- package/dist/cli/templates/frontend/svelte.js +130 -0
- package/dist/cli/templates/frontend/svelte.js.map +1 -0
- package/dist/cli/templates/frontend/vue.d.ts +6 -0
- package/dist/cli/templates/frontend/vue.d.ts.map +1 -0
- package/dist/cli/templates/frontend/vue.js +129 -0
- package/dist/cli/templates/frontend/vue.js.map +1 -0
- package/dist/cli/templates/generators/index.d.ts +29 -0
- package/dist/cli/templates/generators/index.d.ts.map +1 -0
- package/dist/cli/templates/generators/index.js +308 -0
- package/dist/cli/templates/generators/index.js.map +1 -0
- package/dist/cli/templates/generators/types.d.ts +32 -0
- package/dist/cli/templates/generators/types.d.ts.map +1 -0
- package/dist/cli/templates/generators/types.js +21 -0
- package/dist/cli/templates/generators/types.js.map +1 -0
- package/dist/cli/templates/index.d.ts +12 -0
- package/dist/cli/templates/index.d.ts.map +1 -0
- package/dist/cli/templates/index.js +18 -0
- package/dist/cli/templates/index.js.map +1 -0
- package/dist/cli/templates/project/api.d.ts +6 -0
- package/dist/cli/templates/project/api.d.ts.map +1 -0
- package/dist/cli/templates/project/api.js +79 -0
- package/dist/cli/templates/project/api.js.map +1 -0
- package/dist/cli/templates/project/default.d.ts +6 -0
- package/dist/cli/templates/project/default.d.ts.map +1 -0
- package/dist/cli/templates/project/default.js +136 -0
- package/dist/cli/templates/project/default.js.map +1 -0
- package/dist/cli/templates/project/fullstack.d.ts +14 -0
- package/dist/cli/templates/project/fullstack.d.ts.map +1 -0
- package/dist/cli/templates/project/fullstack.js +19 -0
- package/dist/cli/templates/project/fullstack.js.map +1 -0
- package/dist/cli/templates/project/index.d.ts +26 -0
- package/dist/cli/templates/project/index.d.ts.map +1 -0
- package/dist/cli/templates/project/index.js +60 -0
- package/dist/cli/templates/project/index.js.map +1 -0
- package/dist/cli/templates/project/minimal.d.ts +6 -0
- package/dist/cli/templates/project/minimal.d.ts.map +1 -0
- package/dist/cli/templates/project/minimal.js +43 -0
- package/dist/cli/templates/project/minimal.js.map +1 -0
- package/dist/cli/templates/project/types.d.ts +80 -0
- package/dist/cli/templates/project/types.d.ts.map +1 -0
- package/dist/cli/templates/project/types.js +7 -0
- package/dist/cli/templates/project/types.js.map +1 -0
- package/dist/cli/templates/project/website.d.ts +8 -0
- package/dist/cli/templates/project/website.d.ts.map +1 -0
- package/dist/cli/templates/project/website.js +312 -0
- package/dist/cli/templates/project/website.js.map +1 -0
- package/dist/cli/utils/fs.d.ts +137 -0
- package/dist/cli/utils/fs.d.ts.map +1 -0
- package/dist/cli/utils/fs.js +350 -0
- package/dist/cli/utils/fs.js.map +1 -0
- package/dist/cli/utils/index.d.ts +9 -0
- package/dist/cli/utils/index.d.ts.map +1 -0
- package/dist/cli/utils/index.js +9 -0
- package/dist/cli/utils/index.js.map +1 -0
- package/dist/cli/utils/strings.d.ts +86 -0
- package/dist/cli/utils/strings.d.ts.map +1 -0
- package/dist/cli/utils/strings.js +190 -0
- package/dist/cli/utils/strings.js.map +1 -0
- package/dist/cli/utils/version.d.ts +15 -0
- package/dist/cli/utils/version.d.ts.map +1 -0
- package/dist/cli/utils/version.js +38 -0
- package/dist/cli/utils/version.js.map +1 -0
- package/dist/config/env-validation.d.ts +49 -0
- package/dist/config/env-validation.d.ts.map +1 -0
- package/dist/config/env-validation.js +77 -0
- package/dist/config/env-validation.js.map +1 -0
- package/dist/config/env.d.ts +167 -0
- package/dist/config/env.d.ts.map +1 -0
- package/dist/config/env.js +392 -0
- package/dist/config/env.js.map +1 -0
- package/dist/config/index.d.ts +168 -0
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +329 -0
- package/dist/config/index.js.map +1 -0
- package/dist/config/loader.d.ts +81 -0
- package/dist/config/loader.d.ts.map +1 -0
- package/dist/config/loader.js +242 -0
- package/dist/config/loader.js.map +1 -0
- package/dist/config/merge.d.ts +66 -0
- package/dist/config/merge.d.ts.map +1 -0
- package/dist/config/merge.js +226 -0
- package/dist/config/merge.js.map +1 -0
- package/dist/config/types.d.ts +322 -0
- package/dist/config/types.d.ts.map +1 -0
- package/dist/config/types.js +443 -0
- package/dist/config/types.js.map +1 -0
- package/dist/config/validation.d.ts +100 -0
- package/dist/config/validation.d.ts.map +1 -0
- package/dist/config/validation.js +548 -0
- package/dist/config/validation.js.map +1 -0
- package/dist/container/forward-ref.d.ts +116 -0
- package/dist/container/forward-ref.d.ts.map +1 -0
- package/dist/container/forward-ref.js +105 -0
- package/dist/container/forward-ref.js.map +1 -0
- package/dist/container/index.d.ts +95 -0
- package/dist/container/index.d.ts.map +1 -0
- package/dist/container/index.js.map +1 -0
- package/dist/context/index.d.ts +143 -0
- package/dist/context/index.d.ts.map +1 -0
- package/dist/context/index.js.map +1 -0
- package/dist/database/index.d.ts +219 -0
- package/dist/database/index.d.ts.map +1 -0
- package/dist/database/index.js.map +1 -0
- package/dist/database/migrations/index.d.ts +151 -0
- package/dist/database/migrations/index.d.ts.map +1 -0
- package/dist/database/migrations/index.js +258 -0
- package/dist/database/migrations/index.js.map +1 -0
- package/dist/database/orm/builder.d.ts +122 -0
- package/dist/database/orm/builder.d.ts.map +1 -0
- package/dist/database/orm/builder.js +355 -0
- package/dist/database/orm/builder.js.map +1 -0
- package/dist/database/orm/casts/index.d.ts +16 -0
- package/dist/database/orm/casts/index.d.ts.map +1 -0
- package/dist/database/orm/casts/index.js +131 -0
- package/dist/database/orm/casts/index.js.map +1 -0
- package/dist/database/orm/casts/types.d.ts +16 -0
- package/dist/database/orm/casts/types.d.ts.map +1 -0
- package/dist/database/orm/casts/types.js +5 -0
- package/dist/database/orm/casts/types.js.map +1 -0
- package/dist/database/orm/compiler.d.ts +90 -0
- package/dist/database/orm/compiler.d.ts.map +1 -0
- package/dist/database/orm/compiler.js +218 -0
- package/dist/database/orm/compiler.js.map +1 -0
- package/dist/database/orm/hooks/index.d.ts +53 -0
- package/dist/database/orm/hooks/index.d.ts.map +1 -0
- package/dist/database/orm/hooks/index.js +81 -0
- package/dist/database/orm/hooks/index.js.map +1 -0
- package/dist/database/orm/index.d.ts +21 -0
- package/dist/database/orm/index.d.ts.map +1 -0
- package/dist/database/orm/index.js +23 -0
- package/dist/database/orm/index.js.map +1 -0
- package/dist/database/orm/model-registry.d.ts +33 -0
- package/dist/database/orm/model-registry.d.ts.map +1 -0
- package/dist/database/orm/model-registry.js +49 -0
- package/dist/database/orm/model-registry.js.map +1 -0
- package/dist/database/orm/model.d.ts +245 -0
- package/dist/database/orm/model.d.ts.map +1 -0
- package/dist/database/orm/model.js +599 -0
- package/dist/database/orm/model.js.map +1 -0
- package/dist/database/orm/relationships/base.d.ts +69 -0
- package/dist/database/orm/relationships/base.d.ts.map +1 -0
- package/dist/database/orm/relationships/base.js +84 -0
- package/dist/database/orm/relationships/base.js.map +1 -0
- package/dist/database/orm/relationships/belongs-to-many.d.ts +47 -0
- package/dist/database/orm/relationships/belongs-to-many.d.ts.map +1 -0
- package/dist/database/orm/relationships/belongs-to-many.js +136 -0
- package/dist/database/orm/relationships/belongs-to-many.js.map +1 -0
- package/dist/database/orm/relationships/belongs-to.d.ts +17 -0
- package/dist/database/orm/relationships/belongs-to.d.ts.map +1 -0
- package/dist/database/orm/relationships/belongs-to.js +38 -0
- package/dist/database/orm/relationships/belongs-to.js.map +1 -0
- package/dist/database/orm/relationships/has-many.d.ts +14 -0
- package/dist/database/orm/relationships/has-many.d.ts.map +1 -0
- package/dist/database/orm/relationships/has-many.js +35 -0
- package/dist/database/orm/relationships/has-many.js.map +1 -0
- package/dist/database/orm/relationships/has-one.d.ts +14 -0
- package/dist/database/orm/relationships/has-one.d.ts.map +1 -0
- package/dist/database/orm/relationships/has-one.js +32 -0
- package/dist/database/orm/relationships/has-one.js.map +1 -0
- package/dist/database/orm/relationships/index.d.ts +10 -0
- package/dist/database/orm/relationships/index.d.ts.map +1 -0
- package/dist/database/orm/relationships/index.js +9 -0
- package/dist/database/orm/relationships/index.js.map +1 -0
- package/dist/database/orm/scopes/index.d.ts +36 -0
- package/dist/database/orm/scopes/index.d.ts.map +1 -0
- package/dist/database/orm/scopes/index.js +47 -0
- package/dist/database/orm/scopes/index.js.map +1 -0
- package/dist/database/schema/index.d.ts +155 -0
- package/dist/database/schema/index.d.ts.map +1 -0
- package/dist/database/schema/index.js +401 -0
- package/dist/database/schema/index.js.map +1 -0
- package/dist/frontend/api-routes.d.ts +189 -0
- package/dist/frontend/api-routes.d.ts.map +1 -0
- package/dist/frontend/api-routes.js +548 -0
- package/dist/frontend/api-routes.js.map +1 -0
- package/dist/frontend/bundler.d.ts +99 -0
- package/dist/frontend/bundler.d.ts.map +1 -0
- package/dist/frontend/bundler.js +555 -0
- package/dist/frontend/bundler.js.map +1 -0
- package/dist/frontend/console-client.d.ts +11 -0
- package/dist/frontend/console-client.d.ts.map +1 -0
- package/dist/frontend/console-client.js +414 -0
- package/dist/frontend/console-client.js.map +1 -0
- package/dist/frontend/console-stream.d.ts +138 -0
- package/dist/frontend/console-stream.d.ts.map +1 -0
- package/dist/frontend/console-stream.js +535 -0
- package/dist/frontend/console-stream.js.map +1 -0
- package/dist/frontend/dev-server.d.ts +174 -0
- package/dist/frontend/dev-server.d.ts.map +1 -0
- package/dist/frontend/dev-server.js +735 -0
- package/dist/frontend/dev-server.js.map +1 -0
- package/dist/frontend/file-router.d.ts +170 -0
- package/dist/frontend/file-router.d.ts.map +1 -0
- package/dist/frontend/file-router.js +531 -0
- package/dist/frontend/file-router.js.map +1 -0
- package/dist/frontend/frameworks/index.d.ts +41 -0
- package/dist/frontend/frameworks/index.d.ts.map +1 -0
- package/dist/frontend/frameworks/index.js +87 -0
- package/dist/frontend/frameworks/index.js.map +1 -0
- package/dist/frontend/frameworks/react.d.ts +32 -0
- package/dist/frontend/frameworks/react.d.ts.map +1 -0
- package/dist/frontend/frameworks/react.js +66 -0
- package/dist/frontend/frameworks/react.js.map +1 -0
- package/dist/frontend/frameworks/solid.d.ts +42 -0
- package/dist/frontend/frameworks/solid.d.ts.map +1 -0
- package/dist/frontend/frameworks/solid.js +84 -0
- package/dist/frontend/frameworks/solid.js.map +1 -0
- package/dist/frontend/frameworks/svelte.d.ts +57 -0
- package/dist/frontend/frameworks/svelte.d.ts.map +1 -0
- package/dist/frontend/frameworks/svelte.js +90 -0
- package/dist/frontend/frameworks/svelte.js.map +1 -0
- package/dist/frontend/frameworks/vue.d.ts +36 -0
- package/dist/frontend/frameworks/vue.d.ts.map +1 -0
- package/dist/frontend/frameworks/vue.js +72 -0
- package/dist/frontend/frameworks/vue.js.map +1 -0
- package/dist/frontend/hmr-client.d.ts +22 -0
- package/dist/frontend/hmr-client.d.ts.map +1 -0
- package/dist/frontend/hmr-client.js +654 -0
- package/dist/frontend/hmr-client.js.map +1 -0
- package/dist/frontend/hmr.d.ts +185 -0
- package/dist/frontend/hmr.d.ts.map +1 -0
- package/dist/frontend/hmr.js +619 -0
- package/dist/frontend/hmr.js.map +1 -0
- package/dist/frontend/index.d.ts +34 -0
- package/dist/frontend/index.d.ts.map +1 -0
- package/dist/frontend/index.js.map +1 -0
- package/dist/frontend/islands.d.ts +135 -0
- package/dist/frontend/islands.d.ts.map +1 -0
- package/dist/frontend/islands.js +455 -0
- package/dist/frontend/islands.js.map +1 -0
- package/dist/frontend/isr.d.ts +143 -0
- package/dist/frontend/isr.d.ts.map +1 -0
- package/dist/frontend/isr.js +440 -0
- package/dist/frontend/isr.js.map +1 -0
- package/dist/frontend/layout.d.ts +140 -0
- package/dist/frontend/layout.d.ts.map +1 -0
- package/dist/frontend/layout.js +392 -0
- package/dist/frontend/layout.js.map +1 -0
- package/dist/frontend/ssr/react.d.ts +118 -0
- package/dist/frontend/ssr/react.d.ts.map +1 -0
- package/dist/frontend/ssr/react.js +373 -0
- package/dist/frontend/ssr/react.js.map +1 -0
- package/dist/frontend/ssr/solid.d.ts +141 -0
- package/dist/frontend/ssr/solid.d.ts.map +1 -0
- package/dist/frontend/ssr/solid.js +440 -0
- package/dist/frontend/ssr/solid.js.map +1 -0
- package/dist/frontend/ssr/svelte.d.ts +158 -0
- package/dist/frontend/ssr/svelte.d.ts.map +1 -0
- package/dist/frontend/ssr/svelte.js +439 -0
- package/dist/frontend/ssr/svelte.js.map +1 -0
- package/dist/frontend/ssr/vue.d.ts +161 -0
- package/dist/frontend/ssr/vue.d.ts.map +1 -0
- package/dist/frontend/ssr/vue.js +385 -0
- package/dist/frontend/ssr/vue.js.map +1 -0
- package/dist/frontend/ssr.d.ts +147 -0
- package/dist/frontend/ssr.d.ts.map +1 -0
- package/dist/frontend/ssr.js +609 -0
- package/dist/frontend/ssr.js.map +1 -0
- package/dist/frontend/types.d.ts +1902 -0
- package/dist/frontend/types.d.ts.map +1 -0
- package/dist/frontend/types.js +8 -0
- package/dist/frontend/types.js.map +1 -0
- package/dist/graphql/built-in-engine.d.ts +36 -0
- package/dist/graphql/built-in-engine.d.ts.map +1 -0
- package/dist/graphql/built-in-engine.js +443 -0
- package/dist/graphql/built-in-engine.js.map +1 -0
- package/dist/graphql/context-builder.d.ts +44 -0
- package/dist/graphql/context-builder.d.ts.map +1 -0
- package/dist/graphql/context-builder.js +91 -0
- package/dist/graphql/context-builder.js.map +1 -0
- package/dist/graphql/decorators.d.ts +162 -0
- package/dist/graphql/decorators.d.ts.map +1 -0
- package/dist/graphql/decorators.js +291 -0
- package/dist/graphql/decorators.js.map +1 -0
- package/dist/graphql/execution-pipeline.d.ts +67 -0
- package/dist/graphql/execution-pipeline.d.ts.map +1 -0
- package/dist/graphql/execution-pipeline.js +127 -0
- package/dist/graphql/execution-pipeline.js.map +1 -0
- package/dist/graphql/graphql-module.d.ts +70 -0
- package/dist/graphql/graphql-module.d.ts.map +1 -0
- package/dist/graphql/graphql-module.js +442 -0
- package/dist/graphql/graphql-module.js.map +1 -0
- package/dist/graphql/index.d.ts +48 -0
- package/dist/graphql/index.d.ts.map +1 -0
- package/dist/graphql/index.js.map +1 -0
- package/dist/graphql/metadata.d.ts +37 -0
- package/dist/graphql/metadata.d.ts.map +1 -0
- package/dist/graphql/metadata.js +130 -0
- package/dist/graphql/metadata.js.map +1 -0
- package/dist/graphql/schema-builder.d.ts +34 -0
- package/dist/graphql/schema-builder.d.ts.map +1 -0
- package/dist/graphql/schema-builder.js +251 -0
- package/dist/graphql/schema-builder.js.map +1 -0
- package/dist/graphql/subscription-handler.d.ts +47 -0
- package/dist/graphql/subscription-handler.d.ts.map +1 -0
- package/dist/graphql/subscription-handler.js +201 -0
- package/dist/graphql/subscription-handler.js.map +1 -0
- package/dist/graphql/types.d.ts +252 -0
- package/dist/graphql/types.d.ts.map +1 -0
- package/dist/graphql/types.js +28 -0
- package/dist/graphql/types.js.map +1 -0
- package/dist/health/index.d.ts +176 -0
- package/dist/health/index.d.ts.map +1 -0
- package/dist/health/index.js.map +1 -0
- package/dist/i18n/engine.d.ts +105 -0
- package/dist/i18n/engine.d.ts.map +1 -0
- package/dist/i18n/engine.js +248 -0
- package/dist/i18n/engine.js.map +1 -0
- package/dist/i18n/index.d.ts +13 -0
- package/dist/i18n/index.d.ts.map +1 -0
- package/dist/i18n/index.js.map +1 -0
- package/dist/i18n/loader.d.ts +79 -0
- package/dist/i18n/loader.d.ts.map +1 -0
- package/dist/i18n/loader.js +192 -0
- package/dist/i18n/loader.js.map +1 -0
- package/dist/i18n/middleware.d.ts +96 -0
- package/dist/i18n/middleware.d.ts.map +1 -0
- package/dist/i18n/middleware.js +126 -0
- package/dist/i18n/middleware.js.map +1 -0
- package/dist/i18n/negotiator.d.ts +84 -0
- package/dist/i18n/negotiator.d.ts.map +1 -0
- package/dist/i18n/negotiator.js +139 -0
- package/dist/i18n/negotiator.js.map +1 -0
- package/dist/i18n/types.d.ts +129 -0
- package/dist/i18n/types.d.ts.map +1 -0
- package/dist/i18n/types.js +8 -0
- package/dist/i18n/types.js.map +1 -0
- package/dist/index.d.ts +48 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js.map +1 -0
- package/dist/jobs/drivers/memory.d.ts +38 -0
- package/dist/jobs/drivers/memory.d.ts.map +1 -0
- package/dist/jobs/drivers/memory.js +246 -0
- package/dist/jobs/drivers/memory.js.map +1 -0
- package/dist/jobs/drivers/redis.d.ts +34 -0
- package/dist/jobs/drivers/redis.d.ts.map +1 -0
- package/dist/jobs/drivers/redis.js +355 -0
- package/dist/jobs/drivers/redis.js.map +1 -0
- package/dist/jobs/index.d.ts +12 -0
- package/dist/jobs/index.d.ts.map +1 -0
- package/dist/jobs/index.js.map +1 -0
- package/dist/jobs/queue.d.ts +93 -0
- package/dist/jobs/queue.d.ts.map +1 -0
- package/dist/jobs/queue.js +233 -0
- package/dist/jobs/queue.js.map +1 -0
- package/dist/jobs/types.d.ts +193 -0
- package/dist/jobs/types.d.ts.map +1 -0
- package/dist/jobs/types.js +8 -0
- package/dist/jobs/types.js.map +1 -0
- package/dist/jobs/worker.d.ts +91 -0
- package/dist/jobs/worker.d.ts.map +1 -0
- package/dist/jobs/worker.js +300 -0
- package/dist/jobs/worker.js.map +1 -0
- package/dist/lock/index.d.ts +141 -0
- package/dist/lock/index.d.ts.map +1 -0
- package/dist/lock/index.js.map +1 -0
- package/dist/logger/index.d.ts +156 -0
- package/dist/logger/index.d.ts.map +1 -0
- package/dist/logger/index.js.map +1 -0
- package/dist/logger/transports/index.d.ts +371 -0
- package/dist/logger/transports/index.d.ts.map +1 -0
- package/dist/logger/transports/index.js +740 -0
- package/dist/logger/transports/index.js.map +1 -0
- package/dist/metrics/index.d.ts +163 -0
- package/dist/metrics/index.d.ts.map +1 -0
- package/dist/metrics/index.js.map +1 -0
- package/dist/middleware/built-in.d.ts +50 -0
- package/dist/middleware/built-in.d.ts.map +1 -0
- package/dist/middleware/built-in.js +220 -0
- package/dist/middleware/built-in.js.map +1 -0
- package/dist/middleware/index.d.ts +40 -0
- package/dist/middleware/index.d.ts.map +1 -0
- package/dist/middleware/index.js.map +1 -0
- package/dist/migrations/index.d.ts +48 -0
- package/dist/migrations/index.d.ts.map +1 -0
- package/dist/migrations/index.js +3 -0
- package/dist/migrations/index.js.map +1 -0
- package/dist/modules/filters.d.ts +150 -0
- package/dist/modules/filters.d.ts.map +1 -0
- package/dist/modules/filters.js +338 -0
- package/dist/modules/filters.js.map +1 -0
- package/dist/modules/guards.d.ts +188 -0
- package/dist/modules/guards.d.ts.map +1 -0
- package/dist/modules/guards.js +278 -0
- package/dist/modules/guards.js.map +1 -0
- package/dist/modules/index.d.ts +266 -0
- package/dist/modules/index.d.ts.map +1 -0
- package/dist/modules/index.js.map +1 -0
- package/dist/modules/interceptors.d.ts +242 -0
- package/dist/modules/interceptors.d.ts.map +1 -0
- package/dist/modules/interceptors.js +407 -0
- package/dist/modules/interceptors.js.map +1 -0
- package/dist/modules/lazy.d.ts +187 -0
- package/dist/modules/lazy.d.ts.map +1 -0
- package/dist/modules/lazy.js +305 -0
- package/dist/modules/lazy.js.map +1 -0
- package/dist/modules/lifecycle.d.ts +221 -0
- package/dist/modules/lifecycle.d.ts.map +1 -0
- package/dist/modules/lifecycle.js +314 -0
- package/dist/modules/lifecycle.js.map +1 -0
- package/dist/modules/metadata.d.ts +32 -0
- package/dist/modules/metadata.d.ts.map +1 -0
- package/dist/modules/metadata.js +59 -0
- package/dist/modules/metadata.js.map +1 -0
- package/dist/modules/pipes.d.ts +287 -0
- package/dist/modules/pipes.d.ts.map +1 -0
- package/dist/modules/pipes.js +443 -0
- package/dist/modules/pipes.js.map +1 -0
- package/dist/notification/channels/base.d.ts +32 -0
- package/dist/notification/channels/base.d.ts.map +1 -0
- package/dist/notification/channels/base.js +37 -0
- package/dist/notification/channels/base.js.map +1 -0
- package/dist/notification/channels/email.d.ts +37 -0
- package/dist/notification/channels/email.d.ts.map +1 -0
- package/dist/notification/channels/email.js +85 -0
- package/dist/notification/channels/email.js.map +1 -0
- package/dist/notification/channels/push.d.ts +37 -0
- package/dist/notification/channels/push.d.ts.map +1 -0
- package/dist/notification/channels/push.js +84 -0
- package/dist/notification/channels/push.js.map +1 -0
- package/dist/notification/channels/sms.d.ts +37 -0
- package/dist/notification/channels/sms.d.ts.map +1 -0
- package/dist/notification/channels/sms.js +83 -0
- package/dist/notification/channels/sms.js.map +1 -0
- package/dist/notification/channels/whatsapp.d.ts +37 -0
- package/dist/notification/channels/whatsapp.d.ts.map +1 -0
- package/dist/notification/channels/whatsapp.js +81 -0
- package/dist/notification/channels/whatsapp.js.map +1 -0
- package/dist/notification/index.d.ts +15 -0
- package/dist/notification/index.d.ts.map +1 -0
- package/dist/notification/index.js.map +1 -0
- package/dist/notification/service.d.ts +100 -0
- package/dist/notification/service.d.ts.map +1 -0
- package/dist/notification/service.js +279 -0
- package/dist/notification/service.js.map +1 -0
- package/dist/notification/types.d.ts +253 -0
- package/dist/notification/types.d.ts.map +1 -0
- package/dist/notification/types.js +14 -0
- package/dist/notification/types.js.map +1 -0
- package/dist/observability/__tests__/observability.test.d.ts +2 -0
- package/dist/observability/__tests__/observability.test.d.ts.map +1 -0
- package/dist/observability/__tests__/observability.test.js +404 -0
- package/dist/observability/__tests__/observability.test.js.map +1 -0
- package/dist/observability/breadcrumbs.d.ts +48 -0
- package/dist/observability/breadcrumbs.d.ts.map +1 -0
- package/dist/observability/breadcrumbs.js +97 -0
- package/dist/observability/breadcrumbs.js.map +1 -0
- package/dist/observability/index.d.ts +95 -0
- package/dist/observability/index.d.ts.map +1 -0
- package/dist/observability/index.js.map +1 -0
- package/dist/observability/interceptor.d.ts +19 -0
- package/dist/observability/interceptor.d.ts.map +1 -0
- package/dist/observability/interceptor.js +67 -0
- package/dist/observability/interceptor.js.map +1 -0
- package/dist/observability/service.d.ts +101 -0
- package/dist/observability/service.d.ts.map +1 -0
- package/dist/observability/service.js +249 -0
- package/dist/observability/service.js.map +1 -0
- package/dist/observability/trace.d.ts +21 -0
- package/dist/observability/trace.d.ts.map +1 -0
- package/dist/observability/trace.js +35 -0
- package/dist/observability/trace.js.map +1 -0
- package/dist/observability/types.d.ts +172 -0
- package/dist/observability/types.d.ts.map +1 -0
- package/dist/observability/types.js +8 -0
- package/dist/observability/types.js.map +1 -0
- package/dist/openapi/decorators.d.ts +173 -0
- package/dist/openapi/decorators.d.ts.map +1 -0
- package/dist/openapi/decorators.js +276 -0
- package/dist/openapi/decorators.js.map +1 -0
- package/dist/openapi/document-builder.d.ts +82 -0
- package/dist/openapi/document-builder.d.ts.map +1 -0
- package/dist/openapi/document-builder.js +228 -0
- package/dist/openapi/document-builder.js.map +1 -0
- package/dist/openapi/index.d.ts +48 -0
- package/dist/openapi/index.d.ts.map +1 -0
- package/dist/openapi/index.js.map +1 -0
- package/dist/openapi/metadata.d.ts +36 -0
- package/dist/openapi/metadata.d.ts.map +1 -0
- package/dist/openapi/metadata.js +78 -0
- package/dist/openapi/metadata.js.map +1 -0
- package/dist/openapi/route-scanner.d.ts +34 -0
- package/dist/openapi/route-scanner.d.ts.map +1 -0
- package/dist/openapi/route-scanner.js +174 -0
- package/dist/openapi/route-scanner.js.map +1 -0
- package/dist/openapi/schema-generator.d.ts +53 -0
- package/dist/openapi/schema-generator.d.ts.map +1 -0
- package/dist/openapi/schema-generator.js +236 -0
- package/dist/openapi/schema-generator.js.map +1 -0
- package/dist/openapi/swagger-module.d.ts +57 -0
- package/dist/openapi/swagger-module.d.ts.map +1 -0
- package/dist/openapi/swagger-module.js +143 -0
- package/dist/openapi/swagger-module.js.map +1 -0
- package/dist/openapi/types.d.ts +344 -0
- package/dist/openapi/types.d.ts.map +1 -0
- package/dist/openapi/types.js +7 -0
- package/dist/openapi/types.js.map +1 -0
- package/dist/orm/index.d.ts +10 -0
- package/dist/orm/index.d.ts.map +1 -0
- package/dist/orm/index.js.map +1 -0
- package/dist/router/index.d.ts +73 -0
- package/dist/router/index.d.ts.map +1 -0
- package/dist/router/index.js.map +1 -0
- package/dist/router/linear.d.ts +54 -0
- package/dist/router/linear.d.ts.map +1 -0
- package/dist/router/linear.js +261 -0
- package/dist/router/linear.js.map +1 -0
- package/dist/router/regex.d.ts +49 -0
- package/dist/router/regex.d.ts.map +1 -0
- package/dist/router/regex.js +201 -0
- package/dist/router/regex.js.map +1 -0
- package/dist/router/tree.d.ts +112 -0
- package/dist/router/tree.d.ts.map +1 -0
- package/dist/router/tree.js +360 -0
- package/dist/router/tree.js.map +1 -0
- package/dist/rpc/index.d.ts +321 -0
- package/dist/rpc/index.d.ts.map +1 -0
- package/dist/rpc/index.js.map +1 -0
- package/dist/schema/index.d.ts +10 -0
- package/dist/schema/index.d.ts.map +1 -0
- package/dist/schema/index.js.map +1 -0
- package/dist/security/index.d.ts +126 -0
- package/dist/security/index.d.ts.map +1 -0
- package/dist/security/index.js +309 -0
- package/dist/security/index.js.map +1 -0
- package/dist/ssg/index.d.ts +73 -0
- package/dist/ssg/index.d.ts.map +1 -0
- package/dist/ssg/index.js +464 -0
- package/dist/ssg/index.js.map +1 -0
- package/dist/storage/index.d.ts +99 -0
- package/dist/storage/index.d.ts.map +1 -0
- package/dist/storage/index.js +338 -0
- package/dist/storage/index.js.map +1 -0
- package/dist/telemetry/index.d.ts +376 -0
- package/dist/telemetry/index.d.ts.map +1 -0
- package/dist/telemetry/index.js.map +1 -0
- package/dist/template/index.d.ts +7 -0
- package/dist/template/index.d.ts.map +1 -0
- package/dist/template/index.js.map +1 -0
- package/dist/templates/engine.d.ts +60 -0
- package/dist/templates/engine.d.ts.map +1 -0
- package/dist/templates/engine.js +177 -0
- package/dist/templates/engine.js.map +1 -0
- package/dist/templates/index.d.ts +9 -0
- package/dist/templates/index.d.ts.map +1 -0
- package/dist/templates/index.js.map +1 -0
- package/dist/templates/loader.d.ts +45 -0
- package/dist/templates/loader.d.ts.map +1 -0
- package/dist/templates/loader.js +274 -0
- package/dist/templates/loader.js.map +1 -0
- package/dist/templates/renderers/markdown.d.ts +46 -0
- package/dist/templates/renderers/markdown.d.ts.map +1 -0
- package/dist/templates/renderers/markdown.js +181 -0
- package/dist/templates/renderers/markdown.js.map +1 -0
- package/dist/templates/renderers/simple.d.ts +35 -0
- package/dist/templates/renderers/simple.d.ts.map +1 -0
- package/dist/templates/renderers/simple.js +245 -0
- package/dist/templates/renderers/simple.js.map +1 -0
- package/dist/templates/types.d.ts +138 -0
- package/dist/templates/types.d.ts.map +1 -0
- package/dist/templates/types.js +8 -0
- package/dist/templates/types.js.map +1 -0
- package/dist/testing/index.d.ts +539 -0
- package/dist/testing/index.d.ts.map +1 -0
- package/dist/testing/index.js.map +1 -0
- package/dist/types/index.d.ts +116 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js.map +1 -0
- package/dist/validation/index.d.ts +89 -0
- package/dist/validation/index.d.ts.map +1 -0
- package/dist/validation/index.js +276 -0
- package/dist/validation/index.js.map +1 -0
- package/dist/validation/schemas.d.ts +283 -0
- package/dist/validation/schemas.d.ts.map +1 -0
- package/dist/validation/schemas.js +407 -0
- package/dist/validation/schemas.js.map +1 -0
- package/dist/websocket/index.d.ts +252 -0
- package/dist/websocket/index.d.ts.map +1 -0
- package/dist/websocket/index.js +749 -0
- package/dist/websocket/index.js.map +1 -0
- package/package.json +3 -3
- package/src/database/migrations/index.ts +8 -0
- package/src/migrations/index.ts +40 -1
- package/src/types/index.ts +1 -1
- package/tsconfig.json +2 -6
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Base Relationship Class
|
|
3
|
+
*
|
|
4
|
+
* Abstract base for all relationship types (HasOne, HasMany, etc.)
|
|
5
|
+
*/
|
|
6
|
+
import type { Database } from "../../index";
|
|
7
|
+
import { OrmQueryBuilder } from "../builder";
|
|
8
|
+
import type { Model } from "../model";
|
|
9
|
+
export interface RelationshipOptions {
|
|
10
|
+
foreignKey?: string;
|
|
11
|
+
localKey?: string;
|
|
12
|
+
ownerKey?: string;
|
|
13
|
+
relatedKey?: string;
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Abstract base relationship class
|
|
17
|
+
*/
|
|
18
|
+
export declare abstract class Relationship<TParent extends Model, TRelated extends Model> {
|
|
19
|
+
protected parentModel: TParent;
|
|
20
|
+
protected relatedClass: {
|
|
21
|
+
new (): TRelated;
|
|
22
|
+
} & typeof Model;
|
|
23
|
+
protected foreignKey: string;
|
|
24
|
+
protected localKey: string;
|
|
25
|
+
protected query: OrmQueryBuilder<any>;
|
|
26
|
+
protected db: Database;
|
|
27
|
+
constructor(parentModel: TParent, relatedClass: {
|
|
28
|
+
new (): TRelated;
|
|
29
|
+
} & typeof Model, foreignKey: string, localKey?: string);
|
|
30
|
+
/**
|
|
31
|
+
* Initialize constraints — call this in subclass constructors after all
|
|
32
|
+
* private fields are assigned, if the subclass needs them in addConstraints().
|
|
33
|
+
*/
|
|
34
|
+
protected initConstraints(): void;
|
|
35
|
+
/**
|
|
36
|
+
* Add WHERE clause for this relationship
|
|
37
|
+
* (override in subclasses)
|
|
38
|
+
*/
|
|
39
|
+
abstract addConstraints(): void;
|
|
40
|
+
/**
|
|
41
|
+
* Add eager load constraints
|
|
42
|
+
* (override in subclasses)
|
|
43
|
+
*/
|
|
44
|
+
abstract addEagerConstraints(parents: TParent[]): void;
|
|
45
|
+
/**
|
|
46
|
+
* Match eager-loaded results to parent models
|
|
47
|
+
* (override in subclasses)
|
|
48
|
+
*/
|
|
49
|
+
abstract match(parents: TParent[], results: TRelated[], relation: string): void;
|
|
50
|
+
/**
|
|
51
|
+
* Get the results for this relationship
|
|
52
|
+
*/
|
|
53
|
+
abstract getResults(): Promise<TRelated | TRelated[] | null>;
|
|
54
|
+
/**
|
|
55
|
+
* Reset the query builder to a fresh state
|
|
56
|
+
* Used during eager loading to clear single-model constraints from constructor
|
|
57
|
+
*/
|
|
58
|
+
protected resetQuery(): void;
|
|
59
|
+
where(column: string, operator: unknown, value?: unknown): this;
|
|
60
|
+
orWhere(column: string, operator: unknown, value?: unknown): this;
|
|
61
|
+
orderBy(column: string, direction?: "ASC" | "DESC"): this;
|
|
62
|
+
limit(n: number): this;
|
|
63
|
+
get(): Promise<TRelated[]>;
|
|
64
|
+
first(): Promise<TRelated | null>;
|
|
65
|
+
count(): Promise<number>;
|
|
66
|
+
exists(): Promise<boolean>;
|
|
67
|
+
create(data: Record<string, unknown>): Promise<TRelated>;
|
|
68
|
+
}
|
|
69
|
+
//# sourceMappingURL=base.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"base.d.ts","sourceRoot":"","sources":["../../../../src/database/orm/relationships/base.ts"],"names":[],"mappings":"AAGA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAC5C,OAAO,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAC7C,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,UAAU,CAAC;AAGtC,MAAM,WAAW,mBAAmB;IACnC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,UAAU,CAAC,EAAE,MAAM,CAAC;CACpB;AAED;;GAEG;AACH,8BAAsB,YAAY,CACjC,OAAO,SAAS,KAAK,EACrB,QAAQ,SAAS,KAAK;IAMrB,SAAS,CAAC,WAAW,EAAE,OAAO;IAC9B,SAAS,CAAC,YAAY,EAAE;QAAE,QAAQ,QAAQ,CAAA;KAAE,GAAG,OAAO,KAAK;IAC3D,SAAS,CAAC,UAAU,EAAE,MAAM;IAC5B,SAAS,CAAC,QAAQ;IAPnB,SAAS,CAAC,KAAK,EAAE,eAAe,CAAC,GAAG,CAAC,CAAC;IACtC,SAAS,CAAC,EAAE,EAAE,QAAQ,CAAC;gBAGZ,WAAW,EAAE,OAAO,EACpB,YAAY,EAAE;QAAE,QAAQ,QAAQ,CAAA;KAAE,GAAG,OAAO,KAAK,EACjD,UAAU,EAAE,MAAM,EAClB,QAAQ,SAAO;IAS1B;;;OAGG;IACH,SAAS,CAAC,eAAe,IAAI,IAAI;IAQjC;;;OAGG;IACH,QAAQ,CAAC,cAAc,IAAI,IAAI;IAE/B;;;OAGG;IACH,QAAQ,CAAC,mBAAmB,CAAC,OAAO,EAAE,OAAO,EAAE,GAAG,IAAI;IAEtD;;;OAGG;IACH,QAAQ,CAAC,KAAK,CACb,OAAO,EAAE,OAAO,EAAE,EAClB,OAAO,EAAE,QAAQ,EAAE,EACnB,QAAQ,EAAE,MAAM,GACd,IAAI;IAEP;;OAEG;IACH,QAAQ,CAAC,UAAU,IAAI,OAAO,CAAC,QAAQ,GAAG,QAAQ,EAAE,GAAG,IAAI,CAAC;IAE5D;;;OAGG;IACH,SAAS,CAAC,UAAU,IAAI,IAAI;IAS5B,KAAK,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,KAAK,CAAC,EAAE,OAAO,GAAG,IAAI;IAK/D,OAAO,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,KAAK,CAAC,EAAE,OAAO,GAAG,IAAI;IAKjE,OAAO,CAAC,MAAM,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,KAAK,GAAG,MAAM,GAAG,IAAI;IAKzD,KAAK,CAAC,CAAC,EAAE,MAAM,GAAG,IAAI;IAOhB,GAAG,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;IAK1B,KAAK,IAAI,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC;IAMjC,KAAK,IAAI,OAAO,CAAC,MAAM,CAAC;IAIxB,MAAM,IAAI,OAAO,CAAC,OAAO,CAAC;IAI1B,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,OAAO,CAAC,QAAQ,CAAC;CAQ9D"}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
// @ts-nocheck - Abstract class generic constraints cause false positives in TypeScript.
|
|
2
|
+
// The implementation is logically correct; see .idea/orm-implementation-status.md
|
|
3
|
+
import { OrmQueryBuilder } from "../builder";
|
|
4
|
+
import { getModelDatabase } from "../model-registry";
|
|
5
|
+
/**
|
|
6
|
+
* Abstract base relationship class
|
|
7
|
+
*/
|
|
8
|
+
export class Relationship {
|
|
9
|
+
parentModel;
|
|
10
|
+
relatedClass;
|
|
11
|
+
foreignKey;
|
|
12
|
+
localKey;
|
|
13
|
+
query;
|
|
14
|
+
db;
|
|
15
|
+
constructor(parentModel, relatedClass, foreignKey, localKey = "id") {
|
|
16
|
+
this.parentModel = parentModel;
|
|
17
|
+
this.relatedClass = relatedClass;
|
|
18
|
+
this.foreignKey = foreignKey;
|
|
19
|
+
this.localKey = localKey;
|
|
20
|
+
this.db = getModelDatabase(relatedClass.name);
|
|
21
|
+
this.query = new OrmQueryBuilder(this.db, relatedClass.table);
|
|
22
|
+
// Note: subclasses that use private fields must call initConstraints()
|
|
23
|
+
// themselves after their field assignments, rather than relying on this call.
|
|
24
|
+
this.addConstraints();
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Initialize constraints — call this in subclass constructors after all
|
|
28
|
+
* private fields are assigned, if the subclass needs them in addConstraints().
|
|
29
|
+
*/
|
|
30
|
+
initConstraints() {
|
|
31
|
+
this.query = new OrmQueryBuilder(this.db, this.relatedClass.table);
|
|
32
|
+
this.addConstraints();
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Reset the query builder to a fresh state
|
|
36
|
+
* Used during eager loading to clear single-model constraints from constructor
|
|
37
|
+
*/
|
|
38
|
+
resetQuery() {
|
|
39
|
+
this.query = new OrmQueryBuilder(this.db, this.relatedClass.table);
|
|
40
|
+
}
|
|
41
|
+
// ============= Chainable Methods =============
|
|
42
|
+
where(column, operator, value) {
|
|
43
|
+
this.query.where(column, operator, value);
|
|
44
|
+
return this;
|
|
45
|
+
}
|
|
46
|
+
orWhere(column, operator, value) {
|
|
47
|
+
this.query.orWhere(column, operator, value);
|
|
48
|
+
return this;
|
|
49
|
+
}
|
|
50
|
+
orderBy(column, direction) {
|
|
51
|
+
this.query.orderBy(column, direction);
|
|
52
|
+
return this;
|
|
53
|
+
}
|
|
54
|
+
limit(n) {
|
|
55
|
+
this.query.limit(n);
|
|
56
|
+
return this;
|
|
57
|
+
}
|
|
58
|
+
// ============= Query Terminals =============
|
|
59
|
+
async get() {
|
|
60
|
+
const rows = await this.query.get();
|
|
61
|
+
return this.relatedClass.hydrate(rows);
|
|
62
|
+
}
|
|
63
|
+
async first() {
|
|
64
|
+
const rows = await this.query.limit(1).get();
|
|
65
|
+
if (rows.length === 0)
|
|
66
|
+
return null;
|
|
67
|
+
return this.relatedClass.hydrate([rows[0]])[0];
|
|
68
|
+
}
|
|
69
|
+
async count() {
|
|
70
|
+
return this.query.count();
|
|
71
|
+
}
|
|
72
|
+
async exists() {
|
|
73
|
+
return this.query.exists();
|
|
74
|
+
}
|
|
75
|
+
async create(data) {
|
|
76
|
+
// Set the foreign key
|
|
77
|
+
const model_data = {
|
|
78
|
+
...data,
|
|
79
|
+
[this.foreignKey]: this.parentModel.getAttribute(this.localKey),
|
|
80
|
+
};
|
|
81
|
+
return this.relatedClass.create(model_data);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
//# sourceMappingURL=base.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"base.js","sourceRoot":"","sources":["../../../../src/database/orm/relationships/base.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* BelongsToMany Relationship
|
|
3
|
+
*
|
|
4
|
+
* Model belongs to many related models through a pivot table (n:m)
|
|
5
|
+
*/
|
|
6
|
+
import type { Model } from "../model";
|
|
7
|
+
import { Relationship } from "./base";
|
|
8
|
+
export declare class BelongsToMany<TRelated extends Model> extends Relationship<any, TRelated> {
|
|
9
|
+
private pivotTable;
|
|
10
|
+
private foreignPivotKey;
|
|
11
|
+
private relatedPivotKey;
|
|
12
|
+
private parentKey;
|
|
13
|
+
private relatedKey;
|
|
14
|
+
private pivotData;
|
|
15
|
+
constructor(parentModel: Model, relatedClass: {
|
|
16
|
+
new (): TRelated;
|
|
17
|
+
} & typeof Model, pivotTable: string, foreignPivotKey: string, relatedPivotKey: string, parentKey?: string, relatedKey?: string);
|
|
18
|
+
addConstraints(): void;
|
|
19
|
+
addEagerConstraints(parents: Model[]): void;
|
|
20
|
+
match(parents: Model[], results: TRelated[], relation: string): void;
|
|
21
|
+
/**
|
|
22
|
+
* Include specific pivot columns in results
|
|
23
|
+
*/
|
|
24
|
+
withPivot(...columns: string[]): this;
|
|
25
|
+
/**
|
|
26
|
+
* Attach related models to the pivot table
|
|
27
|
+
*/
|
|
28
|
+
attach(ids: unknown | unknown[], pivotData?: Record<string, unknown>): Promise<void>;
|
|
29
|
+
/**
|
|
30
|
+
* Detach related models from the pivot table
|
|
31
|
+
*/
|
|
32
|
+
detach(ids?: unknown | unknown[]): Promise<void>;
|
|
33
|
+
/**
|
|
34
|
+
* Sync related models (replace all with given IDs)
|
|
35
|
+
*/
|
|
36
|
+
sync(ids: unknown[], detaching?: boolean): Promise<void>;
|
|
37
|
+
/**
|
|
38
|
+
* Toggle related models
|
|
39
|
+
*/
|
|
40
|
+
toggle(ids: unknown | unknown[]): Promise<void>;
|
|
41
|
+
/**
|
|
42
|
+
* Update pivot data
|
|
43
|
+
*/
|
|
44
|
+
updateExistingPivot(id: unknown, data: Record<string, unknown>): Promise<void>;
|
|
45
|
+
getResults(): Promise<TRelated[]>;
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=belongs-to-many.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"belongs-to-many.d.ts","sourceRoot":"","sources":["../../../../src/database/orm/relationships/belongs-to-many.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAIH,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,UAAU,CAAC;AAEtC,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAEtC,qBAAa,aAAa,CAAC,QAAQ,SAAS,KAAK,CAAE,SAAQ,YAAY,CACtE,GAAG,EACH,QAAQ,CACR;IAMC,OAAO,CAAC,UAAU;IAClB,OAAO,CAAC,eAAe;IACvB,OAAO,CAAC,eAAe;IACvB,OAAO,CAAC,SAAS;IACjB,OAAO,CAAC,UAAU;IATnB,OAAO,CAAC,SAAS,CAA0B;gBAG1C,WAAW,EAAE,KAAK,EAClB,YAAY,EAAE;QAAE,QAAQ,QAAQ,CAAA;KAAE,GAAG,OAAO,KAAK,EACzC,UAAU,EAAE,MAAM,EAClB,eAAe,EAAE,MAAM,EACvB,eAAe,EAAE,MAAM,EACvB,SAAS,SAAO,EAChB,UAAU,SAAO;IAQ1B,cAAc,IAAI,IAAI;IAatB,mBAAmB,CAAC,OAAO,EAAE,KAAK,EAAE,GAAG,IAAI;IAK3C,KAAK,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,QAAQ,EAAE,MAAM,GAAG,IAAI;IAmBpE;;OAEG;IACH,SAAS,CAAC,GAAG,OAAO,EAAE,MAAM,EAAE,GAAG,IAAI;IAOrC;;OAEG;IACG,MAAM,CACX,GAAG,EAAE,OAAO,GAAG,OAAO,EAAE,EACxB,SAAS,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GACjC,OAAO,CAAC,IAAI,CAAC;IA2BhB;;OAEG;IACG,MAAM,CAAC,GAAG,CAAC,EAAE,OAAO,GAAG,OAAO,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAiBtD;;OAEG;IACG,IAAI,CAAC,GAAG,EAAE,OAAO,EAAE,EAAE,SAAS,UAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAO3D;;OAEG;IACG,MAAM,CAAC,GAAG,EAAE,OAAO,GAAG,OAAO,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAarD;;OAEG;IACG,mBAAmB,CACxB,EAAE,EAAE,OAAO,EACX,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAC3B,OAAO,CAAC,IAAI,CAAC;IAUV,UAAU,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;CAGvC"}
|
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* BelongsToMany Relationship
|
|
3
|
+
*
|
|
4
|
+
* Model belongs to many related models through a pivot table (n:m)
|
|
5
|
+
*/
|
|
6
|
+
import { OrmQueryBuilder } from "../builder";
|
|
7
|
+
import { getModelDatabase } from "../model-registry";
|
|
8
|
+
import { Relationship } from "./base";
|
|
9
|
+
export class BelongsToMany extends Relationship {
|
|
10
|
+
pivotTable;
|
|
11
|
+
foreignPivotKey;
|
|
12
|
+
relatedPivotKey;
|
|
13
|
+
parentKey;
|
|
14
|
+
relatedKey;
|
|
15
|
+
pivotData = new Set();
|
|
16
|
+
constructor(parentModel, relatedClass, pivotTable, foreignPivotKey, relatedPivotKey, parentKey = "id", relatedKey = "id") {
|
|
17
|
+
super(parentModel, relatedClass, foreignPivotKey, parentKey);
|
|
18
|
+
this.pivotTable = pivotTable;
|
|
19
|
+
this.foreignPivotKey = foreignPivotKey;
|
|
20
|
+
this.relatedPivotKey = relatedPivotKey;
|
|
21
|
+
this.parentKey = parentKey;
|
|
22
|
+
this.relatedKey = relatedKey;
|
|
23
|
+
// Private fields are assigned after super() returns, so we must
|
|
24
|
+
// re-initialize constraints now that they are available.
|
|
25
|
+
this.initConstraints();
|
|
26
|
+
}
|
|
27
|
+
addConstraints() {
|
|
28
|
+
// Guard: if pivotTable hasn't been assigned yet (called from base super()),
|
|
29
|
+
// do nothing — initConstraints() will call us again after field assignment.
|
|
30
|
+
if (!this.pivotTable)
|
|
31
|
+
return;
|
|
32
|
+
const parentId = this.parentModel.getAttribute(this.parentKey);
|
|
33
|
+
this.query.join(this.pivotTable, `${this.pivotTable}.${this.relatedPivotKey} = ${this.relatedClass.table}.${this.relatedKey}`);
|
|
34
|
+
this.query.where(`${this.pivotTable}.${this.foreignPivotKey}`, parentId);
|
|
35
|
+
}
|
|
36
|
+
addEagerConstraints(parents) {
|
|
37
|
+
const ids = parents.map((p) => p.getAttribute(this.parentKey));
|
|
38
|
+
this.query.whereIn(`${this.pivotTable}.${this.foreignPivotKey}`, ids);
|
|
39
|
+
}
|
|
40
|
+
match(parents, results, relation) {
|
|
41
|
+
const grouped = new Map();
|
|
42
|
+
for (const result of results) {
|
|
43
|
+
// The JOIN puts the pivot FK column in the result row as a regular attribute
|
|
44
|
+
const parentId = result.getAttribute(this.foreignPivotKey);
|
|
45
|
+
if (!grouped.has(parentId)) {
|
|
46
|
+
grouped.set(parentId, []);
|
|
47
|
+
}
|
|
48
|
+
grouped.get(parentId).push(result);
|
|
49
|
+
}
|
|
50
|
+
for (const parent of parents) {
|
|
51
|
+
const key = parent.getAttribute(this.parentKey);
|
|
52
|
+
const related = grouped.get(key) ?? [];
|
|
53
|
+
parent._relations.set(relation, related);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* Include specific pivot columns in results
|
|
58
|
+
*/
|
|
59
|
+
withPivot(...columns) {
|
|
60
|
+
for (const col of columns) {
|
|
61
|
+
this.pivotData.add(col);
|
|
62
|
+
}
|
|
63
|
+
return this;
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Attach related models to the pivot table
|
|
67
|
+
*/
|
|
68
|
+
async attach(ids, pivotData) {
|
|
69
|
+
const idArray = Array.isArray(ids) ? ids : [ids];
|
|
70
|
+
const parentId = this.parentModel.getAttribute(this.parentKey);
|
|
71
|
+
const db = getModelDatabase(this.relatedClass.name);
|
|
72
|
+
for (const id of idArray) {
|
|
73
|
+
const data = {
|
|
74
|
+
[this.foreignPivotKey]: parentId,
|
|
75
|
+
[this.relatedPivotKey]: id,
|
|
76
|
+
...pivotData,
|
|
77
|
+
};
|
|
78
|
+
// Use raw insert to avoid OrmQueryBuilder.insert()'s SELECT-by-id fetch-back,
|
|
79
|
+
// which fails on pivot tables that have no 'id' primary key column.
|
|
80
|
+
const columns = Object.keys(data).join(", ");
|
|
81
|
+
const placeholders = Object.keys(data)
|
|
82
|
+
.map(() => "?")
|
|
83
|
+
.join(", ");
|
|
84
|
+
const values = Object.values(data);
|
|
85
|
+
await db.raw(`INSERT INTO ${this.pivotTable} (${columns}) VALUES (${placeholders})`, values);
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Detach related models from the pivot table
|
|
90
|
+
*/
|
|
91
|
+
async detach(ids) {
|
|
92
|
+
const parentId = this.parentModel.getAttribute(this.parentKey);
|
|
93
|
+
const db = getModelDatabase(this.relatedClass.name);
|
|
94
|
+
let builder = new OrmQueryBuilder(db, this.pivotTable).where(this.foreignPivotKey, parentId);
|
|
95
|
+
if (ids) {
|
|
96
|
+
const idArray = Array.isArray(ids) ? ids : [ids];
|
|
97
|
+
builder = builder.whereIn(this.relatedPivotKey, idArray);
|
|
98
|
+
}
|
|
99
|
+
await builder.delete();
|
|
100
|
+
}
|
|
101
|
+
/**
|
|
102
|
+
* Sync related models (replace all with given IDs)
|
|
103
|
+
*/
|
|
104
|
+
async sync(ids, detaching = true) {
|
|
105
|
+
if (detaching) {
|
|
106
|
+
await this.detach();
|
|
107
|
+
}
|
|
108
|
+
await this.attach(ids);
|
|
109
|
+
}
|
|
110
|
+
/**
|
|
111
|
+
* Toggle related models
|
|
112
|
+
*/
|
|
113
|
+
async toggle(ids) {
|
|
114
|
+
const idArray = Array.isArray(ids) ? ids : [ids];
|
|
115
|
+
const attached = await this.get();
|
|
116
|
+
const attachedIds = attached.map((m) => m.getAttribute(this.relatedKey));
|
|
117
|
+
const toAttach = idArray.filter((id) => !attachedIds.includes(id));
|
|
118
|
+
const toDetach = attachedIds.filter((id) => idArray.includes(id));
|
|
119
|
+
await Promise.all([this.attach(toAttach), this.detach(toDetach)]);
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* Update pivot data
|
|
123
|
+
*/
|
|
124
|
+
async updateExistingPivot(id, data) {
|
|
125
|
+
const parentId = this.parentModel.getAttribute(this.parentKey);
|
|
126
|
+
const db = getModelDatabase(this.relatedClass.name);
|
|
127
|
+
await new OrmQueryBuilder(db, this.pivotTable)
|
|
128
|
+
.where(this.foreignPivotKey, parentId)
|
|
129
|
+
.where(this.relatedPivotKey, id)
|
|
130
|
+
.update(data);
|
|
131
|
+
}
|
|
132
|
+
async getResults() {
|
|
133
|
+
return this.get();
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
//# sourceMappingURL=belongs-to-many.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"belongs-to-many.js","sourceRoot":"","sources":["../../../../src/database/orm/relationships/belongs-to-many.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* BelongsTo Relationship
|
|
3
|
+
*
|
|
4
|
+
* Model belongs to a parent model (reverse of HasOne/HasMany)
|
|
5
|
+
*/
|
|
6
|
+
import type { Model } from "../model";
|
|
7
|
+
import { Relationship } from "./base";
|
|
8
|
+
export declare class BelongsTo<TRelated extends Model> extends Relationship<any, TRelated> {
|
|
9
|
+
constructor(parentModel: Model, relatedClass: {
|
|
10
|
+
new (): TRelated;
|
|
11
|
+
} & typeof Model, foreignKey: string, ownerKey?: string);
|
|
12
|
+
addConstraints(): void;
|
|
13
|
+
addEagerConstraints(parents: Model[]): void;
|
|
14
|
+
match(parents: Model[], results: TRelated[], relation: string): void;
|
|
15
|
+
getResults(): Promise<TRelated | null>;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=belongs-to.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"belongs-to.d.ts","sourceRoot":"","sources":["../../../../src/database/orm/relationships/belongs-to.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,UAAU,CAAC;AACtC,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAEtC,qBAAa,SAAS,CAAC,QAAQ,SAAS,KAAK,CAAE,SAAQ,YAAY,CAClE,GAAG,EACH,QAAQ,CACR;gBAEC,WAAW,EAAE,KAAK,EAClB,YAAY,EAAE;QAAE,QAAQ,QAAQ,CAAA;KAAE,GAAG,OAAO,KAAK,EACjD,UAAU,EAAE,MAAM,EAClB,QAAQ,SAAO;IAOhB,cAAc,IAAI,IAAI;IAQtB,mBAAmB,CAAC,OAAO,EAAE,KAAK,EAAE,GAAG,IAAI;IAK3C,KAAK,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,QAAQ,EAAE,MAAM,GAAG,IAAI;IAe9D,UAAU,IAAI,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC;CAG5C"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* BelongsTo Relationship
|
|
3
|
+
*
|
|
4
|
+
* Model belongs to a parent model (reverse of HasOne/HasMany)
|
|
5
|
+
*/
|
|
6
|
+
import { Relationship } from "./base";
|
|
7
|
+
export class BelongsTo extends Relationship {
|
|
8
|
+
constructor(parentModel, relatedClass, foreignKey, ownerKey = "id") {
|
|
9
|
+
// Pass ownerKey as localKey so addConstraints() (called inside super())
|
|
10
|
+
// can access it via this.localKey before ownerKey is assigned as a field.
|
|
11
|
+
super(parentModel, relatedClass, foreignKey, ownerKey);
|
|
12
|
+
}
|
|
13
|
+
addConstraints() {
|
|
14
|
+
const parentForeignId = this.parentModel.getAttribute(this.foreignKey);
|
|
15
|
+
// this.localKey holds the ownerKey value (e.g. "id")
|
|
16
|
+
this.query.where(this.localKey, parentForeignId);
|
|
17
|
+
}
|
|
18
|
+
addEagerConstraints(parents) {
|
|
19
|
+
const ids = parents.map((p) => p.getAttribute(this.foreignKey));
|
|
20
|
+
this.query.whereIn(this.localKey, ids);
|
|
21
|
+
}
|
|
22
|
+
match(parents, results, relation) {
|
|
23
|
+
const grouped = new Map();
|
|
24
|
+
for (const result of results) {
|
|
25
|
+
const key = result.getAttribute(this.localKey);
|
|
26
|
+
grouped.set(key, result);
|
|
27
|
+
}
|
|
28
|
+
for (const parent of parents) {
|
|
29
|
+
const key = parent.getAttribute(this.foreignKey);
|
|
30
|
+
const related = grouped.get(key) ?? null;
|
|
31
|
+
parent._relations.set(relation, related);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
async getResults() {
|
|
35
|
+
return this.first();
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=belongs-to.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"belongs-to.js","sourceRoot":"","sources":["../../../../src/database/orm/relationships/belongs-to.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAEtC,MAAM,OAAO,SAAkC,SAAQ,YAGtD;IACA,YACC,WAAkB,EAClB,YAAiD,EACjD,UAAkB,EAClB,QAAQ,GAAG,IAAI;QAEf,wEAAwE;QACxE,0EAA0E;QAC1E,KAAK,CAAC,WAAW,EAAE,YAAY,EAAE,UAAU,EAAE,QAAQ,CAAC,CAAC;IACxD,CAAC;IAED,cAAc;QACb,MAAM,eAAe,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,CACpD,IAAI,CAAC,UAAiB,CACtB,CAAC;QACF,qDAAqD;QACrD,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE,eAAe,CAAC,CAAC;IAClD,CAAC;IAED,mBAAmB,CAAC,OAAgB;QACnC,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,UAAiB,CAAC,CAAC,CAAC;QACvE,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;IACxC,CAAC;IAED,KAAK,CAAC,OAAgB,EAAE,OAAmB,EAAE,QAAgB;QAC5D,MAAM,OAAO,GAAG,IAAI,GAAG,EAAqB,CAAC;QAE7C,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC9B,MAAM,GAAG,GAAG,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,QAAe,CAAC,CAAC;YACtD,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;QAC1B,CAAC;QAED,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC9B,MAAM,GAAG,GAAG,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,UAAiB,CAAC,CAAC;YACxD,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC;YACxC,MAAc,CAAC,UAAU,CAAC,GAAG,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;QACnD,CAAC;IACF,CAAC;IAED,KAAK,CAAC,UAAU;QACf,OAAO,IAAI,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;CACD"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* HasMany Relationship
|
|
3
|
+
*
|
|
4
|
+
* Model has many related models (1:n)
|
|
5
|
+
*/
|
|
6
|
+
import type { Model } from "../model";
|
|
7
|
+
import { Relationship } from "./base";
|
|
8
|
+
export declare class HasMany<TRelated extends Model> extends Relationship<any, TRelated> {
|
|
9
|
+
addConstraints(): void;
|
|
10
|
+
addEagerConstraints(parents: Model[]): void;
|
|
11
|
+
match(parents: Model[], results: TRelated[], relation: string): void;
|
|
12
|
+
getResults(): Promise<TRelated[]>;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=has-many.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"has-many.d.ts","sourceRoot":"","sources":["../../../../src/database/orm/relationships/has-many.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,UAAU,CAAC;AACtC,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAEtC,qBAAa,OAAO,CAAC,QAAQ,SAAS,KAAK,CAAE,SAAQ,YAAY,CAChE,GAAG,EACH,QAAQ,CACR;IACA,cAAc,IAAI,IAAI;IAKtB,mBAAmB,CAAC,OAAO,EAAE,KAAK,EAAE,GAAG,IAAI;IAK3C,KAAK,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,QAAQ,EAAE,MAAM,GAAG,IAAI;IAkB9D,UAAU,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;CAGvC"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* HasMany Relationship
|
|
3
|
+
*
|
|
4
|
+
* Model has many related models (1:n)
|
|
5
|
+
*/
|
|
6
|
+
import { Relationship } from "./base";
|
|
7
|
+
export class HasMany extends Relationship {
|
|
8
|
+
addConstraints() {
|
|
9
|
+
const parentId = this.parentModel.getAttribute(this.localKey);
|
|
10
|
+
this.query.where(this.foreignKey, parentId);
|
|
11
|
+
}
|
|
12
|
+
addEagerConstraints(parents) {
|
|
13
|
+
const ids = parents.map((p) => p.getAttribute(this.localKey));
|
|
14
|
+
this.query.whereIn(this.foreignKey, ids);
|
|
15
|
+
}
|
|
16
|
+
match(parents, results, relation) {
|
|
17
|
+
const grouped = new Map();
|
|
18
|
+
for (const result of results) {
|
|
19
|
+
const key = result.getAttribute(this.foreignKey);
|
|
20
|
+
if (!grouped.has(key)) {
|
|
21
|
+
grouped.set(key, []);
|
|
22
|
+
}
|
|
23
|
+
grouped.get(key).push(result);
|
|
24
|
+
}
|
|
25
|
+
for (const parent of parents) {
|
|
26
|
+
const key = parent.getAttribute(this.localKey);
|
|
27
|
+
const related = grouped.get(key) ?? [];
|
|
28
|
+
parent._relations.set(relation, related);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
async getResults() {
|
|
32
|
+
return this.get();
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=has-many.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"has-many.js","sourceRoot":"","sources":["../../../../src/database/orm/relationships/has-many.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAEtC,MAAM,OAAO,OAAgC,SAAQ,YAGpD;IACA,cAAc;QACb,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,IAAI,CAAC,QAAe,CAAC,CAAC;QACrE,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC;IAC7C,CAAC;IAED,mBAAmB,CAAC,OAAgB;QACnC,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,QAAe,CAAC,CAAC,CAAC;QACrE,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC;IAC1C,CAAC;IAED,KAAK,CAAC,OAAgB,EAAE,OAAmB,EAAE,QAAgB;QAC5D,MAAM,OAAO,GAAG,IAAI,GAAG,EAAuB,CAAC;QAE/C,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC9B,MAAM,GAAG,GAAG,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,UAAiB,CAAC,CAAC;YACxD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;gBACvB,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;YACtB,CAAC;YACD,OAAO,CAAC,GAAG,CAAC,GAAG,CAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAChC,CAAC;QAED,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC9B,MAAM,GAAG,GAAG,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,QAAe,CAAC,CAAC;YACtD,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC;YACtC,MAAc,CAAC,UAAU,CAAC,GAAG,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;QACnD,CAAC;IACF,CAAC;IAED,KAAK,CAAC,UAAU;QACf,OAAO,IAAI,CAAC,GAAG,EAAE,CAAC;IACnB,CAAC;CACD"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* HasOne Relationship
|
|
3
|
+
*
|
|
4
|
+
* Model has one related model (1:1)
|
|
5
|
+
*/
|
|
6
|
+
import type { Model } from "../model";
|
|
7
|
+
import { Relationship } from "./base";
|
|
8
|
+
export declare class HasOne<TRelated extends Model> extends Relationship<any, TRelated> {
|
|
9
|
+
addConstraints(): void;
|
|
10
|
+
addEagerConstraints(parents: Model[]): void;
|
|
11
|
+
match(parents: Model[], results: TRelated[], relation: string): void;
|
|
12
|
+
getResults(): Promise<TRelated | null>;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=has-one.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"has-one.d.ts","sourceRoot":"","sources":["../../../../src/database/orm/relationships/has-one.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,UAAU,CAAC;AACtC,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAEtC,qBAAa,MAAM,CAAC,QAAQ,SAAS,KAAK,CAAE,SAAQ,YAAY,CAC/D,GAAG,EACH,QAAQ,CACR;IACA,cAAc,IAAI,IAAI;IAKtB,mBAAmB,CAAC,OAAO,EAAE,KAAK,EAAE,GAAG,IAAI;IAK3C,KAAK,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,QAAQ,EAAE,MAAM,GAAG,IAAI;IAc9D,UAAU,IAAI,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC;CAG5C"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* HasOne Relationship
|
|
3
|
+
*
|
|
4
|
+
* Model has one related model (1:1)
|
|
5
|
+
*/
|
|
6
|
+
import { Relationship } from "./base";
|
|
7
|
+
export class HasOne extends Relationship {
|
|
8
|
+
addConstraints() {
|
|
9
|
+
const parentId = this.parentModel.getAttribute(this.localKey);
|
|
10
|
+
this.query.where(this.foreignKey, parentId);
|
|
11
|
+
}
|
|
12
|
+
addEagerConstraints(parents) {
|
|
13
|
+
const ids = parents.map((p) => p.getAttribute(this.localKey));
|
|
14
|
+
this.query.whereIn(this.foreignKey, ids);
|
|
15
|
+
}
|
|
16
|
+
match(parents, results, relation) {
|
|
17
|
+
const grouped = new Map();
|
|
18
|
+
for (const result of results) {
|
|
19
|
+
const key = result.getAttribute(this.foreignKey);
|
|
20
|
+
grouped.set(key, result);
|
|
21
|
+
}
|
|
22
|
+
for (const parent of parents) {
|
|
23
|
+
const key = parent.getAttribute(this.localKey);
|
|
24
|
+
const related = grouped.get(key) ?? null;
|
|
25
|
+
parent._relations.set(relation, related);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
async getResults() {
|
|
29
|
+
return this.first();
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=has-one.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"has-one.js","sourceRoot":"","sources":["../../../../src/database/orm/relationships/has-one.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAEtC,MAAM,OAAO,MAA+B,SAAQ,YAGnD;IACA,cAAc;QACb,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,IAAI,CAAC,QAAe,CAAC,CAAC;QACrE,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC;IAC7C,CAAC;IAED,mBAAmB,CAAC,OAAgB;QACnC,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,CAAC,QAAe,CAAC,CAAC,CAAC;QACrE,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC;IAC1C,CAAC;IAED,KAAK,CAAC,OAAgB,EAAE,OAAmB,EAAE,QAAgB;QAC5D,MAAM,OAAO,GAAG,IAAI,GAAG,EAAqB,CAAC;QAC7C,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC9B,MAAM,GAAG,GAAG,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,UAAiB,CAAC,CAAC;YACxD,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;QAC1B,CAAC;QAED,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC9B,MAAM,GAAG,GAAG,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,QAAe,CAAC,CAAC;YACtD,MAAM,OAAO,GAAG,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC;YACxC,MAAc,CAAC,UAAU,CAAC,GAAG,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;QACnD,CAAC;IACF,CAAC;IAED,KAAK,CAAC,UAAU;QACf,OAAO,IAAI,CAAC,KAAK,EAAE,CAAC;IACrB,CAAC;CACD"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Relationship Exports
|
|
3
|
+
*/
|
|
4
|
+
export { Relationship } from "./base";
|
|
5
|
+
export { HasOne } from "./has-one";
|
|
6
|
+
export { HasMany } from "./has-many";
|
|
7
|
+
export { BelongsTo } from "./belongs-to";
|
|
8
|
+
export { BelongsToMany } from "./belongs-to-many";
|
|
9
|
+
export type { RelationshipOptions } from "./base";
|
|
10
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/database/orm/relationships/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AACtC,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AACnC,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AACrC,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAElD,YAAY,EAAE,mBAAmB,EAAE,MAAM,QAAQ,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Relationship Exports
|
|
3
|
+
*/
|
|
4
|
+
export { Relationship } from "./base";
|
|
5
|
+
export { HasOne } from "./has-one";
|
|
6
|
+
export { HasMany } from "./has-many";
|
|
7
|
+
export { BelongsTo } from "./belongs-to";
|
|
8
|
+
export { BelongsToMany } from "./belongs-to-many";
|
|
9
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/database/orm/relationships/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AACtC,OAAO,EAAE,MAAM,EAAE,MAAM,WAAW,CAAC;AACnC,OAAO,EAAE,OAAO,EAAE,MAAM,YAAY,CAAC;AACrC,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACzC,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Model Scopes
|
|
3
|
+
*
|
|
4
|
+
* Local scopes (scopeXxx methods) and global scopes (auto-applied to all queries)
|
|
5
|
+
*/
|
|
6
|
+
export type ScopeDefinition<M> = (query: any) => any;
|
|
7
|
+
export declare class ScopeRegistry<M> {
|
|
8
|
+
private globalScopes;
|
|
9
|
+
/**
|
|
10
|
+
* Register a global scope
|
|
11
|
+
*/
|
|
12
|
+
addGlobalScope(name: string, scope: ScopeDefinition<M>): void;
|
|
13
|
+
/**
|
|
14
|
+
* Remove a global scope by name
|
|
15
|
+
*/
|
|
16
|
+
removeGlobalScope(name: string): void;
|
|
17
|
+
/**
|
|
18
|
+
* Get all global scopes
|
|
19
|
+
*/
|
|
20
|
+
getGlobalScopes(): ScopeDefinition<M>[];
|
|
21
|
+
/**
|
|
22
|
+
* Clear all global scopes
|
|
23
|
+
*/
|
|
24
|
+
clearGlobalScopes(): void;
|
|
25
|
+
/**
|
|
26
|
+
* Check if a global scope exists
|
|
27
|
+
*/
|
|
28
|
+
hasGlobalScope(name: string): boolean;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Soft delete global scope — automatically added when model has softDeletes = true
|
|
32
|
+
*/
|
|
33
|
+
export declare class SoftDeleteScope {
|
|
34
|
+
apply(query: any): void;
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/database/orm/scopes/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,MAAM,MAAM,eAAe,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,KAAK,GAAG,CAAC;AAErD,qBAAa,aAAa,CAAC,CAAC;IAC3B,OAAO,CAAC,YAAY,CAA8C;IAElE;;OAEG;IACH,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,eAAe,CAAC,CAAC,CAAC,GAAG,IAAI;IAI7D;;OAEG;IACH,iBAAiB,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAIrC;;OAEG;IACH,eAAe,IAAI,eAAe,CAAC,CAAC,CAAC,EAAE;IAIvC;;OAEG;IACH,iBAAiB,IAAI,IAAI;IAIzB;;OAEG;IACH,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;CAGrC;AAED;;GAEG;AACH,qBAAa,eAAe;IAC3B,KAAK,CAAC,KAAK,EAAE,GAAG,GAAG,IAAI;CAGvB"}
|