@furystack/rest-service 6.2.22 → 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/package.json +29 -12
- package/src/actions/error-action.spec.ts +1 -0
- package/src/actions/get-current-user.spec.ts +1 -0
- package/src/actions/get-current-user.ts +0 -1
- package/src/actions/is-authenticated.spec.ts +1 -0
- package/src/actions/is-authenticated.ts +0 -1
- package/src/actions/login-action.spec.ts +3 -2
- package/src/actions/logout-action.spec.ts +2 -1
- package/src/actions/logout.ts +0 -1
- package/src/actions/not-found-action.spec.ts +1 -0
- package/src/add-cors-header.spec.ts +7 -6
- package/src/authenticate.spec.ts +7 -6
- package/src/authorize.spec.ts +7 -6
- package/src/endpoint-generators/create-delete-endpoint.spec.ts +1 -0
- package/src/endpoint-generators/create-delete-endpoint.ts +0 -1
- package/src/endpoint-generators/create-get-collection-endpoint.spec.ts +1 -0
- package/src/endpoint-generators/create-get-collection-endpoint.ts +0 -1
- package/src/endpoint-generators/create-get-entity-endpoint.spec.ts +1 -0
- package/src/endpoint-generators/create-get-entity-endpoint.ts +0 -1
- package/src/endpoint-generators/create-patch-endpoint.spec.ts +1 -0
- package/src/endpoint-generators/create-patch-endpoint.ts +0 -1
- package/src/endpoint-generators/create-post-endpoint.spec.ts +1 -0
- package/src/endpoint-generators/create-post-endpoint.ts +0 -1
- package/src/helpers.spec.ts +1 -0
- package/src/helpers.ts +2 -6
- package/src/http-user-context.spec.ts +15 -14
- package/src/http-user-context.ts +0 -3
- package/src/incoming-message-extensions.spec.ts +1 -0
- package/src/mime-types.spec.ts +1 -0
- package/src/rest-service.integration.spec.ts +1 -0
- package/src/rest.integration.test.ts +1 -0
- package/src/schema-validator/schema-validator.test.ts +1 -0
- package/src/server-manager.ts +2 -2
- package/src/server-response-extensions.spec.ts +23 -18
- package/src/static-server-manager.spec.ts +2 -2
- package/src/utils.ts +0 -2
- package/src/validate.integration.spec.ts +1 -0
- package/types/actions/get-current-user.d.ts +0 -1
- package/types/actions/get-current-user.d.ts.map +1 -1
- package/types/actions/is-authenticated.d.ts +0 -1
- package/types/actions/is-authenticated.d.ts.map +1 -1
- package/types/actions/logout.d.ts +0 -1
- package/types/actions/logout.d.ts.map +1 -1
- package/types/endpoint-generators/create-delete-endpoint.d.ts +0 -1
- package/types/endpoint-generators/create-delete-endpoint.d.ts.map +1 -1
- package/types/endpoint-generators/create-get-collection-endpoint.d.ts +0 -1
- package/types/endpoint-generators/create-get-collection-endpoint.d.ts.map +1 -1
- package/types/endpoint-generators/create-get-entity-endpoint.d.ts +0 -1
- package/types/endpoint-generators/create-get-entity-endpoint.d.ts.map +1 -1
- package/types/endpoint-generators/create-patch-endpoint.d.ts +0 -1
- package/types/endpoint-generators/create-patch-endpoint.d.ts.map +1 -1
- package/types/endpoint-generators/create-post-endpoint.d.ts +0 -1
- package/types/endpoint-generators/create-post-endpoint.d.ts.map +1 -1
- package/types/helpers.d.ts +2 -4
- package/types/helpers.d.ts.map +1 -1
- package/types/http-user-context.d.ts +0 -3
- package/types/http-user-context.d.ts.map +1 -1
- package/types/server-manager.d.ts.map +1 -1
- package/types/utils.d.ts +0 -2
- package/types/utils.d.ts.map +1 -1
- package/dist/actions/error-action.js +0 -29
- package/dist/actions/error-action.js.map +0 -1
- package/dist/actions/error-action.spec.js +0 -48
- package/dist/actions/error-action.spec.js.map +0 -1
- package/dist/actions/get-current-user.js +0 -16
- package/dist/actions/get-current-user.js.map +0 -1
- package/dist/actions/get-current-user.spec.js +0 -20
- package/dist/actions/get-current-user.spec.js.map +0 -1
- package/dist/actions/index.js +0 -23
- package/dist/actions/index.js.map +0 -1
- package/dist/actions/is-authenticated.js +0 -18
- package/dist/actions/is-authenticated.js.map +0 -1
- package/dist/actions/is-authenticated.spec.js +0 -19
- package/dist/actions/is-authenticated.spec.js.map +0 -1
- package/dist/actions/login-action.spec.js +0 -35
- package/dist/actions/login-action.spec.js.map +0 -1
- package/dist/actions/login.js +0 -26
- package/dist/actions/login.js.map +0 -1
- package/dist/actions/logout-action.spec.js +0 -23
- package/dist/actions/logout-action.spec.js.map +0 -1
- package/dist/actions/logout.js +0 -20
- package/dist/actions/logout.js.map +0 -1
- package/dist/actions/not-found-action.js +0 -14
- package/dist/actions/not-found-action.js.map +0 -1
- package/dist/actions/not-found-action.spec.js +0 -17
- package/dist/actions/not-found-action.spec.js.map +0 -1
- package/dist/add-cors-header.spec.js +0 -99
- package/dist/add-cors-header.spec.js.map +0 -1
- package/dist/api-manager.js +0 -156
- package/dist/api-manager.js.map +0 -1
- package/dist/authenticate.js +0 -20
- package/dist/authenticate.js.map +0 -1
- package/dist/authenticate.spec.js +0 -59
- package/dist/authenticate.spec.js.map +0 -1
- package/dist/authorize.js +0 -23
- package/dist/authorize.js.map +0 -1
- package/dist/authorize.spec.js +0 -55
- package/dist/authorize.spec.js.map +0 -1
- package/dist/endpoint-generators/create-delete-endpoint.js +0 -25
- package/dist/endpoint-generators/create-delete-endpoint.js.map +0 -1
- package/dist/endpoint-generators/create-delete-endpoint.spec.js +0 -35
- package/dist/endpoint-generators/create-delete-endpoint.spec.js.map +0 -1
- package/dist/endpoint-generators/create-get-collection-endpoint.js +0 -27
- package/dist/endpoint-generators/create-get-collection-endpoint.js.map +0 -1
- package/dist/endpoint-generators/create-get-collection-endpoint.spec.js +0 -157
- package/dist/endpoint-generators/create-get-collection-endpoint.spec.js.map +0 -1
- package/dist/endpoint-generators/create-get-entity-endpoint.js +0 -30
- package/dist/endpoint-generators/create-get-entity-endpoint.js.map +0 -1
- package/dist/endpoint-generators/create-get-entity-endpoint.spec.js +0 -75
- package/dist/endpoint-generators/create-get-entity-endpoint.spec.js.map +0 -1
- package/dist/endpoint-generators/create-patch-endpoint.js +0 -27
- package/dist/endpoint-generators/create-patch-endpoint.js.map +0 -1
- package/dist/endpoint-generators/create-patch-endpoint.spec.js +0 -38
- package/dist/endpoint-generators/create-patch-endpoint.spec.js.map +0 -1
- package/dist/endpoint-generators/create-post-endpoint.js +0 -30
- package/dist/endpoint-generators/create-post-endpoint.js.map +0 -1
- package/dist/endpoint-generators/create-post-endpoint.spec.js +0 -36
- package/dist/endpoint-generators/create-post-endpoint.spec.js.map +0 -1
- package/dist/endpoint-generators/index.js +0 -22
- package/dist/endpoint-generators/index.js.map +0 -1
- package/dist/endpoint-generators/utils.js +0 -28
- package/dist/endpoint-generators/utils.js.map +0 -1
- package/dist/helpers.js +0 -39
- package/dist/helpers.js.map +0 -1
- package/dist/helpers.spec.js +0 -35
- package/dist/helpers.spec.js.map +0 -1
- package/dist/http-authentication-settings.js +0 -29
- package/dist/http-authentication-settings.js.map +0 -1
- package/dist/http-user-context.js +0 -174
- package/dist/http-user-context.js.map +0 -1
- package/dist/http-user-context.spec.js +0 -272
- package/dist/http-user-context.spec.js.map +0 -1
- package/dist/incoming-message-extensions.js +0 -16
- package/dist/incoming-message-extensions.js.map +0 -1
- package/dist/incoming-message-extensions.spec.js +0 -39
- package/dist/incoming-message-extensions.spec.js.map +0 -1
- package/dist/index.js +0 -35
- package/dist/index.js.map +0 -1
- package/dist/mime-types.js +0 -340
- package/dist/mime-types.js.map +0 -1
- package/dist/mime-types.spec.js +0 -15
- package/dist/mime-types.spec.js.map +0 -1
- package/dist/models/cors-options.js +0 -3
- package/dist/models/cors-options.js.map +0 -1
- package/dist/models/default-session.js +0 -10
- package/dist/models/default-session.js.map +0 -1
- package/dist/models/index.js +0 -19
- package/dist/models/index.js.map +0 -1
- package/dist/request-action-implementation.js +0 -42
- package/dist/request-action-implementation.js.map +0 -1
- package/dist/rest-service.integration.spec.js +0 -143
- package/dist/rest-service.integration.spec.js.map +0 -1
- package/dist/rest.integration.test.js +0 -156
- package/dist/rest.integration.test.js.map +0 -1
- package/dist/schema-validator/index.js +0 -19
- package/dist/schema-validator/index.js.map +0 -1
- package/dist/schema-validator/schema-validation-error.js +0 -15
- package/dist/schema-validator/schema-validation-error.js.map +0 -1
- package/dist/schema-validator/schema-validator.js +0 -38
- package/dist/schema-validator/schema-validator.js.map +0 -1
- package/dist/schema-validator/schema-validator.test.js +0 -62
- package/dist/schema-validator/schema-validator.test.js.map +0 -1
- package/dist/schema-validator/validate-examples.js +0 -29
- package/dist/schema-validator/validate-examples.js.map +0 -1
- package/dist/server-manager.js +0 -79
- package/dist/server-manager.js.map +0 -1
- package/dist/server-response-extensions.js +0 -17
- package/dist/server-response-extensions.js.map +0 -1
- package/dist/server-response-extensions.spec.js +0 -49
- package/dist/server-response-extensions.spec.js.map +0 -1
- package/dist/static-server-manager.js +0 -71
- package/dist/static-server-manager.js.map +0 -1
- package/dist/static-server-manager.spec.js +0 -218
- package/dist/static-server-manager.spec.js.map +0 -1
- package/dist/utils.js +0 -75
- package/dist/utils.js.map +0 -1
- package/dist/validate.integration.schema.js +0 -3
- package/dist/validate.integration.schema.js.map +0 -1
- package/dist/validate.integration.spec.js +0 -216
- package/dist/validate.integration.spec.js.map +0 -1
- package/dist/validate.integration.spec.schema.json +0 -903
- package/dist/validate.js +0 -47
- package/dist/validate.js.map +0 -1
- package/types/actions/error-action.spec.d.ts +0 -2
- package/types/actions/error-action.spec.d.ts.map +0 -1
- package/types/actions/get-current-user.spec.d.ts +0 -2
- package/types/actions/get-current-user.spec.d.ts.map +0 -1
- package/types/actions/is-authenticated.spec.d.ts +0 -2
- package/types/actions/is-authenticated.spec.d.ts.map +0 -1
- package/types/actions/login-action.spec.d.ts +0 -2
- package/types/actions/login-action.spec.d.ts.map +0 -1
- package/types/actions/logout-action.spec.d.ts +0 -2
- package/types/actions/logout-action.spec.d.ts.map +0 -1
- package/types/actions/not-found-action.spec.d.ts +0 -2
- package/types/actions/not-found-action.spec.d.ts.map +0 -1
- package/types/add-cors-header.spec.d.ts +0 -2
- package/types/add-cors-header.spec.d.ts.map +0 -1
- package/types/authenticate.spec.d.ts +0 -2
- package/types/authenticate.spec.d.ts.map +0 -1
- package/types/authorize.spec.d.ts +0 -2
- package/types/authorize.spec.d.ts.map +0 -1
- package/types/endpoint-generators/create-delete-endpoint.spec.d.ts +0 -2
- package/types/endpoint-generators/create-delete-endpoint.spec.d.ts.map +0 -1
- package/types/endpoint-generators/create-get-collection-endpoint.spec.d.ts +0 -2
- package/types/endpoint-generators/create-get-collection-endpoint.spec.d.ts.map +0 -1
- package/types/endpoint-generators/create-get-entity-endpoint.spec.d.ts +0 -2
- package/types/endpoint-generators/create-get-entity-endpoint.spec.d.ts.map +0 -1
- package/types/endpoint-generators/create-patch-endpoint.spec.d.ts +0 -2
- package/types/endpoint-generators/create-patch-endpoint.spec.d.ts.map +0 -1
- package/types/endpoint-generators/create-post-endpoint.spec.d.ts +0 -2
- package/types/endpoint-generators/create-post-endpoint.spec.d.ts.map +0 -1
- package/types/helpers.spec.d.ts +0 -2
- package/types/helpers.spec.d.ts.map +0 -1
- package/types/http-user-context.spec.d.ts +0 -3
- package/types/http-user-context.spec.d.ts.map +0 -1
- package/types/incoming-message-extensions.spec.d.ts +0 -2
- package/types/incoming-message-extensions.spec.d.ts.map +0 -1
- package/types/mime-types.spec.d.ts +0 -2
- package/types/mime-types.spec.d.ts.map +0 -1
- package/types/rest-service.integration.spec.d.ts +0 -2
- package/types/rest-service.integration.spec.d.ts.map +0 -1
- package/types/rest.integration.test.d.ts +0 -90
- package/types/rest.integration.test.d.ts.map +0 -1
- package/types/schema-validator/schema-validator.test.d.ts +0 -2
- package/types/schema-validator/schema-validator.test.d.ts.map +0 -1
- package/types/server-response-extensions.spec.d.ts +0 -2
- package/types/server-response-extensions.spec.d.ts.map +0 -1
- package/types/static-server-manager.spec.d.ts +0 -2
- package/types/static-server-manager.spec.d.ts.map +0 -1
- package/types/validate.integration.spec.d.ts +0 -2
- package/types/validate.integration.spec.d.ts.map +0 -1
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const utils_1 = require("@furystack/utils");
|
|
4
|
-
const inject_1 = require("@furystack/inject");
|
|
5
|
-
const create_delete_endpoint_1 = require("./create-delete-endpoint");
|
|
6
|
-
const utils_2 = require("./utils");
|
|
7
|
-
const helpers_1 = require("../helpers");
|
|
8
|
-
const repository_1 = require("@furystack/repository");
|
|
9
|
-
describe('createDeleteEndpoint', () => {
|
|
10
|
-
it('Should delete the entity and report the success', async () => {
|
|
11
|
-
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
12
|
-
(0, utils_2.setupContext)(i);
|
|
13
|
-
await (0, helpers_1.useRestService)({
|
|
14
|
-
injector: i,
|
|
15
|
-
root: '/api',
|
|
16
|
-
port: 1111,
|
|
17
|
-
api: {
|
|
18
|
-
DELETE: {
|
|
19
|
-
'/:id': (0, create_delete_endpoint_1.createDeleteEndpoint)({ model: utils_2.MockClass, primaryKey: 'id' }),
|
|
20
|
-
},
|
|
21
|
-
},
|
|
22
|
-
});
|
|
23
|
-
await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').add(i, { id: 'mock', value: 'mock' });
|
|
24
|
-
const countBeforeDelete = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').count(i);
|
|
25
|
-
expect(countBeforeDelete).toBe(1);
|
|
26
|
-
const response = await fetch('http://127.0.0.1:1111/api/mock', { method: 'DELETE' });
|
|
27
|
-
expect(response.status).toBe(204);
|
|
28
|
-
const txt = await response.text();
|
|
29
|
-
expect(txt).toBe('');
|
|
30
|
-
const countAfterDelete = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').count(i);
|
|
31
|
-
expect(countAfterDelete).toBe(0);
|
|
32
|
-
});
|
|
33
|
-
});
|
|
34
|
-
});
|
|
35
|
-
//# sourceMappingURL=create-delete-endpoint.spec.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"create-delete-endpoint.spec.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-delete-endpoint.spec.ts"],"names":[],"mappings":";;AAAA,4CAA6C;AAC7C,8CAA4C;AAE5C,qEAA+D;AAC/D,mCAAiD;AACjD,wCAA2C;AAC3C,sDAAqD;AAErD,QAAQ,CAAC,sBAAsB,EAAE,GAAG,EAAE;IACpC,EAAE,CAAC,iDAAiD,EAAE,KAAK,IAAI,EAAE;QAC/D,MAAM,IAAA,kBAAU,EAAC,IAAI,iBAAQ,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;YAC3C,IAAA,oBAAY,EAAC,CAAC,CAAC,CAAA;YACf,MAAM,IAAA,wBAAc,EAA0D;gBAC5E,QAAQ,EAAE,CAAC;gBACX,IAAI,EAAE,MAAM;gBACZ,IAAI,EAAE,IAAI;gBACV,GAAG,EAAE;oBACH,MAAM,EAAE;wBACN,MAAM,EAAE,IAAA,6CAAoB,EAAC,EAAE,KAAK,EAAE,iBAAS,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC;qBACrE;iBACF;aACF,CAAC,CAAA;YACF,MAAM,IAAA,0BAAa,EAAC,CAAC,EAAE,iBAAS,EAAE,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAA;YAE7E,MAAM,iBAAiB,GAAG,MAAM,IAAA,0BAAa,EAAC,CAAC,EAAE,iBAAS,EAAE,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;YAC1E,MAAM,CAAC,iBAAiB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;YAEjC,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,gCAAgC,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAA;YACpF,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;YACjC,MAAM,GAAG,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAA;YACjC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;YAEpB,MAAM,gBAAgB,GAAG,MAAM,IAAA,0BAAa,EAAC,CAAC,EAAE,iBAAS,EAAE,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;YACzE,MAAM,CAAC,gBAAgB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QAClC,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.createGetCollectionEndpoint = void 0;
|
|
4
|
-
require("@furystack/repository");
|
|
5
|
-
const request_action_implementation_1 = require("../request-action-implementation");
|
|
6
|
-
const repository_1 = require("@furystack/repository");
|
|
7
|
-
/**
|
|
8
|
-
* Creates a GetCollection endpoint for the given model. The model should have a Repository DataSet
|
|
9
|
-
*
|
|
10
|
-
* @param options The options for endpoint creation
|
|
11
|
-
* @param options.model The Model class
|
|
12
|
-
* @param options.primaryKey The field used as primary key on the model
|
|
13
|
-
* @returns The created endpoint
|
|
14
|
-
*/
|
|
15
|
-
const createGetCollectionEndpoint = (options) => {
|
|
16
|
-
const endpoint = async ({ injector, getQuery }) => {
|
|
17
|
-
const { findOptions } = getQuery();
|
|
18
|
-
const dataSet = (0, repository_1.getRepository)(injector).getDataSetFor(options.model, options.primaryKey);
|
|
19
|
-
const entriesPromise = dataSet.find(injector, findOptions || {});
|
|
20
|
-
const countPromise = dataSet.count(injector, findOptions?.filter);
|
|
21
|
-
const [entries, count] = await Promise.all([entriesPromise, countPromise]);
|
|
22
|
-
return (0, request_action_implementation_1.JsonResult)({ entries, count });
|
|
23
|
-
};
|
|
24
|
-
return endpoint;
|
|
25
|
-
};
|
|
26
|
-
exports.createGetCollectionEndpoint = createGetCollectionEndpoint;
|
|
27
|
-
//# sourceMappingURL=create-get-collection-endpoint.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"create-get-collection-endpoint.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-get-collection-endpoint.ts"],"names":[],"mappings":";;;AAEA,iCAA8B;AAE9B,oFAA6D;AAC7D,sDAAqD;AAErD;;;;;;;GAOG;AACI,MAAM,2BAA2B,GAAG,CAAiC,OAG3E,EAAE,EAAE;IACH,MAAM,QAAQ,GAA4C,KAAK,EAAE,EAAE,QAAQ,EAAE,QAAQ,EAAE,EAAE,EAAE;QACzF,MAAM,EAAE,WAAW,EAAE,GAAG,QAAQ,EAAE,CAAA;QAClC,MAAM,OAAO,GAAG,IAAA,0BAAa,EAAC,QAAQ,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,UAAU,CAAC,CAAA;QACxF,MAAM,cAAc,GAAG,OAAO,CAAC,IAAI,CAAM,QAAQ,EAAE,WAAW,IAAI,EAAE,CAAC,CAAA;QACrE,MAAM,YAAY,GAAG,OAAO,CAAC,KAAK,CAAC,QAAQ,EAAE,WAAW,EAAE,MAAM,CAAC,CAAA;QACjE,MAAM,CAAC,OAAO,EAAE,KAAK,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC,cAAc,EAAE,YAAY,CAAC,CAAC,CAAA;QAE1E,OAAO,IAAA,0CAAU,EAAC,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAA;IACvC,CAAC,CAAA;IACD,OAAO,QAAQ,CAAA;AACjB,CAAC,CAAA;AAdY,QAAA,2BAA2B,+BAcvC"}
|
|
@@ -1,157 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const utils_1 = require("@furystack/utils");
|
|
4
|
-
const inject_1 = require("@furystack/inject");
|
|
5
|
-
const utils_2 = require("./utils");
|
|
6
|
-
const create_get_collection_endpoint_1 = require("./create-get-collection-endpoint");
|
|
7
|
-
const rest_1 = require("@furystack/rest");
|
|
8
|
-
const repository_1 = require("@furystack/repository");
|
|
9
|
-
const helpers_1 = require("../helpers");
|
|
10
|
-
const addMockEntities = async (i) => await (0, repository_1.getRepository)(i)
|
|
11
|
-
.getDataSetFor(utils_2.MockClass, 'id')
|
|
12
|
-
.add(i, { id: 'mock1', value: '4' }, { id: 'mock2', value: '3' }, { id: 'mock3', value: '2' }, { id: 'mock4', value: '1' });
|
|
13
|
-
describe('createGetCollectionEndpoint', () => {
|
|
14
|
-
it('Should return the collection without filter / order', async () => {
|
|
15
|
-
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
16
|
-
(0, utils_2.setupContext)(i);
|
|
17
|
-
await (0, helpers_1.useRestService)({
|
|
18
|
-
injector: i,
|
|
19
|
-
root: '/api',
|
|
20
|
-
port: 1112,
|
|
21
|
-
api: {
|
|
22
|
-
GET: {
|
|
23
|
-
'/entities': (0, create_get_collection_endpoint_1.createGetCollectionEndpoint)({ model: utils_2.MockClass, primaryKey: 'id' }),
|
|
24
|
-
},
|
|
25
|
-
},
|
|
26
|
-
});
|
|
27
|
-
await addMockEntities(i);
|
|
28
|
-
const count = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').count(i);
|
|
29
|
-
const allEntities = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').find(i, {});
|
|
30
|
-
const response = await fetch('http://127.0.0.1:1112/api/entities', { method: 'GET' });
|
|
31
|
-
expect(response.ok).toBe(true);
|
|
32
|
-
const json = await response.json();
|
|
33
|
-
expect(response.status).toBe(200);
|
|
34
|
-
expect(json.count).toBe(count);
|
|
35
|
-
expect(json.entries).toEqual(allEntities);
|
|
36
|
-
});
|
|
37
|
-
});
|
|
38
|
-
it('Should return entities in order', async () => {
|
|
39
|
-
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
40
|
-
(0, utils_2.setupContext)(i);
|
|
41
|
-
await (0, helpers_1.useRestService)({
|
|
42
|
-
injector: i,
|
|
43
|
-
root: '/api',
|
|
44
|
-
port: 1113,
|
|
45
|
-
api: {
|
|
46
|
-
GET: {
|
|
47
|
-
'/entities': (0, create_get_collection_endpoint_1.createGetCollectionEndpoint)({ model: utils_2.MockClass, primaryKey: 'id' }),
|
|
48
|
-
},
|
|
49
|
-
},
|
|
50
|
-
});
|
|
51
|
-
await addMockEntities(i);
|
|
52
|
-
const findOptions = { order: { value: 'ASC' } };
|
|
53
|
-
const count = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').count(i, findOptions.filter);
|
|
54
|
-
const orderedEntities = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').find(i, findOptions);
|
|
55
|
-
const response = await fetch(`http://127.0.0.1:1113/api/entities?${(0, rest_1.serializeToQueryString)({ findOptions })}`, {
|
|
56
|
-
method: 'GET',
|
|
57
|
-
});
|
|
58
|
-
expect(response.ok).toBe(true);
|
|
59
|
-
const json = await response.json();
|
|
60
|
-
expect(response.status).toBe(200);
|
|
61
|
-
expect(json.count).toBe(count);
|
|
62
|
-
expect(json.entries).toEqual(orderedEntities);
|
|
63
|
-
});
|
|
64
|
-
});
|
|
65
|
-
it('Should return entities with filtering', async () => {
|
|
66
|
-
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
67
|
-
(0, utils_2.setupContext)(i);
|
|
68
|
-
await (0, helpers_1.useRestService)({
|
|
69
|
-
injector: i,
|
|
70
|
-
root: '/api',
|
|
71
|
-
port: 1113,
|
|
72
|
-
api: {
|
|
73
|
-
GET: {
|
|
74
|
-
'/entities': (0, create_get_collection_endpoint_1.createGetCollectionEndpoint)({ model: utils_2.MockClass, primaryKey: 'id' }),
|
|
75
|
-
},
|
|
76
|
-
},
|
|
77
|
-
});
|
|
78
|
-
await addMockEntities(i);
|
|
79
|
-
const findOptions = {
|
|
80
|
-
filter: { id: { $ne: 'mock2' } },
|
|
81
|
-
};
|
|
82
|
-
const count = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').count(i, findOptions.filter);
|
|
83
|
-
const filteredEntities = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').find(i, findOptions);
|
|
84
|
-
expect(filteredEntities).not.toContainEqual({ id: 'mock2', value: '3' });
|
|
85
|
-
const response = await fetch(`http://127.0.0.1:1113/api/entities?${(0, rest_1.serializeToQueryString)({ findOptions })}`, {
|
|
86
|
-
method: 'GET',
|
|
87
|
-
});
|
|
88
|
-
expect(response.ok).toBe(true);
|
|
89
|
-
const json = await response.json();
|
|
90
|
-
expect(response.status).toBe(200);
|
|
91
|
-
expect(json.count).toBe(count);
|
|
92
|
-
expect(json.entries).toEqual(filteredEntities);
|
|
93
|
-
});
|
|
94
|
-
});
|
|
95
|
-
it('Should return entities with selecting specific fields', async () => {
|
|
96
|
-
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
97
|
-
(0, utils_2.setupContext)(i);
|
|
98
|
-
await (0, helpers_1.useRestService)({
|
|
99
|
-
injector: i,
|
|
100
|
-
root: '/api',
|
|
101
|
-
port: 1113,
|
|
102
|
-
api: {
|
|
103
|
-
GET: {
|
|
104
|
-
'/entities': (0, create_get_collection_endpoint_1.createGetCollectionEndpoint)({ model: utils_2.MockClass, primaryKey: 'id' }),
|
|
105
|
-
},
|
|
106
|
-
},
|
|
107
|
-
});
|
|
108
|
-
await addMockEntities(i);
|
|
109
|
-
const findOptions = {
|
|
110
|
-
select: ['id'],
|
|
111
|
-
};
|
|
112
|
-
const count = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').count(i, findOptions.filter);
|
|
113
|
-
const selectedEntities = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').find(i, findOptions);
|
|
114
|
-
selectedEntities.forEach((e) => expect(e.value).toBeUndefined());
|
|
115
|
-
const response = await fetch(`http://127.0.0.1:1113/api/entities?${(0, rest_1.serializeToQueryString)({ findOptions })}`, {
|
|
116
|
-
method: 'GET',
|
|
117
|
-
});
|
|
118
|
-
expect(response.ok).toBe(true);
|
|
119
|
-
const json = await response.json();
|
|
120
|
-
expect(response.status).toBe(200);
|
|
121
|
-
expect(json.count).toBe(count);
|
|
122
|
-
expect(json.entries).toEqual(selectedEntities);
|
|
123
|
-
});
|
|
124
|
-
});
|
|
125
|
-
it('Should return entities with top/skip', async () => {
|
|
126
|
-
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
127
|
-
(0, utils_2.setupContext)(i);
|
|
128
|
-
await (0, helpers_1.useRestService)({
|
|
129
|
-
injector: i,
|
|
130
|
-
root: '/api',
|
|
131
|
-
port: 1113,
|
|
132
|
-
api: {
|
|
133
|
-
GET: {
|
|
134
|
-
'/entities': (0, create_get_collection_endpoint_1.createGetCollectionEndpoint)({ model: utils_2.MockClass, primaryKey: 'id' }),
|
|
135
|
-
},
|
|
136
|
-
},
|
|
137
|
-
});
|
|
138
|
-
await addMockEntities(i);
|
|
139
|
-
const findOptions = {
|
|
140
|
-
skip: 1,
|
|
141
|
-
top: 2,
|
|
142
|
-
};
|
|
143
|
-
const count = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').count(i, findOptions.filter);
|
|
144
|
-
const topSkipEntities = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').find(i, findOptions);
|
|
145
|
-
expect(topSkipEntities).not.toContainEqual({ id: 'mock1', value: '4' });
|
|
146
|
-
expect(topSkipEntities).not.toContainEqual({ id: 'mock4', value: '1' });
|
|
147
|
-
const response = await fetch(`http://127.0.0.1:1113/api/entities?${(0, rest_1.serializeToQueryString)({ findOptions })}`, {
|
|
148
|
-
method: 'GET',
|
|
149
|
-
});
|
|
150
|
-
expect(response.status).toBe(200);
|
|
151
|
-
const json = await response.json();
|
|
152
|
-
expect(json.count).toBe(count);
|
|
153
|
-
expect(json.entries).toEqual(topSkipEntities);
|
|
154
|
-
});
|
|
155
|
-
});
|
|
156
|
-
});
|
|
157
|
-
//# sourceMappingURL=create-get-collection-endpoint.spec.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"create-get-collection-endpoint.spec.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-get-collection-endpoint.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.createGetEntityEndpoint = void 0;
|
|
4
|
-
const rest_1 = require("@furystack/rest");
|
|
5
|
-
require("@furystack/repository");
|
|
6
|
-
const request_action_implementation_1 = require("../request-action-implementation");
|
|
7
|
-
const repository_1 = require("@furystack/repository");
|
|
8
|
-
/**
|
|
9
|
-
* Creates a simple Get Entity endpoint for a specified model.
|
|
10
|
-
*
|
|
11
|
-
* @param options The options for endpoint creation
|
|
12
|
-
* @param options.model The entity model, should have a Repository DataSet
|
|
13
|
-
* @param options.primaryKey The field name used as primary key on the model
|
|
14
|
-
* @returns The generated endpoint
|
|
15
|
-
*/
|
|
16
|
-
const createGetEntityEndpoint = (options) => {
|
|
17
|
-
const endpoint = async ({ injector, getUrlParams, getQuery }) => {
|
|
18
|
-
const { id } = getUrlParams();
|
|
19
|
-
const { select } = getQuery();
|
|
20
|
-
const dataSet = (0, repository_1.getRepository)(injector).getDataSetFor(options.model, options.primaryKey);
|
|
21
|
-
const entry = await dataSet.get(injector, id, select);
|
|
22
|
-
if (!entry) {
|
|
23
|
-
throw new rest_1.RequestError('Entity not found', 404);
|
|
24
|
-
}
|
|
25
|
-
return (0, request_action_implementation_1.JsonResult)(entry);
|
|
26
|
-
};
|
|
27
|
-
return endpoint;
|
|
28
|
-
};
|
|
29
|
-
exports.createGetEntityEndpoint = createGetEntityEndpoint;
|
|
30
|
-
//# sourceMappingURL=create-get-entity-endpoint.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"create-get-entity-endpoint.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-get-entity-endpoint.ts"],"names":[],"mappings":";;;AAEA,0CAA8C;AAC9C,iCAA8B;AAE9B,oFAA6D;AAC7D,sDAAqD;AAErD;;;;;;;GAOG;AACI,MAAM,uBAAuB,GAAG,CAAgD,OAGtF,EAAE,EAAE;IACH,MAAM,QAAQ,GAAqD,KAAK,EAAE,EAAE,QAAQ,EAAE,YAAY,EAAE,QAAQ,EAAE,EAAE,EAAE;QAChH,MAAM,EAAE,EAAE,EAAE,GAAG,YAAY,EAAE,CAAA;QAC7B,MAAM,EAAE,MAAM,EAAE,GAAG,QAAQ,EAAE,CAAA;QAC7B,MAAM,OAAO,GAAG,IAAA,0BAAa,EAAC,QAAQ,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,UAAU,CAAC,CAAA;QACxF,MAAM,KAAK,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,EAAE,EAAE,MAAM,CAAC,CAAA;QACrD,IAAI,CAAC,KAAK,EAAE;YACV,MAAM,IAAI,mBAAY,CAAC,kBAAkB,EAAE,GAAG,CAAC,CAAA;SAChD;QACD,OAAO,IAAA,0CAAU,EAAC,KAAK,CAAC,CAAA;IAC1B,CAAC,CAAA;IACD,OAAO,QAAQ,CAAA;AACjB,CAAC,CAAA;AAfY,QAAA,uBAAuB,2BAenC"}
|
|
@@ -1,75 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const utils_1 = require("@furystack/utils");
|
|
4
|
-
const inject_1 = require("@furystack/inject");
|
|
5
|
-
const rest_1 = require("@furystack/rest");
|
|
6
|
-
const utils_2 = require("./utils");
|
|
7
|
-
const create_get_entity_endpoint_1 = require("./create-get-entity-endpoint");
|
|
8
|
-
const repository_1 = require("@furystack/repository");
|
|
9
|
-
const helpers_1 = require("../helpers");
|
|
10
|
-
describe('createGetEntityEndpoint', () => {
|
|
11
|
-
it('Should return the entity', async () => {
|
|
12
|
-
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
13
|
-
(0, utils_2.setupContext)(i);
|
|
14
|
-
await (0, helpers_1.useRestService)({
|
|
15
|
-
injector: i,
|
|
16
|
-
root: '/api',
|
|
17
|
-
port: 1113,
|
|
18
|
-
api: {
|
|
19
|
-
GET: {
|
|
20
|
-
'/:id': (0, create_get_entity_endpoint_1.createGetEntityEndpoint)({ model: utils_2.MockClass, primaryKey: 'id' }),
|
|
21
|
-
},
|
|
22
|
-
},
|
|
23
|
-
});
|
|
24
|
-
const mockEntity = { id: 'mock', value: 'mock' };
|
|
25
|
-
await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').add(i, mockEntity);
|
|
26
|
-
const response = await fetch('http://127.0.0.1:1113/api/mock', { method: 'GET' });
|
|
27
|
-
expect(response.status).toBe(200);
|
|
28
|
-
const body = await response.json();
|
|
29
|
-
expect(body).toEqual(mockEntity);
|
|
30
|
-
});
|
|
31
|
-
});
|
|
32
|
-
it('Should return the entity with the selected fields', async () => {
|
|
33
|
-
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
34
|
-
(0, utils_2.setupContext)(i);
|
|
35
|
-
await (0, helpers_1.useRestService)({
|
|
36
|
-
injector: i,
|
|
37
|
-
root: '/api',
|
|
38
|
-
port: 1114,
|
|
39
|
-
api: {
|
|
40
|
-
GET: {
|
|
41
|
-
'/:id': (0, create_get_entity_endpoint_1.createGetEntityEndpoint)({ model: utils_2.MockClass, primaryKey: 'id' }),
|
|
42
|
-
},
|
|
43
|
-
},
|
|
44
|
-
});
|
|
45
|
-
const mockEntity = { id: 'mock', value: 'mock' };
|
|
46
|
-
await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').add(i, mockEntity);
|
|
47
|
-
const response = await fetch(`http://127.0.0.1:1114/api/mock?${(0, rest_1.serializeToQueryString)({ select: ['id'] })}`, {
|
|
48
|
-
method: 'GET',
|
|
49
|
-
});
|
|
50
|
-
expect(response.status).toBe(200);
|
|
51
|
-
const body = await response.json();
|
|
52
|
-
expect(body).toEqual({ id: mockEntity.id });
|
|
53
|
-
});
|
|
54
|
-
});
|
|
55
|
-
it('Should return 404 if no entity has been found', async () => {
|
|
56
|
-
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
57
|
-
(0, utils_2.setupContext)(i);
|
|
58
|
-
await (0, helpers_1.useRestService)({
|
|
59
|
-
injector: i,
|
|
60
|
-
root: '/api',
|
|
61
|
-
port: 1115,
|
|
62
|
-
api: {
|
|
63
|
-
GET: {
|
|
64
|
-
'/:id': (0, create_get_entity_endpoint_1.createGetEntityEndpoint)({ model: utils_2.MockClass, primaryKey: 'id' }),
|
|
65
|
-
},
|
|
66
|
-
},
|
|
67
|
-
});
|
|
68
|
-
const result = await fetch(`http://127.0.0.1:1115/api/mock`, { method: 'GET' });
|
|
69
|
-
expect(result.status).toBe(404);
|
|
70
|
-
const body = await result.json();
|
|
71
|
-
expect(body).toEqual({ message: 'Entity not found' });
|
|
72
|
-
});
|
|
73
|
-
});
|
|
74
|
-
});
|
|
75
|
-
//# sourceMappingURL=create-get-entity-endpoint.spec.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"create-get-entity-endpoint.spec.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-get-entity-endpoint.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.createPatchEndpoint = void 0;
|
|
4
|
-
require("@furystack/repository");
|
|
5
|
-
require("../incoming-message-extensions");
|
|
6
|
-
const request_action_implementation_1 = require("../request-action-implementation");
|
|
7
|
-
const repository_1 = require("@furystack/repository");
|
|
8
|
-
/**
|
|
9
|
-
* Creates a PATCH endpoint for updating entities
|
|
10
|
-
*
|
|
11
|
-
* @param options The options for endpoint creation
|
|
12
|
-
* @param options.model The Model class
|
|
13
|
-
* @param options.primaryKey The field name that is used as primary key on the model
|
|
14
|
-
* @returns a boolean that indicates the success
|
|
15
|
-
*/
|
|
16
|
-
const createPatchEndpoint = (options) => {
|
|
17
|
-
const endpoint = async ({ injector, request, getUrlParams, }) => {
|
|
18
|
-
const { id } = getUrlParams();
|
|
19
|
-
const patchData = await request.readPostBody();
|
|
20
|
-
const dataSet = (0, repository_1.getRepository)(injector).getDataSetFor(options.model, options.primaryKey);
|
|
21
|
-
await dataSet.update(injector, id, patchData);
|
|
22
|
-
return (0, request_action_implementation_1.JsonResult)({});
|
|
23
|
-
};
|
|
24
|
-
return endpoint;
|
|
25
|
-
};
|
|
26
|
-
exports.createPatchEndpoint = createPatchEndpoint;
|
|
27
|
-
//# sourceMappingURL=create-patch-endpoint.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"create-patch-endpoint.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-patch-endpoint.ts"],"names":[],"mappings":";;;AAEA,iCAA8B;AAC9B,0CAAuC;AAEvC,oFAA6D;AAC7D,sDAAqD;AAGrD;;;;;;;GAOG;AACI,MAAM,mBAAmB,GAAG,CAIjC,OAGD,EAAE,EAAE;IACH,MAAM,QAAQ,GAAgE,KAAK,EAAE,EACnF,QAAQ,EACR,OAAO,EACP,YAAY,GACb,EAAE,EAAE;QACH,MAAM,EAAE,EAAE,EAAE,GAAG,YAAY,EAAE,CAAA;QAC7B,MAAM,SAAS,GAAG,MAAM,OAAO,CAAC,YAAY,EAAK,CAAA;QACjD,MAAM,OAAO,GAAG,IAAA,0BAAa,EAAC,QAAQ,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,UAAU,CAAC,CAAA;QACxF,MAAM,OAAO,CAAC,MAAM,CAAC,QAAQ,EAAE,EAAE,EAAE,SAAS,CAAC,CAAA;QAC7C,OAAO,IAAA,0CAAU,EAAC,EAAE,CAAC,CAAA;IACvB,CAAC,CAAA;IACD,OAAO,QAAQ,CAAA;AACjB,CAAC,CAAA;AApBY,QAAA,mBAAmB,uBAoB/B"}
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const utils_1 = require("@furystack/utils");
|
|
4
|
-
const inject_1 = require("@furystack/inject");
|
|
5
|
-
const create_patch_endpoint_1 = require("./create-patch-endpoint");
|
|
6
|
-
const utils_2 = require("./utils");
|
|
7
|
-
const repository_1 = require("@furystack/repository");
|
|
8
|
-
const helpers_1 = require("../helpers");
|
|
9
|
-
describe('createPatchEndpoint', () => {
|
|
10
|
-
it('Should update the entity and report the success', async () => {
|
|
11
|
-
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
12
|
-
(0, utils_2.setupContext)(i);
|
|
13
|
-
await (0, helpers_1.useRestService)({
|
|
14
|
-
injector: i,
|
|
15
|
-
root: '/api',
|
|
16
|
-
port: 1116,
|
|
17
|
-
api: {
|
|
18
|
-
PATCH: {
|
|
19
|
-
'/:id': (0, create_patch_endpoint_1.createPatchEndpoint)({ model: utils_2.MockClass, primaryKey: 'id' }),
|
|
20
|
-
},
|
|
21
|
-
},
|
|
22
|
-
});
|
|
23
|
-
await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').add(i, { id: 'mock', value: 'mock' });
|
|
24
|
-
const countBeforeDelete = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').count(i);
|
|
25
|
-
expect(countBeforeDelete).toBe(1);
|
|
26
|
-
const response = await fetch('http://127.0.0.1:1116/api/mock', {
|
|
27
|
-
method: 'PATCH',
|
|
28
|
-
body: JSON.stringify({ value: 'updated' }),
|
|
29
|
-
});
|
|
30
|
-
expect(response.status).toBe(200);
|
|
31
|
-
const body = await response.json();
|
|
32
|
-
expect(body).toEqual({});
|
|
33
|
-
const updated = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').get(i, 'mock');
|
|
34
|
-
expect(updated?.value).toBe('updated');
|
|
35
|
-
});
|
|
36
|
-
});
|
|
37
|
-
});
|
|
38
|
-
//# sourceMappingURL=create-patch-endpoint.spec.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"create-patch-endpoint.spec.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-patch-endpoint.spec.ts"],"names":[],"mappings":";;AAAA,4CAA6C;AAC7C,8CAA4C;AAE5C,mEAA6D;AAC7D,mCAAiD;AACjD,sDAAqD;AACrD,wCAA2C;AAE3C,QAAQ,CAAC,qBAAqB,EAAE,GAAG,EAAE;IACnC,EAAE,CAAC,iDAAiD,EAAE,KAAK,IAAI,EAAE;QAC/D,MAAM,IAAA,kBAAU,EAAC,IAAI,iBAAQ,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;YAC3C,IAAA,oBAAY,EAAC,CAAC,CAAC,CAAA;YACf,MAAM,IAAA,wBAAc,EAAwD;gBAC1E,QAAQ,EAAE,CAAC;gBACX,IAAI,EAAE,MAAM;gBACZ,IAAI,EAAE,IAAI;gBACV,GAAG,EAAE;oBACH,KAAK,EAAE;wBACL,MAAM,EAAE,IAAA,2CAAmB,EAAC,EAAE,KAAK,EAAE,iBAAS,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC;qBACpE;iBACF;aACF,CAAC,CAAA;YACF,MAAM,IAAA,0BAAa,EAAC,CAAC,EAAE,iBAAS,EAAE,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAA;YAE7E,MAAM,iBAAiB,GAAG,MAAM,IAAA,0BAAa,EAAC,CAAC,EAAE,iBAAS,EAAE,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;YAC1E,MAAM,CAAC,iBAAiB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;YAEjC,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,gCAAgC,EAAE;gBAC7D,MAAM,EAAE,OAAO;gBACf,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;aAC3C,CAAC,CAAA;YACF,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;YACjC,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAA;YAClC,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAA;YACxB,MAAM,OAAO,GAAG,MAAM,IAAA,0BAAa,EAAC,CAAC,EAAE,iBAAS,EAAE,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,CAAA;YACtE,MAAM,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;QACxC,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.createPostEndpoint = void 0;
|
|
4
|
-
const rest_1 = require("@furystack/rest");
|
|
5
|
-
require("@furystack/repository");
|
|
6
|
-
require("../incoming-message-extensions");
|
|
7
|
-
const request_action_implementation_1 = require("../request-action-implementation");
|
|
8
|
-
const repository_1 = require("@furystack/repository");
|
|
9
|
-
/**
|
|
10
|
-
* Creates a POST endpoint for updating entities
|
|
11
|
-
*
|
|
12
|
-
* @param options The options for endpoint creation
|
|
13
|
-
* @param options.model The Model class
|
|
14
|
-
* @param options.primaryKey The field name used as primary key
|
|
15
|
-
* @returns a boolean that indicates the success
|
|
16
|
-
*/
|
|
17
|
-
const createPostEndpoint = (options) => {
|
|
18
|
-
const endpoint = async ({ injector, request }) => {
|
|
19
|
-
const dataSet = (0, repository_1.getRepository)(injector).getDataSetFor(options.model, options.primaryKey);
|
|
20
|
-
const entityToCreate = await request.readPostBody();
|
|
21
|
-
const { created } = await dataSet.add(injector, entityToCreate);
|
|
22
|
-
if (!created || !created.length) {
|
|
23
|
-
throw new rest_1.RequestError('Entity not found', 404);
|
|
24
|
-
}
|
|
25
|
-
return (0, request_action_implementation_1.JsonResult)(created[0], 201);
|
|
26
|
-
};
|
|
27
|
-
return endpoint;
|
|
28
|
-
};
|
|
29
|
-
exports.createPostEndpoint = createPostEndpoint;
|
|
30
|
-
//# sourceMappingURL=create-post-endpoint.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"create-post-endpoint.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-post-endpoint.ts"],"names":[],"mappings":";;;AAEA,0CAA8C;AAC9C,iCAA8B;AAC9B,0CAAuC;AAEvC,oFAA6D;AAE7D,sDAAqD;AACrD;;;;;;;GAOG;AACI,MAAM,kBAAkB,GAAG,CAIhC,OAGD,EAAE,EAAE;IACH,MAAM,QAAQ,GAA+D,KAAK,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,EAAE,EAAE;QAC3G,MAAM,OAAO,GAAG,IAAA,0BAAa,EAAC,QAAQ,CAAC,CAAC,aAAa,CACnD,OAAO,CAAC,KAAK,EACb,OAAO,CAAC,UAAU,CACnB,CAAA;QAED,MAAM,cAAc,GAAG,MAAM,OAAO,CAAC,YAAY,EAAiB,CAAA;QAClE,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,cAAc,CAAC,CAAA;QAC/D,IAAI,CAAC,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;YAC/B,MAAM,IAAI,mBAAY,CAAC,kBAAkB,EAAE,GAAG,CAAC,CAAA;SAChD;QACD,OAAO,IAAA,0CAAU,EAAC,OAAO,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAA;IACpC,CAAC,CAAA;IACD,OAAO,QAAQ,CAAA;AACjB,CAAC,CAAA;AAtBY,QAAA,kBAAkB,sBAsB9B"}
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const utils_1 = require("@furystack/utils");
|
|
4
|
-
const inject_1 = require("@furystack/inject");
|
|
5
|
-
const create_post_endpoint_1 = require("./create-post-endpoint");
|
|
6
|
-
const utils_2 = require("./utils");
|
|
7
|
-
const helpers_1 = require("../helpers");
|
|
8
|
-
const repository_1 = require("@furystack/repository");
|
|
9
|
-
describe('createPostEndpoint', () => {
|
|
10
|
-
it('Should create the entity and report the success', async () => {
|
|
11
|
-
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
12
|
-
(0, utils_2.setupContext)(i);
|
|
13
|
-
await (0, helpers_1.useRestService)({
|
|
14
|
-
injector: i,
|
|
15
|
-
root: '/api',
|
|
16
|
-
port: 1117,
|
|
17
|
-
api: {
|
|
18
|
-
POST: {
|
|
19
|
-
'/': (0, create_post_endpoint_1.createPostEndpoint)({ model: utils_2.MockClass, primaryKey: 'id' }),
|
|
20
|
-
},
|
|
21
|
-
},
|
|
22
|
-
});
|
|
23
|
-
const entityToPost = { id: 'mock', value: 'posted' };
|
|
24
|
-
const response = await fetch('http://127.0.0.1:1117/api', {
|
|
25
|
-
method: 'POST',
|
|
26
|
-
body: JSON.stringify(entityToPost),
|
|
27
|
-
});
|
|
28
|
-
expect(response.status).toBe(201);
|
|
29
|
-
const body = await response.json();
|
|
30
|
-
expect(body).toEqual(entityToPost);
|
|
31
|
-
const posted = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').get(i, entityToPost.id);
|
|
32
|
-
expect(posted?.value).toBe('posted');
|
|
33
|
-
});
|
|
34
|
-
});
|
|
35
|
-
});
|
|
36
|
-
//# sourceMappingURL=create-post-endpoint.spec.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"create-post-endpoint.spec.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-post-endpoint.spec.ts"],"names":[],"mappings":";;AAAA,4CAA6C;AAC7C,8CAA4C;AAE5C,iEAA2D;AAC3D,mCAAiD;AACjD,wCAA2C;AAC3C,sDAAqD;AAErD,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;IAClC,EAAE,CAAC,iDAAiD,EAAE,KAAK,IAAI,EAAE;QAC/D,MAAM,IAAA,kBAAU,EAAC,IAAI,iBAAQ,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;YAC3C,IAAA,oBAAY,EAAC,CAAC,CAAC,CAAA;YACf,MAAM,IAAA,wBAAc,EAAmD;gBACrE,QAAQ,EAAE,CAAC;gBACX,IAAI,EAAE,MAAM;gBACZ,IAAI,EAAE,IAAI;gBACV,GAAG,EAAE;oBACH,IAAI,EAAE;wBACJ,GAAG,EAAE,IAAA,yCAAkB,EAAC,EAAE,KAAK,EAAE,iBAAS,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC;qBAChE;iBACF;aACF,CAAC,CAAA;YACF,MAAM,YAAY,GAAG,EAAE,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAA;YACpD,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,2BAA2B,EAAE;gBACxD,MAAM,EAAE,MAAM;gBACd,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC;aACnC,CAAC,CAAA;YACF,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;YACjC,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,IAAI,EAAE,CAAA;YAClC,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,CAAA;YAClC,MAAM,MAAM,GAAG,MAAM,IAAA,0BAAa,EAAC,CAAC,EAAE,iBAAS,EAAE,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,YAAY,CAAC,EAAE,CAAC,CAAA;YAC9E,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;QACtC,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
-
};
|
|
16
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
__exportStar(require("./create-delete-endpoint"), exports);
|
|
18
|
-
__exportStar(require("./create-get-collection-endpoint"), exports);
|
|
19
|
-
__exportStar(require("./create-get-entity-endpoint"), exports);
|
|
20
|
-
__exportStar(require("./create-patch-endpoint"), exports);
|
|
21
|
-
__exportStar(require("./create-post-endpoint"), exports);
|
|
22
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/endpoint-generators/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2DAAwC;AACxC,mEAAgD;AAChD,+DAA4C;AAC5C,0DAAuC;AACvC,yDAAsC"}
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.setupContext = exports.MockClass = void 0;
|
|
4
|
-
const core_1 = require("@furystack/core");
|
|
5
|
-
const default_session_1 = require("../models/default-session");
|
|
6
|
-
require("@furystack/repository");
|
|
7
|
-
require("../helpers");
|
|
8
|
-
const repository_1 = require("@furystack/repository");
|
|
9
|
-
class MockClass {
|
|
10
|
-
}
|
|
11
|
-
exports.MockClass = MockClass;
|
|
12
|
-
const setupContext = (i) => {
|
|
13
|
-
(0, core_1.addStore)(i, new core_1.InMemoryStore({
|
|
14
|
-
model: MockClass,
|
|
15
|
-
primaryKey: 'id',
|
|
16
|
-
}))
|
|
17
|
-
.addStore(new core_1.InMemoryStore({
|
|
18
|
-
model: core_1.User,
|
|
19
|
-
primaryKey: 'username',
|
|
20
|
-
}))
|
|
21
|
-
.addStore(new core_1.InMemoryStore({
|
|
22
|
-
model: default_session_1.DefaultSession,
|
|
23
|
-
primaryKey: 'sessionId',
|
|
24
|
-
}));
|
|
25
|
-
(0, repository_1.getRepository)(i).createDataSet(MockClass, 'id');
|
|
26
|
-
};
|
|
27
|
-
exports.setupContext = setupContext;
|
|
28
|
-
//# sourceMappingURL=utils.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/endpoint-generators/utils.ts"],"names":[],"mappings":";;;AACA,0CAA+D;AAC/D,+DAA0D;AAC1D,iCAA8B;AAC9B,sBAAmB;AACnB,sDAAqD;AAErD,MAAa,SAAS;CAGrB;AAHD,8BAGC;AAEM,MAAM,YAAY,GAAG,CAAC,CAAW,EAAE,EAAE;IAC1C,IAAA,eAAQ,EACN,CAAC,EACD,IAAI,oBAAa,CAAC;QAChB,KAAK,EAAE,SAAS;QAChB,UAAU,EAAE,IAAI;KACjB,CAAC,CACH;SACE,QAAQ,CACP,IAAI,oBAAa,CAAC;QAChB,KAAK,EAAE,WAAI;QACX,UAAU,EAAE,UAAU;KACvB,CAAC,CACH;SACA,QAAQ,CACP,IAAI,oBAAa,CAAC;QAChB,KAAK,EAAE,gCAAc;QACrB,UAAU,EAAE,WAAW;KACxB,CAAC,CACH,CAAA;IACH,IAAA,0BAAa,EAAC,CAAC,CAAC,CAAC,aAAa,CAAC,SAAS,EAAE,IAAI,CAAC,CAAA;AACjD,CAAC,CAAA;AArBY,QAAA,YAAY,gBAqBxB"}
|
package/dist/helpers.js
DELETED
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.useStaticFiles = exports.useHttpAuthentication = exports.useRestService = void 0;
|
|
4
|
-
const http_authentication_settings_1 = require("./http-authentication-settings");
|
|
5
|
-
const api_manager_1 = require("./api-manager");
|
|
6
|
-
const static_server_manager_1 = require("./static-server-manager");
|
|
7
|
-
/**
|
|
8
|
-
* Sets up the @furystack/rest-service with the provided settings
|
|
9
|
-
*
|
|
10
|
-
* @param api The API implementation details
|
|
11
|
-
*/
|
|
12
|
-
const useRestService = async (api) => {
|
|
13
|
-
await api.injector.getInstance(api_manager_1.ApiManager).addApi({ ...api });
|
|
14
|
-
return this;
|
|
15
|
-
};
|
|
16
|
-
exports.useRestService = useRestService;
|
|
17
|
-
/**
|
|
18
|
-
* Sets up the HTTP Authentication
|
|
19
|
-
*
|
|
20
|
-
* @param injector The Injector instance
|
|
21
|
-
* @param settings Settings for HTTP Authentication
|
|
22
|
-
* @returns void
|
|
23
|
-
*/
|
|
24
|
-
const useHttpAuthentication = (injector, settings) => injector.setExplicitInstance({ ...new http_authentication_settings_1.HttpAuthenticationSettings(), ...settings }, http_authentication_settings_1.HttpAuthenticationSettings);
|
|
25
|
-
exports.useHttpAuthentication = useHttpAuthentication;
|
|
26
|
-
/**
|
|
27
|
-
* Sets up a static file server
|
|
28
|
-
*
|
|
29
|
-
* @param options The settings for the static file server
|
|
30
|
-
* @param options.injector The Injector instance
|
|
31
|
-
* @param options.settings Settings for the static file server
|
|
32
|
-
* @returns a promise that resolves when the server is ready
|
|
33
|
-
*/
|
|
34
|
-
const useStaticFiles = (options) => {
|
|
35
|
-
const { injector, ...settings } = options;
|
|
36
|
-
return injector.getInstance(static_server_manager_1.StaticServerManager).addStaticSite(settings);
|
|
37
|
-
};
|
|
38
|
-
exports.useStaticFiles = useStaticFiles;
|
|
39
|
-
//# sourceMappingURL=helpers.js.map
|
package/dist/helpers.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"helpers.js","sourceRoot":"","sources":["../src/helpers.ts"],"names":[],"mappings":";;;AAEA,iFAA2E;AAG3E,+CAA0C;AAG1C,mEAA6D;AAE7D;;;;GAIG;AACI,MAAM,cAAc,GAAG,KAAK,EAAqB,GAA2B,EAAE,EAAE;IACrF,MAAM,GAAG,CAAC,QAAQ,CAAC,WAAW,CAAC,wBAAU,CAAC,CAAC,MAAM,CAAC,EAAE,GAAG,GAAG,EAAE,CAAC,CAAA;IAC7D,OAAO,IAAI,CAAA;AACb,CAAC,CAAA;AAHY,QAAA,cAAc,kBAG1B;AAED;;;;;;GAMG;AACI,MAAM,qBAAqB,GAAG,CACnC,QAAkB,EAClB,QAA+D,EAC/D,EAAE,CAAC,QAAQ,CAAC,mBAAmB,CAAC,EAAE,GAAG,IAAI,yDAA0B,EAAE,EAAE,GAAG,QAAQ,EAAE,EAAE,yDAA0B,CAAC,CAAA;AAHtG,QAAA,qBAAqB,yBAGiF;AAEnH;;;;;;;GAOG;AACI,MAAM,cAAc,GAAG,CAAC,OAAqD,EAAE,EAAE;IACtF,MAAM,EAAE,QAAQ,EAAE,GAAG,QAAQ,EAAE,GAAG,OAAO,CAAA;IACzC,OAAO,QAAQ,CAAC,WAAW,CAAC,2CAAmB,CAAC,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAA;AAC1E,CAAC,CAAA;AAHY,QAAA,cAAc,kBAG1B"}
|