@furystack/rest-service 4.0.19
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/LICENSE +339 -0
- package/README.md +219 -0
- package/dist/actions/error-action.d.ts +14 -0
- package/dist/actions/error-action.d.ts.map +1 -0
- package/dist/actions/error-action.js +29 -0
- package/dist/actions/error-action.js.map +1 -0
- package/dist/actions/error-action.spec.d.ts +2 -0
- package/dist/actions/error-action.spec.d.ts.map +1 -0
- package/dist/actions/error-action.spec.js +51 -0
- package/dist/actions/error-action.spec.js.map +1 -0
- package/dist/actions/get-current-user.d.ts +11 -0
- package/dist/actions/get-current-user.d.ts.map +1 -0
- package/dist/actions/get-current-user.js +15 -0
- package/dist/actions/get-current-user.js.map +1 -0
- package/dist/actions/get-current-user.spec.d.ts +2 -0
- package/dist/actions/get-current-user.spec.d.ts.map +1 -0
- package/dist/actions/get-current-user.spec.js +20 -0
- package/dist/actions/get-current-user.spec.js.map +1 -0
- package/dist/actions/index.d.ts +7 -0
- package/dist/actions/index.d.ts.map +1 -0
- package/dist/actions/index.js +10 -0
- package/dist/actions/index.js.map +1 -0
- package/dist/actions/is-authenticated.d.ts +14 -0
- package/dist/actions/is-authenticated.d.ts.map +1 -0
- package/dist/actions/is-authenticated.js +17 -0
- package/dist/actions/is-authenticated.js.map +1 -0
- package/dist/actions/is-authenticated.spec.d.ts +2 -0
- package/dist/actions/is-authenticated.spec.d.ts.map +1 -0
- package/dist/actions/is-authenticated.spec.js +19 -0
- package/dist/actions/is-authenticated.spec.js.map +1 -0
- package/dist/actions/login-action.spec.d.ts +2 -0
- package/dist/actions/login-action.spec.d.ts.map +1 -0
- package/dist/actions/login-action.spec.js +35 -0
- package/dist/actions/login-action.spec.js.map +1 -0
- package/dist/actions/login.d.ts +16 -0
- package/dist/actions/login.d.ts.map +1 -0
- package/dist/actions/login.js +26 -0
- package/dist/actions/login.js.map +1 -0
- package/dist/actions/logout-action.spec.d.ts +2 -0
- package/dist/actions/logout-action.spec.d.ts.map +1 -0
- package/dist/actions/logout-action.spec.js +23 -0
- package/dist/actions/logout-action.spec.js.map +1 -0
- package/dist/actions/logout.d.ts +14 -0
- package/dist/actions/logout.d.ts.map +1 -0
- package/dist/actions/logout.js +20 -0
- package/dist/actions/logout.js.map +1 -0
- package/dist/actions/not-found-action.d.ts +10 -0
- package/dist/actions/not-found-action.d.ts.map +1 -0
- package/dist/actions/not-found-action.js +14 -0
- package/dist/actions/not-found-action.js.map +1 -0
- package/dist/actions/not-found-action.spec.d.ts +2 -0
- package/dist/actions/not-found-action.spec.d.ts.map +1 -0
- package/dist/actions/not-found-action.spec.js +17 -0
- package/dist/actions/not-found-action.spec.js.map +1 -0
- package/dist/add-cors-header.spec.d.ts +2 -0
- package/dist/add-cors-header.spec.d.ts.map +1 -0
- package/dist/add-cors-header.spec.js +99 -0
- package/dist/add-cors-header.spec.js.map +1 -0
- package/dist/api-manager.d.ts +61 -0
- package/dist/api-manager.d.ts.map +1 -0
- package/dist/api-manager.js +144 -0
- package/dist/api-manager.js.map +1 -0
- package/dist/authenticate.d.ts +5 -0
- package/dist/authenticate.d.ts.map +1 -0
- package/dist/authenticate.js +20 -0
- package/dist/authenticate.js.map +1 -0
- package/dist/authenticate.spec.d.ts +2 -0
- package/dist/authenticate.spec.d.ts.map +1 -0
- package/dist/authenticate.spec.js +59 -0
- package/dist/authenticate.spec.js.map +1 -0
- package/dist/authorize.d.ts +5 -0
- package/dist/authorize.d.ts.map +1 -0
- package/dist/authorize.js +22 -0
- package/dist/authorize.js.map +1 -0
- package/dist/authorize.spec.d.ts +2 -0
- package/dist/authorize.spec.d.ts.map +1 -0
- package/dist/authorize.spec.js +55 -0
- package/dist/authorize.spec.js.map +1 -0
- package/dist/endpoint-generators/create-delete-endpoint.d.ts +17 -0
- package/dist/endpoint-generators/create-delete-endpoint.d.ts.map +1 -0
- package/dist/endpoint-generators/create-delete-endpoint.js +24 -0
- package/dist/endpoint-generators/create-delete-endpoint.js.map +1 -0
- package/dist/endpoint-generators/create-delete-endpoint.spec.d.ts +2 -0
- package/dist/endpoint-generators/create-delete-endpoint.spec.d.ts.map +1 -0
- package/dist/endpoint-generators/create-delete-endpoint.spec.js +33 -0
- package/dist/endpoint-generators/create-delete-endpoint.spec.js.map +1 -0
- package/dist/endpoint-generators/create-get-collection-endpoint.d.ts +17 -0
- package/dist/endpoint-generators/create-get-collection-endpoint.d.ts.map +1 -0
- package/dist/endpoint-generators/create-get-collection-endpoint.js +26 -0
- package/dist/endpoint-generators/create-get-collection-endpoint.js.map +1 -0
- package/dist/endpoint-generators/create-get-collection-endpoint.spec.d.ts +2 -0
- package/dist/endpoint-generators/create-get-collection-endpoint.spec.d.ts.map +1 -0
- package/dist/endpoint-generators/create-get-collection-endpoint.spec.js +143 -0
- package/dist/endpoint-generators/create-get-collection-endpoint.spec.js.map +1 -0
- package/dist/endpoint-generators/create-get-entity-endpoint.d.ts +17 -0
- package/dist/endpoint-generators/create-get-entity-endpoint.d.ts.map +1 -0
- package/dist/endpoint-generators/create-get-entity-endpoint.js +29 -0
- package/dist/endpoint-generators/create-get-entity-endpoint.js.map +1 -0
- package/dist/endpoint-generators/create-get-entity-endpoint.spec.d.ts +2 -0
- package/dist/endpoint-generators/create-get-entity-endpoint.spec.d.ts.map +1 -0
- package/dist/endpoint-generators/create-get-entity-endpoint.spec.js +74 -0
- package/dist/endpoint-generators/create-get-entity-endpoint.spec.js.map +1 -0
- package/dist/endpoint-generators/create-patch-endpoint.d.ts +18 -0
- package/dist/endpoint-generators/create-patch-endpoint.d.ts.map +1 -0
- package/dist/endpoint-generators/create-patch-endpoint.js +26 -0
- package/dist/endpoint-generators/create-patch-endpoint.js.map +1 -0
- package/dist/endpoint-generators/create-patch-endpoint.spec.d.ts +2 -0
- package/dist/endpoint-generators/create-patch-endpoint.spec.d.ts.map +1 -0
- package/dist/endpoint-generators/create-patch-endpoint.spec.js +36 -0
- package/dist/endpoint-generators/create-patch-endpoint.spec.js.map +1 -0
- package/dist/endpoint-generators/create-post-endpoint.d.ts +18 -0
- package/dist/endpoint-generators/create-post-endpoint.d.ts.map +1 -0
- package/dist/endpoint-generators/create-post-endpoint.js +29 -0
- package/dist/endpoint-generators/create-post-endpoint.js.map +1 -0
- package/dist/endpoint-generators/create-post-endpoint.spec.d.ts +2 -0
- package/dist/endpoint-generators/create-post-endpoint.spec.d.ts.map +1 -0
- package/dist/endpoint-generators/create-post-endpoint.spec.js +34 -0
- package/dist/endpoint-generators/create-post-endpoint.spec.js.map +1 -0
- package/dist/endpoint-generators/index.d.ts +6 -0
- package/dist/endpoint-generators/index.d.ts.map +1 -0
- package/dist/endpoint-generators/index.js +9 -0
- package/dist/endpoint-generators/index.js.map +1 -0
- package/dist/endpoint-generators/utils.d.ts +9 -0
- package/dist/endpoint-generators/utils.d.ts.map +1 -0
- package/dist/endpoint-generators/utils.js +27 -0
- package/dist/endpoint-generators/utils.js.map +1 -0
- package/dist/http-authentication-settings.d.ts +17 -0
- package/dist/http-authentication-settings.d.ts.map +1 -0
- package/dist/http-authentication-settings.js +26 -0
- package/dist/http-authentication-settings.js.map +1 -0
- package/dist/http-user-context.d.ts +54 -0
- package/dist/http-user-context.d.ts.map +1 -0
- package/dist/http-user-context.js +153 -0
- package/dist/http-user-context.js.map +1 -0
- package/dist/http-user-context.spec.d.ts +4 -0
- package/dist/http-user-context.spec.d.ts.map +1 -0
- package/dist/http-user-context.spec.js +267 -0
- package/dist/http-user-context.spec.js.map +1 -0
- package/dist/incoming-message-extensions.d.ts +8 -0
- package/dist/incoming-message-extensions.d.ts.map +1 -0
- package/dist/incoming-message-extensions.js +14 -0
- package/dist/incoming-message-extensions.js.map +1 -0
- package/dist/incoming-message-extensions.spec.d.ts +2 -0
- package/dist/incoming-message-extensions.spec.d.ts.map +1 -0
- package/dist/incoming-message-extensions.spec.js +39 -0
- package/dist/incoming-message-extensions.spec.js.map +1 -0
- package/dist/index.d.ts +17 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +20 -0
- package/dist/index.js.map +1 -0
- package/dist/injector-extensions.d.ts +21 -0
- package/dist/injector-extensions.d.ts.map +1 -0
- package/dist/injector-extensions.js +14 -0
- package/dist/injector-extensions.js.map +1 -0
- package/dist/injector-extensions.spec.d.ts +2 -0
- package/dist/injector-extensions.spec.d.ts.map +1 -0
- package/dist/injector-extensions.spec.js +19 -0
- package/dist/injector-extensions.spec.js.map +1 -0
- package/dist/models/cors-options.d.ts +22 -0
- package/dist/models/cors-options.d.ts.map +1 -0
- package/dist/models/cors-options.js +3 -0
- package/dist/models/cors-options.js.map +1 -0
- package/dist/models/default-session.d.ts +14 -0
- package/dist/models/default-session.d.ts.map +1 -0
- package/dist/models/default-session.js +10 -0
- package/dist/models/default-session.js.map +1 -0
- package/dist/request-action-implementation.d.ts +54 -0
- package/dist/request-action-implementation.d.ts.map +1 -0
- package/dist/request-action-implementation.js +42 -0
- package/dist/request-action-implementation.js.map +1 -0
- package/dist/rest-service.integration.spec.d.ts +2 -0
- package/dist/rest-service.integration.spec.d.ts.map +1 -0
- package/dist/rest-service.integration.spec.js +129 -0
- package/dist/rest-service.integration.spec.js.map +1 -0
- package/dist/rest.integration.test.d.ts +58 -0
- package/dist/rest.integration.test.d.ts.map +1 -0
- package/dist/rest.integration.test.js +94 -0
- package/dist/rest.integration.test.js.map +1 -0
- package/dist/schema-validator/index.d.ts +3 -0
- package/dist/schema-validator/index.d.ts.map +1 -0
- package/dist/schema-validator/index.js +6 -0
- package/dist/schema-validator/index.js.map +1 -0
- package/dist/schema-validator/schema-validation-error.d.ts +10 -0
- package/dist/schema-validator/schema-validation-error.d.ts.map +1 -0
- package/dist/schema-validator/schema-validation-error.js +15 -0
- package/dist/schema-validator/schema-validation-error.js.map +1 -0
- package/dist/schema-validator/schema-validator.d.ts +20 -0
- package/dist/schema-validator/schema-validator.d.ts.map +1 -0
- package/dist/schema-validator/schema-validator.js +36 -0
- package/dist/schema-validator/schema-validator.js.map +1 -0
- package/dist/schema-validator/schema-validator.test.d.ts +2 -0
- package/dist/schema-validator/schema-validator.test.d.ts.map +1 -0
- package/dist/schema-validator/schema-validator.test.js +62 -0
- package/dist/schema-validator/schema-validator.test.js.map +1 -0
- package/dist/schema-validator/validate-examples.d.ts +37 -0
- package/dist/schema-validator/validate-examples.d.ts.map +1 -0
- package/dist/schema-validator/validate-examples.js +29 -0
- package/dist/schema-validator/validate-examples.js.map +1 -0
- package/dist/server-manager.d.ts +30 -0
- package/dist/server-manager.d.ts.map +1 -0
- package/dist/server-manager.js +71 -0
- package/dist/server-manager.js.map +1 -0
- package/dist/server-response-extensions.d.ts +21 -0
- package/dist/server-response-extensions.d.ts.map +1 -0
- package/dist/server-response-extensions.js +15 -0
- package/dist/server-response-extensions.js.map +1 -0
- package/dist/server-response-extensions.spec.d.ts +2 -0
- package/dist/server-response-extensions.spec.d.ts.map +1 -0
- package/dist/server-response-extensions.spec.js +49 -0
- package/dist/server-response-extensions.spec.js.map +1 -0
- package/dist/utils.d.ts +24 -0
- package/dist/utils.d.ts.map +1 -0
- package/dist/utils.js +66 -0
- package/dist/utils.js.map +1 -0
- package/dist/validate.d.ts +18 -0
- package/dist/validate.d.ts.map +1 -0
- package/dist/validate.integration.schema.d.ts +69 -0
- package/dist/validate.integration.schema.d.ts.map +1 -0
- package/dist/validate.integration.schema.js +3 -0
- package/dist/validate.integration.schema.js.map +1 -0
- package/dist/validate.integration.spec.d.ts +13 -0
- package/dist/validate.integration.spec.d.ts.map +1 -0
- package/dist/validate.integration.spec.js +223 -0
- package/dist/validate.integration.spec.js.map +1 -0
- package/dist/validate.integration.spec.schema.json +749 -0
- package/dist/validate.js +49 -0
- package/dist/validate.js.map +1 -0
- package/package.json +56 -0
- package/src/actions/error-action.spec.ts +54 -0
- package/src/actions/error-action.ts +34 -0
- package/src/actions/get-current-user.spec.ts +23 -0
- package/src/actions/get-current-user.ts +15 -0
- package/src/actions/index.ts +6 -0
- package/src/actions/is-authenticated.spec.ts +18 -0
- package/src/actions/is-authenticated.ts +13 -0
- package/src/actions/login-action.spec.ts +41 -0
- package/src/actions/login.ts +26 -0
- package/src/actions/logout-action.spec.ts +27 -0
- package/src/actions/logout.ts +16 -0
- package/src/actions/not-found-action.spec.ts +17 -0
- package/src/actions/not-found-action.ts +13 -0
- package/src/add-cors-header.spec.ts +133 -0
- package/src/api-manager.ts +222 -0
- package/src/authenticate.spec.ts +78 -0
- package/src/authenticate.ts +22 -0
- package/src/authorize.spec.ts +69 -0
- package/src/authorize.ts +19 -0
- package/src/endpoint-generators/create-delete-endpoint.spec.ts +34 -0
- package/src/endpoint-generators/create-delete-endpoint.ts +25 -0
- package/src/endpoint-generators/create-get-collection-endpoint.spec.ts +164 -0
- package/src/endpoint-generators/create-get-collection-endpoint.ts +28 -0
- package/src/endpoint-generators/create-get-entity-endpoint.spec.ts +75 -0
- package/src/endpoint-generators/create-get-entity-endpoint.ts +29 -0
- package/src/endpoint-generators/create-patch-endpoint.spec.ts +36 -0
- package/src/endpoint-generators/create-patch-endpoint.ts +27 -0
- package/src/endpoint-generators/create-post-endpoint.spec.ts +32 -0
- package/src/endpoint-generators/create-post-endpoint.ts +30 -0
- package/src/endpoint-generators/index.ts +5 -0
- package/src/endpoint-generators/utils.ts +34 -0
- package/src/http-authentication-settings.ts +23 -0
- package/src/http-user-context.spec.ts +299 -0
- package/src/http-user-context.ts +160 -0
- package/src/incoming-message-extensions.spec.ts +41 -0
- package/src/incoming-message-extensions.ts +19 -0
- package/src/index.ts +16 -0
- package/src/injector-extensions.spec.ts +19 -0
- package/src/injector-extensions.ts +35 -0
- package/src/models/cors-options.ts +21 -0
- package/src/models/default-session.ts +14 -0
- package/src/request-action-implementation.ts +70 -0
- package/src/rest-service.integration.spec.ts +166 -0
- package/src/rest.integration.test.ts +112 -0
- package/src/schema-validator/index.ts +2 -0
- package/src/schema-validator/schema-validation-error.ts +11 -0
- package/src/schema-validator/schema-validator.test.ts +72 -0
- package/src/schema-validator/schema-validator.ts +31 -0
- package/src/schema-validator/validate-examples.ts +38 -0
- package/src/server-manager.ts +88 -0
- package/src/server-response-extensions.spec.ts +53 -0
- package/src/server-response-extensions.ts +30 -0
- package/src/utils.ts +65 -0
- package/src/validate.integration.schema.ts +50 -0
- package/src/validate.integration.spec.schema.json +779 -0
- package/src/validate.integration.spec.ts +218 -0
- package/src/validate.ts +60 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"authenticate.js","sourceRoot":"","sources":["../src/authenticate.ts"],"names":[],"mappings":";;;AAAA,4CAA6C;AAC7C,2DAAqD;AACrD,mFAA+G;AAExG,MAAM,YAAY,GACvB,GAAG,EAAE,CACL,CAAgC,MAAwB,EAAoB,EAAE;IAC5E,OAAO,KAAK,EAAE,IAA6B,EAA4B,EAAE;QACvE,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,eAAe,EAAE,CAAA;QAC3D,IAAI,CAAC,aAAa,EAAE;YAClB,MAAM,IAAA,kBAAU,EAAC,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,CAAA;YACtC,OAAO,IAAA,0CAAU,EACf,EAAE,KAAK,EAAE,cAAc,EAAE,EACzB,GAAG,EACH,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,mCAAe,CAAC,CAAC,cAAc,CAAC,eAAe;gBACvE,CAAC,CAAC,EAAE,kBAAkB,EAAE,OAAO,EAAE;gBACjC,CAAC,CAAC,EAAE,CACuB,CAAA;SAChC;QACD,OAAO,CAAC,MAAM,MAAM,CAAC,IAAI,CAAC,CAAQ,CAAA;IACpC,CAAC,CAAA;AACH,CAAC,CAAA;AAjBU,QAAA,YAAY,gBAiBtB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"authenticate.spec.d.ts","sourceRoot":"","sources":["../src/authenticate.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const inject_1 = require("@furystack/inject");
|
|
4
|
+
const utils_1 = require("@furystack/utils");
|
|
5
|
+
const http_user_context_1 = require("./http-user-context");
|
|
6
|
+
const authenticate_1 = require("./authenticate");
|
|
7
|
+
const core_1 = require("@furystack/core");
|
|
8
|
+
const request_action_implementation_1 = require("./request-action-implementation");
|
|
9
|
+
describe('Authenticate', () => {
|
|
10
|
+
const response = {};
|
|
11
|
+
const request = { url: 'http://google.com' };
|
|
12
|
+
it('Should return 403 w/o basic auth header, when unauthorized and basic auth is disabled', async () => {
|
|
13
|
+
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
14
|
+
const isAuthenticatedAction = jest.fn(async () => false);
|
|
15
|
+
i.setExplicitInstance({ isAuthenticated: isAuthenticatedAction, getCurrentUser: async () => Promise.reject(':(') }, core_1.IdentityContext);
|
|
16
|
+
i.setExplicitInstance({
|
|
17
|
+
authentication: { enableBasicAuth: false },
|
|
18
|
+
}, http_user_context_1.HttpUserContext);
|
|
19
|
+
const exampleAuthenticatedAction = jest.fn(async (_args) => (0, request_action_implementation_1.EmptyResult)());
|
|
20
|
+
const authorized = (0, authenticate_1.Authenticate)()(exampleAuthenticatedAction);
|
|
21
|
+
const result = await authorized({ injector: i, request, response });
|
|
22
|
+
expect(result.statusCode).toBe(401);
|
|
23
|
+
expect(result.chunk).toEqual({ error: 'unauthorized' });
|
|
24
|
+
expect(result.headers).toEqual({ 'Content-Type': 'application/json' });
|
|
25
|
+
expect(exampleAuthenticatedAction).not.toBeCalled();
|
|
26
|
+
});
|
|
27
|
+
});
|
|
28
|
+
it('Should return 403 with basic auth headers when unauthorized and basic auth is enabled', async () => {
|
|
29
|
+
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
30
|
+
const isAuthenticatedAction = jest.fn(async () => false);
|
|
31
|
+
i.setExplicitInstance({
|
|
32
|
+
isAuthenticated: isAuthenticatedAction,
|
|
33
|
+
getCurrentUser: async () => Promise.reject(':('),
|
|
34
|
+
authentication: { enableBasicAuth: true },
|
|
35
|
+
}, http_user_context_1.HttpUserContext);
|
|
36
|
+
const exampleAuthenticatedAction = jest.fn(async (_args) => (0, request_action_implementation_1.EmptyResult)());
|
|
37
|
+
const authorized = (0, authenticate_1.Authenticate)()(exampleAuthenticatedAction);
|
|
38
|
+
const result = await authorized({ injector: i, request, response });
|
|
39
|
+
expect(result.statusCode).toBe(401);
|
|
40
|
+
expect(result.chunk).toEqual({ error: 'unauthorized' });
|
|
41
|
+
expect(result.headers).toEqual({ 'Content-Type': 'application/json', 'WWW-Authenticate': 'Basic' });
|
|
42
|
+
expect(exampleAuthenticatedAction).not.toBeCalled();
|
|
43
|
+
});
|
|
44
|
+
});
|
|
45
|
+
it('Should exec the original action if authorized', async () => {
|
|
46
|
+
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
47
|
+
const isAuthenticatedAction = jest.fn(async () => true);
|
|
48
|
+
i.setExplicitInstance({ isAuthenticated: isAuthenticatedAction, getCurrentUser: async () => Promise.reject(':(') }, core_1.IdentityContext);
|
|
49
|
+
const exampleAuthenticatedAction = jest.fn(async (_args) => (0, request_action_implementation_1.EmptyResult)());
|
|
50
|
+
const authorized = (0, authenticate_1.Authenticate)()(exampleAuthenticatedAction);
|
|
51
|
+
const params = { injector: i, body: undefined, query: undefined, request, response };
|
|
52
|
+
const result = await authorized(params);
|
|
53
|
+
expect(result.statusCode).toBe(200);
|
|
54
|
+
expect(result.chunk).toBe(undefined);
|
|
55
|
+
expect(exampleAuthenticatedAction).toBeCalledWith(params);
|
|
56
|
+
});
|
|
57
|
+
});
|
|
58
|
+
});
|
|
59
|
+
//# sourceMappingURL=authenticate.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"authenticate.spec.js","sourceRoot":"","sources":["../src/authenticate.spec.ts"],"names":[],"mappings":";;AACA,8CAA4C;AAC5C,4CAA6C;AAC7C,2DAAqD;AACrD,iDAA6C;AAE7C,0CAAiD;AACjD,mFAA6D;AAE7D,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;IAC5B,MAAM,QAAQ,GAAG,EAA2B,CAAA;IAC5C,MAAM,OAAO,GAAG,EAAE,GAAG,EAAE,mBAAmB,EAAqB,CAAA;IAE/D,EAAE,CAAC,uFAAuF,EAAE,KAAK,IAAI,EAAE;QACrG,MAAM,IAAA,kBAAU,EAAC,IAAI,iBAAQ,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;YAC3C,MAAM,qBAAqB,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,IAAI,EAAE,CAAC,KAAK,CAAC,CAAA;YAExD,CAAC,CAAC,mBAAmB,CACnB,EAAE,eAAe,EAAE,qBAAqB,EAAE,cAAc,EAAE,KAAK,IAAI,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,EAC5F,sBAAe,CAChB,CAAA;YAED,CAAC,CAAC,mBAAmB,CACnB;gBACE,cAAc,EAAE,EAAE,eAAe,EAAE,KAAK,EAAE;aAC3C,EACD,mCAAe,CAChB,CAAA;YACD,MAAM,0BAA0B,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,KAAU,EAAE,EAAE,CAAC,IAAA,2CAAW,GAAE,CAAC,CAAA;YAC/E,MAAM,UAAU,GAAG,IAAA,2BAAY,GAAE,CAAC,0BAA0B,CAAC,CAAA;YAE7D,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC,CAAA;YACnE,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;YACnC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,cAAc,EAAE,CAAC,CAAA;YACvD,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,EAAE,cAAc,EAAE,kBAAkB,EAAE,CAAC,CAAA;YACtE,MAAM,CAAC,0BAA0B,CAAC,CAAC,GAAG,CAAC,UAAU,EAAE,CAAA;QACrD,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,uFAAuF,EAAE,KAAK,IAAI,EAAE;QACrG,MAAM,IAAA,kBAAU,EAAC,IAAI,iBAAQ,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;YAC3C,MAAM,qBAAqB,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,IAAI,EAAE,CAAC,KAAK,CAAC,CAAA;YACxD,CAAC,CAAC,mBAAmB,CACnB;gBACE,eAAe,EAAE,qBAAqB;gBACtC,cAAc,EAAE,KAAK,IAAI,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC;gBAChD,cAAc,EAAE,EAAE,eAAe,EAAE,IAAI,EAAE;aAC1C,EACD,mCAAe,CAChB,CAAA;YACD,MAAM,0BAA0B,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,KAAU,EAAE,EAAE,CAAC,IAAA,2CAAW,GAAE,CAAC,CAAA;YAC/E,MAAM,UAAU,GAAG,IAAA,2BAAY,GAAE,CAAC,0BAA0B,CAAC,CAAA;YAE7D,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC,CAAA;YACnE,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;YACnC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,cAAc,EAAE,CAAC,CAAA;YACvD,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,EAAE,cAAc,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,OAAO,EAAE,CAAC,CAAA;YACnG,MAAM,CAAC,0BAA0B,CAAC,CAAC,GAAG,CAAC,UAAU,EAAE,CAAA;QACrD,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,+CAA+C,EAAE,KAAK,IAAI,EAAE;QAC7D,MAAM,IAAA,kBAAU,EAAC,IAAI,iBAAQ,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;YAC3C,MAAM,qBAAqB,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,IAAI,EAAE,CAAC,IAAI,CAAC,CAAA;YACvD,CAAC,CAAC,mBAAmB,CACnB,EAAE,eAAe,EAAE,qBAAqB,EAAE,cAAc,EAAE,KAAK,IAAI,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,EAC5F,sBAAe,CAChB,CAAA;YACD,MAAM,0BAA0B,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,KAAU,EAAE,EAAE,CAAC,IAAA,2CAAW,GAAE,CAAC,CAAA;YAC/E,MAAM,UAAU,GAAG,IAAA,2BAAY,GAAE,CAAC,0BAA0B,CAAC,CAAA;YAC7D,MAAM,MAAM,GAAG,EAAE,QAAQ,EAAE,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAA;YACpF,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,MAAM,CAAC,CAAA;YACvC,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;YACnC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;YACpC,MAAM,CAAC,0BAA0B,CAAC,CAAC,cAAc,CAAC,MAAM,CAAC,CAAA;QAC3D,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"authorize.d.ts","sourceRoot":"","sources":["../src/authorize.ts"],"names":[],"mappings":"AACA,OAAO,EAA4B,aAAa,EAAwB,MAAM,iCAAiC,CAAA;AAE/G,eAAO,MAAM,SAAS,aACT,MAAM,EAAE;YACE,OAAO;gDAa3B,CAAA"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Authorize = void 0;
|
|
4
|
+
const utils_1 = require("@furystack/utils");
|
|
5
|
+
const request_action_implementation_1 = require("./request-action-implementation");
|
|
6
|
+
const Authorize = (...roles) => (action) => {
|
|
7
|
+
return async (options) => {
|
|
8
|
+
try {
|
|
9
|
+
const authorized = await options.injector.isAuthorized(...roles);
|
|
10
|
+
if (!authorized) {
|
|
11
|
+
await (0, utils_1.sleepAsync)(Math.random() * 1000);
|
|
12
|
+
return (0, request_action_implementation_1.JsonResult)({ error: 'forbidden' }, 403);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
catch (error) {
|
|
16
|
+
return (0, request_action_implementation_1.JsonResult)({ error: 'forbidden' }, 403);
|
|
17
|
+
}
|
|
18
|
+
return (await action(options));
|
|
19
|
+
};
|
|
20
|
+
};
|
|
21
|
+
exports.Authorize = Authorize;
|
|
22
|
+
//# sourceMappingURL=authorize.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"authorize.js","sourceRoot":"","sources":["../src/authorize.ts"],"names":[],"mappings":";;;AAAA,4CAA6C;AAC7C,mFAA+G;AAExG,MAAM,SAAS,GACpB,CAAC,GAAG,KAAe,EAAE,EAAE,CACvB,CAAgC,MAAwB,EAAoB,EAAE;IAC5E,OAAO,KAAK,EAAE,OAAgC,EAA4B,EAAE;QAC1E,IAAI;YACF,MAAM,UAAU,GAAG,MAAM,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAC,GAAG,KAAK,CAAC,CAAA;YAChE,IAAI,CAAC,UAAU,EAAE;gBACf,MAAM,IAAA,kBAAU,EAAC,IAAI,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,CAAA;gBACtC,OAAO,IAAA,0CAAU,EAAC,EAAE,KAAK,EAAE,WAAW,EAAE,EAAE,GAAG,CAAQ,CAAA;aACtD;SACF;QAAC,OAAO,KAAK,EAAE;YACd,OAAO,IAAA,0CAAU,EAAC,EAAE,KAAK,EAAE,WAAW,EAAE,EAAE,GAAG,CAAQ,CAAA;SACtD;QACD,OAAO,CAAC,MAAM,MAAM,CAAC,OAAO,CAAC,CAAQ,CAAA;IACvC,CAAC,CAAA;AACH,CAAC,CAAA;AAfU,QAAA,SAAS,aAenB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"authorize.spec.d.ts","sourceRoot":"","sources":["../src/authorize.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const inject_1 = require("@furystack/inject");
|
|
4
|
+
const utils_1 = require("@furystack/utils");
|
|
5
|
+
const core_1 = require("@furystack/core");
|
|
6
|
+
const authorize_1 = require("./authorize");
|
|
7
|
+
const request_action_implementation_1 = require("./request-action-implementation");
|
|
8
|
+
describe('Authorize', () => {
|
|
9
|
+
const response = {};
|
|
10
|
+
const request = { url: 'http://google.com' };
|
|
11
|
+
it('Should return 403 when failed to get current user', async () => {
|
|
12
|
+
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
13
|
+
const isAuthorizedAction = jest.fn(async () => false);
|
|
14
|
+
i.setExplicitInstance({ isAuthorized: isAuthorizedAction, getCurrentUser: () => Promise.reject(':(') }, core_1.IdentityContext);
|
|
15
|
+
const exampleAuthorizedAction = jest.fn(async (_args) => (0, request_action_implementation_1.EmptyResult)());
|
|
16
|
+
const authorized = (0, authorize_1.Authorize)('Role1')(exampleAuthorizedAction);
|
|
17
|
+
const result = await authorized({ injector: i, request, response });
|
|
18
|
+
expect(result.statusCode).toBe(403);
|
|
19
|
+
expect(result.chunk).toEqual({ error: 'forbidden' });
|
|
20
|
+
expect(exampleAuthorizedAction).not.toBeCalled();
|
|
21
|
+
});
|
|
22
|
+
});
|
|
23
|
+
it('Should return 403 if the current user does not have the role', async () => {
|
|
24
|
+
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
25
|
+
const isAuthorizedAction = jest.fn(async () => false);
|
|
26
|
+
i.setExplicitInstance({
|
|
27
|
+
isAuthorized: isAuthorizedAction,
|
|
28
|
+
getCurrentUser: async () => Promise.resolve({ username: 'a', roles: ['Role1'] }),
|
|
29
|
+
}, core_1.IdentityContext);
|
|
30
|
+
const exampleAuthorizedAction = jest.fn(async (_args) => (0, request_action_implementation_1.EmptyResult)());
|
|
31
|
+
const authorized = (0, authorize_1.Authorize)('Role2')(exampleAuthorizedAction);
|
|
32
|
+
const result = await authorized({ injector: i, request, response });
|
|
33
|
+
expect(result.statusCode).toBe(403);
|
|
34
|
+
expect(result.chunk).toEqual({ error: 'forbidden' });
|
|
35
|
+
expect(exampleAuthorizedAction).not.toBeCalled();
|
|
36
|
+
});
|
|
37
|
+
});
|
|
38
|
+
it('Should exec the original action if authorized', async () => {
|
|
39
|
+
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
40
|
+
const isAuthorizedAction = jest.fn(async () => true);
|
|
41
|
+
i.setExplicitInstance({
|
|
42
|
+
isAuthorized: isAuthorizedAction,
|
|
43
|
+
getCurrentUser: async () => Promise.resolve({ username: 'a', roles: ['Role1'] }),
|
|
44
|
+
}, core_1.IdentityContext);
|
|
45
|
+
const exampleAuthorizedAction = jest.fn(async (_args) => (0, request_action_implementation_1.EmptyResult)());
|
|
46
|
+
const authorized = (0, authorize_1.Authorize)('Role1')(exampleAuthorizedAction);
|
|
47
|
+
const params = { injector: i, body: undefined, query: undefined, request, response };
|
|
48
|
+
const result = await authorized(params);
|
|
49
|
+
expect(result.statusCode).toBe(200);
|
|
50
|
+
expect(result.chunk).toBe(undefined);
|
|
51
|
+
expect(exampleAuthorizedAction).toBeCalledWith(params);
|
|
52
|
+
});
|
|
53
|
+
});
|
|
54
|
+
});
|
|
55
|
+
//# sourceMappingURL=authorize.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"authorize.spec.js","sourceRoot":"","sources":["../src/authorize.spec.ts"],"names":[],"mappings":";;AACA,8CAA4C;AAC5C,4CAA6C;AAC7C,0CAAuD;AACvD,2CAAuC;AAEvC,mFAA6D;AAE7D,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE;IACzB,MAAM,QAAQ,GAAG,EAA2B,CAAA;IAC5C,MAAM,OAAO,GAAG,EAAE,GAAG,EAAE,mBAAmB,EAAqB,CAAA;IAE/D,EAAE,CAAC,mDAAmD,EAAE,KAAK,IAAI,EAAE;QACjE,MAAM,IAAA,kBAAU,EAAC,IAAI,iBAAQ,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;YAC3C,MAAM,kBAAkB,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,IAAI,EAAE,CAAC,KAAK,CAAC,CAAA;YACrD,CAAC,CAAC,mBAAmB,CACnB,EAAE,YAAY,EAAE,kBAAkB,EAAE,cAAc,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,EAChF,sBAAe,CAChB,CAAA;YACD,MAAM,uBAAuB,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,KAAU,EAAE,EAAE,CAAC,IAAA,2CAAW,GAAE,CAAC,CAAA;YAC5E,MAAM,UAAU,GAAG,IAAA,qBAAS,EAAC,OAAO,CAAC,CAAC,uBAAuB,CAAC,CAAA;YAE9D,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC,CAAA;YACnE,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;YACnC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE,CAAC,CAAA;YACpD,MAAM,CAAC,uBAAuB,CAAC,CAAC,GAAG,CAAC,UAAU,EAAE,CAAA;QAClD,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,8DAA8D,EAAE,KAAK,IAAI,EAAE;QAC5E,MAAM,IAAA,kBAAU,EAAC,IAAI,iBAAQ,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;YAC3C,MAAM,kBAAkB,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,IAAI,EAAE,CAAC,KAAK,CAAC,CAAA;YACrD,CAAC,CAAC,mBAAmB,CACnB;gBACE,YAAY,EAAE,kBAAkB;gBAChC,cAAc,EAAE,KAAK,IAAI,EAAE,CAAC,OAAO,CAAC,OAAO,CAAO,EAAE,QAAQ,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC;aACvF,EACD,sBAAe,CAChB,CAAA;YACD,MAAM,uBAAuB,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,KAAU,EAAE,EAAE,CAAC,IAAA,2CAAW,GAAE,CAAC,CAAA;YAC5E,MAAM,UAAU,GAAG,IAAA,qBAAS,EAAC,OAAO,CAAC,CAAC,uBAAuB,CAAC,CAAA;YAE9D,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC,CAAA;YACnE,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;YACnC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,WAAW,EAAE,CAAC,CAAA;YACpD,MAAM,CAAC,uBAAuB,CAAC,CAAC,GAAG,CAAC,UAAU,EAAE,CAAA;QAClD,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;IAEF,EAAE,CAAC,+CAA+C,EAAE,KAAK,IAAI,EAAE;QAC7D,MAAM,IAAA,kBAAU,EAAC,IAAI,iBAAQ,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;YAC3C,MAAM,kBAAkB,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,IAAI,EAAE,CAAC,IAAI,CAAC,CAAA;YACpD,CAAC,CAAC,mBAAmB,CACnB;gBACE,YAAY,EAAE,kBAAkB;gBAChC,cAAc,EAAE,KAAK,IAAI,EAAE,CAAC,OAAO,CAAC,OAAO,CAAO,EAAE,QAAQ,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC;aACvF,EACD,sBAAe,CAChB,CAAA;YACD,MAAM,uBAAuB,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,KAAU,EAAE,EAAE,CAAC,IAAA,2CAAW,GAAE,CAAC,CAAA;YAC5E,MAAM,UAAU,GAAG,IAAA,qBAAS,EAAC,OAAO,CAAC,CAAC,uBAAuB,CAAC,CAAA;YAC9D,MAAM,MAAM,GAAG,EAAE,QAAQ,EAAE,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAA;YACpF,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,MAAM,CAAC,CAAA;YACvC,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;YACnC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;YACpC,MAAM,CAAC,uBAAuB,CAAC,CAAC,cAAc,CAAC,MAAM,CAAC,CAAA;QACxD,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Constructable } from '@furystack/inject';
|
|
2
|
+
import { DeleteEndpoint } from '@furystack/rest';
|
|
3
|
+
import '@furystack/repository';
|
|
4
|
+
import { RequestAction } from '../request-action-implementation';
|
|
5
|
+
/**
|
|
6
|
+
* Creates a DELETE endpoint for removing entities
|
|
7
|
+
*
|
|
8
|
+
* @param options The options for endpoint creation
|
|
9
|
+
* @param options.model The Model class
|
|
10
|
+
* @param options.primaryKey The field used as primary key on the model
|
|
11
|
+
* @returns a boolean that indicates the success
|
|
12
|
+
*/
|
|
13
|
+
export declare const createDeleteEndpoint: <T extends object, TPrimaryKey extends keyof T>(options: {
|
|
14
|
+
model: Constructable<T>;
|
|
15
|
+
primaryKey: TPrimaryKey;
|
|
16
|
+
}) => RequestAction<DeleteEndpoint<T, TPrimaryKey>>;
|
|
17
|
+
//# sourceMappingURL=create-delete-endpoint.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-delete-endpoint.d.ts","sourceRoot":"","sources":["../../src/endpoint-generators/create-delete-endpoint.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AACjD,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAA;AAChD,OAAO,uBAAuB,CAAA;AAC9B,OAAO,EAAc,aAAa,EAAE,MAAM,kCAAkC,CAAA;AAE5E;;;;;;;GAOG;AACH,eAAO,MAAM,oBAAoB;;;mDAWhC,CAAA"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.createDeleteEndpoint = void 0;
|
|
4
|
+
require("@furystack/repository");
|
|
5
|
+
const request_action_implementation_1 = require("../request-action-implementation");
|
|
6
|
+
/**
|
|
7
|
+
* Creates a DELETE endpoint for removing entities
|
|
8
|
+
*
|
|
9
|
+
* @param options The options for endpoint creation
|
|
10
|
+
* @param options.model The Model class
|
|
11
|
+
* @param options.primaryKey The field used as primary key on the model
|
|
12
|
+
* @returns a boolean that indicates the success
|
|
13
|
+
*/
|
|
14
|
+
const createDeleteEndpoint = (options) => {
|
|
15
|
+
const endpoint = async ({ injector, getUrlParams }) => {
|
|
16
|
+
const { id } = getUrlParams();
|
|
17
|
+
const dataSet = injector.getDataSetFor(options.model, options.primaryKey);
|
|
18
|
+
await dataSet.remove(injector, id);
|
|
19
|
+
return (0, request_action_implementation_1.JsonResult)({}, 204);
|
|
20
|
+
};
|
|
21
|
+
return endpoint;
|
|
22
|
+
};
|
|
23
|
+
exports.createDeleteEndpoint = createDeleteEndpoint;
|
|
24
|
+
//# sourceMappingURL=create-delete-endpoint.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-delete-endpoint.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-delete-endpoint.ts"],"names":[],"mappings":";;;AAEA,iCAA8B;AAC9B,oFAA4E;AAE5E;;;;;;;GAOG;AACI,MAAM,oBAAoB,GAAG,CAAgD,OAGnF,EAAE,EAAE;IACH,MAAM,QAAQ,GAAkD,KAAK,EAAE,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE,EAAE;QACnG,MAAM,EAAE,EAAE,EAAE,GAAG,YAAY,EAAE,CAAA;QAC7B,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,UAAU,CAAC,CAAA;QACzE,MAAM,OAAO,CAAC,MAAM,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAA;QAClC,OAAO,IAAA,0CAAU,EAAC,EAAE,EAAE,GAAG,CAAC,CAAA;IAC5B,CAAC,CAAA;IACD,OAAO,QAAQ,CAAA;AACjB,CAAC,CAAA;AAXY,QAAA,oBAAoB,wBAWhC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-delete-endpoint.spec.d.ts","sourceRoot":"","sources":["../../src/endpoint-generators/create-delete-endpoint.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const tslib_1 = require("tslib");
|
|
4
|
+
const utils_1 = require("@furystack/utils");
|
|
5
|
+
const inject_1 = require("@furystack/inject");
|
|
6
|
+
const create_delete_endpoint_1 = require("./create-delete-endpoint");
|
|
7
|
+
const got_1 = (0, tslib_1.__importDefault)(require("got"));
|
|
8
|
+
const utils_2 = require("./utils");
|
|
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 i.useRestService({
|
|
14
|
+
root: '/api',
|
|
15
|
+
port: 1111,
|
|
16
|
+
api: {
|
|
17
|
+
DELETE: {
|
|
18
|
+
'/:id': (0, create_delete_endpoint_1.createDeleteEndpoint)({ model: utils_2.MockClass, primaryKey: 'id' }),
|
|
19
|
+
},
|
|
20
|
+
},
|
|
21
|
+
});
|
|
22
|
+
await i.getDataSetFor(utils_2.MockClass, 'id').add(i, { id: 'mock', value: 'mock' });
|
|
23
|
+
const countBeforeDelete = await i.getDataSetFor(utils_2.MockClass, 'id').count(i);
|
|
24
|
+
expect(countBeforeDelete).toBe(1);
|
|
25
|
+
const response = await (0, got_1.default)('http://127.0.0.1:1111/api/mock', { method: 'DELETE' });
|
|
26
|
+
expect(response.statusCode).toBe(204);
|
|
27
|
+
expect(response.body).toBe('');
|
|
28
|
+
const countAfterDelete = await i.getDataSetFor(utils_2.MockClass, 'id').count(i);
|
|
29
|
+
expect(countAfterDelete).toBe(0);
|
|
30
|
+
});
|
|
31
|
+
});
|
|
32
|
+
});
|
|
33
|
+
//# sourceMappingURL=create-delete-endpoint.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
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,2DAAqB;AACrB,mCAAiD;AAEjD,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,CAAC,CAAC,cAAc,CAA0D;gBAC9E,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,CAAC,CAAC,aAAa,CAAC,iBAAS,EAAE,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAA;YAE5E,MAAM,iBAAiB,GAAG,MAAM,CAAC,CAAC,aAAa,CAAC,iBAAS,EAAE,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;YACzE,MAAM,CAAC,iBAAiB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;YAEjC,MAAM,QAAQ,GAAG,MAAM,IAAA,aAAG,EAAC,gCAAgC,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAA;YAClF,MAAM,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;YACrC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;YAE9B,MAAM,gBAAgB,GAAG,MAAM,CAAC,CAAC,aAAa,CAAC,iBAAS,EAAE,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;YACxE,MAAM,CAAC,gBAAgB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QAClC,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { Constructable } from '@furystack/inject';
|
|
2
|
+
import { GetCollectionEndpoint } from '@furystack/rest';
|
|
3
|
+
import '@furystack/repository';
|
|
4
|
+
import { RequestAction } from '../request-action-implementation';
|
|
5
|
+
/**
|
|
6
|
+
* Creates a GetCollection endpoint for the given model. The model should have a Repository DataSet
|
|
7
|
+
*
|
|
8
|
+
* @param options The options for endpoint creation
|
|
9
|
+
* @param options.model The Model class
|
|
10
|
+
* @param options.primaryKey The field used as primary key on the model
|
|
11
|
+
* @returns The created endpoint
|
|
12
|
+
*/
|
|
13
|
+
export declare const createGetCollectionEndpoint: <T, TPrimaryKey extends keyof T>(options: {
|
|
14
|
+
model: Constructable<T>;
|
|
15
|
+
primaryKey: TPrimaryKey;
|
|
16
|
+
}) => RequestAction<GetCollectionEndpoint<T>>;
|
|
17
|
+
//# sourceMappingURL=create-get-collection-endpoint.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-get-collection-endpoint.d.ts","sourceRoot":"","sources":["../../src/endpoint-generators/create-get-collection-endpoint.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAA;AACjD,OAAO,EAAE,qBAAqB,EAAE,MAAM,iBAAiB,CAAA;AACvD,OAAO,uBAAuB,CAAA;AAC9B,OAAO,EAAc,aAAa,EAAE,MAAM,kCAAkC,CAAA;AAE5E;;;;;;;GAOG;AACH,eAAO,MAAM,2BAA2B;;;6CAcvC,CAAA"}
|
|
@@ -0,0 +1,26 @@
|
|
|
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
|
+
/**
|
|
7
|
+
* Creates a GetCollection endpoint for the given model. The model should have a Repository DataSet
|
|
8
|
+
*
|
|
9
|
+
* @param options The options for endpoint creation
|
|
10
|
+
* @param options.model The Model class
|
|
11
|
+
* @param options.primaryKey The field used as primary key on the model
|
|
12
|
+
* @returns The created endpoint
|
|
13
|
+
*/
|
|
14
|
+
const createGetCollectionEndpoint = (options) => {
|
|
15
|
+
const endpoint = async ({ injector, getQuery }) => {
|
|
16
|
+
const { findOptions } = getQuery();
|
|
17
|
+
const dataSet = injector.getDataSetFor(options.model, options.primaryKey);
|
|
18
|
+
const entriesPromise = dataSet.find(injector, findOptions || {});
|
|
19
|
+
const countPromise = dataSet.count(injector, findOptions === null || findOptions === void 0 ? void 0 : findOptions.filter);
|
|
20
|
+
const [entries, count] = await Promise.all([entriesPromise, countPromise]);
|
|
21
|
+
return (0, request_action_implementation_1.JsonResult)({ entries, count });
|
|
22
|
+
};
|
|
23
|
+
return endpoint;
|
|
24
|
+
};
|
|
25
|
+
exports.createGetCollectionEndpoint = createGetCollectionEndpoint;
|
|
26
|
+
//# sourceMappingURL=create-get-collection-endpoint.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-get-collection-endpoint.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-get-collection-endpoint.ts"],"names":[],"mappings":";;;AAEA,iCAA8B;AAC9B,oFAA4E;AAE5E;;;;;;;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,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,UAAU,CAAC,CAAA;QACzE,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,aAAX,WAAW,uBAAX,WAAW,CAAE,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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-get-collection-endpoint.spec.d.ts","sourceRoot":"","sources":["../../src/endpoint-generators/create-get-collection-endpoint.spec.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const tslib_1 = require("tslib");
|
|
4
|
+
const utils_1 = require("@furystack/utils");
|
|
5
|
+
const inject_1 = require("@furystack/inject");
|
|
6
|
+
const got_1 = (0, tslib_1.__importDefault)(require("got"));
|
|
7
|
+
const utils_2 = require("./utils");
|
|
8
|
+
const create_get_collection_endpoint_1 = require("./create-get-collection-endpoint");
|
|
9
|
+
const rest_1 = require("@furystack/rest");
|
|
10
|
+
const addMockEntities = async (i) => await 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 i.useRestService({
|
|
18
|
+
root: '/api',
|
|
19
|
+
port: 1112,
|
|
20
|
+
api: {
|
|
21
|
+
GET: {
|
|
22
|
+
'/entities': (0, create_get_collection_endpoint_1.createGetCollectionEndpoint)({ model: utils_2.MockClass, primaryKey: 'id' }),
|
|
23
|
+
},
|
|
24
|
+
},
|
|
25
|
+
});
|
|
26
|
+
await addMockEntities(i);
|
|
27
|
+
const count = await i.getDataSetFor(utils_2.MockClass, 'id').count(i);
|
|
28
|
+
const allEntities = await i.getDataSetFor(utils_2.MockClass, 'id').find(i, {});
|
|
29
|
+
const response = await (0, got_1.default)('http://127.0.0.1:1112/api/entities', { method: 'GET' });
|
|
30
|
+
const json = JSON.parse(response.body);
|
|
31
|
+
expect(json.count).toBe(count);
|
|
32
|
+
expect(json.entries).toEqual(allEntities);
|
|
33
|
+
});
|
|
34
|
+
});
|
|
35
|
+
it('Should return entities in order', async () => {
|
|
36
|
+
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
37
|
+
(0, utils_2.setupContext)(i);
|
|
38
|
+
await i.useRestService({
|
|
39
|
+
root: '/api',
|
|
40
|
+
port: 1113,
|
|
41
|
+
api: {
|
|
42
|
+
GET: {
|
|
43
|
+
'/entities': (0, create_get_collection_endpoint_1.createGetCollectionEndpoint)({ model: utils_2.MockClass, primaryKey: 'id' }),
|
|
44
|
+
},
|
|
45
|
+
},
|
|
46
|
+
});
|
|
47
|
+
await addMockEntities(i);
|
|
48
|
+
const findOptions = { order: { value: 'ASC' } };
|
|
49
|
+
const count = await i.getDataSetFor(utils_2.MockClass, 'id').count(i, findOptions.filter);
|
|
50
|
+
const orderedEntities = await i.getDataSetFor(utils_2.MockClass, 'id').find(i, findOptions);
|
|
51
|
+
const response = await (0, got_1.default)(`http://127.0.0.1:1113/api/entities?${(0, rest_1.serializeToQueryString)({ findOptions })}`, {
|
|
52
|
+
method: 'GET',
|
|
53
|
+
});
|
|
54
|
+
const json = JSON.parse(response.body);
|
|
55
|
+
expect(json.count).toBe(count);
|
|
56
|
+
expect(json.entries).toEqual(orderedEntities);
|
|
57
|
+
});
|
|
58
|
+
});
|
|
59
|
+
it('Should return entities with filtering', async () => {
|
|
60
|
+
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
61
|
+
(0, utils_2.setupContext)(i);
|
|
62
|
+
await i.useRestService({
|
|
63
|
+
root: '/api',
|
|
64
|
+
port: 1113,
|
|
65
|
+
api: {
|
|
66
|
+
GET: {
|
|
67
|
+
'/entities': (0, create_get_collection_endpoint_1.createGetCollectionEndpoint)({ model: utils_2.MockClass, primaryKey: 'id' }),
|
|
68
|
+
},
|
|
69
|
+
},
|
|
70
|
+
});
|
|
71
|
+
await addMockEntities(i);
|
|
72
|
+
const findOptions = {
|
|
73
|
+
filter: { id: { $ne: 'mock2' } },
|
|
74
|
+
};
|
|
75
|
+
const count = await i.getDataSetFor(utils_2.MockClass, 'id').count(i, findOptions.filter);
|
|
76
|
+
const filteredEntities = await i.getDataSetFor(utils_2.MockClass, 'id').find(i, findOptions);
|
|
77
|
+
expect(filteredEntities).not.toContainEqual({ id: 'mock2', value: '3' });
|
|
78
|
+
const response = await (0, got_1.default)(`http://127.0.0.1:1113/api/entities?${(0, rest_1.serializeToQueryString)({ findOptions })}`, {
|
|
79
|
+
method: 'GET',
|
|
80
|
+
});
|
|
81
|
+
const json = JSON.parse(response.body);
|
|
82
|
+
expect(json.count).toBe(count);
|
|
83
|
+
expect(json.entries).toEqual(filteredEntities);
|
|
84
|
+
});
|
|
85
|
+
});
|
|
86
|
+
it('Should return entities with selecting specific fields', async () => {
|
|
87
|
+
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
88
|
+
(0, utils_2.setupContext)(i);
|
|
89
|
+
await i.useRestService({
|
|
90
|
+
root: '/api',
|
|
91
|
+
port: 1113,
|
|
92
|
+
api: {
|
|
93
|
+
GET: {
|
|
94
|
+
'/entities': (0, create_get_collection_endpoint_1.createGetCollectionEndpoint)({ model: utils_2.MockClass, primaryKey: 'id' }),
|
|
95
|
+
},
|
|
96
|
+
},
|
|
97
|
+
});
|
|
98
|
+
await addMockEntities(i);
|
|
99
|
+
const findOptions = {
|
|
100
|
+
select: ['id'],
|
|
101
|
+
};
|
|
102
|
+
const count = await i.getDataSetFor(utils_2.MockClass, 'id').count(i, findOptions.filter);
|
|
103
|
+
const selectedEntities = await i.getDataSetFor(utils_2.MockClass, 'id').find(i, findOptions);
|
|
104
|
+
selectedEntities.forEach((e) => expect(e.value).toBeUndefined());
|
|
105
|
+
const response = await (0, got_1.default)(`http://127.0.0.1:1113/api/entities?${(0, rest_1.serializeToQueryString)({ findOptions })}`, {
|
|
106
|
+
method: 'GET',
|
|
107
|
+
});
|
|
108
|
+
const json = JSON.parse(response.body);
|
|
109
|
+
expect(json.count).toBe(count);
|
|
110
|
+
expect(json.entries).toEqual(selectedEntities);
|
|
111
|
+
});
|
|
112
|
+
});
|
|
113
|
+
it('Should return entities with top/skip', async () => {
|
|
114
|
+
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
115
|
+
(0, utils_2.setupContext)(i);
|
|
116
|
+
await i.useRestService({
|
|
117
|
+
root: '/api',
|
|
118
|
+
port: 1113,
|
|
119
|
+
api: {
|
|
120
|
+
GET: {
|
|
121
|
+
'/entities': (0, create_get_collection_endpoint_1.createGetCollectionEndpoint)({ model: utils_2.MockClass, primaryKey: 'id' }),
|
|
122
|
+
},
|
|
123
|
+
},
|
|
124
|
+
});
|
|
125
|
+
await addMockEntities(i);
|
|
126
|
+
const findOptions = {
|
|
127
|
+
skip: 1,
|
|
128
|
+
top: 2,
|
|
129
|
+
};
|
|
130
|
+
const count = await i.getDataSetFor(utils_2.MockClass, 'id').count(i, findOptions.filter);
|
|
131
|
+
const topSkipEntities = await i.getDataSetFor(utils_2.MockClass, 'id').find(i, findOptions);
|
|
132
|
+
expect(topSkipEntities).not.toContainEqual({ id: 'mock1', value: '4' });
|
|
133
|
+
expect(topSkipEntities).not.toContainEqual({ id: 'mock4', value: '1' });
|
|
134
|
+
const response = await (0, got_1.default)(`http://127.0.0.1:1113/api/entities?${(0, rest_1.serializeToQueryString)({ findOptions })}`, {
|
|
135
|
+
method: 'GET',
|
|
136
|
+
});
|
|
137
|
+
const json = JSON.parse(response.body);
|
|
138
|
+
expect(json.count).toBe(count);
|
|
139
|
+
expect(json.entries).toEqual(topSkipEntities);
|
|
140
|
+
});
|
|
141
|
+
});
|
|
142
|
+
});
|
|
143
|
+
//# sourceMappingURL=create-get-collection-endpoint.spec.js.map
|