elemento-alpha-tools 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (38) hide show
  1. package/README.md +2 -0
  2. package/dist/ap/303/255/ExpressLogableConfig.d.ts +5 -0
  3. package/dist/ap/303/255/ExpressLogableConfig.js +16 -0
  4. package/dist/ap/303/255/ExpressLogableConfig.js.map +1 -0
  5. package/dist/ap/303/255/checkers/RoleServicePermissionsCheckers.d.ts +13 -0
  6. package/dist/ap/303/255/checkers/RoleServicePermissionsCheckers.js +63 -0
  7. package/dist/ap/303/255/checkers/RoleServicePermissionsCheckers.js.map +1 -0
  8. package/dist/ap/303/255/checkers/ServiceSessionChecker.d.ts +28 -0
  9. package/dist/ap/303/255/checkers/ServiceSessionChecker.js +105 -0
  10. package/dist/ap/303/255/checkers/ServiceSessionChecker.js.map +1 -0
  11. package/dist/crud/AvailablePlataformManager.d.ts +18 -0
  12. package/dist/crud/AvailablePlataformManager.js +3 -0
  13. package/dist/crud/AvailablePlataformManager.js.map +1 -0
  14. package/dist/crud/ComponentManager.d.ts +33 -0
  15. package/dist/crud/ComponentManager.js +3 -0
  16. package/dist/crud/ComponentManager.js.map +1 -0
  17. package/dist/crud/PlatformManager.d.ts +34 -0
  18. package/dist/crud/PlatformManager.js +49 -0
  19. package/dist/crud/PlatformManager.js.map +1 -0
  20. package/dist/crud/RoleManager.d.ts +44 -0
  21. package/dist/crud/RoleManager.js +49 -0
  22. package/dist/crud/RoleManager.js.map +1 -0
  23. package/dist/crud/StatusManager.d.ts +26 -0
  24. package/dist/crud/StatusManager.js +51 -0
  25. package/dist/crud/StatusManager.js.map +1 -0
  26. package/dist/crud/TypeManager.d.ts +25 -0
  27. package/dist/crud/TypeManager.js +53 -0
  28. package/dist/crud/TypeManager.js.map +1 -0
  29. package/dist/crud/UserCredentialsManager.d.ts +20 -0
  30. package/dist/crud/UserCredentialsManager.js +3 -0
  31. package/dist/crud/UserCredentialsManager.js.map +1 -0
  32. package/dist/crud/UserManager.d.ts +15 -0
  33. package/dist/crud/UserManager.js +3 -0
  34. package/dist/crud/UserManager.js.map +1 -0
  35. package/dist/index.d.ts +10 -0
  36. package/dist/index.js +21 -0
  37. package/dist/index.js.map +1 -0
  38. package/package.json +43 -0
