@furystack/rest-service 6.2.23 → 7.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm/actions/error-action.js +25 -0
- package/esm/actions/error-action.js.map +1 -0
- package/esm/actions/get-current-user.js +12 -0
- package/esm/actions/get-current-user.js.map +1 -0
- package/esm/actions/index.js +7 -0
- package/esm/actions/index.js.map +1 -0
- package/esm/actions/is-authenticated.js +13 -0
- package/esm/actions/is-authenticated.js.map +1 -0
- package/esm/actions/login.js +22 -0
- package/esm/actions/login.js.map +1 -0
- package/esm/actions/logout.js +15 -0
- package/esm/actions/logout.js.map +1 -0
- package/esm/actions/not-found-action.js +10 -0
- package/esm/actions/not-found-action.js.map +1 -0
- package/{dist → esm}/api-manager.js +29 -32
- package/esm/api-manager.js.map +1 -0
- package/esm/authenticate.js +16 -0
- package/esm/authenticate.js.map +1 -0
- package/esm/authorize.js +19 -0
- package/esm/authorize.js.map +1 -0
- package/esm/endpoint-generators/create-delete-endpoint.js +20 -0
- package/esm/endpoint-generators/create-delete-endpoint.js.map +1 -0
- package/esm/endpoint-generators/create-get-collection-endpoint.js +22 -0
- package/esm/endpoint-generators/create-get-collection-endpoint.js.map +1 -0
- package/esm/endpoint-generators/create-get-entity-endpoint.js +25 -0
- package/esm/endpoint-generators/create-get-entity-endpoint.js.map +1 -0
- package/esm/endpoint-generators/create-patch-endpoint.js +22 -0
- package/esm/endpoint-generators/create-patch-endpoint.js.map +1 -0
- package/esm/endpoint-generators/create-post-endpoint.js +25 -0
- package/esm/endpoint-generators/create-post-endpoint.js.map +1 -0
- package/esm/endpoint-generators/index.js +6 -0
- package/esm/endpoint-generators/index.js.map +1 -0
- package/esm/endpoint-generators/utils.js +23 -0
- package/esm/endpoint-generators/utils.js.map +1 -0
- package/esm/helpers.js +28 -0
- package/esm/helpers.js.map +1 -0
- package/{dist → esm}/http-authentication-settings.js +8 -11
- package/esm/http-authentication-settings.js.map +1 -0
- package/{dist → esm}/http-user-context.js +19 -25
- package/esm/http-user-context.js.map +1 -0
- package/esm/incoming-message-extensions.js +11 -0
- package/esm/incoming-message-extensions.js.map +1 -0
- package/esm/index.js +19 -0
- package/esm/index.js.map +1 -0
- package/{dist → esm}/mime-types.js +5 -12
- package/esm/mime-types.js.map +1 -0
- package/esm/models/cors-options.js +2 -0
- package/esm/models/default-session.js +6 -0
- package/{dist → esm}/models/default-session.js.map +1 -1
- package/esm/models/index.js +3 -0
- package/esm/models/index.js.map +1 -0
- package/esm/request-action-implementation.js +34 -0
- package/esm/request-action-implementation.js.map +1 -0
- package/esm/schema-validator/index.js +3 -0
- package/esm/schema-validator/index.js.map +1 -0
- package/esm/schema-validator/schema-validation-error.js +11 -0
- package/esm/schema-validator/schema-validation-error.js.map +1 -0
- package/{dist → esm}/schema-validator/schema-validator.js +7 -14
- package/esm/schema-validator/schema-validator.js.map +1 -0
- package/{dist → esm}/schema-validator/validate-examples.js +1 -4
- package/esm/schema-validator/validate-examples.js.map +1 -0
- package/{dist → esm}/server-manager.js +7 -13
- package/esm/server-manager.js.map +1 -0
- package/esm/server-response-extensions.js +12 -0
- package/esm/server-response-extensions.js.map +1 -0
- package/{dist → esm}/static-server-manager.js +16 -19
- package/esm/static-server-manager.js.map +1 -0
- package/{dist → esm}/utils.js +3 -8
- package/esm/utils.js.map +1 -0
- package/esm/validate.integration.schema.js +2 -0
- package/{dist → esm}/validate.js +3 -7
- package/esm/validate.js.map +1 -0
- package/package.json +30 -13
- 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.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.map +0 -1
- 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.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/default-session.js +0 -10
- 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.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.map +0 -1
- 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.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.map +0 -1
- package/dist/validate.integration.schema.js +0 -3
- package/dist/validate.integration.spec.js +0 -216
- package/dist/validate.integration.spec.js.map +0 -1
- 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
- /package/{dist → esm}/models/cors-options.js.map +0 -0
- /package/{dist → esm}/validate.integration.schema.js.map +0 -0
- /package/{dist → esm}/validate.integration.spec.schema.json +0 -0
package/dist/actions/login.js
DELETED
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.LoginAction = void 0;
|
|
4
|
-
const http_user_context_1 = require("../http-user-context");
|
|
5
|
-
require("../helpers");
|
|
6
|
-
const rest_1 = require("@furystack/rest");
|
|
7
|
-
const request_action_implementation_1 = require("../request-action-implementation");
|
|
8
|
-
/**
|
|
9
|
-
* Action that logs in the current user
|
|
10
|
-
* Should be called with a JSON Post body with ``username`` and ``password`` fields.
|
|
11
|
-
* Returns the current user instance
|
|
12
|
-
*/
|
|
13
|
-
const LoginAction = async ({ injector, getBody, response }) => {
|
|
14
|
-
const userContext = injector.getInstance(http_user_context_1.HttpUserContext);
|
|
15
|
-
const body = await getBody();
|
|
16
|
-
try {
|
|
17
|
-
const user = await userContext.authenticateUser(body.username, body.password);
|
|
18
|
-
await userContext.cookieLogin(user, response);
|
|
19
|
-
return (0, request_action_implementation_1.JsonResult)(user, 200);
|
|
20
|
-
}
|
|
21
|
-
catch (error) {
|
|
22
|
-
throw new rest_1.RequestError('Login Failed', 400);
|
|
23
|
-
}
|
|
24
|
-
};
|
|
25
|
-
exports.LoginAction = LoginAction;
|
|
26
|
-
//# sourceMappingURL=login.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"login.js","sourceRoot":"","sources":["../../src/actions/login.ts"],"names":[],"mappings":";;;AAAA,4DAAsD;AACtD,sBAAmB;AAEnB,0CAA8C;AAE9C,oFAA6D;AAE7D;;;;GAIG;AAEI,MAAM,WAAW,GAGnB,KAAK,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE;IAC7C,MAAM,WAAW,GAAG,QAAQ,CAAC,WAAW,CAAC,mCAAe,CAAC,CAAA;IACzD,MAAM,IAAI,GAAG,MAAM,OAAO,EAAE,CAAA;IAC5B,IAAI;QACF,MAAM,IAAI,GAAG,MAAM,WAAW,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAA;QAC7E,MAAM,WAAW,CAAC,WAAW,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAA;QAC7C,OAAO,IAAA,0CAAU,EAAC,IAAI,EAAE,GAAG,CAAC,CAAA;KAC7B;IAAC,OAAO,KAAK,EAAE;QACd,MAAM,IAAI,mBAAY,CAAC,cAAc,EAAE,GAAG,CAAC,CAAA;KAC5C;AACH,CAAC,CAAA;AAbY,QAAA,WAAW,eAavB"}
|
|
@@ -1,23 +0,0 @@
|
|
|
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 logout_1 = require("./logout");
|
|
7
|
-
describe('LogoutAction', () => {
|
|
8
|
-
const request = { url: 'https://google.com' };
|
|
9
|
-
const response = {};
|
|
10
|
-
it('exec', async () => {
|
|
11
|
-
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
12
|
-
const cookieLogout = jest.fn(async () => true);
|
|
13
|
-
i.setExplicitInstance({
|
|
14
|
-
cookieLogout,
|
|
15
|
-
}, http_user_context_1.HttpUserContext);
|
|
16
|
-
const result = await (0, logout_1.LogoutAction)({ request, response, injector: i });
|
|
17
|
-
expect(result.statusCode).toBe(200);
|
|
18
|
-
expect(result.chunk).toBe(undefined);
|
|
19
|
-
expect(cookieLogout).toBeCalled();
|
|
20
|
-
});
|
|
21
|
-
});
|
|
22
|
-
});
|
|
23
|
-
//# sourceMappingURL=logout-action.spec.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"logout-action.spec.js","sourceRoot":"","sources":["../../src/actions/logout-action.spec.ts"],"names":[],"mappings":";;AAAA,8CAA4C;AAC5C,4CAA6C;AAC7C,4DAAsD;AACtD,qCAAuC;AAGvC,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;IAC5B,MAAM,OAAO,GAAG,EAAE,GAAG,EAAE,oBAAoB,EAAqB,CAAA;IAChE,MAAM,QAAQ,GAAG,EAAoB,CAAA;IAErC,EAAE,CAAC,MAAM,EAAE,KAAK,IAAI,EAAE;QACpB,MAAM,IAAA,kBAAU,EAAC,IAAI,iBAAQ,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;YAC3C,MAAM,YAAY,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,IAAI,EAAE,CAAC,IAAI,CAAC,CAAA;YAC9C,CAAC,CAAC,mBAAmB,CACnB;gBACE,YAAY;aACb,EACD,mCAAe,CAChB,CAAA;YAED,MAAM,MAAM,GAAG,MAAM,IAAA,qBAAY,EAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,EAAS,CAAC,CAAA;YAC5E,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,YAAY,CAAC,CAAC,UAAU,EAAE,CAAA;QACnC,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
package/dist/actions/logout.js
DELETED
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.LogoutAction = void 0;
|
|
4
|
-
const http_user_context_1 = require("../http-user-context");
|
|
5
|
-
const request_action_implementation_1 = require("../request-action-implementation");
|
|
6
|
-
/**
|
|
7
|
-
* Action that logs out the current user
|
|
8
|
-
*
|
|
9
|
-
* @param root0 The Options object
|
|
10
|
-
* @param root0.injector The injector from the context
|
|
11
|
-
* @param root0.request The current Request object
|
|
12
|
-
* @param root0.response The Response object
|
|
13
|
-
* @returns An empty result that indicates the success
|
|
14
|
-
*/
|
|
15
|
-
const LogoutAction = async ({ injector, request, response }) => {
|
|
16
|
-
await injector.getInstance(http_user_context_1.HttpUserContext).cookieLogout(request, response);
|
|
17
|
-
return (0, request_action_implementation_1.EmptyResult)();
|
|
18
|
-
};
|
|
19
|
-
exports.LogoutAction = LogoutAction;
|
|
20
|
-
//# sourceMappingURL=logout.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"logout.js","sourceRoot":"","sources":["../../src/actions/logout.ts"],"names":[],"mappings":";;;AAAA,4DAAsD;AAEtD,oFAA8D;AAE9D;;;;;;;;GAQG;AACI,MAAM,YAAY,GAAuC,KAAK,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE;IACxG,MAAM,QAAQ,CAAC,WAAW,CAAC,mCAAe,CAAC,CAAC,YAAY,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAA;IAC3E,OAAO,IAAA,2CAAW,GAAE,CAAA;AACtB,CAAC,CAAA;AAHY,QAAA,YAAY,gBAGxB"}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.NotFoundAction = void 0;
|
|
4
|
-
const request_action_implementation_1 = require("../request-action-implementation");
|
|
5
|
-
/**
|
|
6
|
-
* @returns The standard Not Found action result
|
|
7
|
-
*/
|
|
8
|
-
const NotFoundAction = async () => {
|
|
9
|
-
return (0, request_action_implementation_1.JsonResult)({
|
|
10
|
-
error: 'Content not found',
|
|
11
|
-
}, 404);
|
|
12
|
-
};
|
|
13
|
-
exports.NotFoundAction = NotFoundAction;
|
|
14
|
-
//# sourceMappingURL=not-found-action.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"not-found-action.js","sourceRoot":"","sources":["../../src/actions/not-found-action.ts"],"names":[],"mappings":";;;AACA,oFAA6D;AAE7D;;GAEG;AACI,MAAM,cAAc,GAAiD,KAAK,IAAI,EAAE;IACrF,OAAO,IAAA,0CAAU,EACf;QACE,KAAK,EAAE,mBAAmB;KAC3B,EACD,GAAG,CACJ,CAAA;AACH,CAAC,CAAA;AAPY,QAAA,cAAc,kBAO1B"}
|
|
@@ -1,17 +0,0 @@
|
|
|
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 not_found_action_1 = require("./not-found-action");
|
|
6
|
-
describe('NotFoundAction tests', () => {
|
|
7
|
-
const request = { url: 'https://google.com' };
|
|
8
|
-
const response = {};
|
|
9
|
-
it('exec', async () => {
|
|
10
|
-
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
11
|
-
const result = await (0, not_found_action_1.NotFoundAction)({ injector: i, request, response });
|
|
12
|
-
expect(result.statusCode).toBe(404);
|
|
13
|
-
expect(result.chunk).toEqual({ error: 'Content not found' });
|
|
14
|
-
});
|
|
15
|
-
});
|
|
16
|
-
});
|
|
17
|
-
//# sourceMappingURL=not-found-action.spec.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"not-found-action.spec.js","sourceRoot":"","sources":["../../src/actions/not-found-action.spec.ts"],"names":[],"mappings":";;AAAA,8CAA4C;AAC5C,4CAA6C;AAC7C,yDAAmD;AAGnD,QAAQ,CAAC,sBAAsB,EAAE,GAAG,EAAE;IACpC,MAAM,OAAO,GAAG,EAAE,GAAG,EAAE,oBAAoB,EAAqB,CAAA;IAChE,MAAM,QAAQ,GAAG,EAAoB,CAAA;IAErC,EAAE,CAAC,MAAM,EAAE,KAAK,IAAI,EAAE;QACpB,MAAM,IAAA,kBAAU,EAAC,IAAI,iBAAQ,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;YAC3C,MAAM,MAAM,GAAG,MAAM,IAAA,iCAAc,EAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC,CAAA;YACvE,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,mBAAmB,EAAE,CAAC,CAAA;QAC9D,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -1,99 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const utils_1 = require("./utils");
|
|
4
|
-
describe('AddCorsHeaders', () => {
|
|
5
|
-
const utils = new utils_1.Utils();
|
|
6
|
-
it('Should NOT add headers for non-cross-site requests', () => {
|
|
7
|
-
const req = {
|
|
8
|
-
headers: { origin: 'http://localhost/', host: 'http://localhost' },
|
|
9
|
-
};
|
|
10
|
-
const resp = {
|
|
11
|
-
setHeader: jest.fn(),
|
|
12
|
-
};
|
|
13
|
-
utils.addCorsHeaders({
|
|
14
|
-
origins: ['https://google.com'],
|
|
15
|
-
credentials: true,
|
|
16
|
-
headers: ['my-custom-header', 'header-2'],
|
|
17
|
-
}, req, resp);
|
|
18
|
-
expect(resp.setHeader).not.toBeCalled();
|
|
19
|
-
});
|
|
20
|
-
it('Should NOT add headers for not-enabled hosts', () => {
|
|
21
|
-
const req = {
|
|
22
|
-
headers: { origin: 'http://localhost/', host: 'http://google.com' },
|
|
23
|
-
};
|
|
24
|
-
const resp = {
|
|
25
|
-
setHeader: jest.fn(),
|
|
26
|
-
};
|
|
27
|
-
utils.addCorsHeaders({
|
|
28
|
-
origins: ['https://github.com'],
|
|
29
|
-
credentials: true,
|
|
30
|
-
headers: ['my-custom-header', 'header-2'],
|
|
31
|
-
}, req, resp);
|
|
32
|
-
expect(resp.setHeader).not.toBeCalled();
|
|
33
|
-
});
|
|
34
|
-
it('Should add allow-origin header for enabled hosts', () => {
|
|
35
|
-
const req = {
|
|
36
|
-
headers: { origin: 'http://localhost/', host: 'http://github.com' },
|
|
37
|
-
};
|
|
38
|
-
const resp = {
|
|
39
|
-
setHeader: jest.fn(),
|
|
40
|
-
};
|
|
41
|
-
utils.addCorsHeaders({
|
|
42
|
-
origins: ['http://localhost/'],
|
|
43
|
-
}, req, resp);
|
|
44
|
-
expect(resp.setHeader).toBeCalledTimes(1);
|
|
45
|
-
expect(resp.setHeader).toBeCalledWith('Access-Control-Allow-Origin', 'http://localhost/');
|
|
46
|
-
});
|
|
47
|
-
it('Should add allow-credentials header if enabled', () => {
|
|
48
|
-
const req = {
|
|
49
|
-
headers: { origin: 'http://localhost/', host: 'http://github.com' },
|
|
50
|
-
};
|
|
51
|
-
const resp = {
|
|
52
|
-
setHeader: jest.fn(),
|
|
53
|
-
};
|
|
54
|
-
utils.addCorsHeaders({
|
|
55
|
-
origins: ['http://localhost/'],
|
|
56
|
-
credentials: true,
|
|
57
|
-
// headers: ['my-custom-header', 'header-2'],
|
|
58
|
-
// methods: ['DELETE', 'GET', 'POST', 'PUT', 'PATCH'],
|
|
59
|
-
}, req, resp);
|
|
60
|
-
expect(resp.setHeader).toBeCalledTimes(2);
|
|
61
|
-
expect(resp.setHeader).toBeCalledWith('Access-Control-Allow-Origin', 'http://localhost/');
|
|
62
|
-
expect(resp.setHeader).toBeCalledWith('Access-Control-Allow-Credentials', 'true');
|
|
63
|
-
// expect(resp.setHeader).toBeCalledWith('Access-Control-Allow-Headers', 'my-custom-header, header-2')
|
|
64
|
-
// expect(resp.setHeader).toBeCalledWith('Access-Control-Allow-Methods', 'DELETE, GET, POST, PUT, PATCH')
|
|
65
|
-
});
|
|
66
|
-
it('Should add allow-headers header if enabled', () => {
|
|
67
|
-
const req = {
|
|
68
|
-
headers: { origin: 'http://localhost/', host: 'http://github.com' },
|
|
69
|
-
};
|
|
70
|
-
const resp = {
|
|
71
|
-
setHeader: jest.fn(),
|
|
72
|
-
};
|
|
73
|
-
utils.addCorsHeaders({
|
|
74
|
-
origins: ['http://localhost/'],
|
|
75
|
-
headers: ['my-custom-header', 'header-2'],
|
|
76
|
-
// methods: ['DELETE', 'GET', 'POST', 'PUT', 'PATCH'],
|
|
77
|
-
}, req, resp);
|
|
78
|
-
expect(resp.setHeader).toBeCalledTimes(2);
|
|
79
|
-
expect(resp.setHeader).toBeCalledWith('Access-Control-Allow-Origin', 'http://localhost/');
|
|
80
|
-
expect(resp.setHeader).toBeCalledWith('Access-Control-Allow-Headers', 'my-custom-header, header-2');
|
|
81
|
-
// expect(resp.setHeader).toBeCalledWith('Access-Control-Allow-Methods', 'DELETE, GET, POST, PUT, PATCH')
|
|
82
|
-
});
|
|
83
|
-
it('Should add allow-methods header if enabled', () => {
|
|
84
|
-
const req = {
|
|
85
|
-
headers: { origin: 'http://localhost/', host: 'http://github.com' },
|
|
86
|
-
};
|
|
87
|
-
const resp = {
|
|
88
|
-
setHeader: jest.fn(),
|
|
89
|
-
};
|
|
90
|
-
utils.addCorsHeaders({
|
|
91
|
-
origins: ['http://localhost/'],
|
|
92
|
-
methods: ['DELETE', 'GET', 'POST', 'PUT', 'PATCH'],
|
|
93
|
-
}, req, resp);
|
|
94
|
-
expect(resp.setHeader).toBeCalledTimes(2);
|
|
95
|
-
expect(resp.setHeader).toBeCalledWith('Access-Control-Allow-Origin', 'http://localhost/');
|
|
96
|
-
expect(resp.setHeader).toBeCalledWith('Access-Control-Allow-Methods', 'DELETE, GET, POST, PUT, PATCH');
|
|
97
|
-
});
|
|
98
|
-
});
|
|
99
|
-
//# sourceMappingURL=add-cors-header.spec.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"add-cors-header.spec.js","sourceRoot":"","sources":["../src/add-cors-header.spec.ts"],"names":[],"mappings":"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"}
|
package/dist/api-manager.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"api-manager.js","sourceRoot":"","sources":["../src/api-manager.ts"],"names":[],"mappings":"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"}
|
package/dist/authenticate.js
DELETED
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Authenticate = void 0;
|
|
4
|
-
const core_1 = require("@furystack/core");
|
|
5
|
-
const utils_1 = require("@furystack/utils");
|
|
6
|
-
const http_user_context_1 = require("./http-user-context");
|
|
7
|
-
const request_action_implementation_1 = require("./request-action-implementation");
|
|
8
|
-
const Authenticate = () => (action) => {
|
|
9
|
-
return async (args) => {
|
|
10
|
-
const { injector } = args;
|
|
11
|
-
const authenticated = await (0, core_1.isAuthenticated)(injector);
|
|
12
|
-
if (!authenticated) {
|
|
13
|
-
await (0, utils_1.sleepAsync)(Math.random() * 1000);
|
|
14
|
-
return (0, request_action_implementation_1.JsonResult)({ error: 'unauthorized' }, 401, injector.getInstance(http_user_context_1.HttpUserContext).authentication.enableBasicAuth ? { 'WWW-Authenticate': 'Basic' } : {});
|
|
15
|
-
}
|
|
16
|
-
return (await action(args));
|
|
17
|
-
};
|
|
18
|
-
};
|
|
19
|
-
exports.Authenticate = Authenticate;
|
|
20
|
-
//# sourceMappingURL=authenticate.js.map
|
package/dist/authenticate.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"authenticate.js","sourceRoot":"","sources":["../src/authenticate.ts"],"names":[],"mappings":";;;AAAA,0CAAiD;AACjD,4CAA6C;AAC7C,2DAAqD;AAErD,mFAA4D;AAErD,MAAM,YAAY,GACvB,GAAG,EAAE,CACL,CAAgC,MAAwB,EAAoB,EAAE;IAC5E,OAAO,KAAK,EAAE,IAA6B,EAA4B,EAAE;QACvE,MAAM,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAA;QACzB,MAAM,aAAa,GAAG,MAAM,IAAA,sBAAe,EAAC,QAAQ,CAAC,CAAA;QACrD,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,QAAQ,CAAC,WAAW,CAAC,mCAAe,CAAC,CAAC,cAAc,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,kBAAkB,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CAC9E,CAAA;SAChC;QACD,OAAO,CAAC,MAAM,MAAM,CAAC,IAAI,CAAC,CAAQ,CAAA;IACpC,CAAC,CAAA;AACH,CAAC,CAAA;AAhBU,QAAA,YAAY,gBAgBtB"}
|
|
@@ -1,59 +0,0 @@
|
|
|
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 () => (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 () => (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 () => (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
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"authenticate.spec.js","sourceRoot":"","sources":["../src/authenticate.spec.ts"],"names":[],"mappings":"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"}
|
package/dist/authorize.js
DELETED
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Authorize = void 0;
|
|
4
|
-
const core_1 = require("@furystack/core");
|
|
5
|
-
const utils_1 = require("@furystack/utils");
|
|
6
|
-
const request_action_implementation_1 = require("./request-action-implementation");
|
|
7
|
-
const Authorize = (...roles) => (action) => {
|
|
8
|
-
return async (options) => {
|
|
9
|
-
try {
|
|
10
|
-
const authorized = await (0, core_1.isAuthorized)(options.injector, ...roles);
|
|
11
|
-
if (!authorized) {
|
|
12
|
-
await (0, utils_1.sleepAsync)(Math.random() * 1000);
|
|
13
|
-
return (0, request_action_implementation_1.JsonResult)({ error: 'forbidden' }, 403);
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
|
-
catch (error) {
|
|
17
|
-
return (0, request_action_implementation_1.JsonResult)({ error: 'forbidden' }, 403);
|
|
18
|
-
}
|
|
19
|
-
return (await action(options));
|
|
20
|
-
};
|
|
21
|
-
};
|
|
22
|
-
exports.Authorize = Authorize;
|
|
23
|
-
//# sourceMappingURL=authorize.js.map
|
package/dist/authorize.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"authorize.js","sourceRoot":"","sources":["../src/authorize.ts"],"names":[],"mappings":";;;AAAA,0CAA8C;AAC9C,4CAA6C;AAE7C,mFAA4D;AAErD,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,IAAA,mBAAY,EAAC,OAAO,CAAC,QAAQ,EAAE,GAAG,KAAK,CAAC,CAAA;YACjE,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"}
|
package/dist/authorize.spec.js
DELETED
|
@@ -1,55 +0,0 @@
|
|
|
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 () => (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 () => (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 () => (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
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"authorize.spec.js","sourceRoot":"","sources":["../src/authorize.spec.ts"],"names":[],"mappings":";;AACA,8CAA4C;AAC5C,4CAA6C;AAE7C,0CAAiD;AACjD,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,IAAI,EAAE,CAAC,IAAA,2CAAW,GAAE,CAAC,CAAA;YAClE,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,IAAI,EAAE,CAAC,IAAA,2CAAW,GAAE,CAAC,CAAA;YAClE,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,IAAI,EAAE,CAAC,IAAA,2CAAW,GAAE,CAAC,CAAA;YAClE,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"}
|
|
@@ -1,25 +0,0 @@
|
|
|
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
|
-
const repository_1 = require("@furystack/repository");
|
|
7
|
-
/**
|
|
8
|
-
* Creates a DELETE endpoint for removing entities
|
|
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 a boolean that indicates the success
|
|
14
|
-
*/
|
|
15
|
-
const createDeleteEndpoint = (options) => {
|
|
16
|
-
const endpoint = async ({ injector, getUrlParams }) => {
|
|
17
|
-
const { id } = getUrlParams();
|
|
18
|
-
const dataSet = (0, repository_1.getRepository)(injector).getDataSetFor(options.model, options.primaryKey);
|
|
19
|
-
await dataSet.remove(injector, id);
|
|
20
|
-
return (0, request_action_implementation_1.JsonResult)({}, 204);
|
|
21
|
-
};
|
|
22
|
-
return endpoint;
|
|
23
|
-
};
|
|
24
|
-
exports.createDeleteEndpoint = createDeleteEndpoint;
|
|
25
|
-
//# sourceMappingURL=create-delete-endpoint.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"create-delete-endpoint.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-delete-endpoint.ts"],"names":[],"mappings":";;;AAEA,iCAA8B;AAE9B,oFAA6D;AAC7D,sDAAqD;AAErD;;;;;;;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,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,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"}
|
|
@@ -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"}
|