@furystack/rest-service 5.0.4 → 6.0.2
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/dist/actions/get-current-user.js +2 -1
- package/dist/actions/get-current-user.js.map +1 -1
- package/dist/actions/is-authenticated.js +3 -2
- package/dist/actions/is-authenticated.js.map +1 -1
- package/dist/actions/login.js +1 -1
- package/dist/actions/login.js.map +1 -1
- package/dist/authenticate.js +4 -4
- package/dist/authenticate.js.map +1 -1
- package/dist/authorize.js +2 -1
- package/dist/authorize.js.map +1 -1
- package/dist/endpoint-generators/create-delete-endpoint.js +2 -1
- package/dist/endpoint-generators/create-delete-endpoint.js.map +1 -1
- package/dist/endpoint-generators/create-delete-endpoint.spec.js +7 -4
- package/dist/endpoint-generators/create-delete-endpoint.spec.js.map +1 -1
- package/dist/endpoint-generators/create-get-collection-endpoint.js +2 -1
- package/dist/endpoint-generators/create-get-collection-endpoint.js.map +1 -1
- package/dist/endpoint-generators/create-get-collection-endpoint.spec.js +23 -16
- package/dist/endpoint-generators/create-get-collection-endpoint.spec.js.map +1 -1
- package/dist/endpoint-generators/create-get-entity-endpoint.js +2 -1
- package/dist/endpoint-generators/create-get-entity-endpoint.js.map +1 -1
- package/dist/endpoint-generators/create-get-entity-endpoint.spec.js +10 -5
- package/dist/endpoint-generators/create-get-entity-endpoint.spec.js.map +1 -1
- package/dist/endpoint-generators/create-patch-endpoint.js +2 -1
- package/dist/endpoint-generators/create-patch-endpoint.js.map +1 -1
- package/dist/endpoint-generators/create-patch-endpoint.spec.js +7 -4
- package/dist/endpoint-generators/create-patch-endpoint.spec.js.map +1 -1
- package/dist/endpoint-generators/create-post-endpoint.js +2 -1
- package/dist/endpoint-generators/create-post-endpoint.js.map +1 -1
- package/dist/endpoint-generators/create-post-endpoint.spec.js +5 -2
- package/dist/endpoint-generators/create-post-endpoint.spec.js.map +1 -1
- package/dist/endpoint-generators/utils.js +5 -4
- package/dist/endpoint-generators/utils.js.map +1 -1
- package/dist/helpers.js +25 -0
- package/dist/helpers.js.map +1 -0
- package/dist/helpers.spec.js +19 -0
- package/dist/helpers.spec.js.map +1 -0
- package/dist/http-user-context.js +2 -2
- package/dist/http-user-context.js.map +1 -1
- package/dist/http-user-context.spec.js +4 -6
- package/dist/http-user-context.spec.js.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/rest-service.integration.spec.js +33 -32
- package/dist/rest-service.integration.spec.js.map +1 -1
- package/dist/rest.integration.test.js +7 -6
- package/dist/rest.integration.test.js.map +1 -1
- package/dist/validate.integration.spec.js +4 -2
- package/dist/validate.integration.spec.js.map +1 -1
- package/package.json +14 -15
- package/src/actions/get-current-user.ts +2 -2
- package/src/actions/is-authenticated.ts +3 -2
- package/src/actions/login.ts +1 -1
- package/src/authenticate.ts +4 -4
- package/src/authorize.ts +2 -1
- package/src/endpoint-generators/create-delete-endpoint.spec.ts +7 -4
- package/src/endpoint-generators/create-delete-endpoint.ts +2 -1
- package/src/endpoint-generators/create-get-collection-endpoint.spec.ts +23 -16
- package/src/endpoint-generators/create-get-collection-endpoint.ts +2 -1
- package/src/endpoint-generators/create-get-entity-endpoint.spec.ts +10 -5
- package/src/endpoint-generators/create-get-entity-endpoint.ts +2 -1
- package/src/endpoint-generators/create-patch-endpoint.spec.ts +7 -4
- package/src/endpoint-generators/create-patch-endpoint.ts +2 -1
- package/src/endpoint-generators/create-post-endpoint.spec.ts +5 -2
- package/src/endpoint-generators/create-post-endpoint.ts +2 -1
- package/src/endpoint-generators/utils.ts +23 -23
- package/src/helpers.spec.ts +24 -0
- package/src/helpers.ts +28 -0
- package/src/http-user-context.spec.ts +6 -10
- package/src/http-user-context.ts +3 -3
- package/src/index.ts +1 -1
- package/src/rest-service.integration.spec.ts +36 -36
- package/src/rest.integration.test.ts +7 -6
- package/src/validate.integration.spec.ts +5 -3
- package/{dist → types}/actions/error-action.d.ts +0 -0
- package/{dist → types}/actions/error-action.d.ts.map +0 -0
- package/{dist → types}/actions/error-action.spec.d.ts +0 -0
- package/{dist → types}/actions/error-action.spec.d.ts.map +0 -0
- package/{dist → types}/actions/get-current-user.d.ts +0 -0
- package/types/actions/get-current-user.d.ts.map +1 -0
- package/{dist → types}/actions/get-current-user.spec.d.ts +0 -0
- package/{dist → types}/actions/get-current-user.spec.d.ts.map +0 -0
- package/{dist → types}/actions/index.d.ts +0 -0
- package/{dist → types}/actions/index.d.ts.map +0 -0
- package/{dist → types}/actions/is-authenticated.d.ts +0 -0
- package/{dist → types}/actions/is-authenticated.d.ts.map +1 -1
- package/{dist → types}/actions/is-authenticated.spec.d.ts +0 -0
- package/{dist → types}/actions/is-authenticated.spec.d.ts.map +0 -0
- package/{dist → types}/actions/login-action.spec.d.ts +0 -0
- package/{dist → types}/actions/login-action.spec.d.ts.map +0 -0
- package/{dist → types}/actions/login.d.ts +1 -1
- package/types/actions/login.d.ts.map +1 -0
- package/{dist → types}/actions/logout-action.spec.d.ts +0 -0
- package/{dist → types}/actions/logout-action.spec.d.ts.map +0 -0
- package/{dist → types}/actions/logout.d.ts +0 -0
- package/{dist → types}/actions/logout.d.ts.map +0 -0
- package/{dist → types}/actions/not-found-action.d.ts +0 -0
- package/{dist → types}/actions/not-found-action.d.ts.map +0 -0
- package/{dist → types}/actions/not-found-action.spec.d.ts +0 -0
- package/{dist → types}/actions/not-found-action.spec.d.ts.map +0 -0
- package/{dist → types}/add-cors-header.spec.d.ts +0 -0
- package/{dist → types}/add-cors-header.spec.d.ts.map +0 -0
- package/{dist → types}/api-manager.d.ts +0 -0
- package/{dist → types}/api-manager.d.ts.map +0 -0
- package/{dist → types}/authenticate.d.ts +0 -0
- package/{dist → types}/authenticate.d.ts.map +1 -1
- package/{dist → types}/authenticate.spec.d.ts +0 -0
- package/{dist → types}/authenticate.spec.d.ts.map +0 -0
- package/{dist → types}/authorize.d.ts +0 -0
- package/{dist → types}/authorize.d.ts.map +1 -1
- package/{dist → types}/authorize.spec.d.ts +0 -0
- package/{dist → types}/authorize.spec.d.ts.map +0 -0
- package/{dist → types}/endpoint-generators/create-delete-endpoint.d.ts +0 -0
- package/{dist → types}/endpoint-generators/create-delete-endpoint.d.ts.map +1 -1
- package/{dist → types}/endpoint-generators/create-delete-endpoint.spec.d.ts +0 -0
- package/{dist → types}/endpoint-generators/create-delete-endpoint.spec.d.ts.map +0 -0
- package/{dist → types}/endpoint-generators/create-get-collection-endpoint.d.ts +0 -0
- package/{dist → types}/endpoint-generators/create-get-collection-endpoint.d.ts.map +1 -1
- package/{dist → types}/endpoint-generators/create-get-collection-endpoint.spec.d.ts +0 -0
- package/{dist → types}/endpoint-generators/create-get-collection-endpoint.spec.d.ts.map +0 -0
- package/{dist → types}/endpoint-generators/create-get-entity-endpoint.d.ts +0 -0
- package/{dist → types}/endpoint-generators/create-get-entity-endpoint.d.ts.map +1 -1
- package/{dist → types}/endpoint-generators/create-get-entity-endpoint.spec.d.ts +0 -0
- package/{dist → types}/endpoint-generators/create-get-entity-endpoint.spec.d.ts.map +0 -0
- package/{dist → types}/endpoint-generators/create-patch-endpoint.d.ts +0 -0
- package/{dist → types}/endpoint-generators/create-patch-endpoint.d.ts.map +1 -1
- package/{dist → types}/endpoint-generators/create-patch-endpoint.spec.d.ts +0 -0
- package/{dist → types}/endpoint-generators/create-patch-endpoint.spec.d.ts.map +0 -0
- package/{dist → types}/endpoint-generators/create-post-endpoint.d.ts +0 -0
- package/{dist → types}/endpoint-generators/create-post-endpoint.d.ts.map +1 -1
- package/{dist → types}/endpoint-generators/create-post-endpoint.spec.d.ts +0 -0
- package/{dist → types}/endpoint-generators/create-post-endpoint.spec.d.ts.map +0 -0
- package/{dist → types}/endpoint-generators/index.d.ts +0 -0
- package/{dist → types}/endpoint-generators/index.d.ts.map +0 -0
- package/{dist → types}/endpoint-generators/utils.d.ts +1 -1
- package/{dist → types}/endpoint-generators/utils.d.ts.map +1 -1
- package/types/helpers.d.ts +21 -0
- package/types/helpers.d.ts.map +1 -0
- package/types/helpers.spec.d.ts +2 -0
- package/types/helpers.spec.d.ts.map +1 -0
- package/{dist → types}/http-authentication-settings.d.ts +0 -0
- package/{dist → types}/http-authentication-settings.d.ts.map +0 -0
- package/{dist → types}/http-user-context.d.ts +1 -1
- package/{dist → types}/http-user-context.d.ts.map +1 -1
- package/{dist → types}/http-user-context.spec.d.ts +0 -1
- package/{dist → types}/http-user-context.spec.d.ts.map +1 -1
- package/{dist → types}/incoming-message-extensions.d.ts +0 -0
- package/{dist → types}/incoming-message-extensions.d.ts.map +0 -0
- package/{dist → types}/incoming-message-extensions.spec.d.ts +0 -0
- package/{dist → types}/incoming-message-extensions.spec.d.ts.map +0 -0
- package/{dist → types}/index.d.ts +1 -1
- package/types/index.d.ts.map +1 -0
- package/{dist → types}/models/cors-options.d.ts +0 -0
- package/{dist → types}/models/cors-options.d.ts.map +0 -0
- package/{dist → types}/models/default-session.d.ts +0 -0
- package/{dist → types}/models/default-session.d.ts.map +0 -0
- package/{dist → types}/models/index.d.ts +0 -0
- package/{dist → types}/models/index.d.ts.map +0 -0
- package/{dist → types}/request-action-implementation.d.ts +0 -0
- package/{dist → types}/request-action-implementation.d.ts.map +0 -0
- package/types/rest-service.integration.spec.d.ts +2 -0
- package/{dist → types}/rest-service.integration.spec.d.ts.map +1 -1
- package/{dist → types}/rest.integration.test.d.ts +1 -1
- package/types/rest.integration.test.d.ts.map +1 -0
- package/{dist → types}/schema-validator/index.d.ts +0 -0
- package/{dist → types}/schema-validator/index.d.ts.map +0 -0
- package/{dist → types}/schema-validator/schema-validation-error.d.ts +0 -0
- package/{dist → types}/schema-validator/schema-validation-error.d.ts.map +0 -0
- package/{dist → types}/schema-validator/schema-validator.d.ts +0 -0
- package/{dist → types}/schema-validator/schema-validator.d.ts.map +0 -0
- package/{dist → types}/schema-validator/schema-validator.test.d.ts +0 -0
- package/{dist → types}/schema-validator/schema-validator.test.d.ts.map +0 -0
- package/{dist → types}/schema-validator/validate-examples.d.ts +0 -0
- package/{dist → types}/schema-validator/validate-examples.d.ts.map +0 -0
- package/{dist → types}/server-manager.d.ts +0 -0
- package/{dist → types}/server-manager.d.ts.map +0 -0
- package/{dist → types}/server-response-extensions.d.ts +0 -0
- package/{dist → types}/server-response-extensions.d.ts.map +0 -0
- package/{dist → types}/server-response-extensions.spec.d.ts +0 -0
- package/{dist → types}/server-response-extensions.spec.d.ts.map +0 -0
- package/{dist → types}/utils.d.ts +0 -0
- package/{dist → types}/utils.d.ts.map +0 -0
- package/{dist → types}/validate.d.ts +0 -0
- package/{dist → types}/validate.d.ts.map +0 -0
- package/{dist → types}/validate.integration.schema.d.ts +0 -0
- package/{dist → types}/validate.integration.schema.d.ts.map +0 -0
- package/types/validate.integration.spec.d.ts +2 -0
- package/{dist → types}/validate.integration.spec.d.ts.map +1 -1
- package/dist/actions/get-current-user.d.ts.map +0 -1
- package/dist/actions/login.d.ts.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/injector-extensions.d.ts +0 -21
- package/dist/injector-extensions.d.ts.map +0 -1
- package/dist/injector-extensions.js +0 -14
- package/dist/injector-extensions.js.map +0 -1
- package/dist/injector-extensions.spec.d.ts +0 -2
- package/dist/injector-extensions.spec.d.ts.map +0 -1
- package/dist/injector-extensions.spec.js +0 -19
- package/dist/injector-extensions.spec.js.map +0 -1
- package/dist/rest-service.integration.spec.d.ts +0 -2
- package/dist/rest.integration.test.d.ts.map +0 -1
- package/dist/validate.integration.spec.d.ts +0 -2
- package/src/injector-extensions.spec.ts +0 -19
- package/src/injector-extensions.ts +0 -35
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.GetCurrentUser = void 0;
|
|
4
|
+
const core_1 = require("@furystack/core");
|
|
4
5
|
const authenticate_1 = require("../authenticate");
|
|
5
6
|
const request_action_implementation_1 = require("../request-action-implementation");
|
|
6
7
|
/**
|
|
@@ -9,7 +10,7 @@ const request_action_implementation_1 = require("../request-action-implementatio
|
|
|
9
10
|
* @param injector The injector from the current stack
|
|
10
11
|
*/
|
|
11
12
|
exports.GetCurrentUser = (0, authenticate_1.Authenticate)()(async ({ injector }) => {
|
|
12
|
-
const user = await
|
|
13
|
+
const user = await (0, core_1.getCurrentUser)(injector);
|
|
13
14
|
return (0, request_action_implementation_1.JsonResult)(user);
|
|
14
15
|
});
|
|
15
16
|
//# sourceMappingURL=get-current-user.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get-current-user.js","sourceRoot":"","sources":["../../src/actions/get-current-user.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"get-current-user.js","sourceRoot":"","sources":["../../src/actions/get-current-user.ts"],"names":[],"mappings":";;;AAAA,0CAAsD;AACtD,kDAA8C;AAC9C,oFAA4E;AAE5E;;;;GAIG;AACU,QAAA,cAAc,GAEtB,IAAA,2BAAY,GAAE,CAAC,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE;IACzC,MAAM,IAAI,GAAG,MAAM,IAAA,qBAAc,EAAC,QAAQ,CAAC,CAAA;IAC3C,OAAO,IAAA,0CAAU,EAAC,IAAI,CAAC,CAAA;AACzB,CAAC,CAAC,CAAA"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.IsAuthenticated = void 0;
|
|
4
|
+
const core_1 = require("@furystack/core");
|
|
4
5
|
const request_action_implementation_1 = require("../request-action-implementation");
|
|
5
6
|
/**
|
|
6
7
|
* Action that returns if the current user is authenticated
|
|
@@ -10,8 +11,8 @@ const request_action_implementation_1 = require("../request-action-implementatio
|
|
|
10
11
|
* @returns A standard authentication result
|
|
11
12
|
*/
|
|
12
13
|
const IsAuthenticated = async ({ injector }) => {
|
|
13
|
-
const
|
|
14
|
-
return (0, request_action_implementation_1.JsonResult)({ isAuthenticated });
|
|
14
|
+
const isAuthenticatedResult = await (0, core_1.isAuthenticated)(injector);
|
|
15
|
+
return (0, request_action_implementation_1.JsonResult)({ isAuthenticated: isAuthenticatedResult });
|
|
15
16
|
};
|
|
16
17
|
exports.IsAuthenticated = IsAuthenticated;
|
|
17
18
|
//# sourceMappingURL=is-authenticated.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"is-authenticated.js","sourceRoot":"","sources":["../../src/actions/is-authenticated.ts"],"names":[],"mappings":";;;AAAA,oFAA4E;AAE5E;;;;;;GAMG;AACI,MAAM,eAAe,GAA4D,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE;IAC7G,MAAM,
|
|
1
|
+
{"version":3,"file":"is-authenticated.js","sourceRoot":"","sources":["../../src/actions/is-authenticated.ts"],"names":[],"mappings":";;;AAAA,0CAAiD;AACjD,oFAA4E;AAE5E;;;;;;GAMG;AACI,MAAM,eAAe,GAA4D,KAAK,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE;IAC7G,MAAM,qBAAqB,GAAG,MAAM,IAAA,sBAAe,EAAC,QAAQ,CAAC,CAAA;IAC7D,OAAO,IAAA,0CAAU,EAAC,EAAE,eAAe,EAAE,qBAAqB,EAAE,CAAC,CAAA;AAC/D,CAAC,CAAA;AAHY,QAAA,eAAe,mBAG3B"}
|
package/dist/actions/login.js
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.LoginAction = void 0;
|
|
4
4
|
const http_user_context_1 = require("../http-user-context");
|
|
5
|
-
require("../
|
|
5
|
+
require("../helpers");
|
|
6
6
|
const rest_1 = require("@furystack/rest");
|
|
7
7
|
const request_action_implementation_1 = require("../request-action-implementation");
|
|
8
8
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"login.js","sourceRoot":"","sources":["../../src/actions/login.ts"],"names":[],"mappings":";;;AAAA,4DAAsD;AACtD,
|
|
1
|
+
{"version":3,"file":"login.js","sourceRoot":"","sources":["../../src/actions/login.ts"],"names":[],"mappings":";;;AAAA,4DAAsD;AACtD,sBAAmB;AAEnB,0CAA8C;AAC9C,oFAA4E;AAE5E;;;;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"}
|
package/dist/authenticate.js
CHANGED
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.Authenticate = void 0;
|
|
4
|
+
const core_1 = require("@furystack/core");
|
|
4
5
|
const utils_1 = require("@furystack/utils");
|
|
5
6
|
const http_user_context_1 = require("./http-user-context");
|
|
6
7
|
const request_action_implementation_1 = require("./request-action-implementation");
|
|
7
8
|
const Authenticate = () => (action) => {
|
|
8
9
|
return async (args) => {
|
|
9
|
-
const
|
|
10
|
+
const { injector } = args;
|
|
11
|
+
const authenticated = await (0, core_1.isAuthenticated)(injector);
|
|
10
12
|
if (!authenticated) {
|
|
11
13
|
await (0, utils_1.sleepAsync)(Math.random() * 1000);
|
|
12
|
-
return (0, request_action_implementation_1.JsonResult)({ error: 'unauthorized' }, 401,
|
|
13
|
-
? { 'WWW-Authenticate': 'Basic' }
|
|
14
|
-
: {});
|
|
14
|
+
return (0, request_action_implementation_1.JsonResult)({ error: 'unauthorized' }, 401, injector.getInstance(http_user_context_1.HttpUserContext).authentication.enableBasicAuth ? { 'WWW-Authenticate': 'Basic' } : {});
|
|
15
15
|
}
|
|
16
16
|
return (await action(args));
|
|
17
17
|
};
|
package/dist/authenticate.js.map
CHANGED
|
@@ -1 +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,
|
|
1
|
+
{"version":3,"file":"authenticate.js","sourceRoot":"","sources":["../src/authenticate.ts"],"names":[],"mappings":";;;AAAA,0CAAiD;AACjD,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,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"}
|
package/dist/authorize.js
CHANGED
|
@@ -1,12 +1,13 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.Authorize = void 0;
|
|
4
|
+
const core_1 = require("@furystack/core");
|
|
4
5
|
const utils_1 = require("@furystack/utils");
|
|
5
6
|
const request_action_implementation_1 = require("./request-action-implementation");
|
|
6
7
|
const Authorize = (...roles) => (action) => {
|
|
7
8
|
return async (options) => {
|
|
8
9
|
try {
|
|
9
|
-
const authorized = await options.injector
|
|
10
|
+
const authorized = await (0, core_1.isAuthorized)(options.injector, ...roles);
|
|
10
11
|
if (!authorized) {
|
|
11
12
|
await (0, utils_1.sleepAsync)(Math.random() * 1000);
|
|
12
13
|
return (0, request_action_implementation_1.JsonResult)({ error: 'forbidden' }, 403);
|
package/dist/authorize.js.map
CHANGED
|
@@ -1 +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,
|
|
1
|
+
{"version":3,"file":"authorize.js","sourceRoot":"","sources":["../src/authorize.ts"],"names":[],"mappings":";;;AAAA,0CAA8C;AAC9C,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,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"}
|
|
@@ -3,6 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.createDeleteEndpoint = void 0;
|
|
4
4
|
require("@furystack/repository");
|
|
5
5
|
const request_action_implementation_1 = require("../request-action-implementation");
|
|
6
|
+
const repository_1 = require("@furystack/repository");
|
|
6
7
|
/**
|
|
7
8
|
* Creates a DELETE endpoint for removing entities
|
|
8
9
|
*
|
|
@@ -14,7 +15,7 @@ const request_action_implementation_1 = require("../request-action-implementatio
|
|
|
14
15
|
const createDeleteEndpoint = (options) => {
|
|
15
16
|
const endpoint = async ({ injector, getUrlParams }) => {
|
|
16
17
|
const { id } = getUrlParams();
|
|
17
|
-
const dataSet = injector.getDataSetFor(options.model, options.primaryKey);
|
|
18
|
+
const dataSet = (0, repository_1.getRepository)(injector).getDataSetFor(options.model, options.primaryKey);
|
|
18
19
|
await dataSet.remove(injector, id);
|
|
19
20
|
return (0, request_action_implementation_1.JsonResult)({}, 204);
|
|
20
21
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-delete-endpoint.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-delete-endpoint.ts"],"names":[],"mappings":";;;AAEA,iCAA8B;AAC9B,oFAA4E;
|
|
1
|
+
{"version":3,"file":"create-delete-endpoint.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-delete-endpoint.ts"],"names":[],"mappings":";;;AAEA,iCAA8B;AAC9B,oFAA4E;AAC5E,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"}
|
|
@@ -6,11 +6,14 @@ const inject_1 = require("@furystack/inject");
|
|
|
6
6
|
const create_delete_endpoint_1 = require("./create-delete-endpoint");
|
|
7
7
|
const got_1 = tslib_1.__importDefault(require("got"));
|
|
8
8
|
const utils_2 = require("./utils");
|
|
9
|
+
const helpers_1 = require("../helpers");
|
|
10
|
+
const repository_1 = require("@furystack/repository");
|
|
9
11
|
describe('createDeleteEndpoint', () => {
|
|
10
12
|
it('Should delete the entity and report the success', async () => {
|
|
11
13
|
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
12
14
|
(0, utils_2.setupContext)(i);
|
|
13
|
-
await
|
|
15
|
+
await (0, helpers_1.useRestService)({
|
|
16
|
+
injector: i,
|
|
14
17
|
root: '/api',
|
|
15
18
|
port: 1111,
|
|
16
19
|
api: {
|
|
@@ -19,13 +22,13 @@ describe('createDeleteEndpoint', () => {
|
|
|
19
22
|
},
|
|
20
23
|
},
|
|
21
24
|
});
|
|
22
|
-
await
|
|
23
|
-
const countBeforeDelete = await
|
|
25
|
+
await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').add(i, { id: 'mock', value: 'mock' });
|
|
26
|
+
const countBeforeDelete = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').count(i);
|
|
24
27
|
expect(countBeforeDelete).toBe(1);
|
|
25
28
|
const response = await (0, got_1.default)('http://127.0.0.1:1111/api/mock', { method: 'DELETE' });
|
|
26
29
|
expect(response.statusCode).toBe(204);
|
|
27
30
|
expect(response.body).toBe('');
|
|
28
|
-
const countAfterDelete = await
|
|
31
|
+
const countAfterDelete = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').count(i);
|
|
29
32
|
expect(countAfterDelete).toBe(0);
|
|
30
33
|
});
|
|
31
34
|
});
|
|
@@ -1 +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,sDAAqB;AACrB,mCAAiD;
|
|
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,sDAAqB;AACrB,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,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,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"}
|
|
@@ -3,6 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.createGetCollectionEndpoint = void 0;
|
|
4
4
|
require("@furystack/repository");
|
|
5
5
|
const request_action_implementation_1 = require("../request-action-implementation");
|
|
6
|
+
const repository_1 = require("@furystack/repository");
|
|
6
7
|
/**
|
|
7
8
|
* Creates a GetCollection endpoint for the given model. The model should have a Repository DataSet
|
|
8
9
|
*
|
|
@@ -14,7 +15,7 @@ const request_action_implementation_1 = require("../request-action-implementatio
|
|
|
14
15
|
const createGetCollectionEndpoint = (options) => {
|
|
15
16
|
const endpoint = async ({ injector, getQuery }) => {
|
|
16
17
|
const { findOptions } = getQuery();
|
|
17
|
-
const dataSet = injector.getDataSetFor(options.model, options.primaryKey);
|
|
18
|
+
const dataSet = (0, repository_1.getRepository)(injector).getDataSetFor(options.model, options.primaryKey);
|
|
18
19
|
const entriesPromise = dataSet.find(injector, findOptions || {});
|
|
19
20
|
const countPromise = dataSet.count(injector, findOptions === null || findOptions === void 0 ? void 0 : findOptions.filter);
|
|
20
21
|
const [entries, count] = await Promise.all([entriesPromise, countPromise]);
|
|
@@ -1 +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;
|
|
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;AAC5E,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,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"}
|
|
@@ -7,14 +7,17 @@ const got_1 = tslib_1.__importDefault(require("got"));
|
|
|
7
7
|
const utils_2 = require("./utils");
|
|
8
8
|
const create_get_collection_endpoint_1 = require("./create-get-collection-endpoint");
|
|
9
9
|
const rest_1 = require("@furystack/rest");
|
|
10
|
-
const
|
|
10
|
+
const repository_1 = require("@furystack/repository");
|
|
11
|
+
const helpers_1 = require("../helpers");
|
|
12
|
+
const addMockEntities = async (i) => await (0, repository_1.getRepository)(i)
|
|
11
13
|
.getDataSetFor(utils_2.MockClass, 'id')
|
|
12
14
|
.add(i, { id: 'mock1', value: '4' }, { id: 'mock2', value: '3' }, { id: 'mock3', value: '2' }, { id: 'mock4', value: '1' });
|
|
13
15
|
describe('createGetCollectionEndpoint', () => {
|
|
14
16
|
it('Should return the collection without filter / order', async () => {
|
|
15
17
|
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
16
18
|
(0, utils_2.setupContext)(i);
|
|
17
|
-
await
|
|
19
|
+
await (0, helpers_1.useRestService)({
|
|
20
|
+
injector: i,
|
|
18
21
|
root: '/api',
|
|
19
22
|
port: 1112,
|
|
20
23
|
api: {
|
|
@@ -24,8 +27,8 @@ describe('createGetCollectionEndpoint', () => {
|
|
|
24
27
|
},
|
|
25
28
|
});
|
|
26
29
|
await addMockEntities(i);
|
|
27
|
-
const count = await
|
|
28
|
-
const allEntities = await
|
|
30
|
+
const count = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').count(i);
|
|
31
|
+
const allEntities = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').find(i, {});
|
|
29
32
|
const response = await (0, got_1.default)('http://127.0.0.1:1112/api/entities', { method: 'GET' });
|
|
30
33
|
const json = JSON.parse(response.body);
|
|
31
34
|
expect(json.count).toBe(count);
|
|
@@ -35,7 +38,8 @@ describe('createGetCollectionEndpoint', () => {
|
|
|
35
38
|
it('Should return entities in order', async () => {
|
|
36
39
|
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
37
40
|
(0, utils_2.setupContext)(i);
|
|
38
|
-
await
|
|
41
|
+
await (0, helpers_1.useRestService)({
|
|
42
|
+
injector: i,
|
|
39
43
|
root: '/api',
|
|
40
44
|
port: 1113,
|
|
41
45
|
api: {
|
|
@@ -46,8 +50,8 @@ describe('createGetCollectionEndpoint', () => {
|
|
|
46
50
|
});
|
|
47
51
|
await addMockEntities(i);
|
|
48
52
|
const findOptions = { order: { value: 'ASC' } };
|
|
49
|
-
const count = await
|
|
50
|
-
const orderedEntities = await
|
|
53
|
+
const count = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').count(i, findOptions.filter);
|
|
54
|
+
const orderedEntities = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').find(i, findOptions);
|
|
51
55
|
const response = await (0, got_1.default)(`http://127.0.0.1:1113/api/entities?${(0, rest_1.serializeToQueryString)({ findOptions })}`, {
|
|
52
56
|
method: 'GET',
|
|
53
57
|
});
|
|
@@ -59,7 +63,8 @@ describe('createGetCollectionEndpoint', () => {
|
|
|
59
63
|
it('Should return entities with filtering', async () => {
|
|
60
64
|
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
61
65
|
(0, utils_2.setupContext)(i);
|
|
62
|
-
await
|
|
66
|
+
await (0, helpers_1.useRestService)({
|
|
67
|
+
injector: i,
|
|
63
68
|
root: '/api',
|
|
64
69
|
port: 1113,
|
|
65
70
|
api: {
|
|
@@ -72,8 +77,8 @@ describe('createGetCollectionEndpoint', () => {
|
|
|
72
77
|
const findOptions = {
|
|
73
78
|
filter: { id: { $ne: 'mock2' } },
|
|
74
79
|
};
|
|
75
|
-
const count = await
|
|
76
|
-
const filteredEntities = await
|
|
80
|
+
const count = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').count(i, findOptions.filter);
|
|
81
|
+
const filteredEntities = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').find(i, findOptions);
|
|
77
82
|
expect(filteredEntities).not.toContainEqual({ id: 'mock2', value: '3' });
|
|
78
83
|
const response = await (0, got_1.default)(`http://127.0.0.1:1113/api/entities?${(0, rest_1.serializeToQueryString)({ findOptions })}`, {
|
|
79
84
|
method: 'GET',
|
|
@@ -86,7 +91,8 @@ describe('createGetCollectionEndpoint', () => {
|
|
|
86
91
|
it('Should return entities with selecting specific fields', async () => {
|
|
87
92
|
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
88
93
|
(0, utils_2.setupContext)(i);
|
|
89
|
-
await
|
|
94
|
+
await (0, helpers_1.useRestService)({
|
|
95
|
+
injector: i,
|
|
90
96
|
root: '/api',
|
|
91
97
|
port: 1113,
|
|
92
98
|
api: {
|
|
@@ -99,8 +105,8 @@ describe('createGetCollectionEndpoint', () => {
|
|
|
99
105
|
const findOptions = {
|
|
100
106
|
select: ['id'],
|
|
101
107
|
};
|
|
102
|
-
const count = await
|
|
103
|
-
const selectedEntities = await
|
|
108
|
+
const count = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').count(i, findOptions.filter);
|
|
109
|
+
const selectedEntities = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').find(i, findOptions);
|
|
104
110
|
selectedEntities.forEach((e) => expect(e.value).toBeUndefined());
|
|
105
111
|
const response = await (0, got_1.default)(`http://127.0.0.1:1113/api/entities?${(0, rest_1.serializeToQueryString)({ findOptions })}`, {
|
|
106
112
|
method: 'GET',
|
|
@@ -113,7 +119,8 @@ describe('createGetCollectionEndpoint', () => {
|
|
|
113
119
|
it('Should return entities with top/skip', async () => {
|
|
114
120
|
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
115
121
|
(0, utils_2.setupContext)(i);
|
|
116
|
-
await
|
|
122
|
+
await (0, helpers_1.useRestService)({
|
|
123
|
+
injector: i,
|
|
117
124
|
root: '/api',
|
|
118
125
|
port: 1113,
|
|
119
126
|
api: {
|
|
@@ -127,8 +134,8 @@ describe('createGetCollectionEndpoint', () => {
|
|
|
127
134
|
skip: 1,
|
|
128
135
|
top: 2,
|
|
129
136
|
};
|
|
130
|
-
const count = await
|
|
131
|
-
const topSkipEntities = await
|
|
137
|
+
const count = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').count(i, findOptions.filter);
|
|
138
|
+
const topSkipEntities = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').find(i, findOptions);
|
|
132
139
|
expect(topSkipEntities).not.toContainEqual({ id: 'mock1', value: '4' });
|
|
133
140
|
expect(topSkipEntities).not.toContainEqual({ id: 'mock4', value: '1' });
|
|
134
141
|
const response = await (0, got_1.default)(`http://127.0.0.1:1113/api/entities?${(0, rest_1.serializeToQueryString)({ findOptions })}`, {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-get-collection-endpoint.spec.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-get-collection-endpoint.spec.ts"],"names":[],"mappings":";;;AAAA,4CAA6C;AAC7C,8CAA4C;AAC5C,sDAAqB;AACrB,mCAAiD;AACjD,qFAA8E;AAC9E,0CAAoG;
|
|
1
|
+
{"version":3,"file":"create-get-collection-endpoint.spec.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-get-collection-endpoint.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -4,6 +4,7 @@ exports.createGetEntityEndpoint = void 0;
|
|
|
4
4
|
const rest_1 = require("@furystack/rest");
|
|
5
5
|
require("@furystack/repository");
|
|
6
6
|
const request_action_implementation_1 = require("../request-action-implementation");
|
|
7
|
+
const repository_1 = require("@furystack/repository");
|
|
7
8
|
/**
|
|
8
9
|
* Creates a simple Get Entity endpoint for a specified model.
|
|
9
10
|
*
|
|
@@ -16,7 +17,7 @@ const createGetEntityEndpoint = (options) => {
|
|
|
16
17
|
const endpoint = async ({ injector, getUrlParams, getQuery }) => {
|
|
17
18
|
const { id } = getUrlParams();
|
|
18
19
|
const { select } = getQuery();
|
|
19
|
-
const dataSet = injector.getDataSetFor(options.model, options.primaryKey);
|
|
20
|
+
const dataSet = (0, repository_1.getRepository)(injector).getDataSetFor(options.model, options.primaryKey);
|
|
20
21
|
const entry = await dataSet.get(injector, id, select);
|
|
21
22
|
if (!entry) {
|
|
22
23
|
throw new rest_1.RequestError('Entity not found', 404);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-get-entity-endpoint.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-get-entity-endpoint.ts"],"names":[],"mappings":";;;AACA,0CAAiE;AACjE,iCAA8B;AAC9B,oFAA4E;
|
|
1
|
+
{"version":3,"file":"create-get-entity-endpoint.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-get-entity-endpoint.ts"],"names":[],"mappings":";;;AACA,0CAAiE;AACjE,iCAA8B;AAC9B,oFAA4E;AAC5E,sDAAqD;AAErD;;;;;;;GAOG;AACI,MAAM,uBAAuB,GAAG,CAAgD,OAGtF,EAAE,EAAE;IACH,MAAM,QAAQ,GAAqD,KAAK,EAAE,EAAE,QAAQ,EAAE,YAAY,EAAE,QAAQ,EAAE,EAAE,EAAE;QAChH,MAAM,EAAE,EAAE,EAAE,GAAG,YAAY,EAAE,CAAA;QAC7B,MAAM,EAAE,MAAM,EAAE,GAAG,QAAQ,EAAE,CAAA;QAC7B,MAAM,OAAO,GAAG,IAAA,0BAAa,EAAC,QAAQ,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,UAAU,CAAC,CAAA;QACxF,MAAM,KAAK,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,EAAE,EAAE,MAAM,CAAC,CAAA;QACrD,IAAI,CAAC,KAAK,EAAE;YACV,MAAM,IAAI,mBAAY,CAAC,kBAAkB,EAAE,GAAG,CAAC,CAAA;SAChD;QACD,OAAO,IAAA,0CAAU,EAAC,KAAK,CAAC,CAAA;IAC1B,CAAC,CAAA;IACD,OAAO,QAAQ,CAAA;AACjB,CAAC,CAAA;AAfY,QAAA,uBAAuB,2BAenC"}
|
|
@@ -7,11 +7,14 @@ const rest_1 = require("@furystack/rest");
|
|
|
7
7
|
const got_1 = tslib_1.__importDefault(require("got"));
|
|
8
8
|
const utils_2 = require("./utils");
|
|
9
9
|
const create_get_entity_endpoint_1 = require("./create-get-entity-endpoint");
|
|
10
|
+
const repository_1 = require("@furystack/repository");
|
|
11
|
+
const helpers_1 = require("../helpers");
|
|
10
12
|
describe('createGetEntityEndpoint', () => {
|
|
11
13
|
it('Should return the entity', async () => {
|
|
12
14
|
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
13
15
|
(0, utils_2.setupContext)(i);
|
|
14
|
-
await
|
|
16
|
+
await (0, helpers_1.useRestService)({
|
|
17
|
+
injector: i,
|
|
15
18
|
root: '/api',
|
|
16
19
|
port: 1113,
|
|
17
20
|
api: {
|
|
@@ -21,7 +24,7 @@ describe('createGetEntityEndpoint', () => {
|
|
|
21
24
|
},
|
|
22
25
|
});
|
|
23
26
|
const mockEntity = { id: 'mock', value: 'mock' };
|
|
24
|
-
await
|
|
27
|
+
await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').add(i, mockEntity);
|
|
25
28
|
const response = await (0, got_1.default)('http://127.0.0.1:1113/api/mock', { method: 'GET' });
|
|
26
29
|
expect(JSON.parse(response.body)).toStrictEqual(mockEntity);
|
|
27
30
|
});
|
|
@@ -29,7 +32,8 @@ describe('createGetEntityEndpoint', () => {
|
|
|
29
32
|
it('Should return the entity with the selected fields', async () => {
|
|
30
33
|
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
31
34
|
(0, utils_2.setupContext)(i);
|
|
32
|
-
await
|
|
35
|
+
await (0, helpers_1.useRestService)({
|
|
36
|
+
injector: i,
|
|
33
37
|
root: '/api',
|
|
34
38
|
port: 1114,
|
|
35
39
|
api: {
|
|
@@ -39,7 +43,7 @@ describe('createGetEntityEndpoint', () => {
|
|
|
39
43
|
},
|
|
40
44
|
});
|
|
41
45
|
const mockEntity = { id: 'mock', value: 'mock' };
|
|
42
|
-
await
|
|
46
|
+
await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').add(i, mockEntity);
|
|
43
47
|
const response = await (0, got_1.default)(`http://127.0.0.1:1114/api/mock?${(0, rest_1.serializeToQueryString)({ select: ['id'] })}`, {
|
|
44
48
|
method: 'GET',
|
|
45
49
|
});
|
|
@@ -49,7 +53,8 @@ describe('createGetEntityEndpoint', () => {
|
|
|
49
53
|
it('Should return 404 if no entity has been found', async () => {
|
|
50
54
|
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
51
55
|
(0, utils_2.setupContext)(i);
|
|
52
|
-
await
|
|
56
|
+
await (0, helpers_1.useRestService)({
|
|
57
|
+
injector: i,
|
|
53
58
|
root: '/api',
|
|
54
59
|
port: 1115,
|
|
55
60
|
api: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-get-entity-endpoint.spec.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-get-entity-endpoint.spec.ts"],"names":[],"mappings":";;;AAAA,4CAA6C;AAC7C,8CAA4C;AAC5C,0CAA2E;AAC3E,sDAAoC;AACpC,mCAAiD;AACjD,6EAAsE;
|
|
1
|
+
{"version":3,"file":"create-get-entity-endpoint.spec.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-get-entity-endpoint.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -4,6 +4,7 @@ exports.createPatchEndpoint = void 0;
|
|
|
4
4
|
require("@furystack/repository");
|
|
5
5
|
require("../incoming-message-extensions");
|
|
6
6
|
const request_action_implementation_1 = require("../request-action-implementation");
|
|
7
|
+
const repository_1 = require("@furystack/repository");
|
|
7
8
|
/**
|
|
8
9
|
* Creates a PATCH endpoint for updating entities
|
|
9
10
|
*
|
|
@@ -16,7 +17,7 @@ const createPatchEndpoint = (options) => {
|
|
|
16
17
|
const endpoint = async ({ injector, request, getUrlParams }) => {
|
|
17
18
|
const { id } = getUrlParams();
|
|
18
19
|
const patchData = await request.readPostBody();
|
|
19
|
-
const dataSet = injector.getDataSetFor(options.model, options.primaryKey);
|
|
20
|
+
const dataSet = (0, repository_1.getRepository)(injector).getDataSetFor(options.model, options.primaryKey);
|
|
20
21
|
await dataSet.update(injector, id, patchData);
|
|
21
22
|
return (0, request_action_implementation_1.JsonResult)({});
|
|
22
23
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-patch-endpoint.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-patch-endpoint.ts"],"names":[],"mappings":";;;AAEA,iCAA8B;AAC9B,0CAAuC;AACvC,oFAA4E;
|
|
1
|
+
{"version":3,"file":"create-patch-endpoint.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-patch-endpoint.ts"],"names":[],"mappings":";;;AAEA,iCAA8B;AAC9B,0CAAuC;AACvC,oFAA4E;AAC5E,sDAAqD;AAErD;;;;;;;GAOG;AACI,MAAM,mBAAmB,GAAG,CAAgD,OAGlF,EAAE,EAAE;IACH,MAAM,QAAQ,GAAiD,KAAK,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,YAAY,EAAE,EAAE,EAAE;QAC3G,MAAM,EAAE,EAAE,EAAE,GAAG,YAAY,EAAE,CAAA;QAC7B,MAAM,SAAS,GAAG,MAAM,OAAO,CAAC,YAAY,EAAK,CAAA;QACjD,MAAM,OAAO,GAAG,IAAA,0BAAa,EAAC,QAAQ,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,UAAU,CAAC,CAAA;QACxF,MAAM,OAAO,CAAC,MAAM,CAAC,QAAQ,EAAE,EAAE,EAAE,SAAS,CAAC,CAAA;QAC7C,OAAO,IAAA,0CAAU,EAAC,EAAE,CAAC,CAAA;IACvB,CAAC,CAAA;IACD,OAAO,QAAQ,CAAA;AACjB,CAAC,CAAA;AAZY,QAAA,mBAAmB,uBAY/B"}
|
|
@@ -6,11 +6,14 @@ const inject_1 = require("@furystack/inject");
|
|
|
6
6
|
const create_patch_endpoint_1 = require("./create-patch-endpoint");
|
|
7
7
|
const got_1 = tslib_1.__importDefault(require("got"));
|
|
8
8
|
const utils_2 = require("./utils");
|
|
9
|
+
const repository_1 = require("@furystack/repository");
|
|
10
|
+
const helpers_1 = require("../helpers");
|
|
9
11
|
describe('createPatchEndpoint', () => {
|
|
10
12
|
it('Should update the entity and report the success', async () => {
|
|
11
13
|
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
12
14
|
(0, utils_2.setupContext)(i);
|
|
13
|
-
await
|
|
15
|
+
await (0, helpers_1.useRestService)({
|
|
16
|
+
injector: i,
|
|
14
17
|
root: '/api',
|
|
15
18
|
port: 1116,
|
|
16
19
|
api: {
|
|
@@ -19,8 +22,8 @@ describe('createPatchEndpoint', () => {
|
|
|
19
22
|
},
|
|
20
23
|
},
|
|
21
24
|
});
|
|
22
|
-
await
|
|
23
|
-
const countBeforeDelete = await
|
|
25
|
+
await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').add(i, { id: 'mock', value: 'mock' });
|
|
26
|
+
const countBeforeDelete = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').count(i);
|
|
24
27
|
expect(countBeforeDelete).toBe(1);
|
|
25
28
|
const response = await (0, got_1.default)('http://127.0.0.1:1116/api/mock', {
|
|
26
29
|
method: 'PATCH',
|
|
@@ -28,7 +31,7 @@ describe('createPatchEndpoint', () => {
|
|
|
28
31
|
});
|
|
29
32
|
expect(response.statusCode).toBe(200);
|
|
30
33
|
expect(response.body).toBe('{}');
|
|
31
|
-
const updated = await
|
|
34
|
+
const updated = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').get(i, 'mock');
|
|
32
35
|
expect(updated === null || updated === void 0 ? void 0 : updated.value).toBe('updated');
|
|
33
36
|
});
|
|
34
37
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-patch-endpoint.spec.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-patch-endpoint.spec.ts"],"names":[],"mappings":";;;AAAA,4CAA6C;AAC7C,8CAA4C;AAE5C,mEAA6D;AAC7D,sDAAqB;AACrB,mCAAiD;
|
|
1
|
+
{"version":3,"file":"create-patch-endpoint.spec.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-patch-endpoint.spec.ts"],"names":[],"mappings":";;;AAAA,4CAA6C;AAC7C,8CAA4C;AAE5C,mEAA6D;AAC7D,sDAAqB;AACrB,mCAAiD;AACjD,sDAAqD;AACrD,wCAA2C;AAE3C,QAAQ,CAAC,qBAAqB,EAAE,GAAG,EAAE;IACnC,EAAE,CAAC,iDAAiD,EAAE,KAAK,IAAI,EAAE;QAC/D,MAAM,IAAA,kBAAU,EAAC,IAAI,iBAAQ,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;YAC3C,IAAA,oBAAY,EAAC,CAAC,CAAC,CAAA;YACf,MAAM,IAAA,wBAAc,EAAwD;gBAC1E,QAAQ,EAAE,CAAC;gBACX,IAAI,EAAE,MAAM;gBACZ,IAAI,EAAE,IAAI;gBACV,GAAG,EAAE;oBACH,KAAK,EAAE;wBACL,MAAM,EAAE,IAAA,2CAAmB,EAAC,EAAE,KAAK,EAAE,iBAAS,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC;qBACpE;iBACF;aACF,CAAC,CAAA;YACF,MAAM,IAAA,0BAAa,EAAC,CAAC,EAAE,iBAAS,EAAE,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAA;YAE7E,MAAM,iBAAiB,GAAG,MAAM,IAAA,0BAAa,EAAC,CAAC,EAAE,iBAAS,EAAE,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;YAC1E,MAAM,CAAC,iBAAiB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;YAEjC,MAAM,QAAQ,GAAG,MAAM,IAAA,aAAG,EAAC,gCAAgC,EAAE;gBAC3D,MAAM,EAAE,OAAO;gBACf,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;aAC3C,CAAC,CAAA;YACF,MAAM,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;YACrC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YAChC,MAAM,OAAO,GAAG,MAAM,IAAA,0BAAa,EAAC,CAAC,EAAE,iBAAS,EAAE,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,CAAC,CAAA;YACtE,MAAM,CAAC,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,KAAK,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;QACxC,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|
|
@@ -5,6 +5,7 @@ const rest_1 = require("@furystack/rest");
|
|
|
5
5
|
require("@furystack/repository");
|
|
6
6
|
require("../incoming-message-extensions");
|
|
7
7
|
const request_action_implementation_1 = require("../request-action-implementation");
|
|
8
|
+
const repository_1 = require("@furystack/repository");
|
|
8
9
|
/**
|
|
9
10
|
* Creates a POST endpoint for updating entities
|
|
10
11
|
*
|
|
@@ -15,7 +16,7 @@ const request_action_implementation_1 = require("../request-action-implementatio
|
|
|
15
16
|
*/
|
|
16
17
|
const createPostEndpoint = (options) => {
|
|
17
18
|
const endpoint = async ({ injector, request }) => {
|
|
18
|
-
const dataSet = injector.getDataSetFor(options.model, options.primaryKey);
|
|
19
|
+
const dataSet = (0, repository_1.getRepository)(injector).getDataSetFor(options.model, options.primaryKey);
|
|
19
20
|
const entityToCreate = await request.readPostBody();
|
|
20
21
|
const { created } = await dataSet.add(injector, entityToCreate);
|
|
21
22
|
if (!created || !created.length) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-post-endpoint.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-post-endpoint.ts"],"names":[],"mappings":";;;AACA,0CAA4D;AAC5D,iCAA8B;AAC9B,0CAAuC;AACvC,oFAA4E;AAE5E;;;;;;;GAOG;AACI,MAAM,kBAAkB,GAAG,CAAgD,OAGjF,EAAE,EAAE;IACH,MAAM,QAAQ,GAAgD,KAAK,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,EAAE,EAAE;QAC5F,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,UAAU,CAAC,CAAA;
|
|
1
|
+
{"version":3,"file":"create-post-endpoint.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-post-endpoint.ts"],"names":[],"mappings":";;;AACA,0CAA4D;AAC5D,iCAA8B;AAC9B,0CAAuC;AACvC,oFAA4E;AAE5E,sDAAqD;AACrD;;;;;;;GAOG;AACI,MAAM,kBAAkB,GAAG,CAAgD,OAGjF,EAAE,EAAE;IACH,MAAM,QAAQ,GAAgD,KAAK,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,EAAE,EAAE;QAC5F,MAAM,OAAO,GAAG,IAAA,0BAAa,EAAC,QAAQ,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,UAAU,CAAC,CAAA;QAExF,MAAM,cAAc,GAAG,MAAM,OAAO,CAAC,YAAY,EAAmD,CAAA;QACpG,MAAM,EAAE,OAAO,EAAE,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,cAAc,CAAC,CAAA;QAC/D,IAAI,CAAC,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;YAC/B,MAAM,IAAI,mBAAY,CAAC,kBAAkB,EAAE,GAAG,CAAC,CAAA;SAChD;QACD,OAAO,IAAA,0CAAU,EAAC,OAAO,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAA;IACpC,CAAC,CAAA;IACD,OAAO,QAAQ,CAAA;AACjB,CAAC,CAAA;AAfY,QAAA,kBAAkB,sBAe9B"}
|
|
@@ -6,11 +6,14 @@ const inject_1 = require("@furystack/inject");
|
|
|
6
6
|
const create_post_endpoint_1 = require("./create-post-endpoint");
|
|
7
7
|
const got_1 = tslib_1.__importDefault(require("got"));
|
|
8
8
|
const utils_2 = require("./utils");
|
|
9
|
+
const helpers_1 = require("../helpers");
|
|
10
|
+
const repository_1 = require("@furystack/repository");
|
|
9
11
|
describe('createPostEndpoint', () => {
|
|
10
12
|
it('Should create the entity and report the success', async () => {
|
|
11
13
|
await (0, utils_1.usingAsync)(new inject_1.Injector(), async (i) => {
|
|
12
14
|
(0, utils_2.setupContext)(i);
|
|
13
|
-
await
|
|
15
|
+
await (0, helpers_1.useRestService)({
|
|
16
|
+
injector: i,
|
|
14
17
|
root: '/api',
|
|
15
18
|
port: 1117,
|
|
16
19
|
api: {
|
|
@@ -26,7 +29,7 @@ describe('createPostEndpoint', () => {
|
|
|
26
29
|
});
|
|
27
30
|
expect(response.statusCode).toBe(201);
|
|
28
31
|
expect(JSON.parse(response.body)).toStrictEqual(entityToPost);
|
|
29
|
-
const posted = await
|
|
32
|
+
const posted = await (0, repository_1.getDataSetFor)(i, utils_2.MockClass, 'id').get(i, entityToPost.id);
|
|
30
33
|
expect(posted === null || posted === void 0 ? void 0 : posted.value).toBe('posted');
|
|
31
34
|
});
|
|
32
35
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-post-endpoint.spec.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-post-endpoint.spec.ts"],"names":[],"mappings":";;;AAAA,4CAA6C;AAC7C,8CAA4C;AAE5C,iEAA2D;AAC3D,sDAAqB;AACrB,mCAAiD;
|
|
1
|
+
{"version":3,"file":"create-post-endpoint.spec.js","sourceRoot":"","sources":["../../src/endpoint-generators/create-post-endpoint.spec.ts"],"names":[],"mappings":";;;AAAA,4CAA6C;AAC7C,8CAA4C;AAE5C,iEAA2D;AAC3D,sDAAqB;AACrB,mCAAiD;AACjD,wCAA2C;AAC3C,sDAAqD;AAErD,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;IAClC,EAAE,CAAC,iDAAiD,EAAE,KAAK,IAAI,EAAE;QAC/D,MAAM,IAAA,kBAAU,EAAC,IAAI,iBAAQ,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;YAC3C,IAAA,oBAAY,EAAC,CAAC,CAAC,CAAA;YACf,MAAM,IAAA,wBAAc,EAAsD;gBACxE,QAAQ,EAAE,CAAC;gBACX,IAAI,EAAE,MAAM;gBACZ,IAAI,EAAE,IAAI;gBACV,GAAG,EAAE;oBACH,IAAI,EAAE;wBACJ,MAAM,EAAE,IAAA,yCAAkB,EAAC,EAAE,KAAK,EAAE,iBAAS,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC;qBACnE;iBACF;aACF,CAAC,CAAA;YACF,MAAM,YAAY,GAAG,EAAE,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAA;YACpD,MAAM,QAAQ,GAAG,MAAM,IAAA,aAAG,EAAC,gCAAgC,EAAE;gBAC3D,MAAM,EAAE,MAAM;gBACd,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC;aACnC,CAAC,CAAA;YACF,MAAM,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;YACrC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,aAAa,CAAC,YAAY,CAAC,CAAA;YAC7D,MAAM,MAAM,GAAG,MAAM,IAAA,0BAAa,EAAC,CAAC,EAAE,iBAAS,EAAE,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,YAAY,CAAC,EAAE,CAAC,CAAA;YAC9E,MAAM,CAAC,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,KAAK,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;QACtC,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,CAAC,CAAA"}
|