Compare commits
20 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 2fe3a72eaf | |||
| fb7e82557b | |||
| 8a3425e554 | |||
| d2092cc5f3 | |||
| 1a621ca64e | |||
| f6cc07880a | |||
| bf4b11f1f5 | |||
| 181e9da151 | |||
| 3013edb2eb | |||
| 604e4ba265 | |||
| 477f446c34 | |||
| fbb8bb685c | |||
| 4cf62fd91c | |||
| 8ee45c5646 | |||
| 12f1630adf | |||
| 0a349180b2 | |||
| 23aa29a5b8 | |||
| 5bf2aae2b9 | |||
| 5cf9155205 | |||
| ef5491075f |
53
changelog.md
53
changelog.md
@@ -1,5 +1,58 @@
|
|||||||
# Changelog
|
# Changelog
|
||||||
|
|
||||||
|
## 2025-11-28 - 7.0.9 - fix(classes.collection)
|
||||||
|
Fix closure bug in Collection decorator by defining collection getter on original constructor and prototype
|
||||||
|
|
||||||
|
- Define the collection getter on the original constructor so class-level references (e.g. `User.collection`) resolve to the decorated collection instead of the original constructor's closure value.
|
||||||
|
- Also define the getter on the original constructor's prototype to ensure instance access works consistently across runtimes (Deno/Node).
|
||||||
|
|
||||||
|
## 2025-11-28 - 7.0.8 - fix(classes.collection)
|
||||||
|
Fix closure issue in managed decorator so Class.collection/instance.collection resolve correctly
|
||||||
|
|
||||||
|
- Resolve closure bug in the managed() decorator where class methods referencing Class.collection (or instance.collection) could receive the original constructor's captured value and thus the wrong collection/manager.
|
||||||
|
- Define dynamic getters on the original constructor and its prototype that compute the collection from the proper manager/db at access time (supports direct manager objects, delayed manager factory functions, and fallback to defaultManager).
|
||||||
|
- Getters are defined as non-enumerable and configurable to preserve compatibility with existing consumers.
|
||||||
|
|
||||||
|
## 2025-11-28 - 7.0.7 - fix(decorators)
|
||||||
|
Fix decorator metadata initialization and Lucene query transformation
|
||||||
|
|
||||||
|
- Ensure TC39 decorator metadata is used to initialize prototype properties so decorators work reliably across runtimes (context.metadata / Symbol.metadata shim imported early).
|
||||||
|
- Field and class decorators now populate and consume metadata for saveable properties, indexes and searchable fields so prototype initialization happens before instance creation.
|
||||||
|
- Fix Lucene -> MongoDB transformer to produce correct $or/$and/$not structures and improve wildcard/fuzzy/range handling for search queries.
|
||||||
|
- Improve collection initialization to auto-create compound text indexes from searchableFields and ensure index creation is idempotent.
|
||||||
|
|
||||||
|
## 2025-11-28 - 7.0.6 - fix(classes.collection)
|
||||||
|
Guard against missing collection before attaching document constructor in Collection decorator
|
||||||
|
|
||||||
|
- Added a truthy check for `coll` before setting `(coll as any).docCtor` in the Collection decorator (ts/classes.collection.ts).
|
||||||
|
- Prevents a potential TypeError when `collectionFactory.getCollection` returns null/undefined during decorator initialization.
|
||||||
|
|
||||||
|
## 2025-11-28 - 7.0.5 - fix(package)
|
||||||
|
Add package exports entry and remove legacy main/typings fields
|
||||||
|
|
||||||
|
- Added an "exports" entry in package.json mapping "." to ./dist_ts/index.js to declare the package's ESM entrypoint.
|
||||||
|
- Removed legacy "main" and "typings" fields from package.json.
|
||||||
|
- Improves Node/module resolution and modern bundler compatibility by using the package exports field.
|
||||||
|
|
||||||
|
## 2025-11-28 - 7.0.4 - fix(decorators)
|
||||||
|
Add Symbol.metadata polyfill and import it at entry to ensure decorator metadata is available
|
||||||
|
|
||||||
|
- Add ts/shim.ts: defines Symbol.metadata when missing (polyfill for TC39 Stage 3 decorator metadata).
|
||||||
|
- Import './shim.js' at the very top of ts/index.ts so the polyfill runs before any decorator code or exports are evaluated.
|
||||||
|
- Prevents runtime errors when decorators rely on Symbol.metadata and improves compatibility across runtimes/environments.
|
||||||
|
|
||||||
|
## 2025-11-28 - 7.0.3 - fix(build)
|
||||||
|
Bump devDependency @git.zone/tsbuild to ^3.1.2
|
||||||
|
|
||||||
|
- Updated @git.zone/tsbuild in devDependencies from ^3.1.1 to ^3.1.2
|
||||||
|
|
||||||
|
## 2025-11-28 - 7.0.2 - fix(collectionfactory)
|
||||||
|
Simplify CollectionFactory.getCollection: remove unnecessary IIFE and instantiate collection only when dbArg is SmartdataDb
|
||||||
|
|
||||||
|
- Remove redundant IIFE wrapper in getCollection for improved readability
|
||||||
|
- Only create and cache a SmartdataCollection when dbArg is an instance of SmartdataDb
|
||||||
|
- Avoid assigning undefined to the collections map by guarding instantiation and returning existing collection
|
||||||
|
|
||||||
## 2025-11-27 - 7.0.1 - fix(build)
|
## 2025-11-27 - 7.0.1 - fix(build)
|
||||||
Update build tooling and TypeScript compilation target
|
Update build tooling and TypeScript compilation target
|
||||||
|
|
||||||
|
|||||||
85
deno.lock
generated
85
deno.lock
generated
@@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"version": "5",
|
"version": "5",
|
||||||
"specifiers": {
|
"specifiers": {
|
||||||
"npm:@git.zone/tsbuild@^3.1.0": "3.1.0",
|
"npm:@git.zone/tsbuild@^3.1.2": "3.1.2",
|
||||||
"npm:@git.zone/tsrun@2": "2.0.0",
|
"npm:@git.zone/tsrun@2": "2.0.0",
|
||||||
"npm:@git.zone/tstest@^3.1.3": "3.1.3",
|
"npm:@git.zone/tstest@^3.1.3": "3.1.3",
|
||||||
"npm:@push.rocks/lik@^6.2.2": "6.2.2",
|
"npm:@push.rocks/lik@^6.2.2": "6.2.2",
|
||||||
@@ -57,7 +57,7 @@
|
|||||||
"@push.rocks/smartdelay",
|
"@push.rocks/smartdelay",
|
||||||
"@push.rocks/smartenv@5.0.13",
|
"@push.rocks/smartenv@5.0.13",
|
||||||
"@push.rocks/smartfeed",
|
"@push.rocks/smartfeed",
|
||||||
"@push.rocks/smartfile",
|
"@push.rocks/smartfile@11.2.7",
|
||||||
"@push.rocks/smartjson",
|
"@push.rocks/smartjson",
|
||||||
"@push.rocks/smartlog",
|
"@push.rocks/smartlog",
|
||||||
"@push.rocks/smartlog-destination-devtools",
|
"@push.rocks/smartlog-destination-devtools",
|
||||||
@@ -1111,21 +1111,21 @@
|
|||||||
],
|
],
|
||||||
"tarball": "https://verdaccio.lossless.digital/@esm-bundle/chai/-/chai-4.3.4-fix.0.tgz"
|
"tarball": "https://verdaccio.lossless.digital/@esm-bundle/chai/-/chai-4.3.4-fix.0.tgz"
|
||||||
},
|
},
|
||||||
"@git.zone/tsbuild@3.1.0": {
|
"@git.zone/tsbuild@3.1.2": {
|
||||||
"integrity": "sha512-j8lMd84pmzWiU6NG3e+pyu0o41oo6mQVfcZv8kDsCrQwZMhoQV9Jp87MlU0i/XI5IZkqDjelG8Kx1QhOmbK+iQ==",
|
"integrity": "sha512-K0u840Qo0WEhvcpAtktvdBX6KEXjelU32o820WzcK7dMA7dd2YV+mPOEYfbmWLcdtFJkrjkigQq5fpLhTN4oKQ==",
|
||||||
"dependencies": [
|
"dependencies": [
|
||||||
"@git.zone/tspublish",
|
"@git.zone/tspublish",
|
||||||
"@push.rocks/early",
|
"@push.rocks/early",
|
||||||
"@push.rocks/smartcli",
|
"@push.rocks/smartcli",
|
||||||
"@push.rocks/smartdelay",
|
"@push.rocks/smartdelay",
|
||||||
"@push.rocks/smartfile",
|
"@push.rocks/smartfile@11.2.7",
|
||||||
"@push.rocks/smartlog",
|
"@push.rocks/smartlog",
|
||||||
"@push.rocks/smartpath@6.0.0",
|
"@push.rocks/smartpath@6.0.0",
|
||||||
"@push.rocks/smartpromise",
|
"@push.rocks/smartpromise",
|
||||||
"typescript"
|
"typescript"
|
||||||
],
|
],
|
||||||
"bin": true,
|
"bin": true,
|
||||||
"tarball": "https://verdaccio.lossless.digital/@git.zone/tsbuild/-/tsbuild-3.1.0.tgz"
|
"tarball": "https://verdaccio.lossless.digital/@git.zone/tsbuild/-/tsbuild-3.1.2.tgz"
|
||||||
},
|
},
|
||||||
"@git.zone/tsbundle@2.6.1": {
|
"@git.zone/tsbundle@2.6.1": {
|
||||||
"integrity": "sha512-P1ER6A859GBY5mmC2hNro06O1w/vYCDt5XaetE4vsyJMlFSvWGXrKTxFpTdookZvntQyoXJglYsCPKEsy+OXWQ==",
|
"integrity": "sha512-P1ER6A859GBY5mmC2hNro06O1w/vYCDt5XaetE4vsyJMlFSvWGXrKTxFpTdookZvntQyoXJglYsCPKEsy+OXWQ==",
|
||||||
@@ -1155,7 +1155,7 @@
|
|||||||
"@push.rocks/consolecolor",
|
"@push.rocks/consolecolor",
|
||||||
"@push.rocks/smartcli",
|
"@push.rocks/smartcli",
|
||||||
"@push.rocks/smartdelay",
|
"@push.rocks/smartdelay",
|
||||||
"@push.rocks/smartfile",
|
"@push.rocks/smartfile@11.2.7",
|
||||||
"@push.rocks/smartlog",
|
"@push.rocks/smartlog",
|
||||||
"@push.rocks/smartnpm",
|
"@push.rocks/smartnpm",
|
||||||
"@push.rocks/smartpath@6.0.0",
|
"@push.rocks/smartpath@6.0.0",
|
||||||
@@ -1168,7 +1168,7 @@
|
|||||||
"@git.zone/tsrun@2.0.0": {
|
"@git.zone/tsrun@2.0.0": {
|
||||||
"integrity": "sha512-yA6zCjL+kn7xfZe6sL/m4K+zYqgkznG/pF6++i/E17iwzpG6dHmW+VZmYldHe86sW4DcLMvqM6CxM+KlgaEpKw==",
|
"integrity": "sha512-yA6zCjL+kn7xfZe6sL/m4K+zYqgkznG/pF6++i/E17iwzpG6dHmW+VZmYldHe86sW4DcLMvqM6CxM+KlgaEpKw==",
|
||||||
"dependencies": [
|
"dependencies": [
|
||||||
"@push.rocks/smartfile",
|
"@push.rocks/smartfile@11.2.7",
|
||||||
"@push.rocks/smartshell",
|
"@push.rocks/smartshell",
|
||||||
"tsx"
|
"tsx"
|
||||||
],
|
],
|
||||||
@@ -1189,7 +1189,7 @@
|
|||||||
"@push.rocks/smartdelay",
|
"@push.rocks/smartdelay",
|
||||||
"@push.rocks/smartenv@6.0.0",
|
"@push.rocks/smartenv@6.0.0",
|
||||||
"@push.rocks/smartexpect",
|
"@push.rocks/smartexpect",
|
||||||
"@push.rocks/smartfile",
|
"@push.rocks/smartfile@11.2.7",
|
||||||
"@push.rocks/smartjson",
|
"@push.rocks/smartjson",
|
||||||
"@push.rocks/smartlog",
|
"@push.rocks/smartlog",
|
||||||
"@push.rocks/smartmongo",
|
"@push.rocks/smartmongo",
|
||||||
@@ -1625,7 +1625,7 @@
|
|||||||
"@push.rocks/smartcache",
|
"@push.rocks/smartcache",
|
||||||
"@push.rocks/smartenv@5.0.13",
|
"@push.rocks/smartenv@5.0.13",
|
||||||
"@push.rocks/smartexit",
|
"@push.rocks/smartexit",
|
||||||
"@push.rocks/smartfile",
|
"@push.rocks/smartfile@11.2.7",
|
||||||
"@push.rocks/smartjson",
|
"@push.rocks/smartjson",
|
||||||
"@push.rocks/smartpath@6.0.0",
|
"@push.rocks/smartpath@6.0.0",
|
||||||
"@push.rocks/smartpromise",
|
"@push.rocks/smartpromise",
|
||||||
@@ -1654,7 +1654,7 @@
|
|||||||
"integrity": "sha512-kW0ZUGyf1e4nwloVwBQjNId+MzgTcNS834C+RxH21i1NqyOubbpWZtJtPP+K+s35nSJRyCTy3ICfBMdDBTAm2w==",
|
"integrity": "sha512-kW0ZUGyf1e4nwloVwBQjNId+MzgTcNS834C+RxH21i1NqyOubbpWZtJtPP+K+s35nSJRyCTy3ICfBMdDBTAm2w==",
|
||||||
"dependencies": [
|
"dependencies": [
|
||||||
"@push.rocks/lik",
|
"@push.rocks/lik",
|
||||||
"@push.rocks/smartfile",
|
"@push.rocks/smartfile@11.2.7",
|
||||||
"@push.rocks/smartjson",
|
"@push.rocks/smartjson",
|
||||||
"@push.rocks/smartpath@6.0.0",
|
"@push.rocks/smartpath@6.0.0",
|
||||||
"@push.rocks/smartpromise",
|
"@push.rocks/smartpromise",
|
||||||
@@ -1668,17 +1668,17 @@
|
|||||||
"dependencies": [
|
"dependencies": [
|
||||||
"@api.global/typedrequest",
|
"@api.global/typedrequest",
|
||||||
"@configvault.io/interfaces",
|
"@configvault.io/interfaces",
|
||||||
"@push.rocks/smartfile",
|
"@push.rocks/smartfile@11.2.7",
|
||||||
"@push.rocks/smartlog",
|
"@push.rocks/smartlog",
|
||||||
"@push.rocks/smartpath@6.0.0"
|
"@push.rocks/smartpath@6.0.0"
|
||||||
],
|
],
|
||||||
"tarball": "https://verdaccio.lossless.digital/@push.rocks/qenv/-/qenv-6.1.3.tgz"
|
"tarball": "https://verdaccio.lossless.digital/@push.rocks/qenv/-/qenv-6.1.3.tgz"
|
||||||
},
|
},
|
||||||
"@push.rocks/smartarchive@4.2.2": {
|
"@push.rocks/smartarchive@4.2.4": {
|
||||||
"integrity": "sha512-6EpqbKU32D6Gcqsc9+Tn1dOCU5HoTlrqqs/7IdUr9Tirp9Ngtptkapca1Fw/D0kVJ7SSw3kG/miAYnuPMZLEoA==",
|
"integrity": "sha512-uiqVAXPxmr8G5rv3uZvZFMOCt8l7cZC3nzvsy4YQqKf/VkPhKIEX+b7LkAeNlxPSYUiBQUkNRoawg9+5BaMcHg==",
|
||||||
"dependencies": [
|
"dependencies": [
|
||||||
"@push.rocks/smartdelay",
|
"@push.rocks/smartdelay",
|
||||||
"@push.rocks/smartfile",
|
"@push.rocks/smartfile@13.0.1",
|
||||||
"@push.rocks/smartpath@6.0.0",
|
"@push.rocks/smartpath@6.0.0",
|
||||||
"@push.rocks/smartpromise",
|
"@push.rocks/smartpromise",
|
||||||
"@push.rocks/smartrequest@4.4.2",
|
"@push.rocks/smartrequest@4.4.2",
|
||||||
@@ -1688,11 +1688,10 @@
|
|||||||
"@push.rocks/smarturl",
|
"@push.rocks/smarturl",
|
||||||
"@types/tar-stream",
|
"@types/tar-stream",
|
||||||
"fflate",
|
"fflate",
|
||||||
"file-type@21.1.0",
|
"file-type@21.1.1",
|
||||||
"tar-stream",
|
"tar-stream"
|
||||||
"through"
|
|
||||||
],
|
],
|
||||||
"tarball": "https://verdaccio.lossless.digital/@push.rocks/smartarchive/-/smartarchive-4.2.2.tgz"
|
"tarball": "https://verdaccio.lossless.digital/@push.rocks/smartarchive/-/smartarchive-4.2.4.tgz"
|
||||||
},
|
},
|
||||||
"@push.rocks/smartbrowser@2.0.8": {
|
"@push.rocks/smartbrowser@2.0.8": {
|
||||||
"integrity": "sha512-0KWRZj3TuKo/sNwgPbiSE6WL+TMeR19t1JmXBZWh9n8iA2mpc4HhMrQAndEUdRCkx5ofSaHWojIRVFzGChj0Dg==",
|
"integrity": "sha512-0KWRZj3TuKo/sNwgPbiSE6WL+TMeR19t1JmXBZWh9n8iA2mpc4HhMrQAndEUdRCkx5ofSaHWojIRVFzGChj0Dg==",
|
||||||
@@ -1913,6 +1912,25 @@
|
|||||||
],
|
],
|
||||||
"tarball": "https://verdaccio.lossless.digital/@push.rocks/smartfile/-/smartfile-11.2.7.tgz"
|
"tarball": "https://verdaccio.lossless.digital/@push.rocks/smartfile/-/smartfile-11.2.7.tgz"
|
||||||
},
|
},
|
||||||
|
"@push.rocks/smartfile@13.0.1": {
|
||||||
|
"integrity": "sha512-phtryDFtBYHo7R2H9V3Y7VeiYQU9YzKL140gKD3bTicBgXoIYrJ6+b3mbZunSO2yQt1Vy1AxCxYXrFE/K+4grw==",
|
||||||
|
"dependencies": [
|
||||||
|
"@push.rocks/lik",
|
||||||
|
"@push.rocks/smartdelay",
|
||||||
|
"@push.rocks/smartfile-interfaces",
|
||||||
|
"@push.rocks/smarthash",
|
||||||
|
"@push.rocks/smartjson",
|
||||||
|
"@push.rocks/smartmime",
|
||||||
|
"@push.rocks/smartpath@6.0.0",
|
||||||
|
"@push.rocks/smartpromise",
|
||||||
|
"@push.rocks/smartrequest@4.4.2",
|
||||||
|
"@push.rocks/smartstream",
|
||||||
|
"@types/js-yaml@4.0.9",
|
||||||
|
"glob@11.0.3",
|
||||||
|
"js-yaml@4.1.1"
|
||||||
|
],
|
||||||
|
"tarball": "https://verdaccio.lossless.digital/@push.rocks/smartfile/-/smartfile-13.0.1.tgz"
|
||||||
|
},
|
||||||
"@push.rocks/smartfs@1.1.0": {
|
"@push.rocks/smartfs@1.1.0": {
|
||||||
"integrity": "sha512-fg8JIjFUPPX5laRoBpTaGwhMfZ3Y8mFT4fUaW54Y4J/BfOBa/y0+rIFgvgvqcOZgkQlyZU+FIfL8Z6zezqxyTg==",
|
"integrity": "sha512-fg8JIjFUPPX5laRoBpTaGwhMfZ3Y8mFT4fUaW54Y4J/BfOBa/y0+rIFgvgvqcOZgkQlyZU+FIfL8Z6zezqxyTg==",
|
||||||
"dependencies": [
|
"dependencies": [
|
||||||
@@ -1980,7 +1998,7 @@
|
|||||||
"@push.rocks/consolecolor",
|
"@push.rocks/consolecolor",
|
||||||
"@push.rocks/isounique",
|
"@push.rocks/isounique",
|
||||||
"@push.rocks/smartclickhouse",
|
"@push.rocks/smartclickhouse",
|
||||||
"@push.rocks/smartfile",
|
"@push.rocks/smartfile@11.2.7",
|
||||||
"@push.rocks/smarthash",
|
"@push.rocks/smarthash",
|
||||||
"@push.rocks/smartpromise",
|
"@push.rocks/smartpromise",
|
||||||
"@push.rocks/smarttime",
|
"@push.rocks/smarttime",
|
||||||
@@ -2054,7 +2072,7 @@
|
|||||||
"@push.rocks/consolecolor",
|
"@push.rocks/consolecolor",
|
||||||
"@push.rocks/levelcache",
|
"@push.rocks/levelcache",
|
||||||
"@push.rocks/smartarchive",
|
"@push.rocks/smartarchive",
|
||||||
"@push.rocks/smartfile",
|
"@push.rocks/smartfile@11.2.7",
|
||||||
"@push.rocks/smartpath@6.0.0",
|
"@push.rocks/smartpath@6.0.0",
|
||||||
"@push.rocks/smartpromise",
|
"@push.rocks/smartpromise",
|
||||||
"@push.rocks/smartrequest@4.4.2",
|
"@push.rocks/smartrequest@4.4.2",
|
||||||
@@ -2102,7 +2120,7 @@
|
|||||||
"dependencies": [
|
"dependencies": [
|
||||||
"@push.rocks/smartbuffer",
|
"@push.rocks/smartbuffer",
|
||||||
"@push.rocks/smartdelay",
|
"@push.rocks/smartdelay",
|
||||||
"@push.rocks/smartfile",
|
"@push.rocks/smartfile@11.2.7",
|
||||||
"@push.rocks/smartnetwork",
|
"@push.rocks/smartnetwork",
|
||||||
"@push.rocks/smartpath@6.0.0",
|
"@push.rocks/smartpath@6.0.0",
|
||||||
"@push.rocks/smartpromise",
|
"@push.rocks/smartpromise",
|
||||||
@@ -2193,7 +2211,7 @@
|
|||||||
"integrity": "sha512-f2i2keHs+KZr5cyB8nBOnmRGiE2YG42W4pSx+8gmZEsf8yZUT1iUnuD/YZVTKosH2v5dPCKdmtSpMSux8Q/tCw==",
|
"integrity": "sha512-f2i2keHs+KZr5cyB8nBOnmRGiE2YG42W4pSx+8gmZEsf8yZUT1iUnuD/YZVTKosH2v5dPCKdmtSpMSux8Q/tCw==",
|
||||||
"dependencies": [
|
"dependencies": [
|
||||||
"@push.rocks/smartbucket@3.3.10",
|
"@push.rocks/smartbucket@3.3.10",
|
||||||
"@push.rocks/smartfile",
|
"@push.rocks/smartfile@11.2.7",
|
||||||
"@push.rocks/smartpath@6.0.0",
|
"@push.rocks/smartpath@6.0.0",
|
||||||
"@tsclass/tsclass@9.3.0",
|
"@tsclass/tsclass@9.3.0",
|
||||||
"@types/s3rver",
|
"@types/s3rver",
|
||||||
@@ -2363,7 +2381,7 @@
|
|||||||
"@push.rocks/smartdelay",
|
"@push.rocks/smartdelay",
|
||||||
"@push.rocks/smartenv@5.0.13",
|
"@push.rocks/smartenv@5.0.13",
|
||||||
"@push.rocks/smartexpect",
|
"@push.rocks/smartexpect",
|
||||||
"@push.rocks/smartfile",
|
"@push.rocks/smartfile@11.2.7",
|
||||||
"@push.rocks/smartjson",
|
"@push.rocks/smartjson",
|
||||||
"@push.rocks/smartmongo",
|
"@push.rocks/smartmongo",
|
||||||
"@push.rocks/smartpath@5.1.0",
|
"@push.rocks/smartpath@5.1.0",
|
||||||
@@ -3229,14 +3247,13 @@
|
|||||||
"integrity": "sha512-hPJQKO7+oAIY+pDNImrZ9QAINbz9KmwT+yO4iRVwdPanok2YKpaUxdJzIvCUwY0YgAawlvYdffbLvRLV5hbs2g==",
|
"integrity": "sha512-hPJQKO7+oAIY+pDNImrZ9QAINbz9KmwT+yO4iRVwdPanok2YKpaUxdJzIvCUwY0YgAawlvYdffbLvRLV5hbs2g==",
|
||||||
"tarball": "https://verdaccio.lossless.digital/@tempfix/idb/-/idb-8.0.3.tgz"
|
"tarball": "https://verdaccio.lossless.digital/@tempfix/idb/-/idb-8.0.3.tgz"
|
||||||
},
|
},
|
||||||
"@tokenizer/inflate@0.3.1": {
|
"@tokenizer/inflate@0.4.1": {
|
||||||
"integrity": "sha512-4oeoZEBQdLdt5WmP/hx1KZ6D3/Oid/0cUb2nk4F0pTDAWy+KCH3/EnAkZF/bvckWo8I33EqBm01lIPgmgc8rCA==",
|
"integrity": "sha512-2mAv+8pkG6GIZiF1kNg1jAjh27IDxEPKwdGul3snfztFerfPGI1LjDezZp3i7BElXompqEtPmoPx6c2wgtWsOA==",
|
||||||
"dependencies": [
|
"dependencies": [
|
||||||
"debug@4.4.3",
|
"debug@4.4.3",
|
||||||
"fflate",
|
|
||||||
"token-types"
|
"token-types"
|
||||||
],
|
],
|
||||||
"tarball": "https://verdaccio.lossless.digital/@tokenizer/inflate/-/inflate-0.3.1.tgz"
|
"tarball": "https://verdaccio.lossless.digital/@tokenizer/inflate/-/inflate-0.4.1.tgz"
|
||||||
},
|
},
|
||||||
"@tokenizer/token@0.3.0": {
|
"@tokenizer/token@0.3.0": {
|
||||||
"integrity": "sha512-OvjF+z51L3ov0OyAU0duzsYuvO01PH7x4t6DJx+guahgTnBHkhJdG7soQeTSFLWN3efnHyibZ4Z8l2EuWwJN3A==",
|
"integrity": "sha512-OvjF+z51L3ov0OyAU0duzsYuvO01PH7x4t6DJx+guahgTnBHkhJdG7soQeTSFLWN3efnHyibZ4Z8l2EuWwJN3A==",
|
||||||
@@ -5053,15 +5070,15 @@
|
|||||||
],
|
],
|
||||||
"tarball": "https://verdaccio.lossless.digital/file-type/-/file-type-19.6.0.tgz"
|
"tarball": "https://verdaccio.lossless.digital/file-type/-/file-type-19.6.0.tgz"
|
||||||
},
|
},
|
||||||
"file-type@21.1.0": {
|
"file-type@21.1.1": {
|
||||||
"integrity": "sha512-boU4EHmP3JXkwDo4uhyBhTt5pPstxB6eEXKJBu2yu2l7aAMMm7QQYQEzssJmKReZYrFdFOJS8koVo6bXIBGDqA==",
|
"integrity": "sha512-ifJXo8zUqbQ/bLbl9sFoqHNTNWbnPY1COImFfM6CCy7z+E+jC1eY9YfOKkx0fckIg+VljAy2/87T61fp0+eEkg==",
|
||||||
"dependencies": [
|
"dependencies": [
|
||||||
"@tokenizer/inflate",
|
"@tokenizer/inflate",
|
||||||
"strtok3@10.3.4",
|
"strtok3@10.3.4",
|
||||||
"token-types",
|
"token-types",
|
||||||
"uint8array-extras"
|
"uint8array-extras"
|
||||||
],
|
],
|
||||||
"tarball": "https://verdaccio.lossless.digital/file-type/-/file-type-21.1.0.tgz"
|
"tarball": "https://verdaccio.lossless.digital/file-type/-/file-type-21.1.1.tgz"
|
||||||
},
|
},
|
||||||
"fill-range@7.1.1": {
|
"fill-range@7.1.1": {
|
||||||
"integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==",
|
"integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==",
|
||||||
@@ -7925,10 +7942,6 @@
|
|||||||
],
|
],
|
||||||
"tarball": "https://verdaccio.lossless.digital/through2/-/through2-4.0.2.tgz"
|
"tarball": "https://verdaccio.lossless.digital/through2/-/through2-4.0.2.tgz"
|
||||||
},
|
},
|
||||||
"through@2.3.8": {
|
|
||||||
"integrity": "0dd4c9ffaabc357960b1b724115d7e0e86a2e1f5",
|
|
||||||
"tarball": "https://verdaccio.lossless.digital/through/-/through-2.3.8.tgz"
|
|
||||||
},
|
|
||||||
"tiny-worker@2.3.0": {
|
"tiny-worker@2.3.0": {
|
||||||
"integrity": "sha512-pJ70wq5EAqTAEl9IkGzA+fN0836rycEuz2Cn6yeZ6FRzlVS5IDOkFHpIoEsksPRQV34GDqXm65+OlnZqUSyK2g==",
|
"integrity": "sha512-pJ70wq5EAqTAEl9IkGzA+fN0836rycEuz2Cn6yeZ6FRzlVS5IDOkFHpIoEsksPRQV34GDqXm65+OlnZqUSyK2g==",
|
||||||
"dependencies": [
|
"dependencies": [
|
||||||
@@ -8356,7 +8369,7 @@
|
|||||||
"workspace": {
|
"workspace": {
|
||||||
"packageJson": {
|
"packageJson": {
|
||||||
"dependencies": [
|
"dependencies": [
|
||||||
"npm:@git.zone/tsbuild@^3.1.0",
|
"npm:@git.zone/tsbuild@^3.1.2",
|
||||||
"npm:@git.zone/tsrun@2",
|
"npm:@git.zone/tsrun@2",
|
||||||
"npm:@git.zone/tstest@^3.1.3",
|
"npm:@git.zone/tstest@^3.1.3",
|
||||||
"npm:@push.rocks/lik@^6.2.2",
|
"npm:@push.rocks/lik@^6.2.2",
|
||||||
|
|||||||
@@ -1,10 +1,11 @@
|
|||||||
{
|
{
|
||||||
"name": "@push.rocks/smartdata",
|
"name": "@push.rocks/smartdata",
|
||||||
"version": "7.0.1",
|
"version": "7.0.11",
|
||||||
"private": false,
|
"private": false,
|
||||||
"description": "An advanced library for NoSQL data organization and manipulation using TypeScript with support for MongoDB, data validation, collections, and custom data types.",
|
"description": "An advanced library for NoSQL data organization and manipulation using TypeScript with support for MongoDB, data validation, collections, and custom data types.",
|
||||||
"main": "dist_ts/index.js",
|
"exports": {
|
||||||
"typings": "dist_ts/index.d.ts",
|
".": "./dist_ts/index.js"
|
||||||
|
},
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"test": "tstest test/ --verbose --logfile --timeout 120",
|
"test": "tstest test/ --verbose --logfile --timeout 120",
|
||||||
@@ -37,7 +38,7 @@
|
|||||||
"mongodb": "^7.0.0"
|
"mongodb": "^7.0.0"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@git.zone/tsbuild": "^3.1.1",
|
"@git.zone/tsbuild": "^3.1.2",
|
||||||
"@git.zone/tsrun": "^2.0.0",
|
"@git.zone/tsrun": "^2.0.0",
|
||||||
"@git.zone/tstest": "^3.1.3",
|
"@git.zone/tstest": "^3.1.3",
|
||||||
"@push.rocks/qenv": "^6.1.3",
|
"@push.rocks/qenv": "^6.1.3",
|
||||||
|
|||||||
10
pnpm-lock.yaml
generated
10
pnpm-lock.yaml
generated
@@ -46,8 +46,8 @@ importers:
|
|||||||
version: 7.0.0(socks@2.8.7)
|
version: 7.0.0(socks@2.8.7)
|
||||||
devDependencies:
|
devDependencies:
|
||||||
'@git.zone/tsbuild':
|
'@git.zone/tsbuild':
|
||||||
specifier: ^3.1.1
|
specifier: ^3.1.2
|
||||||
version: 3.1.1(@push.rocks/smartfs@1.1.0)
|
version: 3.1.2(@push.rocks/smartfs@1.1.0)
|
||||||
'@git.zone/tsrun':
|
'@git.zone/tsrun':
|
||||||
specifier: ^2.0.0
|
specifier: ^2.0.0
|
||||||
version: 2.0.0
|
version: 2.0.0
|
||||||
@@ -831,8 +831,8 @@ packages:
|
|||||||
'@esm-bundle/chai@4.3.4-fix.0':
|
'@esm-bundle/chai@4.3.4-fix.0':
|
||||||
resolution: {integrity: sha512-26SKdM4uvDWlY8/OOOxSB1AqQWeBosCX3wRYUZO7enTAj03CtVxIiCimYVG2WpULcyV51qapK4qTovwkUr5Mlw==}
|
resolution: {integrity: sha512-26SKdM4uvDWlY8/OOOxSB1AqQWeBosCX3wRYUZO7enTAj03CtVxIiCimYVG2WpULcyV51qapK4qTovwkUr5Mlw==}
|
||||||
|
|
||||||
'@git.zone/tsbuild@3.1.1':
|
'@git.zone/tsbuild@3.1.2':
|
||||||
resolution: {integrity: sha512-x2MxBu5vaGabWGLS2Rcu/75VDKRZ0F74x0wEzgWPEqG/z9+vFu+8E70FOHj/TZJdnrw0yLEL78dUartNdGqm3A==}
|
resolution: {integrity: sha512-K0u840Qo0WEhvcpAtktvdBX6KEXjelU32o820WzcK7dMA7dd2YV+mPOEYfbmWLcdtFJkrjkigQq5fpLhTN4oKQ==}
|
||||||
hasBin: true
|
hasBin: true
|
||||||
|
|
||||||
'@git.zone/tsbundle@2.6.1':
|
'@git.zone/tsbundle@2.6.1':
|
||||||
@@ -6688,7 +6688,7 @@ snapshots:
|
|||||||
dependencies:
|
dependencies:
|
||||||
'@types/chai': 4.3.20
|
'@types/chai': 4.3.20
|
||||||
|
|
||||||
'@git.zone/tsbuild@3.1.1(@push.rocks/smartfs@1.1.0)':
|
'@git.zone/tsbuild@3.1.2(@push.rocks/smartfs@1.1.0)':
|
||||||
dependencies:
|
dependencies:
|
||||||
'@git.zone/tspublish': 1.10.3(@push.rocks/smartfs@1.1.0)
|
'@git.zone/tspublish': 1.10.3(@push.rocks/smartfs@1.1.0)
|
||||||
'@push.rocks/early': 4.0.4
|
'@push.rocks/early': 4.0.4
|
||||||
|
|||||||
@@ -3,6 +3,6 @@
|
|||||||
*/
|
*/
|
||||||
export const commitinfo = {
|
export const commitinfo = {
|
||||||
name: '@push.rocks/smartdata',
|
name: '@push.rocks/smartdata',
|
||||||
version: '7.0.1',
|
version: '7.0.9',
|
||||||
description: 'An advanced library for NoSQL data organization and manipulation using TypeScript with support for MongoDB, data validation, collections, and custom data types.'
|
description: 'An advanced library for NoSQL data organization and manipulation using TypeScript with support for MongoDB, data validation, collections, and custom data types.'
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -41,7 +41,7 @@ export function Collection(dbArg: SmartdataDb | TDelayed<SmartdataDb>) {
|
|||||||
}
|
}
|
||||||
const coll = collectionFactory.getCollection(constructor.name, dbArg);
|
const coll = collectionFactory.getCollection(constructor.name, dbArg);
|
||||||
// Attach document constructor for searchableFields lookup
|
// Attach document constructor for searchableFields lookup
|
||||||
if (!(coll as any).docCtor) {
|
if (coll && !(coll as any).docCtor) {
|
||||||
(coll as any).docCtor = decoratedClass;
|
(coll as any).docCtor = decoratedClass;
|
||||||
}
|
}
|
||||||
return coll;
|
return coll;
|
||||||
@@ -64,6 +64,20 @@ export function Collection(dbArg: SmartdataDb | TDelayed<SmartdataDb>) {
|
|||||||
configurable: true
|
configurable: true
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// Closure fix: When class methods reference the class name (e.g., `User.collection`),
|
||||||
|
// they get the original constructor via closure, not the decorated class.
|
||||||
|
// Define collection getter on the original constructor.
|
||||||
|
Object.defineProperty(constructor, 'collection', {
|
||||||
|
get: getCollection,
|
||||||
|
enumerable: false,
|
||||||
|
configurable: true
|
||||||
|
});
|
||||||
|
Object.defineProperty(constructor.prototype, 'collection', {
|
||||||
|
get: getCollection,
|
||||||
|
enumerable: false,
|
||||||
|
configurable: true
|
||||||
|
});
|
||||||
|
|
||||||
// Deno compatibility note: Property decorators set properties on the prototype.
|
// Deno compatibility note: Property decorators set properties on the prototype.
|
||||||
// Since we removed instance property declarations from SmartDataDbDoc,
|
// Since we removed instance property declarations from SmartDataDbDoc,
|
||||||
// the decorator-set prototype properties are now accessible without shadowing.
|
// the decorator-set prototype properties are now accessible without shadowing.
|
||||||
@@ -188,6 +202,42 @@ export function managed<TManager extends IManager>(managerArg?: TManager | TDela
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Closure fix: When class methods reference the class name (e.g., `User.collection`),
|
||||||
|
// they get the original constructor via closure, not the decorated class.
|
||||||
|
// Define collection/manager getters on the original constructor.
|
||||||
|
const getCollectionStatic = function(this: any) {
|
||||||
|
let dbArg: SmartdataDb;
|
||||||
|
if (!managerArg) {
|
||||||
|
dbArg = this.prototype.defaultManager.db;
|
||||||
|
} else if (managerArg['db']) {
|
||||||
|
dbArg = (managerArg as TManager).db;
|
||||||
|
} else {
|
||||||
|
dbArg = (managerArg as TDelayed<TManager>)().db;
|
||||||
|
}
|
||||||
|
return collectionFactory.getCollection(constructor.name, dbArg);
|
||||||
|
};
|
||||||
|
const getCollectionInstance = function(this: any) {
|
||||||
|
let dbArg: SmartdataDb;
|
||||||
|
if (!managerArg) {
|
||||||
|
dbArg = this.defaultManager.db;
|
||||||
|
} else if (managerArg['db']) {
|
||||||
|
dbArg = (managerArg as TManager).db;
|
||||||
|
} else {
|
||||||
|
dbArg = (managerArg as TDelayed<TManager>)().db;
|
||||||
|
}
|
||||||
|
return collectionFactory.getCollection(constructor.name, dbArg);
|
||||||
|
};
|
||||||
|
Object.defineProperty(constructor, 'collection', {
|
||||||
|
get: getCollectionStatic,
|
||||||
|
enumerable: false,
|
||||||
|
configurable: true
|
||||||
|
});
|
||||||
|
Object.defineProperty(constructor.prototype, 'collection', {
|
||||||
|
get: getCollectionInstance,
|
||||||
|
enumerable: false,
|
||||||
|
configurable: true
|
||||||
|
});
|
||||||
|
|
||||||
// Initialize prototype properties from context.metadata (TC39 decorator metadata)
|
// Initialize prototype properties from context.metadata (TC39 decorator metadata)
|
||||||
// This ensures prototype properties are available before any instance is created
|
// This ensures prototype properties are available before any instance is created
|
||||||
const originalConstructor = value as any;
|
const originalConstructor = value as any;
|
||||||
|
|||||||
@@ -6,13 +6,8 @@ export class CollectionFactory {
|
|||||||
public collections: { [key: string]: SmartdataCollection<any> } = {};
|
public collections: { [key: string]: SmartdataCollection<any> } = {};
|
||||||
|
|
||||||
public getCollection = (nameArg: string, dbArg: SmartdataDb): SmartdataCollection<any> => {
|
public getCollection = (nameArg: string, dbArg: SmartdataDb): SmartdataCollection<any> => {
|
||||||
if (!this.collections[nameArg]) {
|
if (!this.collections[nameArg] && dbArg instanceof SmartdataDb) {
|
||||||
this.collections[nameArg] = (() => {
|
this.collections[nameArg] = new SmartdataCollection(nameArg, dbArg);
|
||||||
if (dbArg instanceof SmartdataDb) {
|
|
||||||
// tslint:disable-next-line: no-string-literal
|
|
||||||
return new SmartdataCollection(nameArg, dbArg);
|
|
||||||
}
|
|
||||||
})();
|
|
||||||
}
|
}
|
||||||
return this.collections[nameArg];
|
return this.collections[nameArg];
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -1,3 +1,6 @@
|
|||||||
|
// Polyfill must be imported first - ES modules hoist exports before code runs
|
||||||
|
import './shim.js';
|
||||||
|
|
||||||
export * from './classes.db.js';
|
export * from './classes.db.js';
|
||||||
export * from './classes.collection.js';
|
export * from './classes.collection.js';
|
||||||
export * from './classes.doc.js';
|
export * from './classes.doc.js';
|
||||||
|
|||||||
6
ts/shim.ts
Normal file
6
ts/shim.ts
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
/**
|
||||||
|
* Polyfill for Symbol.metadata required by TC39 Stage 3 decorators.
|
||||||
|
* Must be imported before any decorator code loads.
|
||||||
|
* @see https://github.com/tc39/proposal-decorator-metadata
|
||||||
|
*/
|
||||||
|
(Symbol as any).metadata ??= Symbol.for('Symbol.metadata');
|
||||||
Reference in New Issue
Block a user