@dereekb/firebase-server 9.12.4 → 9.13.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 +9 -0
- package/mailgun/package.json +9 -9
- package/package.json +7 -7
- package/src/lib/nest/model/crud.assert.function.d.ts +1 -1
- package/src/lib/nest/model/index.d.ts +1 -0
- package/src/lib/nest/model/index.js +1 -0
- package/src/lib/nest/model/index.js.map +1 -1
- package/src/lib/nest/model/read.model.function.d.ts +20 -0
- package/src/lib/nest/model/read.model.function.js +40 -0
- package/src/lib/nest/model/read.model.function.js.map +1 -0
- package/test/package.json +10 -10
package/CHANGELOG.md
CHANGED
|
@@ -2,6 +2,15 @@
|
|
|
2
2
|
|
|
3
3
|
This file was generated using [@jscutlery/semver](https://github.com/jscutlery/semver).
|
|
4
4
|
|
|
5
|
+
# [9.13.0](https://github.com/dereekb/dbx-components/compare/v9.12.4-dev...v9.13.0) (2022-11-08)
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
### Features
|
|
9
|
+
|
|
10
|
+
* added OnCallReadModelFunction ([4c0eeb9](https://github.com/dereekb/dbx-components/commit/4c0eeb938ba409d66ec5d049ef01802084c1a459))
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
|
|
5
14
|
## [9.12.4](https://github.com/dereekb/dbx-components/compare/v9.12.3-dev...v9.12.4) (2022-11-08)
|
|
6
15
|
|
|
7
16
|
|
package/mailgun/package.json
CHANGED
|
@@ -1,33 +1,33 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@dereekb/firebase-server/mailgun",
|
|
3
|
-
"version": "9.
|
|
3
|
+
"version": "9.13.0",
|
|
4
4
|
"type": "commonjs",
|
|
5
5
|
"main": "./src/index.js",
|
|
6
6
|
"typings": "./src/index.d.ts",
|
|
7
7
|
"dependencies": {},
|
|
8
8
|
"peerDependencies": {
|
|
9
|
-
"@dereekb/nestjs/mailgun": "9.
|
|
9
|
+
"@dereekb/nestjs/mailgun": "9.13.0",
|
|
10
10
|
"@nestjs/common": "^9.0.0",
|
|
11
11
|
"mailgun.js": "^8.0.0",
|
|
12
12
|
"form-data": "4.0.0",
|
|
13
|
-
"@dereekb/util": "9.
|
|
13
|
+
"@dereekb/util": "9.13.0",
|
|
14
14
|
"lodash.isequal": "^4.5.0",
|
|
15
15
|
"make-error": "^1.3.0",
|
|
16
16
|
"class-validator": "^0.13.2",
|
|
17
17
|
"ts-essentials": "^9.1.2",
|
|
18
18
|
"extra-set": "^2.2.11",
|
|
19
|
-
"@dereekb/nestjs": "9.
|
|
19
|
+
"@dereekb/nestjs": "9.13.0",
|
|
20
20
|
"@nestjs/config": "^2.0.1",
|
|
21
|
-
"@dereekb/firebase-server": "9.
|
|
21
|
+
"@dereekb/firebase-server": "9.13.0",
|
|
22
22
|
"jsonwebtoken": "^8.0.0",
|
|
23
|
-
"@dereekb/firebase": "9.
|
|
23
|
+
"@dereekb/firebase": "9.13.0",
|
|
24
24
|
"rxjs": "^7.5.0",
|
|
25
25
|
"firebase": "^9.9.2",
|
|
26
26
|
"class-transformer": "^0.5.1",
|
|
27
|
-
"@dereekb/rxjs": "9.
|
|
27
|
+
"@dereekb/rxjs": "9.13.0",
|
|
28
28
|
"ms": "^3.0.0-canary.1",
|
|
29
|
-
"@dereekb/model": "9.
|
|
30
|
-
"@dereekb/date": "9.
|
|
29
|
+
"@dereekb/model": "9.13.0",
|
|
30
|
+
"@dereekb/date": "9.13.0",
|
|
31
31
|
"date-fns": "^2.29.0",
|
|
32
32
|
"date-fns-tz": "^1.3.0",
|
|
33
33
|
"rrule": "git+https://git@github.com/dereekb/rrule#2b13b1ea881059ba2ecfec380e12ef244ef54570",
|
package/package.json
CHANGED
|
@@ -1,25 +1,25 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@dereekb/firebase-server",
|
|
3
|
-
"version": "9.
|
|
3
|
+
"version": "9.13.0",
|
|
4
4
|
"devDependencies": {
|
|
5
5
|
"firebase-functions-test": "2.0.2"
|
|
6
6
|
},
|
|
7
7
|
"peerDependencies": {
|
|
8
8
|
"jsonwebtoken": "^8.0.0",
|
|
9
|
-
"@dereekb/firebase": "9.
|
|
9
|
+
"@dereekb/firebase": "9.13.0",
|
|
10
10
|
"rxjs": "^7.5.0",
|
|
11
11
|
"firebase": "^9.9.2",
|
|
12
|
-
"@dereekb/util": "9.
|
|
12
|
+
"@dereekb/util": "9.13.0",
|
|
13
13
|
"lodash.isequal": "^4.5.0",
|
|
14
14
|
"make-error": "^1.3.0",
|
|
15
15
|
"class-validator": "^0.13.2",
|
|
16
16
|
"ts-essentials": "^9.1.2",
|
|
17
17
|
"extra-set": "^2.2.11",
|
|
18
18
|
"class-transformer": "^0.5.1",
|
|
19
|
-
"@dereekb/rxjs": "9.
|
|
19
|
+
"@dereekb/rxjs": "9.13.0",
|
|
20
20
|
"ms": "^3.0.0-canary.1",
|
|
21
|
-
"@dereekb/model": "9.
|
|
22
|
-
"@dereekb/date": "9.
|
|
21
|
+
"@dereekb/model": "9.13.0",
|
|
22
|
+
"@dereekb/date": "9.13.0",
|
|
23
23
|
"date-fns": "^2.29.0",
|
|
24
24
|
"date-fns-tz": "^1.3.0",
|
|
25
25
|
"rrule": "git+https://git@github.com/dereekb/rrule#2b13b1ea881059ba2ecfec380e12ef244ef54570",
|
|
@@ -30,7 +30,7 @@
|
|
|
30
30
|
"@nestjs/common": "^9.0.0",
|
|
31
31
|
"@nestjs/core": "^9.0.0",
|
|
32
32
|
"@nestjs/platform-express": "^9.0.0",
|
|
33
|
-
"@dereekb/nestjs": "9.
|
|
33
|
+
"@dereekb/nestjs": "9.13.0",
|
|
34
34
|
"@nestjs/config": "^2.0.1",
|
|
35
35
|
"tslib": "^2.0.0"
|
|
36
36
|
},
|
|
@@ -2,7 +2,7 @@ import { Maybe } from '@dereekb/util';
|
|
|
2
2
|
import { NestContextCallableRequestWithAuth } from '../function/nest';
|
|
3
3
|
export interface AssertModelCrudRequestFunctionContext<N, I = unknown> {
|
|
4
4
|
request: NestContextCallableRequestWithAuth<N, I>;
|
|
5
|
-
crud: 'create' | 'update' | 'delete';
|
|
5
|
+
crud: 'create' | 'read' | 'update' | 'delete';
|
|
6
6
|
modelType: string;
|
|
7
7
|
specifier: Maybe<string>;
|
|
8
8
|
}
|
|
@@ -4,6 +4,7 @@ const tslib_1 = require("tslib");
|
|
|
4
4
|
tslib_1.__exportStar(require("./permission.error"), exports);
|
|
5
5
|
tslib_1.__exportStar(require("./specifier.function"), exports);
|
|
6
6
|
tslib_1.__exportStar(require("./create.model.function"), exports);
|
|
7
|
+
tslib_1.__exportStar(require("./read.model.function"), exports);
|
|
7
8
|
tslib_1.__exportStar(require("./update.model.function"), exports);
|
|
8
9
|
tslib_1.__exportStar(require("./delete.model.function"), exports);
|
|
9
10
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../packages/firebase-server/src/lib/nest/model/index.ts"],"names":[],"mappings":";;;AAAA,6DAAmC;AACnC,+DAAqC;AACrC,kEAAwC;AACxC,kEAAwC;AACxC,kEAAwC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../packages/firebase-server/src/lib/nest/model/index.ts"],"names":[],"mappings":";;;AAAA,6DAAmC;AACnC,+DAAqC;AACrC,kEAAwC;AACxC,gEAAsC;AACtC,kEAAwC;AACxC,kEAAwC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { PromiseOrValue } from '@dereekb/util';
|
|
2
|
+
import { FirestoreModelType, FirestoreModelIdentity, FirestoreModelTypes, OnCallReadModelParams, ModelFirebaseCrudFunctionSpecifierRef } from '@dereekb/firebase';
|
|
3
|
+
import { OnCallWithAuthorizedNestContext } from '../function/call';
|
|
4
|
+
import { NestContextCallableRequestWithAuth } from '../function/nest';
|
|
5
|
+
import { AssertModelCrudRequestFunction } from './crud.assert.function';
|
|
6
|
+
export declare type OnCallReadModelFunction<N, I = unknown, O = unknown> = (request: NestContextCallableRequestWithAuth<N, I> & ModelFirebaseCrudFunctionSpecifierRef) => PromiseOrValue<O>;
|
|
7
|
+
export declare type OnCallReadModelMap<N, T extends FirestoreModelIdentity = FirestoreModelIdentity> = {
|
|
8
|
+
[K in FirestoreModelTypes<T>]?: OnCallReadModelFunction<N, any, any>;
|
|
9
|
+
};
|
|
10
|
+
export interface OnCallReadModelConfig<N> {
|
|
11
|
+
preAssert?: AssertModelCrudRequestFunction<N, OnCallReadModelParams>;
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* Creates a OnCallWithAuthorizedNestContext function for updating model params.
|
|
15
|
+
*
|
|
16
|
+
* @param map
|
|
17
|
+
* @returns
|
|
18
|
+
*/
|
|
19
|
+
export declare function onCallReadModel<N>(map: OnCallReadModelMap<N>, config?: OnCallReadModelConfig<N>): OnCallWithAuthorizedNestContext<N, OnCallReadModelParams, unknown>;
|
|
20
|
+
export declare function readModelUnknownModelTypeError(modelType: FirestoreModelType): import("firebase-functions/v1/auth").HttpsError;
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.readModelUnknownModelTypeError = exports.onCallReadModel = void 0;
|
|
4
|
+
const util_1 = require("@dereekb/util");
|
|
5
|
+
const function_1 = require("../../function");
|
|
6
|
+
/**
|
|
7
|
+
* Creates a OnCallWithAuthorizedNestContext function for updating model params.
|
|
8
|
+
*
|
|
9
|
+
* @param map
|
|
10
|
+
* @returns
|
|
11
|
+
*/
|
|
12
|
+
function onCallReadModel(map, config = {}) {
|
|
13
|
+
const { preAssert = () => undefined } = config;
|
|
14
|
+
return (request) => {
|
|
15
|
+
var _a;
|
|
16
|
+
const modelType = (_a = request.data) === null || _a === void 0 ? void 0 : _a.modelType;
|
|
17
|
+
const readFn = map[modelType];
|
|
18
|
+
if (readFn) {
|
|
19
|
+
const specifier = request.data.specifier;
|
|
20
|
+
preAssert({ crud: 'read', request, modelType, specifier });
|
|
21
|
+
return readFn(Object.assign(Object.assign({}, request), { specifier, data: request.data.data }));
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
throw readModelUnknownModelTypeError(modelType);
|
|
25
|
+
}
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
exports.onCallReadModel = onCallReadModel;
|
|
29
|
+
function readModelUnknownModelTypeError(modelType) {
|
|
30
|
+
return (0, function_1.badRequestError)((0, util_1.serverError)({
|
|
31
|
+
status: 400,
|
|
32
|
+
code: 'UNKNOWN_TYPE_ERROR',
|
|
33
|
+
message: 'Invalid type to read.',
|
|
34
|
+
data: {
|
|
35
|
+
modelType
|
|
36
|
+
}
|
|
37
|
+
}));
|
|
38
|
+
}
|
|
39
|
+
exports.readModelUnknownModelTypeError = readModelUnknownModelTypeError;
|
|
40
|
+
//# sourceMappingURL=read.model.function.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"read.model.function.js","sourceRoot":"","sources":["../../../../../../../packages/firebase-server/src/lib/nest/model/read.model.function.ts"],"names":[],"mappings":";;;AAAA,wCAA4D;AAE5D,6CAAiD;AAgBjD;;;;;GAKG;AACH,SAAgB,eAAe,CAAI,GAA0B,EAAE,SAAmC,EAAE;IAClG,MAAM,EAAE,SAAS,GAAG,GAAG,EAAE,CAAC,SAAS,EAAE,GAAG,MAAM,CAAC;IAE/C,OAAO,CAAC,OAAO,EAAE,EAAE;;QACjB,MAAM,SAAS,GAAG,MAAA,OAAO,CAAC,IAAI,0CAAE,SAAS,CAAC;QAC1C,MAAM,MAAM,GAAG,GAAG,CAAC,SAAS,CAAC,CAAC;QAE9B,IAAI,MAAM,EAAE;YACV,MAAM,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC;YACzC,SAAS,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,CAAC,CAAC;YAC3D,OAAO,MAAM,iCACR,OAAO,KACV,SAAS,EACT,IAAI,EAAE,OAAO,CAAC,IAAI,CAAC,IAAI,IACvB,CAAC;SACJ;aAAM;YACL,MAAM,8BAA8B,CAAC,SAAS,CAAC,CAAC;SACjD;IACH,CAAC,CAAC;AACJ,CAAC;AAnBD,0CAmBC;AAED,SAAgB,8BAA8B,CAAC,SAA6B;IAC1E,OAAO,IAAA,0BAAe,EACpB,IAAA,kBAAW,EAAC;QACV,MAAM,EAAE,GAAG;QACX,IAAI,EAAE,oBAAoB;QAC1B,OAAO,EAAE,uBAAuB;QAChC,IAAI,EAAE;YACJ,SAAS;SACV;KACF,CAAC,CACH,CAAC;AACJ,CAAC;AAXD,wEAWC"}
|
package/test/package.json
CHANGED
|
@@ -1,40 +1,40 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@dereekb/firebase-server/test",
|
|
3
|
-
"version": "9.
|
|
3
|
+
"version": "9.13.0",
|
|
4
4
|
"type": "commonjs",
|
|
5
5
|
"main": "./src/index.js",
|
|
6
6
|
"typings": "./src/index.d.ts",
|
|
7
7
|
"dependencies": {},
|
|
8
8
|
"peerDependencies": {
|
|
9
|
-
"@dereekb/firebase": "9.
|
|
9
|
+
"@dereekb/firebase": "9.13.0",
|
|
10
10
|
"rxjs": "^7.5.0",
|
|
11
11
|
"firebase": "^9.9.2",
|
|
12
|
-
"@dereekb/util": "9.
|
|
12
|
+
"@dereekb/util": "9.13.0",
|
|
13
13
|
"lodash.isequal": "^4.5.0",
|
|
14
14
|
"make-error": "^1.3.0",
|
|
15
15
|
"class-validator": "^0.13.2",
|
|
16
16
|
"ts-essentials": "^9.1.2",
|
|
17
17
|
"extra-set": "^2.2.11",
|
|
18
18
|
"class-transformer": "^0.5.1",
|
|
19
|
-
"@dereekb/rxjs": "9.
|
|
19
|
+
"@dereekb/rxjs": "9.13.0",
|
|
20
20
|
"ms": "^3.0.0-canary.1",
|
|
21
|
-
"@dereekb/model": "9.
|
|
22
|
-
"@dereekb/date": "9.
|
|
21
|
+
"@dereekb/model": "9.13.0",
|
|
22
|
+
"@dereekb/date": "9.13.0",
|
|
23
23
|
"date-fns": "^2.29.0",
|
|
24
24
|
"date-fns-tz": "^1.3.0",
|
|
25
25
|
"rrule": "git+https://git@github.com/dereekb/rrule#2b13b1ea881059ba2ecfec380e12ef244ef54570",
|
|
26
26
|
"@vvo/tzdb": "^6.0.0",
|
|
27
|
-
"@dereekb/util/test": "9.
|
|
27
|
+
"@dereekb/util/test": "9.13.0",
|
|
28
28
|
"firebase-admin": "^11.1.0",
|
|
29
29
|
"jsonwebtoken": "^8.0.0",
|
|
30
30
|
"firebase-functions": "^3.24.0",
|
|
31
31
|
"@nestjs/common": "^9.0.0",
|
|
32
32
|
"@google-cloud/firestore": "^6.3.0",
|
|
33
|
-
"@dereekb/firebase/test": "9.
|
|
34
|
-
"@dereekb/firebase-server": "9.
|
|
33
|
+
"@dereekb/firebase/test": "9.13.0",
|
|
34
|
+
"@dereekb/firebase-server": "9.13.0",
|
|
35
35
|
"@nestjs/core": "^9.0.0",
|
|
36
36
|
"@nestjs/platform-express": "^9.0.0",
|
|
37
|
-
"@dereekb/nestjs": "9.
|
|
37
|
+
"@dereekb/nestjs": "9.13.0",
|
|
38
38
|
"@nestjs/config": "^2.0.1",
|
|
39
39
|
"tslib": "^2.0.0"
|
|
40
40
|
}
|