@effect-app/infra 0.221.0 → 0.223.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/CHANGELOG.md +21 -0
- package/_cjs/services/Operations.cjs +3 -2
- package/_cjs/services/Operations.cjs.map +1 -1
- package/_cjs/services/Repository/ext.cjs.map +1 -1
- package/_cjs/services/RepositoryBase.cjs +6 -4
- package/_cjs/services/RepositoryBase.cjs.map +1 -1
- package/_cjs/services/Store/Cosmos.cjs.map +1 -1
- package/_cjs/services/Store/Disk.cjs.map +1 -1
- package/_cjs/services/Store/Memory.cjs +1 -0
- package/_cjs/services/Store/Memory.cjs.map +1 -1
- package/_cjs/services/Store/service.cjs.map +1 -1
- package/_cjs/services/Store/utils.cjs.map +1 -1
- package/dist/services/Operations.d.ts +1 -0
- package/dist/services/Operations.d.ts.map +1 -1
- package/dist/services/Operations.js +4 -3
- package/dist/services/Repository/ext.d.ts +42 -15
- package/dist/services/Repository/ext.d.ts.map +1 -1
- package/dist/services/Repository/ext.js +1 -1
- package/dist/services/Repository/service.d.ts +3 -2
- package/dist/services/Repository/service.d.ts.map +1 -1
- package/dist/services/RepositoryBase.d.ts +81 -86
- package/dist/services/RepositoryBase.d.ts.map +1 -1
- package/dist/services/RepositoryBase.js +11 -7
- package/dist/services/Store/Cosmos.d.ts.map +1 -1
- package/dist/services/Store/Cosmos.js +1 -1
- package/dist/services/Store/Disk.d.ts +3 -1
- package/dist/services/Store/Disk.d.ts.map +1 -1
- package/dist/services/Store/Disk.js +1 -1
- package/dist/services/Store/Memory.d.ts +9 -3
- package/dist/services/Store/Memory.d.ts.map +1 -1
- package/dist/services/Store/Memory.js +2 -2
- package/dist/services/Store/service.d.ts +37 -18
- package/dist/services/Store/service.d.ts.map +1 -1
- package/dist/services/Store/service.js +1 -1
- package/dist/services/Store/utils.d.ts +6 -2
- package/dist/services/Store/utils.d.ts.map +1 -1
- package/dist/services/Store/utils.js +1 -1
- package/dist/services/query/new-kid-interpreter.d.ts +1 -1
- package/package.json +10 -10
- package/src/services/Operations.ts +4 -2
- package/src/services/Repository/ext.ts +28 -29
- package/src/services/Repository/service.ts +2 -3
- package/src/services/RepositoryBase.ts +177 -169
- package/src/services/Store/Cosmos.ts +13 -12
- package/src/services/Store/Disk.ts +12 -11
- package/src/services/Store/Memory.ts +13 -12
- package/src/services/Store/index.test.ts.bak +3 -3
- package/src/services/Store/service.ts +22 -19
- package/src/services/Store/utils.ts +2 -2
- package/test/query.test.ts +1 -1
|
@@ -35,43 +35,59 @@ export type Where = {
|
|
|
35
35
|
value: readonly (SupportedValues)[];
|
|
36
36
|
};
|
|
37
37
|
export type Filter<E extends FieldValues> = QueryBuilder<E>;
|
|
38
|
-
export interface O<
|
|
39
|
-
|
|
38
|
+
export interface O<Encoded extends {
|
|
39
|
+
id: string;
|
|
40
|
+
}> {
|
|
41
|
+
key: keyof Encoded;
|
|
40
42
|
direction: "ASC" | "DESC";
|
|
41
43
|
}
|
|
42
|
-
export interface FilterArgs<
|
|
43
|
-
|
|
44
|
+
export interface FilterArgs<Encoded extends {
|
|
45
|
+
id: string;
|
|
46
|
+
}, U extends keyof Encoded = never> {
|
|
47
|
+
filter?: Filter<Encoded> | undefined;
|
|
44
48
|
select?: NonEmptyReadonlyArray<U> | undefined;
|
|
45
|
-
order?: NonEmptyReadonlyArray<O<
|
|
49
|
+
order?: NonEmptyReadonlyArray<O<Encoded>>;
|
|
46
50
|
limit?: number | undefined;
|
|
47
51
|
skip?: number | undefined;
|
|
48
52
|
}
|
|
49
|
-
export type FilterFunc<
|
|
50
|
-
|
|
53
|
+
export type FilterFunc<Encoded extends {
|
|
54
|
+
id: string;
|
|
55
|
+
}> = <U extends keyof Encoded = never>(args: FilterArgs<Encoded, U>) => Effect<(U extends undefined ? Encoded : Pick<Encoded, U>)[]>;
|
|
56
|
+
export interface Store<Encoded extends {
|
|
57
|
+
id: Id;
|
|
58
|
+
}, Id extends string, PM extends PersistenceModelType<Encoded> = PersistenceModelType<Encoded>> {
|
|
51
59
|
all: Effect<PM[]>;
|
|
52
|
-
filter: FilterFunc<
|
|
60
|
+
filter: FilterFunc<Encoded>;
|
|
53
61
|
find: (id: Id) => Effect<Option<PM>>;
|
|
54
62
|
set: (e: PM) => Effect<PM, OptimisticConcurrencyException>;
|
|
55
63
|
batchSet: (items: NonEmptyReadonlyArray<PM>) => Effect<NonEmptyReadonlyArray<PM>, OptimisticConcurrencyException>;
|
|
56
64
|
bulkSet: (items: NonEmptyReadonlyArray<PM>) => Effect<NonEmptyReadonlyArray<PM>, OptimisticConcurrencyException>;
|
|
57
65
|
/**
|
|
58
|
-
* Requires the
|
|
66
|
+
* Requires the Encoded type, not Id, because various stores may need to calculate e.g partition keys.
|
|
59
67
|
*/
|
|
60
|
-
remove: (e:
|
|
68
|
+
remove: (e: Encoded) => Effect<void>;
|
|
61
69
|
}
|
|
62
70
|
declare const StoreMaker_base: (abstract new (service: {
|
|
63
|
-
make: <
|
|
71
|
+
make: <Encoded extends {
|
|
72
|
+
id: Id;
|
|
73
|
+
}, Id extends string, R = never, E = never>(name: string, seed?: Effect<Iterable<Encoded>, E, R>, config?: StoreConfig<Encoded>) => Effect<Store<Encoded, Id>, E, R>;
|
|
64
74
|
}) => Readonly<{
|
|
65
|
-
make: <
|
|
75
|
+
make: <Encoded extends {
|
|
76
|
+
id: Id;
|
|
77
|
+
}, Id extends string, R = never, E = never>(name: string, seed?: Effect<Iterable<Encoded>, E, R>, config?: StoreConfig<Encoded>) => Effect<Store<Encoded, Id>, E, R>;
|
|
66
78
|
}> & import("effect/Context").TagClassShape<"effect-app/StoreMaker", {
|
|
67
|
-
make: <
|
|
79
|
+
make: <Encoded extends {
|
|
80
|
+
id: Id;
|
|
81
|
+
}, Id extends string, R = never, E = never>(name: string, seed?: Effect<Iterable<Encoded>, E, R>, config?: StoreConfig<Encoded>) => Effect<Store<Encoded, Id>, E, R>;
|
|
68
82
|
}>) & {
|
|
69
83
|
toLayer: <E_1, R_1>(eff: Effect<Omit<StoreMaker, keyof import("effect/Context").TagClassShape<any, any>>, E_1, R_1>) => import("effect-app").Layer<StoreMaker, E_1, R_1>;
|
|
70
84
|
toLayerScoped: <E_1_1, R_1_1>(eff: Effect<Omit<StoreMaker, keyof import("effect/Context").TagClassShape<any, any>>, E_1_1, R_1_1>) => import("effect-app").Layer<StoreMaker, E_1_1, Exclude<R_1_1, import("effect/Scope").Scope>>;
|
|
71
85
|
of: (service: Omit<StoreMaker, keyof import("effect/Context").TagClassShape<any, any>>) => StoreMaker;
|
|
72
86
|
} & import("effect/Context").Tag<StoreMaker, StoreMaker> & {} & {
|
|
73
87
|
use: <X>(body: (_: {
|
|
74
|
-
make: <
|
|
88
|
+
make: <Encoded extends {
|
|
89
|
+
id: Id;
|
|
90
|
+
}, Id extends string, R = never, E = never>(name: string, seed?: Effect<Iterable<Encoded>, E, R> | undefined, config?: StoreConfig<Encoded> | undefined) => Effect<Store<Encoded, Id, PersistenceModelType<Encoded>>, E, R>;
|
|
75
91
|
}) => X) => X extends Effect<infer A_3, infer E_4, infer R_4> ? Effect<A_3, E_4, StoreMaker | R_4> : Effect<X, never, StoreMaker>;
|
|
76
92
|
};
|
|
77
93
|
/**
|
|
@@ -108,6 +124,10 @@ declare const ContextMap_base: (abstract new (service: {
|
|
|
108
124
|
get: (id: string) => Effect<string | undefined, never, ContextMap>;
|
|
109
125
|
set: (id: string, eTag: string | undefined) => Effect<void, never, ContextMap>;
|
|
110
126
|
} & {
|
|
127
|
+
/**
|
|
128
|
+
* @tsplus type ContextMap
|
|
129
|
+
* @tsplus companion ContextMap.Ops
|
|
130
|
+
*/
|
|
111
131
|
use: <X>(body: (_: {
|
|
112
132
|
get: (id: string) => string | undefined;
|
|
113
133
|
set: (id: string, eTag: string | undefined) => void;
|
|
@@ -119,10 +139,9 @@ declare const ContextMap_base: (abstract new (service: {
|
|
|
119
139
|
*/
|
|
120
140
|
export declare class ContextMap extends ContextMap_base {
|
|
121
141
|
}
|
|
122
|
-
export
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
}
|
|
142
|
+
export type PersistenceModelType<Encoded> = Encoded & {
|
|
143
|
+
_etag?: string | undefined;
|
|
144
|
+
};
|
|
126
145
|
export interface StorageConfig {
|
|
127
146
|
url: Secret.Secret;
|
|
128
147
|
prefix: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"service.d.ts","sourceRoot":"","sources":["../../../src/services/Store/service.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,eAAe,CAAA;AAC9C,OAAO,EAAE,MAAM,EAAE,MAAM,YAAY,CAAA;AACnC,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,YAAY,CAAA;AAEvE,OAAO,KAAK,EAAE,8BAA8B,EAAE,MAAM,iBAAiB,CAAA;AACrE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAA;AACxD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAA;AAExD,MAAM,MAAM,WAAW,CAAC,CAAC,IAAI;IAC3B,UAAU,CAAC,EAAE,SAAS,EAAE,CAAA;IACxB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,cAAc,EAAE,CAAC,CAAC,EAAE,CAAC,KAAK,MAAM,GAAG,SAAS,CAAA;IAC5C,cAAc,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,OAAO,CAAA;IAC/C,aAAa,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC,CAAA;CAC3B,CAAA;AAED,MAAM,MAAM,eAAe,GAAG,MAAM,GAAG,OAAO,GAAG,MAAM,GAAG,IAAI,CAAA;AAC9D,MAAM,MAAM,gBAAgB,GAAG,MAAM,GAAG,OAAO,GAAG,MAAM,CAAA;AAGxD,MAAM,MAAM,KAAK,GACb;IAAE,GAAG,EAAE,MAAM,CAAC;IAAC,CAAC,CAAC,EAAE,IAAI,GAAG,QAAQ,CAAC;IAAC,KAAK,EAAE,eAAe,CAAA;CAAE,GAC5D;IAAE,GAAG,EAAE,MAAM,CAAC;IAAC,CAAC,EAAE,IAAI,GAAG,IAAI,GAAG,KAAK,GAAG,KAAK,CAAC;IAAC,KAAK,EAAE,gBAAgB,CAAA;CAAE,GACxE;IACA,GAAG,EAAE,MAAM,CAAA;IACX,CAAC,EAAE,UAAU,GAAG,aAAa,GAAG,WAAW,GAAG,cAAc,GAAG,iBAAiB,GAAG,eAAe,CAAA;IAClG,KAAK,EAAE,MAAM,CAAA;CACd,GACC;IAAE,GAAG,EAAE,MAAM,CAAC;IAAC,CAAC,EAAE,UAAU,GAAG,cAAc,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,GAC9D;IACA,GAAG,EAAE,MAAM,CAAA;IACX,CAAC,EAAE,IAAI,GAAG,QAAQ,CAAA;IAClB,KAAK,EAAE,SAAS,CAAC,eAAe,CAAC,EAAE,CAAA;CACpC,CAAA;AAEH,MAAM,MAAM,MAAM,CAAC,CAAC,SAAS,WAAW,IAAI,YAAY,CAAC,CAAC,CAAC,CAAA;AAE3D,MAAM,WAAW,CAAC,CAAC,
|
|
1
|
+
{"version":3,"file":"service.d.ts","sourceRoot":"","sources":["../../../src/services/Store/service.ts"],"names":[],"mappings":"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"}
|
|
@@ -72,4 +72,4 @@ const makeMap = Effect.sync(() => makeContextMap());
|
|
|
72
72
|
*/
|
|
73
73
|
export class ContextMap extends TagClassMakeId("effect-app/ContextMap", makeMap)() {
|
|
74
74
|
}
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9zZXJ2aWNlcy9TdG9yZS9zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxZQUFZLENBQUE7QUFFbkMsT0FBTyxFQUFFLFVBQVUsRUFBRSxjQUFjLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQTtBQXdFL0Q7OztHQUdHO0FBQ0gsTUFBTSxPQUFPLFVBQVcsU0FBUSxVQUFVLENBQUMsdUJBQXVCLENBQUMsRUFNL0Q7Q0FDSDtBQUVELE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRyxHQUFHLEVBQUU7SUFDakMsTUFBTSxLQUFLLEdBQUcsSUFBSSxHQUFHLEVBQWtCLENBQUE7SUFDdkMsTUFBTSxPQUFPLEdBQUcsQ0FBQyxFQUFVLEVBQUUsRUFBRSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLENBQUE7SUFDN0MsTUFBTSxPQUFPLEdBQUcsQ0FBQyxFQUFVLEVBQUUsSUFBd0IsRUFBRSxFQUFFO1FBQ3ZELElBQUksS0FBSyxTQUFTLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsRUFBRSxFQUFFLElBQUksQ0FBQyxDQUFBO0lBQzdELENBQUMsQ0FBQTtJQUVELCtCQUErQjtJQUMvQiwyQkFBMkI7SUFDM0IsZ0RBQWdEO0lBQ2hELE1BQU07SUFFTiwrQkFBK0I7SUFDL0IsMkJBQTJCO0lBQzNCLHNDQUFzQztJQUN0QyxNQUFNO0lBRU4sa0NBQWtDO0lBQ2xDLHdCQUF3QjtJQUN4QixvQ0FBb0M7SUFDcEMsU0FBUztJQUNULDJCQUEyQjtJQUMzQixjQUFjO0lBQ2QsSUFBSTtJQUVKLGlDQUFpQztJQUNqQyxvRkFBb0Y7SUFDcEYsb0lBQW9JO0lBQ3BJLGdCQUFnQjtJQUNoQixhQUFhO0lBQ2IsNEdBQTRHO0lBQzVHLHNDQUFzQztJQUN0QyxrRUFBa0U7SUFDbEUsdURBQXVEO0lBQ3ZELHNCQUFzQjtJQUN0QixzQkFBc0I7SUFDdEIsU0FBUztJQUNULHFDQUFxQztJQUNyQyx5Q0FBeUM7SUFDekMsaUJBQWlCO0lBQ2pCLDZCQUE2QjtJQUM3QixtQkFBbUI7SUFDbkIsK0NBQStDO0lBQy9DLHFCQUFxQjtJQUNyQixtQkFBbUI7SUFDbkIsMkNBQTJDO0lBQzNDLHlCQUF5QjtJQUN6QixzQkFBc0I7SUFDdEIsWUFBWTtJQUNaLGlCQUFpQjtJQUNqQix5Q0FBeUM7SUFDekMscURBQXFEO0lBQ3JELG9CQUFvQjtJQUNwQixVQUFVO0lBQ1YsUUFBUTtJQUNSLE1BQU07SUFDTixJQUFJO0lBRUosT0FBTztRQUNMLEdBQUcsRUFBRSxPQUFPO1FBQ1osR0FBRyxFQUFFLE9BQU87UUFDWixZQUFZO0tBQ2IsQ0FBQTtBQUNILENBQUMsQ0FBQTtBQUVELE1BQU0sT0FBTyxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUMsY0FBYyxFQUFFLENBQUMsQ0FBQTtBQUVuRDs7O0dBR0c7QUFDSCxNQUFNLE9BQU8sVUFBVyxTQUFRLGNBQWMsQ0FBQyx1QkFBdUIsRUFBRSxPQUFPLENBQUMsRUFBYztDQUM3RiJ9
|
|
@@ -1,8 +1,12 @@
|
|
|
1
1
|
import { Effect, Option } from "effect-app";
|
|
2
2
|
import { OptimisticConcurrencyException } from "../../errors.js";
|
|
3
3
|
import type { Filter, PersistenceModelType, SupportedValues2 } from "./service.js";
|
|
4
|
-
export declare const makeETag: <E extends
|
|
5
|
-
|
|
4
|
+
export declare const makeETag: <E extends {
|
|
5
|
+
_etag?: string | undefined;
|
|
6
|
+
}>({ _etag, ...e }: E) => E;
|
|
7
|
+
export declare const makeUpdateETag: (type: string) => <E extends PersistenceModelType<{
|
|
8
|
+
id: string;
|
|
9
|
+
}>>(e: E, current: Option<E>) => Effect.Effect<E, OptimisticConcurrencyException, never>;
|
|
6
10
|
export declare function codeFilter<E extends {
|
|
7
11
|
id: string;
|
|
8
12
|
}, NE extends E>(filter: Filter<NE>): (x: E) => Option.None<NE> | Option.Some<NE>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/services/Store/utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,YAAY,CAAA;AAE3C,OAAO,EAAE,8BAA8B,EAAE,MAAM,iBAAiB,CAAA;AAEhE,OAAO,KAAK,EAAE,MAAM,EAAE,oBAAoB,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAA;AAElF,eAAO,MAAM,QAAQ,
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/services/Store/utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,YAAY,CAAA;AAE3C,OAAO,EAAE,8BAA8B,EAAE,MAAM,iBAAiB,CAAA;AAEhE,OAAO,KAAK,EAAE,MAAM,EAAE,oBAAoB,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAA;AAElF,eAAO,MAAM,QAAQ;;oBACF,CAAC,KACjB,CAGO,CAAA;AACV,eAAO,MAAM,cAAc,SAClB,MAAM;QAA2C,MAAM;OAAQ,CAAC,WAAW,OAAO,CAAC,CAAC,4DAsBvF,CAAA;AAEN,wBAAgB,UAAU,CAAC,CAAC,SAAS;IAAE,EAAE,EAAE,MAAM,CAAA;CAAE,EAAE,EAAE,SAAS,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,OACxE,CAAC,uCACb;AAED,wBAAgB,iBAAiB,CAAC,CAAC,EAAE,GAAG,EAAE,CAAC,cAK1C;AAED,wBAAgB,OAAO,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,WAEnD;AAED,wBAAgB,SAAS,CAAC,IAAI,EAAE,gBAAgB,EAAE,IAAI,EAAE,gBAAgB,WAEvE;AAED,wBAAgB,kBAAkB,CAAC,IAAI,EAAE,gBAAgB,EAAE,IAAI,EAAE,gBAAgB,WAEhF;AAED,wBAAgB,WAAW,CAAC,IAAI,EAAE,gBAAgB,EAAE,IAAI,EAAE,gBAAgB,WAEzE;AAED,wBAAgB,oBAAoB,CAAC,IAAI,EAAE,gBAAgB,EAAE,IAAI,EAAE,gBAAgB,WAElF"}
|
|
@@ -45,4 +45,4 @@ export function greaterThan(valA, valB) {
|
|
|
45
45
|
export function greaterThanExclusive(valA, valB) {
|
|
46
46
|
return valA >= valB;
|
|
47
47
|
}
|
|
48
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvc2VydmljZXMvU3RvcmUvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUUsTUFBTSxZQUFZLENBQUE7QUFDM0MsT0FBTyxVQUFVLE1BQU0sYUFBYSxDQUFBO0FBQ3BDLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLGlCQUFpQixDQUFBO0FBQ2hFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQTtBQUc5QyxNQUFNLENBQUMsTUFBTSxRQUFRLEdBQUcsQ0FDdEIsRUFBRSxLQUFLLEVBQUUsR0FBRyxDQUFDLEVBQUssRUFDZixFQUFFLENBQUUsQ0FBQztJQUNSLEdBQUcsQ0FBQztJQUNKLEtBQUssRUFBRSxVQUFVLENBQUMsQ0FBQyxDQUFDO0NBQ3JCLENBQVMsQ0FBQTtBQUNWLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FDekIsQ0FBQyxJQUFZLEVBQUUsRUFBRSxDQUFDLENBQWlELENBQUksRUFBRSxPQUFrQixFQUFFLEVBQUUsQ0FDN0YsTUFBTSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsRUFBQyxDQUFDO0lBQ3BCLElBQUksQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ1osS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUNOLE1BQU0sQ0FBQyxRQUFRLENBQ2IsT0FBTyxFQUNQLEdBQUcsRUFBRSxDQUFDLElBQUksOEJBQThCLENBQUMsRUFBRSxJQUFJLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFFLEVBQUUsT0FBTyxFQUFFLEVBQUUsRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFDLENBQzFGLENBQ0YsQ0FBQTtJQUNILENBQUM7SUFDRCxJQUFJLE1BQU0sQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLElBQUksT0FBTyxDQUFDLEtBQUssQ0FBQyxLQUFLLEtBQUssQ0FBQyxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQzlELE9BQU8sS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUNiLElBQUksOEJBQThCLENBQUM7WUFDakMsSUFBSTtZQUNKLEVBQUUsRUFBRSxPQUFPLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDcEIsT0FBTyxFQUFFLE9BQU8sQ0FBQyxLQUFLLENBQUMsS0FBSztZQUM1QixLQUFLLEVBQUUsQ0FBQyxDQUFDLEtBQUs7U0FDZixDQUFDLENBQ0gsQ0FBQTtJQUNILENBQUM7SUFDRCxNQUFNLElBQUksR0FBRyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUE7SUFDeEIsT0FBTyxJQUFJLENBQUE7QUFDYixDQUFDLENBQUMsQ0FBQTtBQUVOLE1BQU0sVUFBVSxVQUFVLENBQXlDLE1BQWtCO0lBQ25GLE9BQU8sQ0FBQyxDQUFJLEVBQUUsRUFBRSxDQUFDLFlBQVksQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBa0IsQ0FBQyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLENBQUE7QUFDcEcsQ0FBQztBQUVELE1BQU0sVUFBVSxpQkFBaUIsQ0FBSSxHQUFNO0lBQ3pDLElBQUksT0FBTyxHQUFHLEtBQUssUUFBUSxFQUFFLENBQUM7UUFDNUIsT0FBTyxHQUFHLENBQUMsV0FBVyxFQUFFLENBQUE7SUFDMUIsQ0FBQztJQUNELE9BQU8sR0FBRyxDQUFBO0FBQ1osQ0FBQztBQUVELE1BQU0sVUFBVSxPQUFPLENBQUMsSUFBYSxFQUFFLElBQWE7SUFDbEQsT0FBTyxJQUFJLEtBQUssSUFBSSxDQUFBO0FBQ3RCLENBQUM7QUFFRCxNQUFNLFVBQVUsU0FBUyxDQUFDLElBQXNCLEVBQUUsSUFBc0I7SUFDdEUsT0FBTyxJQUFJLEdBQUcsSUFBSSxDQUFBO0FBQ3BCLENBQUM7QUFFRCxNQUFNLFVBQVUsa0JBQWtCLENBQUMsSUFBc0IsRUFBRSxJQUFzQjtJQUMvRSxPQUFPLElBQUksSUFBSSxJQUFJLENBQUE7QUFDckIsQ0FBQztBQUVELE1BQU0sVUFBVSxXQUFXLENBQUMsSUFBc0IsRUFBRSxJQUFzQjtJQUN4RSxPQUFPLElBQUksR0FBRyxJQUFJLENBQUE7QUFDcEIsQ0FBQztBQUVELE1BQU0sVUFBVSxvQkFBb0IsQ0FBQyxJQUFzQixFQUFFLElBQXNCO0lBQ2pGLE9BQU8sSUFBSSxJQUFJLElBQUksQ0FBQTtBQUNyQixDQUFDIn0=
|
|
@@ -14,7 +14,7 @@ export declare const toFilter: <TFieldValues extends FieldValues, A, R>(q: QAll<
|
|
|
14
14
|
key: import("../../filter/types/path/eager.js").Path<TFieldValues>;
|
|
15
15
|
direction: "ASC" | "DESC";
|
|
16
16
|
}[]];
|
|
17
|
-
ttype: "
|
|
17
|
+
ttype: "many" | "one" | "count";
|
|
18
18
|
mode: "project" | "collect" | "transform";
|
|
19
19
|
filter: QueryBuilder<any>;
|
|
20
20
|
};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@effect-app/infra",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.223.0",
|
|
4
4
|
"license": "MIT",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"dependencies": {
|
|
@@ -18,15 +18,15 @@
|
|
|
18
18
|
"proper-lockfile": "^4.1.2",
|
|
19
19
|
"pure-rand": "6.0.4",
|
|
20
20
|
"redlock": "^4.2.0",
|
|
21
|
-
"@effect-app/core": "0.
|
|
22
|
-
"@effect-app/fluent-extensions": "0.
|
|
23
|
-
"@effect-app/
|
|
24
|
-
"effect-app": "0.
|
|
25
|
-
"@effect-app/
|
|
21
|
+
"@effect-app/core": "0.156.0",
|
|
22
|
+
"@effect-app/fluent-extensions": "0.150.0",
|
|
23
|
+
"@effect-app/infra-adapters": "0.144.0",
|
|
24
|
+
"effect-app": "0.189.0",
|
|
25
|
+
"@effect-app/schema": "0.210.0"
|
|
26
26
|
},
|
|
27
27
|
"devDependencies": {
|
|
28
28
|
"@babel/cli": "^7.23.9",
|
|
29
|
-
"@sentry/node": "^7.
|
|
29
|
+
"@sentry/node": "^7.107.0",
|
|
30
30
|
"@types/express": "^4.17.21",
|
|
31
31
|
"@types/node": "~20.11.27",
|
|
32
32
|
"@types/proper-lockfile": "^4.1.4",
|
|
@@ -43,9 +43,9 @@
|
|
|
43
43
|
},
|
|
44
44
|
"peerDependencies": {
|
|
45
45
|
"express": "^4.18.3",
|
|
46
|
-
"@effect/platform": "^0.48.
|
|
47
|
-
"@effect/schema": "^0.64.
|
|
48
|
-
"effect": "^2.4.
|
|
46
|
+
"@effect/platform": "^0.48.7",
|
|
47
|
+
"@effect/schema": "^0.64.4",
|
|
48
|
+
"effect": "^2.4.7"
|
|
49
49
|
},
|
|
50
50
|
"typesVersions": {
|
|
51
51
|
"*": {
|
|
@@ -98,7 +98,7 @@ const make = Effect.sync(() => {
|
|
|
98
98
|
})
|
|
99
99
|
|
|
100
100
|
export class Operations extends TagClassMakeId("effect-app/Operations", make)<Operations>() {
|
|
101
|
-
static readonly
|
|
101
|
+
private static readonly CleanupLive = this
|
|
102
102
|
.use((_) =>
|
|
103
103
|
_.cleanup.pipe(
|
|
104
104
|
Effect.exit,
|
|
@@ -115,7 +115,9 @@ export class Operations extends TagClassMakeId("effect-app/Operations", make)<Op
|
|
|
115
115
|
FiberBag.run
|
|
116
116
|
)
|
|
117
117
|
)
|
|
118
|
-
.pipe(Layer.effectDiscard, Layer.provide(FiberBag.Live)
|
|
118
|
+
.pipe(Layer.effectDiscard, Layer.provide(FiberBag.Live))
|
|
119
|
+
|
|
120
|
+
static readonly Live = this.CleanupLive.pipe(Layer.provideMerge(this.toLayer()))
|
|
119
121
|
}
|
|
120
122
|
|
|
121
123
|
/**
|
|
@@ -5,7 +5,6 @@ import { Effect, ReadonlyArray } from "effect-app"
|
|
|
5
5
|
import type { NonEmptyArray } from "effect-app"
|
|
6
6
|
import { type FixEnv, runTerm } from "effect-app/Pure"
|
|
7
7
|
import { NotFoundError } from "../../errors.js"
|
|
8
|
-
import type { PersistenceModelType } from "../../services/Store.js"
|
|
9
8
|
import type { RepositoryBaseC } from "../RepositoryBase.js"
|
|
10
9
|
import { AnyPureDSL } from "./dsl.js"
|
|
11
10
|
import type { Repository } from "./service.js"
|
|
@@ -15,11 +14,11 @@ import type { Repository } from "./service.js"
|
|
|
15
14
|
*/
|
|
16
15
|
export function get<
|
|
17
16
|
T extends { id: unknown },
|
|
18
|
-
|
|
17
|
+
Encoded extends { id: string },
|
|
19
18
|
Evt,
|
|
20
19
|
ItemType extends string
|
|
21
20
|
>(
|
|
22
|
-
self: RepositoryBaseC<T,
|
|
21
|
+
self: RepositoryBaseC<T, Encoded, Evt, ItemType>,
|
|
23
22
|
id: T["id"]
|
|
24
23
|
) {
|
|
25
24
|
return self
|
|
@@ -32,10 +31,10 @@ export function get<
|
|
|
32
31
|
*/
|
|
33
32
|
export function log<
|
|
34
33
|
T extends { id: unknown },
|
|
35
|
-
|
|
34
|
+
Encoded extends { id: string },
|
|
36
35
|
Evt,
|
|
37
36
|
ItemType extends string
|
|
38
|
-
>(_: RepositoryBaseC<T,
|
|
37
|
+
>(_: RepositoryBaseC<T, Encoded, Evt, ItemType>) {
|
|
39
38
|
return (evt: Evt) => AnyPureDSL.log(evt)
|
|
40
39
|
}
|
|
41
40
|
|
|
@@ -44,10 +43,10 @@ export function log<
|
|
|
44
43
|
*/
|
|
45
44
|
export function byIdAndSaveWithPure<
|
|
46
45
|
T extends { id: unknown },
|
|
47
|
-
|
|
46
|
+
Encoded extends { id: string },
|
|
48
47
|
Evt,
|
|
49
48
|
ItemType extends string
|
|
50
|
-
>(self: RepositoryBaseC<T,
|
|
49
|
+
>(self: RepositoryBaseC<T, Encoded, Evt, ItemType>, id: T["id"]) {
|
|
51
50
|
return <R, A, E, S2 extends T>(pure: Effect<A, E, FixEnv<R, Evt, T, S2>>) =>
|
|
52
51
|
get(self, id).pipe(Effect.flatMap((item) => saveWithPure_(self, item, pure)))
|
|
53
52
|
}
|
|
@@ -58,10 +57,10 @@ export function byIdAndSaveWithPure<
|
|
|
58
57
|
*/
|
|
59
58
|
export function handleByIdAndSaveWithPure<
|
|
60
59
|
T extends { id: unknown },
|
|
61
|
-
|
|
60
|
+
Encoded extends { id: string },
|
|
62
61
|
Evt,
|
|
63
62
|
ItemType extends string
|
|
64
|
-
>(self: RepositoryBaseC<T,
|
|
63
|
+
>(self: RepositoryBaseC<T, Encoded, Evt, ItemType>) {
|
|
65
64
|
return <Req extends { id: T["id"] }, Context, R, A, E, S2 extends T>(
|
|
66
65
|
pure: (req: Req, ctx: Context) => Effect<A, E, FixEnv<R, Evt, T, S2>>
|
|
67
66
|
) =>
|
|
@@ -74,7 +73,7 @@ export function handleByIdAndSaveWithPure<
|
|
|
74
73
|
export function saveManyWithPure_<
|
|
75
74
|
R,
|
|
76
75
|
T extends { id: unknown },
|
|
77
|
-
|
|
76
|
+
Encoded extends { id: string },
|
|
78
77
|
A,
|
|
79
78
|
E,
|
|
80
79
|
Evt,
|
|
@@ -82,7 +81,7 @@ export function saveManyWithPure_<
|
|
|
82
81
|
S2 extends T,
|
|
83
82
|
ItemType extends string
|
|
84
83
|
>(
|
|
85
|
-
self: RepositoryBaseC<T,
|
|
84
|
+
self: RepositoryBaseC<T, Encoded, Evt, ItemType>,
|
|
86
85
|
items: Iterable<S1>,
|
|
87
86
|
pure: Effect<A, E, FixEnv<R, Evt, readonly S1[], readonly S2[]>>
|
|
88
87
|
) {
|
|
@@ -98,7 +97,7 @@ export function saveManyWithPure_<
|
|
|
98
97
|
export function saveWithPure_<
|
|
99
98
|
R,
|
|
100
99
|
T extends { id: unknown },
|
|
101
|
-
|
|
100
|
+
Encoded extends { id: string },
|
|
102
101
|
A,
|
|
103
102
|
E,
|
|
104
103
|
Evt,
|
|
@@ -106,7 +105,7 @@ export function saveWithPure_<
|
|
|
106
105
|
S2 extends T,
|
|
107
106
|
ItemType extends string
|
|
108
107
|
>(
|
|
109
|
-
self: RepositoryBaseC<T,
|
|
108
|
+
self: RepositoryBaseC<T, Encoded, Evt, ItemType>,
|
|
110
109
|
item: S1,
|
|
111
110
|
pure: Effect<A, E, FixEnv<R, Evt, S1, S2>>
|
|
112
111
|
) {
|
|
@@ -120,7 +119,7 @@ export function saveWithPure_<
|
|
|
120
119
|
|
|
121
120
|
export function saveAllWithEffectInt<
|
|
122
121
|
T extends { id: unknown },
|
|
123
|
-
|
|
122
|
+
Encoded extends { id: string },
|
|
124
123
|
P extends T,
|
|
125
124
|
Evt,
|
|
126
125
|
ItemType extends string,
|
|
@@ -128,7 +127,7 @@ export function saveAllWithEffectInt<
|
|
|
128
127
|
E,
|
|
129
128
|
A
|
|
130
129
|
>(
|
|
131
|
-
self: RepositoryBaseC<T,
|
|
130
|
+
self: RepositoryBaseC<T, Encoded, Evt, ItemType>,
|
|
132
131
|
gen: Effect<readonly [Iterable<P>, Iterable<Evt>, A], E, R>
|
|
133
132
|
) {
|
|
134
133
|
return Effect.flatMap(gen, ([items, events, a]) => self.saveAndPublish(items, events).pipe(Effect.map(() => a)))
|
|
@@ -139,10 +138,10 @@ export function saveAllWithEffectInt<
|
|
|
139
138
|
*/
|
|
140
139
|
export function saveManyWithPureBatched<
|
|
141
140
|
T extends { id: unknown },
|
|
142
|
-
|
|
141
|
+
Encoded extends { id: string },
|
|
143
142
|
Evt,
|
|
144
143
|
ItemType extends string
|
|
145
|
-
>(self: RepositoryBaseC<T,
|
|
144
|
+
>(self: RepositoryBaseC<T, Encoded, Evt, ItemType>, batchSize = 100) {
|
|
146
145
|
return <R, A, E, S1 extends T, S2 extends T>(pure: Effect<A, E, FixEnv<R, Evt, readonly S1[], readonly S2[]>>) =>
|
|
147
146
|
(items: Iterable<S1>) => saveManyWithPureBatched_(self, items, pure, batchSize)
|
|
148
147
|
}
|
|
@@ -153,7 +152,7 @@ export function saveManyWithPureBatched<
|
|
|
153
152
|
export function saveManyWithPureBatched_<
|
|
154
153
|
R,
|
|
155
154
|
T extends { id: unknown },
|
|
156
|
-
|
|
155
|
+
Encoded extends { id: string },
|
|
157
156
|
A,
|
|
158
157
|
E,
|
|
159
158
|
Evt,
|
|
@@ -161,7 +160,7 @@ export function saveManyWithPureBatched_<
|
|
|
161
160
|
S2 extends T,
|
|
162
161
|
ItemType extends string
|
|
163
162
|
>(
|
|
164
|
-
self: RepositoryBaseC<T,
|
|
163
|
+
self: RepositoryBaseC<T, Encoded, Evt, ItemType>,
|
|
165
164
|
items: Iterable<S1>,
|
|
166
165
|
pure: Effect<A, E, FixEnv<R, Evt, readonly S1[], readonly S2[]>>,
|
|
167
166
|
batchSize = 100
|
|
@@ -181,11 +180,11 @@ export function saveManyWithPureBatched_<
|
|
|
181
180
|
*/
|
|
182
181
|
export function save<
|
|
183
182
|
T extends { id: unknown },
|
|
184
|
-
|
|
183
|
+
Encoded extends { id: string },
|
|
185
184
|
Evt,
|
|
186
185
|
ItemType extends string
|
|
187
186
|
>(
|
|
188
|
-
self: RepositoryBaseC<T,
|
|
187
|
+
self: RepositoryBaseC<T, Encoded, Evt, ItemType>
|
|
189
188
|
) {
|
|
190
189
|
return (...items: NonEmptyArray<T>) => self.saveAndPublish(items)
|
|
191
190
|
}
|
|
@@ -195,11 +194,11 @@ export function save<
|
|
|
195
194
|
*/
|
|
196
195
|
export function saveWithEvents<
|
|
197
196
|
T extends { id: unknown },
|
|
198
|
-
|
|
197
|
+
Encoded extends { id: string },
|
|
199
198
|
Evt,
|
|
200
199
|
ItemType extends string
|
|
201
200
|
>(
|
|
202
|
-
self: RepositoryBaseC<T,
|
|
201
|
+
self: RepositoryBaseC<T, Encoded, Evt, ItemType>
|
|
203
202
|
) {
|
|
204
203
|
return (events: Iterable<Evt>) => (...items: NonEmptyArray<T>) => self.saveAndPublish(items, events)
|
|
205
204
|
}
|
|
@@ -211,11 +210,11 @@ export function itemUpdateWithEffect<
|
|
|
211
210
|
R,
|
|
212
211
|
E,
|
|
213
212
|
T extends { id: string },
|
|
214
|
-
|
|
213
|
+
Encoded extends { id: string },
|
|
215
214
|
Evt,
|
|
216
215
|
ItemType extends string
|
|
217
216
|
>(
|
|
218
|
-
repo: RepositoryBaseC<T,
|
|
217
|
+
repo: RepositoryBaseC<T, Encoded, Evt, ItemType>,
|
|
219
218
|
id: T["id"],
|
|
220
219
|
mod: (item: T) => Effect<T, E, R>
|
|
221
220
|
) {
|
|
@@ -227,11 +226,11 @@ export function itemUpdateWithEffect<
|
|
|
227
226
|
*/
|
|
228
227
|
export function itemUpdate<
|
|
229
228
|
T extends { id: string },
|
|
230
|
-
|
|
229
|
+
Encoded extends { id: string },
|
|
231
230
|
Evt,
|
|
232
231
|
ItemType extends string
|
|
233
232
|
>(
|
|
234
|
-
repo: RepositoryBaseC<T,
|
|
233
|
+
repo: RepositoryBaseC<T, Encoded, Evt, ItemType>,
|
|
235
234
|
id: T["id"],
|
|
236
235
|
mod: (item: T) => T
|
|
237
236
|
) {
|
|
@@ -248,11 +247,11 @@ export function itemUpdate<
|
|
|
248
247
|
*/
|
|
249
248
|
export function removeById<
|
|
250
249
|
T extends { id: unknown },
|
|
251
|
-
|
|
250
|
+
Encoded extends { id: string },
|
|
252
251
|
Evt,
|
|
253
252
|
ItemType extends string
|
|
254
253
|
>(
|
|
255
|
-
self: Repository<T,
|
|
254
|
+
self: Repository<T, Encoded, Evt, ItemType>,
|
|
256
255
|
id: T["id"]
|
|
257
256
|
) {
|
|
258
257
|
return get(self, id).pipe(Effect.flatMap((_) => self.removeAndPublish([_])))
|
|
@@ -1,12 +1,11 @@
|
|
|
1
1
|
import type { RepositoryBaseC } from "../RepositoryBase.js"
|
|
2
|
-
import type { PersistenceModelType } from "../Store.js"
|
|
3
2
|
|
|
4
3
|
/**
|
|
5
4
|
* @tsplus type Repository
|
|
6
5
|
*/
|
|
7
6
|
export interface Repository<
|
|
8
7
|
T extends { id: unknown },
|
|
9
|
-
|
|
8
|
+
Encoded extends { id: string },
|
|
10
9
|
Evt,
|
|
11
10
|
ItemType extends string
|
|
12
|
-
> extends RepositoryBaseC<T,
|
|
11
|
+
> extends RepositoryBaseC<T, Encoded, Evt, ItemType> {}
|