package/README.md ADDED
@@ -0,0 +1,2 @@
1
+ # elemento-alpha-tools
2
+ Librería para los servicios de elemento alpha
@@ -0,0 +1,5 @@
1
+ import { ExpressStandardConfiguration } from "itrm-tools";
2
+ import { Express } from "express";
3
+ export declare class ExpressLogableConfig extends ExpressStandardConfiguration {
4
+ apply(app: Express): void;
5
+ }
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.ExpressLogableConfig = void 0;
7
+ const itrm_tools_1 = require("itrm-tools");
8
+ const morgan_1 = __importDefault(require("morgan"));
9
+ class ExpressLogableConfig extends itrm_tools_1.ExpressStandardConfiguration {
10
+ apply(app) {
11
+ super.apply(app);
12
+ app.use((0, morgan_1.default)(':remote-addr - :remote-user [:date[web]] ":method :url HTTP/:http-version" :status :res[content-length]'));
13
+ }
14
+ }
15
+ exports.ExpressLogableConfig = ExpressLogableConfig;
16
+ //# sourceMappingURL=ExpressLogableConfig.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ExpressLogableConfig.js","sourceRoot":"","sources":["../../src/apí/ExpressLogableConfig.ts"],"names":[],"mappings":";;;;;;AAAA,2CAA0D;AAE1D,oDAA4B;AAE5B,MAAa,oBAAqB,SAAQ,yCAA4B;IAClE,KAAK,CAAC,GAAY;QACd,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAEjB,GAAG,CAAC,GAAG,CAAC,IAAA,gBAAM,EAAC,yGAAyG,CAAC,CAAC,CAAC;IAC/H,CAAC;CACJ;AAND,oDAMC"}
@@ -0,0 +1,13 @@
1
+ import { APICheck, APICheckConfig, APICheckResult } from "itrm-tools";
2
+ import { Request } from "express";
3
+ export declare class RoleServicePermissionsChecker implements APICheck {
4
+ private service;
5
+ private sessionServiceUrl;
6
+ private roleManager;
7
+ constructor(service: string, sessionServiceUrl: string, sessionServiceCrud: string);
8
+ getConfig(): APICheckConfig;
9
+ apply(config: APICheckConfig, req: Request): Promise<APICheckResult>;
10
+ private checkServicePermissions;
11
+ private isMethodAndPathAllowed;
12
+ private unexpectedErrorRejection;
13
+ }
@@ -0,0 +1,63 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.RoleServicePermissionsChecker = void 0;
13
+ const itrm_tools_1 = require("itrm-tools");
14
+ const RoleManager_1 = require("../../crud/RoleManager");
15
+ class RoleServicePermissionsChecker {
16
+ constructor(service, sessionServiceUrl, sessionServiceCrud) {
17
+ this.service = service;
18
+ this.sessionServiceUrl = sessionServiceUrl;
19
+ this.roleManager = new RoleManager_1.RoleManager(`${sessionServiceCrud}/v1`);
20
+ }
21
+ getConfig() {
22
+ return {
23
+ check: "rolePermissionService",
24
+ };
25
+ }
26
+ apply(config, req) {
27
+ return __awaiter(this, void 0, void 0, function* () {
28
+ var _a, _b;
29
+ try {
30
+ let headers = { headers: { "Authorization": req.headers.authorization } };
31
+ let verification = yield itrm_tools_1.RequestAxiosCall.post(`${this.sessionServiceUrl}/v1/verify`, { jwt: ((_a = req.headers.authorization) !== null && _a !== void 0 ? _a : 'NoToken').replace("Bearer ", "") }, headers);
32
+ let role = yield this.roleManager.find({ name: verification.role, permissions: {}, config: headers });
33
+ return this.checkServicePermissions((_b = role === null || role === void 0 ? void 0 : role.permissions.services) !== null && _b !== void 0 ? _b : {}, req, verification);
34
+ }
35
+ catch (error) {
36
+ return this.unexpectedErrorRejection(error);
37
+ }
38
+ });
39
+ }
40
+ checkServicePermissions(permissions, req, verification) {
41
+ if (permissions[this.service]) {
42
+ if (this.isMethodAndPathAllowed(permissions[this.service], req))
43
+ return { approved: true, payload: verification };
44
+ return { approved: false, rejection: { code: 401, payload: { status: "Error", message: `Method or Path are not allowed: ${req.method} ${req.baseUrl + req.path.replace(/\/\d+$/, "")}` } } };
45
+ }
46
+ return { approved: false, rejection: { code: 401, payload: { status: "Error", message: "Service is not allowed" } } };
47
+ }
48
+ isMethodAndPathAllowed(permissions, req) {
49
+ return permissions[req.method] && permissions[req.method][req.baseUrl + req.path.replace(/\/\d+$/, "")];
50
+ }
51
+ unexpectedErrorRejection(error) {
52
+ var _a, _b, _c, _d;
53
+ return {
54
+ approved: false,
55
+ rejection: {
56
+ code: (_b = (_a = error === null || error === void 0 ? void 0 : error.response) === null || _a === void 0 ? void 0 : _a.status) !== null && _b !== void 0 ? _b : 500,
57
+ payload: { status: "Error", message: (_d = (_c = error === null || error === void 0 ? void 0 : error.response) === null || _c === void 0 ? void 0 : _c.data) !== null && _d !== void 0 ? _d : error, }
58
+ },
59
+ };
60
+ }
61
+ }
62
+ exports.RoleServicePermissionsChecker = RoleServicePermissionsChecker;
63
+ //# sourceMappingURL=RoleServicePermissionsCheckers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RoleServicePermissionsCheckers.js","sourceRoot":"","sources":["../../../src/apí/checkers/RoleServicePermissionsCheckers.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,28 @@
1
+ import { Request } from "express";
2
+ import { APICheck, APICheckConfig, APICheckResult } from "itrm-tools";
3
+ export interface IServiceSessionConfig {
4
+ name: string;
5
+ url: string;
6
+ }
7
+ export interface IServiceCredentials {
8
+ apiKey: string;
9
+ apiSecret: string;
10
+ }
11
+ export declare class ServiceSessionChecker implements APICheck {
12
+ private token;
13
+ private sessionServiceUrl;
14
+ private config;
15
+ constructor(sessionServiceUrl: string, config: IServiceSessionConfig);
16
+ getConfig(): APICheckConfig;
17
+ apply(config: APICheckConfig, req: Request): Promise<APICheckResult>;
18
+ private createToken;
19
+ sign(params: {
20
+ method: string;
21
+ path: string;
22
+ }): Promise<{
23
+ headers: {
24
+ Authorization: string;
25
+ };
26
+ } | undefined>;
27
+ private getServiceCredentials;
28
+ }
@@ -0,0 +1,105 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.ServiceSessionChecker = void 0;
13
+ const crypto_js_1 = require("crypto-js");
14
+ const itrm_tools_1 = require("itrm-tools");
15
+ class ServiceSessionChecker {
16
+ constructor(sessionServiceUrl, config) {
17
+ this.token = "";
18
+ this.sessionServiceUrl = sessionServiceUrl;
19
+ this.config = config;
20
+ }
21
+ getConfig() {
22
+ return {
23
+ check: "serviceSession"
24
+ };
25
+ }
26
+ apply(config, req) {
27
+ return __awaiter(this, void 0, void 0, function* () {
28
+ var _a;
29
+ try {
30
+ let verification = yield itrm_tools_1.RequestAxiosCall.post(`${this.sessionServiceUrl}/v1/verify`, { jwt: ((_a = req.headers.authorization) !== null && _a !== void 0 ? _a : 'NoToken').replace("Bearer ", "") }, { headers: { "Authorization": this.token } });
31
+ console.log("> verification:", verification);
32
+ return {
33
+ approved: true,
34
+ payload: { headers: { "Authorization": this.token } }
35
+ };
36
+ }
37
+ catch (err) {
38
+ return yield this.createToken();
39
+ }
40
+ });
41
+ }
42
+ createToken() {
43
+ return __awaiter(this, void 0, void 0, function* () {
44
+ var _a, _b, _c, _d, _e;
45
+ try {
46
+ const headers = yield this.sign({ method: "POST", path: "/login" });
47
+ if (headers) {
48
+ const session = yield itrm_tools_1.RequestAxiosCall.post(`${this.sessionServiceUrl}/service/login`, { service: this.config.name }, headers);
49
+ this.token = (_c = (_b = (_a = session === null || session === void 0 ? void 0 : session.token) === null || _a === void 0 ? void 0 : _a.payload) === null || _b === void 0 ? void 0 : _b.jwt) !== null && _c !== void 0 ? _c : "";
50
+ return {
51
+ approved: true,
52
+ payload: { headers: { "Authorization": this.token } }
53
+ };
54
+ }
55
+ return {
56
+ approved: false,
57
+ rejection: {
58
+ code: 500,
59
+ payload: { status: 'Error', message: 'Public API is not available' }
60
+ }
61
+ };
62
+ }
63
+ catch (err) {
64
+ return {
65
+ approved: false,
66
+ rejection: {
67
+ code: 401,
68
+ payload: (_e = (_d = err === null || err === void 0 ? void 0 : err.response) === null || _d === void 0 ? void 0 : _d.data) !== null && _e !== void 0 ? _e : err
69
+ }
70
+ };
71
+ }
72
+ });
73
+ }
74
+ sign(params) {
75
+ return __awaiter(this, void 0, void 0, function* () {
76
+ const { method, path } = params;
77
+ let nonce = Date.now();
78
+ let message = `${nonce}${method}${path}${this.config.name ? JSON.stringify(this.config.name) : ""}`;
79
+ const credentials = yield this.getServiceCredentials();
80
+ if (credentials) {
81
+ const hash = (0, crypto_js_1.HmacSHA256)(message, credentials.apiSecret);
82
+ let signature = crypto_js_1.enc.Hex.stringify(hash);
83
+ return {
84
+ headers: {
85
+ Authorization: `${credentials.apiKey}:${nonce}:${signature}`,
86
+ },
87
+ };
88
+ }
89
+ return undefined;
90
+ });
91
+ }
92
+ getServiceCredentials() {
93
+ return __awaiter(this, void 0, void 0, function* () {
94
+ try {
95
+ const credentials = yield itrm_tools_1.RequestAxiosCall.get(`${this.sessionServiceUrl}/service/credentials?service=${this.config.name}`, { headers: { referer: this.config.url } });
96
+ return credentials.payload;
97
+ }
98
+ catch (error) {
99
+ return undefined;
100
+ }
101
+ });
102
+ }
103
+ }
104
+ exports.ServiceSessionChecker = ServiceSessionChecker;
105
+ //# sourceMappingURL=ServiceSessionChecker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ServiceSessionChecker.js","sourceRoot":"","sources":["../../../src/apí/checkers/ServiceSessionChecker.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ import { AxiosRequestConfig } from "axios";
2
+ export interface IAvailablePlatform {
3
+ availablePlatformId?: number;
4
+ userId: number;
5
+ roleId: number;
6
+ platformId: number;
7
+ restictions: any;
8
+ updatedAt?: string;
9
+ createdAt?: string;
10
+ config?: AxiosRequestConfig;
11
+ }
12
+ export interface IAvailablePlatformSearchDetails {
13
+ userId?: number;
14
+ roleId?: number;
15
+ platformId?: number;
16
+ restictions?: any;
17
+ config?: AxiosRequestConfig;
18
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=AvailablePlataformManager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AvailablePlataformManager.js","sourceRoot":"","sources":["../../src/crud/AvailablePlataformManager.ts"],"names":[],"mappings":""}
@@ -0,0 +1,33 @@
1
+ import { AxiosRequestConfig } from "axios";
2
+ import { IPlatform } from "./PlatformManager";
3
+ export interface IComponent {
4
+ componentId?: number;
5
+ platformId?: number;
6
+ name: string;
7
+ details: IComponentDetails;
8
+ platforms?: IPlatform[];
9
+ updatedAt?: string;
10
+ createdAt?: string;
11
+ config?: AxiosRequestConfig;
12
+ }
13
+ export interface IComponentDetails {
14
+ lang: {
15
+ [key: string]: string;
16
+ };
17
+ services: IComponentServiceDetails;
18
+ viewTypes: string[] | string;
19
+ config?: AxiosRequestConfig;
20
+ }
21
+ export interface IComponentServiceDetails {
22
+ [key: string]: {
23
+ [key: string]: {
24
+ [key: string]: boolean;
25
+ };
26
+ };
27
+ }
28
+ export interface IComponentSearchDetails {
29
+ platformId?: number;
30
+ name?: string;
31
+ details?: IComponentDetails;
32
+ config?: AxiosRequestConfig;
33
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=ComponentManager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ComponentManager.js","sourceRoot":"","sources":["../../src/crud/ComponentManager.ts"],"names":[],"mappings":""}
@@ -0,0 +1,34 @@
1
+ import { AxiosRequestConfig } from "axios";
2
+ import { CrudServiceManager, StandardIdRequestDefinition } from "itrm-tools";
3
+ export interface IPlatform {
4
+ platformId?: number;
5
+ name: string;
6
+ details: IPlatformDetails;
7
+ updatedAt?: string;
8
+ createdAt?: string;
9
+ config?: AxiosRequestConfig;
10
+ }
11
+ export interface IPlatformDetails {
12
+ lang: {
13
+ [key: string]: string;
14
+ };
15
+ description?: string;
16
+ platformUrl: string;
17
+ config?: AxiosRequestConfig;
18
+ }
19
+ export interface IPlatformSearchDetails {
20
+ platformId?: number;
21
+ name?: string;
22
+ details?: any;
23
+ config?: AxiosRequestConfig;
24
+ }
25
+ export declare class PlatformManager extends CrudServiceManager<IPlatformSearchDetails, IPlatform> {
26
+ private url;
27
+ constructor(url: string);
28
+ findById(id: StandardIdRequestDefinition): Promise<IPlatform | undefined>;
29
+ find(details: IPlatformSearchDetails): Promise<IPlatform | undefined>;
30
+ findAll(details: IPlatformSearchDetails): Promise<IPlatform[] | undefined>;
31
+ create(details: IPlatformSearchDetails): Promise<IPlatform | undefined>;
32
+ modify(platforms: IPlatform): Promise<any>;
33
+ destroy(platforms: IPlatform): Promise<any>;
34
+ }
@@ -0,0 +1,49 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.PlatformManager = void 0;
13
+ const itrm_tools_1 = require("itrm-tools");
14
+ class PlatformManager extends itrm_tools_1.CrudServiceManager {
15
+ constructor(url) {
16
+ super();
17
+ this.url = url;
18
+ }
19
+ findById(id) {
20
+ return this.sendFinding(`${this.url}/platforms?id=${id.id}`, id.config);
21
+ }
22
+ find(details) {
23
+ return this.sendFinding(`${this.url}/platforms?name=${details.name}`, details.config);
24
+ }
25
+ findAll(details) {
26
+ return __awaiter(this, void 0, void 0, function* () {
27
+ let platforms = [], limit = 100, offset = 0, isEmpty = false;
28
+ do {
29
+ let values = yield this.sendAllFinding(`${this.url}/platforms?limit=${limit}&offset=${offset}`, details.config);
30
+ if (values)
31
+ platforms = platforms.concat(values);
32
+ isEmpty = values != undefined && values.length > 0;
33
+ offset += limit;
34
+ } while (!isEmpty);
35
+ return platforms;
36
+ });
37
+ }
38
+ create(details) {
39
+ return this.sendCreation(`${this.url}/platforms`, { name: details.name, details: details.details }, details.config);
40
+ }
41
+ modify(platforms) {
42
+ return this.sendModification(`${this.url}/platforms/${platforms.platformId}`, { name: platforms.name, details: platforms.details }, platforms.config);
43
+ }
44
+ destroy(platforms) {
45
+ return this.sendDestuction(`${this.url}/platforms/${platforms.platformId}`, platforms.config);
46
+ }
47
+ }
48
+ exports.PlatformManager = PlatformManager;
49
+ //# sourceMappingURL=PlatformManager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PlatformManager.js","sourceRoot":"","sources":["../../src/crud/PlatformManager.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,2CAA6E;AAyB7E,MAAa,eAAgB,SAAQ,+BAAqD;IAGxF,YAAY,GAAW;QACrB,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;IACjB,CAAC;IAEM,QAAQ,CAAC,EAA+B;QAC7C,OAAO,IAAI,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,GAAG,iBAAiB,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC;IAC1E,CAAC;IAEM,IAAI,CAAC,OAA+B;QACzC,OAAO,IAAI,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,GAAG,mBAAmB,OAAO,CAAC,IAAI,EAAE,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;IACxF,CAAC;IAEY,OAAO,CAAC,OAA+B;;YAClD,IAAI,SAAS,GAAgB,EAAE,EAAE,KAAK,GAAG,GAAG,EAAE,MAAM,GAAG,CAAC,EAAE,OAAO,GAAG,KAAK,CAAC;YAC1E,GAAG,CAAC;gBACA,IAAI,MAAM,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC,GAAG,oBAAoB,KAAK,WAAW,MAAM,EAAE,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;gBAChH,IAAI,MAAM;oBACN,SAAS,GAAG,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;gBACzC,OAAO,GAAG,MAAM,IAAI,SAAS,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;gBACnD,MAAM,IAAI,KAAK,CAAC;YACpB,CAAC,QAAO,CAAC,OAAO,EAAE;YAClB,OAAO,SAAS,CAAC;QACnB,CAAC;KAAA;IAEM,MAAM,CAAC,OAA+B;QAC3C,OAAO,IAAI,CAAC,YAAY,CACtB,GAAG,IAAI,CAAC,GAAG,YAAY,EACvB,EAAE,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,EAChD,OAAO,CAAC,MAAM,CACf,CAAC;IACJ,CAAC;IAEM,MAAM,CAAC,SAAoB;QAChC,OAAO,IAAI,CAAC,gBAAgB,CAC1B,GAAG,IAAI,CAAC,GAAG,cAAc,SAAS,CAAC,UAAU,EAAE,EAC/C,EAAE,IAAI,EAAE,SAAS,CAAC,IAAI,EAAE,OAAO,EAAE,SAAS,CAAC,OAAO,EAAE,EACpD,SAAS,CAAC,MAAM,CACjB,CAAC;IACJ,CAAC;IAEM,OAAO,CAAC,SAAoB;QACjC,OAAO,IAAI,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC,GAAG,cAAc,SAAS,CAAC,UAAU,EAAE,EAAE,SAAS,CAAC,MAAM,CAAC,CAAC;IAChG,CAAC;CACF;AA/CD,0CA+CC"}
@@ -0,0 +1,44 @@
1
+ import { AxiosRequestConfig } from "axios";
2
+ import { CrudServiceManager, StandardIdRequestDefinition } from "itrm-tools";
3
+ import { IComponent } from "./ComponentManager";
4
+ export interface IRole {
5
+ roleId?: number;
6
+ name: string;
7
+ permissions: IRolePermissions;
8
+ updateAt?: string;
9
+ CreateAt?: string;
10
+ config?: AxiosRequestConfig;
11
+ }
12
+ export interface IRolePermissions {
13
+ type?: string;
14
+ url?: string;
15
+ components?: {
16
+ [key: string]: {
17
+ [key: string]: string;
18
+ };
19
+ };
20
+ services?: {
21
+ [key: string]: {
22
+ [key: string]: {
23
+ [key: string]: boolean;
24
+ };
25
+ };
26
+ };
27
+ schema?: IComponent;
28
+ }
29
+ export interface IRoleSearchDetails {
30
+ roleId?: number;
31
+ name: string;
32
+ permissions: IRolePermissions;
33
+ config?: AxiosRequestConfig;
34
+ }
35
+ export declare class RoleManager extends CrudServiceManager<IRoleSearchDetails, IRole> {
36
+ private url;
37
+ constructor(url: string);
38
+ findById(id: StandardIdRequestDefinition): Promise<IRole | undefined>;
39
+ find(details: IRoleSearchDetails): Promise<IRole | undefined>;
40
+ findAll(details: IRoleSearchDetails): Promise<IRole[] | undefined>;
41
+ create(details: IRoleSearchDetails): Promise<IRole | undefined>;
42
+ modify(role: IRole): Promise<any>;
43
+ destroy(role: IRole): Promise<any>;
44
+ }
@@ -0,0 +1,49 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.RoleManager = void 0;
13
+ const itrm_tools_1 = require("itrm-tools");
14
+ class RoleManager extends itrm_tools_1.CrudServiceManager {
15
+ constructor(url) {
16
+ super();
17
+ this.url = url;
18
+ }
19
+ findById(id) {
20
+ return this.sendFinding(`${this.url}/roles?id=${id.id}`, id.config);
21
+ }
22
+ find(details) {
23
+ return this.sendFinding(`${this.url}/roles?role=${details.name}`, details.config);
24
+ }
25
+ findAll(details) {
26
+ return __awaiter(this, void 0, void 0, function* () {
27
+ let roles = [], limit = 100, offset = 0, isEmpty = false;
28
+ do {
29
+ let values = yield this.sendAllFinding(`${this.url}/roles?limit=${limit}&offset=${offset}`, details.config);
30
+ if (values)
31
+ roles = roles.concat(values);
32
+ isEmpty = values != undefined && values.length > 0;
33
+ offset += limit;
34
+ } while (!isEmpty);
35
+ return roles;
36
+ });
37
+ }
38
+ create(details) {
39
+ return this.sendCreation(`${this.url}/roles`, { name: details.name, permissions: details.permissions }, details.config);
40
+ }
41
+ modify(role) {
42
+ return this.sendModification(`${this.url}/roles/${role.roleId}`, { name: role.name, permissions: role.permissions }, role.config);
43
+ }
44
+ destroy(role) {
45
+ return this.sendDestuction(`${this.url}/roles/${role.roleId}`, role.config);
46
+ }
47
+ }
48
+ exports.RoleManager = RoleManager;
49
+ //# sourceMappingURL=RoleManager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RoleManager.js","sourceRoot":"","sources":["../../src/crud/RoleManager.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,2CAA0F;AA2B1F,MAAa,WAAY,SAAQ,+BAA6C;IAG1E,YAAY,GAAW;QACnB,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;IACnB,CAAC;IAEM,QAAQ,CAAE,EAA+B;QAC5C,OAAO,IAAI,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,GAAG,aAAa,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC;IACxE,CAAC;IAEM,IAAI,CAAC,OAA2B;QACnC,OAAO,IAAI,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,GAAG,eAAe,OAAO,CAAC,IAAI,EAAE,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;IACtF,CAAC;IAEY,OAAO,CAAC,OAA2B;;YAC5C,IAAI,KAAK,GAAY,EAAE,EAAE,KAAK,GAAG,GAAG,EAAE,MAAM,GAAG,CAAC,EAAE,OAAO,GAAG,KAAK,CAAC;YAClE,GAAG,CAAC;gBACA,IAAI,MAAM,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC,GAAG,gBAAgB,KAAK,WAAW,MAAM,EAAE,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;gBAC5G,IAAI,MAAM;oBACN,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;gBACjC,OAAO,GAAG,MAAM,IAAI,SAAS,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;gBACnD,MAAM,IAAI,KAAK,CAAC;YACpB,CAAC,QAAO,CAAC,OAAO,EAAE;YAClB,OAAO,KAAK,CAAC;QACf,CAAC;KAAA;IAEM,MAAM,CAAC,OAA2B;QACvC,OAAO,IAAI,CAAC,YAAY,CACtB,GAAG,IAAI,CAAC,GAAG,QAAQ,EACnB,EAAE,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,WAAW,EAAE,OAAO,CAAC,WAAW,EAAE,EACxD,OAAO,CAAC,MAAM,CACf,CAAC;IACJ,CAAC;IAEM,MAAM,CAAC,IAAW;QACvB,OAAO,IAAI,CAAC,gBAAgB,CAC1B,GAAG,IAAI,CAAC,GAAG,UAAU,IAAI,CAAC,MAAM,EAAE,EAClC,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,WAAW,EAAE,IAAI,CAAC,WAAW,EAAE,EAClD,IAAI,CAAC,MAAM,CACZ,CAAC;IACJ,CAAC;IAEM,OAAO,CAAC,IAAW;QACxB,OAAO,IAAI,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC,GAAG,UAAU,IAAI,CAAC,MAAM,EAAE,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IAC9E,CAAC;CACN;AA/CD,kCA+CC"}
@@ -0,0 +1,26 @@
1
+ import { CrudServiceManager, StandardIdRequestDefinition } from "itrm-tools";
2
+ import { AxiosRequestConfig } from "axios";
3
+ export interface IStatus {
4
+ statusId?: number;
5
+ status: string;
6
+ details: any;
7
+ updateAt?: string;
8
+ createAt?: string;
9
+ config?: AxiosRequestConfig;
10
+ }
11
+ export interface IStatusSearchDetails {
12
+ statusId?: number;
13
+ status: string;
14
+ details: any;
15
+ config?: AxiosRequestConfig;
16
+ }
17
+ export declare class StatusManager extends CrudServiceManager<IStatusSearchDetails, IStatus> {
18
+ private url;
19
+ constructor(url: string);
20
+ find(details: IStatusSearchDetails): Promise<IStatus | undefined>;
21
+ findAll(details: IStatusSearchDetails): Promise<IStatus[] | undefined>;
22
+ findById(id: StandardIdRequestDefinition): Promise<IStatus | undefined>;
23
+ create(details: IStatusSearchDetails): Promise<IStatus | undefined>;
24
+ modify(status: IStatus): Promise<any>;
25
+ destroy(status: IStatus): Promise<any>;
26
+ }
@@ -0,0 +1,51 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.StatusManager = void 0;
13
+ const itrm_tools_1 = require("itrm-tools");
14
+ class StatusManager extends itrm_tools_1.CrudServiceManager {
15
+ constructor(url) {
16
+ super();
17
+ this.url = url;
18
+ }
19
+ find(details) {
20
+ return __awaiter(this, void 0, void 0, function* () {
21
+ return this.sendFinding(`${this.url}/status?status=${details.status}`, details.config);
22
+ });
23
+ }
24
+ findAll(details) {
25
+ return __awaiter(this, void 0, void 0, function* () {
26
+ let status = [], limit = 100, offset = 0, isEmpty = false;
27
+ do {
28
+ let values = yield this.sendAllFinding(`${this.url}/status?limit=${limit}&offset=${offset}`, details.config);
29
+ if (values)
30
+ status = status.concat(values);
31
+ isEmpty = values != undefined && values.length == 0;
32
+ offset += limit;
33
+ } while (!isEmpty);
34
+ return status;
35
+ });
36
+ }
37
+ findById(id) {
38
+ return this.sendFinding(`${this.url}/status?id=${id.id}`, id.config);
39
+ }
40
+ create(details) {
41
+ return this.sendCreation(`${this.url}/status`, { status: details.status, details: details.details }, details.config);
42
+ }
43
+ modify(status) {
44
+ return this.sendModification(`${this.url}/status/${status.statusId}`, { status: status.status, details: status.details }, status.config);
45
+ }
46
+ destroy(status) {
47
+ return this.sendDestuction(`${this.url}/status/${status.statusId}`, status.config);
48
+ }
49
+ }
50
+ exports.StatusManager = StatusManager;
51
+ //# sourceMappingURL=StatusManager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StatusManager.js","sourceRoot":"","sources":["../../src/crud/StatusManager.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA6E;AAqB7E,MAAa,aAAc,SAAQ,+BAAiD;IAGhF,YAAa,GAAW;QACpB,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;IACnB,CAAC;IAEY,IAAI,CAAC,OAA6B;;YAC3C,OAAO,IAAI,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,GAAG,kBAAkB,OAAO,CAAC,MAAM,EAAE,EAAG,OAAO,CAAC,MAAM,CAAC,CAAC;QAC5F,CAAC;KAAA;IAEY,OAAO,CAAC,OAA6B;;YAC9C,IAAI,MAAM,GAAc,EAAE,EAAE,KAAK,GAAG,GAAG,EAAE,MAAM,GAAG,CAAC,EAAE,OAAO,GAAG,KAAK,CAAC;YACrE,GAAE,CAAC;gBACC,IAAI,MAAM,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC,GAAG,iBAAiB,KAAK,WAAW,MAAM,EAAE,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;gBAC7G,IAAI,MAAM;oBACN,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;gBACnC,OAAO,GAAG,MAAM,IAAI,SAAS,IAAI,MAAM,CAAC,MAAM,IAAI,CAAC,CAAC;gBACpD,MAAM,IAAI,KAAK,CAAC;YACpB,CAAC,QAAQ,CAAC,OAAO,EAAE;YACnB,OAAO,MAAM,CAAC;QAClB,CAAC;KAAA;IAEM,QAAQ,CAAC,EAA+B;QAC3C,OAAO,IAAI,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,GAAG,cAAc,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC;IACzE,CAAC;IAEM,MAAM,CAAC,OAA6B;QACvC,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,GAAG,SAAS,EAAE,EAAE,MAAM,EAAE,OAAO,CAAC,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;IACzH,CAAC;IAEM,MAAM,CAAC,MAAe;QACzB,OAAO,IAAI,CAAC,gBAAgB,CAAC,GAAG,IAAI,CAAC,GAAG,WAAW,MAAM,CAAC,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,OAAO,EAAE,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;IAC7I,CAAC;IAEM,OAAO,CAAC,MAAe;QAC1B,OAAO,IAAI,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC,GAAG,WAAW,MAAM,CAAC,QAAQ,EAAE,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;IACvF,CAAC;CAEJ;AAxCD,sCAwCC"}
@@ -0,0 +1,25 @@
1
+ import { AxiosRequestConfig } from "axios";
2
+ import { CrudServiceManager, StandardIdRequestDefinition } from "itrm-tools";
3
+ export interface IType {
4
+ typeId?: number;
5
+ type: string;
6
+ details: any;
7
+ updatedAt?: string;
8
+ createdAt?: string;
9
+ config?: AxiosRequestConfig;
10
+ }
11
+ export interface ITypeSearchDetails {
12
+ type: string;
13
+ details?: any;
14
+ config?: AxiosRequestConfig;
15
+ }
16
+ export declare class TypeManager extends CrudServiceManager<ITypeSearchDetails, IType> {
17
+ private url;
18
+ constructor(url: string);
19
+ find(details: ITypeSearchDetails): Promise<IType | undefined>;
20
+ findAll(details: ITypeSearchDetails): Promise<IType[] | undefined>;
21
+ findById(id: StandardIdRequestDefinition): Promise<IType | undefined>;
22
+ create(details: ITypeSearchDetails): Promise<IType | undefined>;
23
+ modify(type: IType): Promise<any>;
24
+ destroy(type: IType): Promise<any>;
25
+ }
@@ -0,0 +1,53 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.TypeManager = void 0;
13
+ const itrm_tools_1 = require("itrm-tools");
14
+ class TypeManager extends itrm_tools_1.CrudServiceManager {
15
+ constructor(url) {
16
+ super();
17
+ this.url = url;
18
+ }
19
+ find(details) {
20
+ return __awaiter(this, void 0, void 0, function* () {
21
+ return this.sendFinding(`${this.url}/types?type=${details.type}`, details.config);
22
+ });
23
+ }
24
+ findAll(details) {
25
+ return __awaiter(this, void 0, void 0, function* () {
26
+ let types = [], limit = 100, offset = 0, isEmpty = false;
27
+ do {
28
+ let values = yield this.sendAllFinding(`${this.url}/types?limit=${limit}&offset=${offset}`, details.config);
29
+ if (values)
30
+ types = types.concat(values);
31
+ isEmpty = values != undefined && values.length > 0;
32
+ offset += limit;
33
+ } while (!isEmpty);
34
+ return types;
35
+ });
36
+ }
37
+ findById(id) {
38
+ return this.sendFinding(`${this.url}/types?id=${id.id}`, id.config);
39
+ }
40
+ create(details) {
41
+ var _a;
42
+ return this.sendCreation(`${this.url}/types`, { type: details.type, details: (_a = details.details) !== null && _a !== void 0 ? _a : {} }, details.config);
43
+ }
44
+ modify(type) {
45
+ var _a;
46
+ return this.sendModification(`${this.url}/types/${type.typeId}`, { type: type.type, details: (_a = type.details) !== null && _a !== void 0 ? _a : {} }, type.config);
47
+ }
48
+ destroy(type) {
49
+ return this.sendDestuction(`${this.url}/types/${type.typeId}`, type.config);
50
+ }
51
+ }
52
+ exports.TypeManager = TypeManager;
53
+ //# sourceMappingURL=TypeManager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TypeManager.js","sourceRoot":"","sources":["../../src/crud/TypeManager.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,2CAA6E;AAiB7E,MAAa,WAAY,SAAQ,+BAA6C;IAG1E,YAAY,GAAW;QACnB,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,GAAG,GAAG,GAAG,CAAC;IACnB,CAAC;IAEY,IAAI,CAAC,OAA2B;;YACzC,OAAO,IAAI,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,GAAG,eAAe,OAAO,CAAC,IAAI,EAAE,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;QACtF,CAAC;KAAA;IAEY,OAAO,CAAC,OAA2B;;YAC5C,IAAI,KAAK,GAAY,EAAE,EAAE,KAAK,GAAG,GAAG,EAAE,MAAM,GAAG,CAAC,EAAE,OAAO,GAAG,KAAK,CAAC;YAClE,GAAG,CAAC;gBACA,IAAI,MAAM,GAAG,MAAM,IAAI,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC,GAAG,gBAAgB,KAAK,WAAW,MAAM,EAAE,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;gBAC5G,IAAI,MAAM;oBACN,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;gBACjC,OAAO,GAAG,MAAM,IAAI,SAAS,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;gBACnD,MAAM,IAAI,KAAK,CAAC;YACpB,CAAC,QAAO,CAAC,OAAO,EAAE;YAClB,OAAO,KAAK,CAAC;QACjB,CAAC;KAAA;IAEM,QAAQ,CAAC,EAA+B;QAC3C,OAAO,IAAI,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,GAAG,aAAa,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC;IACxE,CAAC;IAEM,MAAM,CAAC,OAA2B;;QACrC,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,GAAG,QAAQ,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,OAAO,EAAE,MAAA,OAAO,CAAC,OAAO,mCAAI,EAAE,EAAE,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC;IAC1H,CAAC;IAEM,MAAM,CAAC,IAAW;;QACrB,OAAO,IAAI,CAAC,gBAAgB,CAAC,GAAG,IAAI,CAAC,GAAG,UAAU,IAAI,CAAC,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,OAAO,EAAE,MAAA,IAAI,CAAC,OAAO,mCAAI,EAAE,EAAE,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IACpI,CAAC;IAEM,OAAO,CAAC,IAAW;QACtB,OAAO,IAAI,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC,GAAG,UAAU,IAAI,CAAC,MAAM,EAAE,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IAChF,CAAC;CACJ;AAvCD,kCAuCC"}
@@ -0,0 +1,20 @@
1
+ import { AxiosRequestConfig } from "axios";
2
+ export interface IUserCredentials {
3
+ userCredentialId?: number;
4
+ userName: string;
5
+ password: string;
6
+ email: string;
7
+ metadata: any;
8
+ updatedAt?: string;
9
+ createdAt?: string;
10
+ config?: AxiosRequestConfig;
11
+ }
12
+ export interface IUserCredentialsSearchDetails {
13
+ userCredentialId?: number;
14
+ userName?: string;
15
+ password?: string;
16
+ email?: string;
17
+ metadata?: any;
18
+ credentialsId?: number;
19
+ config?: AxiosRequestConfig;
20
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=UserCredentialsManager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UserCredentialsManager.js","sourceRoot":"","sources":["../../src/crud/UserCredentialsManager.ts"],"names":[],"mappings":""}
@@ -0,0 +1,15 @@
1
+ import { AxiosRequestConfig } from "axios";
2
+ export interface IUser {
3
+ userId?: number;
4
+ statusId: number;
5
+ credentialsId: number;
6
+ updatedAt?: string;
7
+ createdAt?: string;
8
+ config?: AxiosRequestConfig;
9
+ }
10
+ export interface IUserSearchDetails {
11
+ userId?: number;
12
+ statusId?: number;
13
+ credentialsId?: number;
14
+ config?: AxiosRequestConfig;
15
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=UserManager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UserManager.js","sourceRoot":"","sources":["../../src/crud/UserManager.ts"],"names":[],"mappings":""}
@@ -0,0 +1,10 @@
1
+ export { ExpressLogableConfig as ExpressLogableConfig } from './apí/ExpressLogableConfig';
2
+ export { IServiceSessionConfig as IServiceSessionConfig, IServiceCredentials as IServiceCredentials, ServiceSessionChecker as ServiceSessionChecker } from './apí/checkers/ServiceSessionChecker';
3
+ export { IComponent as IComponent, IComponentSearchDetails as IComponentSearchDetails, IComponentDetails as IComponentDetails, IComponentServiceDetails as IComponentServiceDetails } from './crud/ComponentManager';
4
+ export { IPlatform as IPlatform, IPlatformSearchDetails as IPlatformSearchDetails, IPlatformDetails as IPlatformDetails, PlatformManager as PlatformManager } from "./crud/PlatformManager";
5
+ export { IAvailablePlatform as IAvailablePlatform, IAvailablePlatformSearchDetails as IAvailablePlatformSearchDetails } from './crud/AvailablePlataformManager';
6
+ export { IRole as IRole, IRoleSearchDetails as IRoleSearchDetails, RoleManager as RoleManager } from "./crud/RoleManager";
7
+ export { IStatus as IStatus, IStatusSearchDetails as IStatusSearchDetails, StatusManager as StatusManager } from "./crud/StatusManager";
8
+ export { IType as IType, ITypeSearchDetails as ITypeSearchDetails, TypeManager as TypeManager } from "./crud/TypeManager";
9
+ export { IUserCredentials as IUserCredentials, IUserCredentialsSearchDetails as IUserCredentialsSearchDetails } from "./crud/UserCredentialsManager";
10
+ export { IUser as IUser, IUserSearchDetails as IUserSearchDetails } from "./crud/UserManager";
package/dist/index.js ADDED
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TypeManager = exports.StatusManager = exports.RoleManager = exports.PlatformManager = exports.ServiceSessionChecker = exports.ExpressLogableConfig = void 0;
4
+ var ExpressLogableConfig_1 = require("./ap\u00ED/ExpressLogableConfig");
5
+ Object.defineProperty(exports, "ExpressLogableConfig", { enumerable: true, get: function () { return ExpressLogableConfig_1.ExpressLogableConfig; } });
6
+ var ServiceSessionChecker_1 = require("./ap\u00ED/checkers/ServiceSessionChecker");
7
+ Object.defineProperty(exports, "ServiceSessionChecker", { enumerable: true, get: function () { return ServiceSessionChecker_1.ServiceSessionChecker; } });
8
+ var PlatformManager_1 = require("./crud/PlatformManager");
9
+ Object.defineProperty(exports, "PlatformManager", { enumerable: true, get: function () { return PlatformManager_1.PlatformManager; } });
10
+ var RoleManager_1 = require("./crud/RoleManager");
11
+ Object.defineProperty(exports, "RoleManager", { enumerable: true, get: function () { return RoleManager_1.RoleManager; } });
12
+ var StatusManager_1 = require("./crud/StatusManager");
13
+ Object.defineProperty(exports, "StatusManager", { enumerable: true, get: function () { return StatusManager_1.StatusManager; } });
14
+ var TypeManager_1 = require("./crud/TypeManager");
15
+ Object.defineProperty(exports, "TypeManager", { enumerable: true, get: function () { return TypeManager_1.TypeManager; } });
16
+ //export { applyLoginMocks as applyLoginMocks } from "./crud/test/LoginServiceMock";
17
+ //export { applyPlatformMocks as applyPlatformMocks } from "./crud/test/PlatformMocks";
18
+ //export { applyRoleMocks as applyRoleMocks } from "./crud/test/RoleMocks";
19
+ //export { applyStatusMocks as applyStatusMocks } from "./crud/test/StatusMocks";
20
+ //export { applyTypeMocks as applyTypeMocks } from "./crud/test/TypeMocks";
21
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;AAAA,wEAA0F;AAAjF,4HAAA,oBAAoB,OAAwB;AAErD,mFAAkM;AAA7F,8HAAA,qBAAqB,OAAyB;AAGnJ,0DAA4L;AAAnE,kHAAA,eAAe,OAAmB;AAE3J,kDAA0H;AAAvD,0GAAA,WAAW,OAAe;AAC7F,sDAAwI;AAA7D,8GAAA,aAAa,OAAiB;AACzG,kDAA0H;AAAvD,0GAAA,WAAW,OAAe;AAK7F,oFAAoF;AACpF,uFAAuF;AACvF,2EAA2E;AAC3E,iFAAiF;AACjF,2EAA2E"}
package/package.json ADDED
@@ -0,0 +1,43 @@
1
+ {
2
+ "name": "elemento-alpha-tools",
3
+ "version": "1.0.0",
4
+ "description": "Librería para los servicios de elemento alpha",
5
+ "main": "dist/index.js",
6
+ "types": "dist/index.d.ts",
7
+ "files": [
8
+ "/dist"
9
+ ],
10
+ "scripts": {
11
+ "build": "rimraf ./dist && tsc --skipLibCheck",
12
+ "publish-lib": "npm run build && npm publish",
13
+ "publish-beta": "npm run build && npm publish --tag beta",
14
+ "publish-dryrun": "npm run build && npm publish --dry-run",
15
+ "link": "npm run build && npm link",
16
+ "test": "npm run build && jest --runInBand --detectOpenHandles",
17
+ "test-watch": "npm run build && jest --watch --runInBand --detectOpenHandles",
18
+ "test-silent": "npm run build && jest --runInBand --detectOpenHandles --silent",
19
+ "test-coverage": "npm run build && jest --runInBand --detectOpenHandles --silent --coverage"
20
+ },
21
+ "repository": {
22
+ "type": "git",
23
+ "url": "git+https://github.com/Elemento-Alpha/elemento-alpha-tools.git"
24
+ },
25
+ "keywords": [],
26
+ "bugs": {
27
+ "url": "https://github.com/Elemento-Alpha/elemento-alpha-tools/issues"
28
+ },
29
+ "homepage": "https://github.com/Elemento-Alpha/elemento-alpha-tools#readme",
30
+ "author": "",
31
+ "license": "ISC",
32
+ "devDependencies": {
33
+ "@types/crypto-js": "^4.2.2",
34
+ "@types/node": "^22.5.5",
35
+ "typescript": "^5.6.2"
36
+ },
37
+ "dependencies": {
38
+ "axios-mock-adapter": "^2.0.0",
39
+ "crypto-js": "^4.2.0",
40
+ "itrm-tools": "^1.1.9",
41
+ "rimraf": "^6.0.1"
42
+ }
43
+ }