@furystack/filesystem-store 6.0.5 → 7.0.0
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/esm/filesystem-store.d.ts +3 -5
- package/esm/filesystem-store.d.ts.map +1 -1
- package/esm/filesystem-store.js +4 -3
- package/esm/filesystem-store.js.map +1 -1
- package/esm/filesystem-store.spec.js +6 -6
- package/esm/filesystem-store.spec.js.map +1 -1
- package/esm/store-manager-helpers.d.ts.map +1 -1
- package/esm/store-manager-helpers.spec.js +8 -8
- package/esm/store-manager-helpers.spec.js.map +1 -1
- package/package.json +7 -7
- package/src/filesystem-store.spec.ts +7 -7
- package/src/filesystem-store.ts +6 -5
- package/src/store-manager-helpers.spec.ts +8 -8
|
@@ -1,9 +1,7 @@
|
|
|
1
|
-
|
|
2
|
-
/// <reference types="node" resolution-mode="require"/>
|
|
3
|
-
import { promises } from 'fs';
|
|
1
|
+
import type { FilterType, FindOptions, PhysicalStore } from '@furystack/core';
|
|
4
2
|
import type { Constructable } from '@furystack/inject';
|
|
5
|
-
import type { PhysicalStore, FindOptions, FilterType } from '@furystack/core';
|
|
6
3
|
import { EventHub } from '@furystack/utils';
|
|
4
|
+
import { promises } from 'fs';
|
|
7
5
|
/**
|
|
8
6
|
* Store implementation that stores info in a simple JSON file
|
|
9
7
|
*/
|
|
@@ -34,7 +32,7 @@ export declare class FileSystemStore<T, TPrimaryKey extends keyof T> extends Eve
|
|
|
34
32
|
count(filter?: FilterType<T>): Promise<number>;
|
|
35
33
|
private fileLock;
|
|
36
34
|
saveChanges(): Promise<void>;
|
|
37
|
-
|
|
35
|
+
[Symbol.asyncDispose](): Promise<void>;
|
|
38
36
|
reloadData(): Promise<void>;
|
|
39
37
|
update(id: T[TPrimaryKey], data: T): Promise<void>;
|
|
40
38
|
readFile: typeof promises.readFile;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"filesystem-store.d.ts","sourceRoot":"","sources":["../src/filesystem-store.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"filesystem-store.d.ts","sourceRoot":"","sources":["../src/filesystem-store.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAE7E,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AACtD,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAA;AAE3C,OAAO,EAAE,QAAQ,EAAS,MAAM,IAAI,CAAA;AAGpC;;GAEG;AACH,qBAAa,eAAe,CAAC,CAAC,EAAE,WAAW,SAAS,MAAM,CAAC,CACzD,SAAQ,QAAQ,CAAC;IACf,aAAa,EAAE;QAAE,MAAM,EAAE,CAAC,CAAA;KAAE,CAAA;IAC5B,eAAe,EAAE;QAAE,EAAE,EAAE,CAAC,CAAC,WAAW,CAAC,CAAC;QAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,CAAA;KAAE,CAAA;IAC3D,eAAe,EAAE;QAAE,GAAG,EAAE,CAAC,CAAC,WAAW,CAAC,CAAA;KAAE,CAAA;CACzC,CACD,YAAW,aAAa,CAAC,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC;IAwGzC,OAAO,CAAC,QAAQ,CAAC,OAAO;IAtG1B,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAW;IAEpC,SAAgB,KAAK,EAAE,aAAa,CAAC,CAAC,CAAC,CAAA;IAEvC,SAAgB,UAAU,EAAE,WAAW,CAAA;IAEvC,OAAO,CAAC,QAAQ,CAAC,aAAa,CAA+B;IAE7D,OAAO,KAAK,KAAK,GAEhB;IAEY,MAAM,CAAC,GAAG,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAO3D,IAAI,EAAE,UAAU,CAAC,OAAO,WAAW,CAAC,CAAA;IACpC,UAAU,UAAQ;IACZ,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC,WAAW,CAAC,EAAE,MAAM,CAAC,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;IAMhD,GAAG,CAAC,GAAG,OAAO,EAAE,CAAC,EAAE;IAQnB,IAAI,CAAC,OAAO,SAAS,KAAK,CAAC,MAAM,CAAC,CAAC,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC,EAAE,OAAO,CAAC;IAMpE,KAAK,CAAC,MAAM,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC;IAMzC,OAAO,CAAC,QAAQ,CAAa;IAChB,WAAW;IAiBX,CAAC,MAAM,CAAC,YAAY,CAAC;IAOrB,UAAU;IAmBV,MAAM,CAAC,EAAE,EAAE,CAAC,CAAC,WAAW,CAAC,EAAE,IAAI,EAAE,CAAC;IAOxC,QAAQ,2BAAoB;IAC5B,SAAS,4BAAqB;gBAGlB,OAAO,EAAE;QACxB,QAAQ,EAAE,MAAM,CAAA;QAChB,UAAU,EAAE,WAAW,CAAA;QACvB,MAAM,CAAC,EAAE,MAAM,CAAA;QACf,KAAK,EAAE,aAAa,CAAC,CAAC,CAAC,CAAA;KACxB;CA2BJ"}
|
package/esm/filesystem-store.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { promises, watch } from 'fs';
|
|
2
|
-
import { Lock } from 'semaphore-async-await';
|
|
3
1
|
import { InMemoryStore } from '@furystack/core';
|
|
4
2
|
import { EventHub } from '@furystack/utils';
|
|
3
|
+
import { promises, watch } from 'fs';
|
|
4
|
+
import { Lock } from 'semaphore-async-await';
|
|
5
5
|
/**
|
|
6
6
|
* Store implementation that stores info in a simple JSON file
|
|
7
7
|
*/
|
|
@@ -62,10 +62,11 @@ export class FileSystemStore extends EventHub {
|
|
|
62
62
|
this.fileLock.release();
|
|
63
63
|
}
|
|
64
64
|
}
|
|
65
|
-
async
|
|
65
|
+
async [Symbol.asyncDispose]() {
|
|
66
66
|
await this.saveChanges();
|
|
67
67
|
this.watcher && this.watcher.close();
|
|
68
68
|
clearInterval(this.tick);
|
|
69
|
+
super[Symbol.dispose]();
|
|
69
70
|
}
|
|
70
71
|
async reloadData() {
|
|
71
72
|
try {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"filesystem-store.js","sourceRoot":"","sources":["../src/filesystem-store.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"filesystem-store.js","sourceRoot":"","sources":["../src/filesystem-store.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { FileSystemStore } from './filesystem-store.js';
|
|
1
|
+
import { StoreManager } from '@furystack/core';
|
|
3
2
|
import { TestClass, createStoreTest } from '@furystack/core/create-physical-store-tests';
|
|
4
3
|
import { sleepAsync } from '@furystack/utils';
|
|
4
|
+
import { promises } from 'fs';
|
|
5
|
+
import { afterAll, describe, expect, it, vi } from 'vitest';
|
|
6
|
+
import { FileSystemStore } from './filesystem-store.js';
|
|
5
7
|
import { useFileSystemStore } from './store-manager-helpers.js';
|
|
6
|
-
import { describe, it, expect, vi, afterAll } from 'vitest';
|
|
7
|
-
import { StoreManager } from '@furystack/core';
|
|
8
8
|
let storeCount = 0;
|
|
9
9
|
describe('FileSystemStore', () => {
|
|
10
10
|
const storeNames = [];
|
|
@@ -39,7 +39,7 @@ describe('FileSystemStore', () => {
|
|
|
39
39
|
});
|
|
40
40
|
await sleepAsync(501);
|
|
41
41
|
expect(store.saveChanges).toHaveBeenCalled();
|
|
42
|
-
await store.
|
|
42
|
+
await store[Symbol.asyncDispose]();
|
|
43
43
|
});
|
|
44
44
|
it('Should reload data from disk', async () => {
|
|
45
45
|
const fileName = `filestore-test-${storeCount++}.json`;
|
|
@@ -59,7 +59,7 @@ describe('FileSystemStore', () => {
|
|
|
59
59
|
await store.reloadData();
|
|
60
60
|
const count = await store.count();
|
|
61
61
|
expect(count).toBe(1);
|
|
62
|
-
await store.
|
|
62
|
+
await store[Symbol.asyncDispose]();
|
|
63
63
|
});
|
|
64
64
|
afterAll(async () => {
|
|
65
65
|
for (const fileName of storeNames) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"filesystem-store.spec.js","sourceRoot":"","sources":["../src/filesystem-store.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"filesystem-store.spec.js","sourceRoot":"","sources":["../src/filesystem-store.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"store-manager-helpers.d.ts","sourceRoot":"","sources":["../src/store-manager-helpers.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAGhE;;;;;;;;GAQG;AACH,eAAO,MAAM,kBAAkB,
|
|
1
|
+
{"version":3,"file":"store-manager-helpers.d.ts","sourceRoot":"","sources":["../src/store-manager-helpers.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAGhE;;;;;;;;GAQG;AACH,eAAO,MAAM,kBAAkB,GAAI,CAAC,WAAW;IAC7C,QAAQ,EAAE,QAAQ,CAAA;IAClB,KAAK,EAAE,aAAa,CAAC,CAAC,CAAC,CAAA;IACvB,UAAU,EAAE,MAAM,CAAC,CAAA;IACnB,QAAQ,EAAE,MAAM,CAAA;IAChB,MAAM,CAAC,EAAE,MAAM,CAAA;CAChB,SAGA,CAAA"}
|
|
@@ -1,16 +1,16 @@
|
|
|
1
|
-
import { promises, existsSync } from 'fs';
|
|
2
|
-
import { FileSystemStore } from './index.js';
|
|
3
|
-
import { useFileSystemStore } from './store-manager-helpers.js';
|
|
4
|
-
import { using } from '@furystack/utils';
|
|
5
|
-
import { Injector } from '@furystack/inject';
|
|
6
1
|
import { StoreManager } from '@furystack/core';
|
|
7
|
-
import { describe, it, expect, afterAll } from 'vitest';
|
|
8
2
|
import { TestClass } from '@furystack/core/create-physical-store-tests';
|
|
3
|
+
import { Injector } from '@furystack/inject';
|
|
4
|
+
import { usingAsync } from '@furystack/utils';
|
|
5
|
+
import { existsSync, promises } from 'fs';
|
|
6
|
+
import { afterAll, describe, expect, it } from 'vitest';
|
|
7
|
+
import { FileSystemStore } from './index.js';
|
|
8
|
+
import { useFileSystemStore } from './store-manager-helpers.js';
|
|
9
9
|
let storeCount = 0;
|
|
10
10
|
describe('FileSystemStore store manager extensions', () => {
|
|
11
11
|
const storeNames = [];
|
|
12
|
-
it('Should create a store with an extensions method from Store Manages', () => {
|
|
13
|
-
|
|
12
|
+
it('Should create a store with an extensions method from Store Manages', async () => {
|
|
13
|
+
await usingAsync(new Injector(), async (i) => {
|
|
14
14
|
const storeManager = i.getInstance(StoreManager);
|
|
15
15
|
const fileName = `filestore-test-${storeCount++}.json`;
|
|
16
16
|
storeNames.push(fileName);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"store-manager-helpers.spec.js","sourceRoot":"","sources":["../src/store-manager-helpers.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"store-manager-helpers.spec.js","sourceRoot":"","sources":["../src/store-manager-helpers.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAA;AAC9C,OAAO,EAAE,SAAS,EAAE,MAAM,6CAA6C,CAAA;AACvE,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAC5C,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAA;AAC7C,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,IAAI,CAAA;AACzC,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAA;AACvD,OAAO,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAC5C,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAA;AAE/D,IAAI,UAAU,GAAG,CAAC,CAAA;AAElB,QAAQ,CAAC,0CAA0C,EAAE,GAAG,EAAE;IACxD,MAAM,UAAU,GAAa,EAAE,CAAA;IAE/B,EAAE,CAAC,oEAAoE,EAAE,KAAK,IAAI,EAAE;QAClF,MAAM,UAAU,CAAC,IAAI,QAAQ,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;YAC3C,MAAM,YAAY,GAAG,CAAC,CAAC,WAAW,CAAC,YAAY,CAAC,CAAA;YAChD,MAAM,QAAQ,GAAG,kBAAkB,UAAU,EAAE,OAAO,CAAA;YACtD,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;YACzB,kBAAkB,CAAC;gBACjB,QAAQ,EAAE,CAAC;gBACX,KAAK,EAAE,SAAS;gBAChB,QAAQ;gBACR,UAAU,EAAE,IAAI;aACjB,CAAC,CAAA;YACF,MAAM,CAAC,YAAY,CAAC,WAAW,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC,cAAc,CAAC,eAAe,CAAC,CAAA;QACnF,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;IAEF,QAAQ,CAAC,KAAK,IAAI,EAAE;QAClB,MAAM,OAAO,CAAC,GAAG,CACf,UAAU,CAAC,GAAG,CAAC,KAAK,EAAE,QAAQ,EAAE,EAAE;YAChC,IAAI,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;gBACzB,MAAM,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAA;YACjC,CAAC;QACH,CAAC,CAAC,CACH,CAAA;IACH,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@furystack/filesystem-store",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "7.0.0",
|
|
4
4
|
"description": "Simple File System store implementation for FuryStack",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"scripts": {
|
|
@@ -37,15 +37,15 @@
|
|
|
37
37
|
},
|
|
38
38
|
"homepage": "https://github.com/furystack/furystack",
|
|
39
39
|
"dependencies": {
|
|
40
|
-
"@furystack/core": "^
|
|
41
|
-
"@furystack/inject": "^
|
|
42
|
-
"@furystack/utils": "^
|
|
40
|
+
"@furystack/core": "^15.0.0",
|
|
41
|
+
"@furystack/inject": "^12.0.0",
|
|
42
|
+
"@furystack/utils": "^8.0.0",
|
|
43
43
|
"semaphore-async-await": "^1.5.1"
|
|
44
44
|
},
|
|
45
45
|
"devDependencies": {
|
|
46
|
-
"@types/node": "^20.14.
|
|
47
|
-
"typescript": "^5.
|
|
48
|
-
"vitest": "^
|
|
46
|
+
"@types/node": "^20.14.10",
|
|
47
|
+
"typescript": "^5.5.3",
|
|
48
|
+
"vitest": "^2.0.0"
|
|
49
49
|
},
|
|
50
50
|
"gitHead": "1045d854bfd8c475b7035471d130d401417a2321"
|
|
51
51
|
}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { FileSystemStore } from './filesystem-store.js'
|
|
1
|
+
import { StoreManager } from '@furystack/core'
|
|
3
2
|
import { TestClass, createStoreTest } from '@furystack/core/create-physical-store-tests'
|
|
4
|
-
import { sleepAsync } from '@furystack/utils'
|
|
5
3
|
import type { Injector } from '@furystack/inject'
|
|
4
|
+
import { sleepAsync } from '@furystack/utils'
|
|
5
|
+
import { promises } from 'fs'
|
|
6
|
+
import { afterAll, describe, expect, it, vi } from 'vitest'
|
|
7
|
+
import { FileSystemStore } from './filesystem-store.js'
|
|
6
8
|
import { useFileSystemStore } from './store-manager-helpers.js'
|
|
7
|
-
import { describe, it, expect, vi, afterAll } from 'vitest'
|
|
8
|
-
import { StoreManager } from '@furystack/core'
|
|
9
9
|
|
|
10
10
|
let storeCount = 0
|
|
11
11
|
|
|
@@ -48,7 +48,7 @@ describe('FileSystemStore', () => {
|
|
|
48
48
|
await sleepAsync(501)
|
|
49
49
|
expect(store.saveChanges).toHaveBeenCalled()
|
|
50
50
|
|
|
51
|
-
await store.
|
|
51
|
+
await store[Symbol.asyncDispose]()
|
|
52
52
|
})
|
|
53
53
|
|
|
54
54
|
it('Should reload data from disk', async () => {
|
|
@@ -69,7 +69,7 @@ describe('FileSystemStore', () => {
|
|
|
69
69
|
await store.reloadData()
|
|
70
70
|
const count = await store.count()
|
|
71
71
|
expect(count).toBe(1)
|
|
72
|
-
await store.
|
|
72
|
+
await store[Symbol.asyncDispose]()
|
|
73
73
|
})
|
|
74
74
|
|
|
75
75
|
afterAll(async () => {
|
package/src/filesystem-store.ts
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
|
+
import type { FilterType, FindOptions, PhysicalStore } from '@furystack/core'
|
|
2
|
+
import { InMemoryStore } from '@furystack/core'
|
|
3
|
+
import type { Constructable } from '@furystack/inject'
|
|
4
|
+
import { EventHub } from '@furystack/utils'
|
|
1
5
|
import type { FSWatcher } from 'fs'
|
|
2
6
|
import { promises, watch } from 'fs'
|
|
3
|
-
import type { Constructable } from '@furystack/inject'
|
|
4
7
|
import { Lock } from 'semaphore-async-await'
|
|
5
|
-
import type { PhysicalStore, FindOptions, FilterType } from '@furystack/core'
|
|
6
|
-
import { InMemoryStore } from '@furystack/core'
|
|
7
|
-
import { EventHub } from '@furystack/utils'
|
|
8
8
|
|
|
9
9
|
/**
|
|
10
10
|
* Store implementation that stores info in a simple JSON file
|
|
@@ -82,10 +82,11 @@ export class FileSystemStore<T, TPrimaryKey extends keyof T>
|
|
|
82
82
|
}
|
|
83
83
|
}
|
|
84
84
|
|
|
85
|
-
public async
|
|
85
|
+
public async [Symbol.asyncDispose]() {
|
|
86
86
|
await this.saveChanges()
|
|
87
87
|
this.watcher && this.watcher.close()
|
|
88
88
|
clearInterval(this.tick)
|
|
89
|
+
super[Symbol.dispose]()
|
|
89
90
|
}
|
|
90
91
|
|
|
91
92
|
public async reloadData() {
|
|
@@ -1,19 +1,19 @@
|
|
|
1
|
-
import { promises, existsSync } from 'fs'
|
|
2
|
-
import { FileSystemStore } from './index.js'
|
|
3
|
-
import { useFileSystemStore } from './store-manager-helpers.js'
|
|
4
|
-
import { using } from '@furystack/utils'
|
|
5
|
-
import { Injector } from '@furystack/inject'
|
|
6
1
|
import { StoreManager } from '@furystack/core'
|
|
7
|
-
import { describe, it, expect, afterAll } from 'vitest'
|
|
8
2
|
import { TestClass } from '@furystack/core/create-physical-store-tests'
|
|
3
|
+
import { Injector } from '@furystack/inject'
|
|
4
|
+
import { usingAsync } from '@furystack/utils'
|
|
5
|
+
import { existsSync, promises } from 'fs'
|
|
6
|
+
import { afterAll, describe, expect, it } from 'vitest'
|
|
7
|
+
import { FileSystemStore } from './index.js'
|
|
8
|
+
import { useFileSystemStore } from './store-manager-helpers.js'
|
|
9
9
|
|
|
10
10
|
let storeCount = 0
|
|
11
11
|
|
|
12
12
|
describe('FileSystemStore store manager extensions', () => {
|
|
13
13
|
const storeNames: string[] = []
|
|
14
14
|
|
|
15
|
-
it('Should create a store with an extensions method from Store Manages', () => {
|
|
16
|
-
|
|
15
|
+
it('Should create a store with an extensions method from Store Manages', async () => {
|
|
16
|
+
await usingAsync(new Injector(), async (i) => {
|
|
17
17
|
const storeManager = i.getInstance(StoreManager)
|
|
18
18
|
const fileName = `filestore-test-${storeCount++}.json`
|
|
19
19
|
storeNames.push(fileName)
|