namirasoft-core 1.2.0 → 1.2.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/.gitlab-ci.yml CHANGED
@@ -1,14 +1,14 @@
1
- stages:
2
- - npm-publish
3
-
4
- publish:
5
- stage: npm-publish
6
- script:
7
- - rm -rf node_modules
8
- - rm -rf dist
9
- - ncu -u
10
- - npm i
11
- - tsc
12
- - npm publish
13
- only:
1
+ stages:
2
+ - npm-publish
3
+
4
+ publish:
5
+ stage: npm-publish
6
+ script:
7
+ - rm -rf node_modules
8
+ - rm -rf dist
9
+ - ncu -u
10
+ - npm i
11
+ - tsc
12
+ - npm publish
13
+ only:
14
14
  - master
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "namirasoft-core",
3
3
  "description": "Namira Software Corporation Core NPM Package",
4
- "version": "1.2.0",
4
+ "version": "1.2.2",
5
5
  "main": "./dist/index.js",
6
6
  "types": "./dist/index.d.ts",
7
7
  "scripts": {},
@@ -9,10 +9,10 @@
9
9
  "license": "MIT",
10
10
  "dependencies": {
11
11
  "@types/md5": "^2.3.5",
12
- "@types/node": "^20.10.0",
12
+ "@types/node": "^20.10.3",
13
13
  "axios": "^1.6.2",
14
14
  "md5": "^2.3.0",
15
15
  "moment": "^2.29.4",
16
16
  "phone": "^3.1.41"
17
17
  }
18
- }
18
+ }
@@ -1,7 +1,7 @@
1
- export type BaseDatabaseRow<ID> =
2
- {
3
- id: ID;
4
- createdAt: string;
5
- updatedAt: string;
6
- deletedAt: string;
1
+ export type BaseDatabaseRow<ID> =
2
+ {
3
+ id: ID;
4
+ createdAt: string;
5
+ updatedAt: string;
6
+ deletedAt: string;
7
7
  }
package/src/BaseServer.ts CHANGED
@@ -1,73 +1,73 @@
1
- import axios, { AxiosRequestConfig, AxiosResponse } from "axios";
2
- import { SignOperation } from "./SignOperation";
3
- import { URLOperation } from "./URLOperation";
4
- import { ErrorOperation } from "./ErrorOperation";
5
- import { ParsedNameValue } from "./ParsedNameValue";
6
-
7
- export abstract class BaseServer
8
- {
9
- protected domain: string = "";
10
- constructor(domain: string)
11
- {
12
- this.domain = domain;
13
- }
14
- protected abstract onBeforeRequest<ReqData = any>(url: string, config?: AxiosRequestConfig<ReqData>): void;
15
- protected abstract onAfterRequest<ResData = any>(url: string, response: AxiosResponse<ResData>): void;
16
- protected abstract onError(error: Error): void;
17
- private async _request<ResData = any, ReqData = any>(onRequest: (url: string, data?: any, config?: AxiosRequestConfig<ReqData>) => Promise<AxiosResponse<ResData>>, sub: string, query?: { [name: string]: ParsedNameValue }, data?: ReqData, config?: AxiosRequestConfig<ReqData>, sign_header?: string, sign_key?: string): Promise<{ response: AxiosResponse<ResData>, data: ResData }>
18
- {
19
- let url: string = URLOperation.getLink(this.domain, sub, query);
20
- if (!config)
21
- config = { headers: {} };
22
- if (sign_header)
23
- if (sign_key)
24
- if (data)
25
- if (config?.headers)
26
- config.headers[sign_header] = SignOperation.sign(sign_key, data);
27
- try
28
- {
29
- this.onBeforeRequest(url, config);
30
- let response: AxiosResponse<ResData> = await onRequest(url, data, config);
31
- this.onAfterRequest(url, response);
32
- return { response, data: response.data };
33
- } catch (error)
34
- {
35
- if (error instanceof Error)
36
- {
37
- this.onError(error);
38
- if (axios.isAxiosError(error))
39
- if (error?.response?.data)
40
- ErrorOperation.throwHTTP(error.response.status, error.response.data);
41
- }
42
- throw error;
43
- }
44
- }
45
- protected async _get<ResData = any, ReqData = any>(sub: string, query?: { [name: string]: ParsedNameValue }, config?: AxiosRequestConfig<ReqData>): Promise<{ response: AxiosResponse<ResData>, data: ResData }>
46
- {
47
- return await this._request(async (url: string, _?: any, config?: AxiosRequestConfig<ReqData>) =>
48
- {
49
- return await axios.get(url, config);
50
- }, sub, query, undefined, config);
51
- }
52
- protected async _post<ResData = any, ReqData = any>(sub: string, query?: { [name: string]: ParsedNameValue }, data?: ReqData, config?: AxiosRequestConfig<ReqData>, sign_header?: string, sign_key?: string): Promise<{ response: AxiosResponse<ResData>, data: ResData }>
53
- {
54
- return await this._request(async (url: string, data: ReqData, config?: AxiosRequestConfig<ReqData>) =>
55
- {
56
- return await axios.post(url, data, config);
57
- }, sub, query, data, config, sign_header, sign_key);
58
- }
59
- protected async _put<ResData = any, ReqData = any>(sub: string, query?: { [name: string]: ParsedNameValue }, data?: ReqData, config?: AxiosRequestConfig<ReqData>, sign_header?: string, sign_key?: string): Promise<{ response: AxiosResponse<ResData>, data: ResData }>
60
- {
61
- return await this._request(async (url: string, data: ReqData, config?: AxiosRequestConfig<ReqData>) =>
62
- {
63
- return await axios.put(url, data, config);
64
- }, sub, query, data, config, sign_header, sign_key);
65
- }
66
- protected async _delete<ResData = any, ReqData = any>(sub: string, query?: { [name: string]: ParsedNameValue }, config?: AxiosRequestConfig<ReqData>, sign_header?: string, sign_key?: string): Promise<{ response: AxiosResponse<ResData>, data: ResData }>
67
- {
68
- return await this._request(async (url: string, _?: any, config?: AxiosRequestConfig<ReqData>) =>
69
- {
70
- return await axios.delete(url, config);
71
- }, sub, query, undefined, config, sign_header, sign_key);
72
- }
1
+ import axios, { AxiosRequestConfig, AxiosResponse } from "axios";
2
+ import { SignOperation } from "./SignOperation";
3
+ import { URLOperation } from "./URLOperation";
4
+ import { ErrorOperation } from "./ErrorOperation";
5
+ import { ParsedNameValue } from "./ParsedNameValue";
6
+
7
+ export abstract class BaseServer
8
+ {
9
+ protected domain: string = "";
10
+ constructor(domain: string)
11
+ {
12
+ this.domain = domain;
13
+ }
14
+ protected abstract onBeforeRequest<ReqData = any>(url: string, config?: AxiosRequestConfig<ReqData>): void;
15
+ protected abstract onAfterRequest<ResData = any>(url: string, response: AxiosResponse<ResData>): void;
16
+ protected abstract onError(error: Error): void;
17
+ private async _request<ResData = any, ReqData = any>(onRequest: (url: string, data?: any, config?: AxiosRequestConfig<ReqData>) => Promise<AxiosResponse<ResData>>, sub: string, query?: { [name: string]: ParsedNameValue }, data?: ReqData, config?: AxiosRequestConfig<ReqData>, sign_header?: string, sign_key?: string): Promise<{ response: AxiosResponse<ResData>, data: ResData }>
18
+ {
19
+ let url: string = URLOperation.getLink(this.domain, sub, query);
20
+ if (!config)
21
+ config = { headers: {} };
22
+ if (sign_header)
23
+ if (sign_key)
24
+ if (data)
25
+ if (config?.headers)
26
+ config.headers[sign_header] = SignOperation.sign(sign_key, data);
27
+ try
28
+ {
29
+ this.onBeforeRequest(url, config);
30
+ let response: AxiosResponse<ResData> = await onRequest(url, data, config);
31
+ this.onAfterRequest(url, response);
32
+ return { response, data: response.data };
33
+ } catch (error)
34
+ {
35
+ if (error instanceof Error)
36
+ {
37
+ this.onError(error);
38
+ if (axios.isAxiosError(error))
39
+ if (error?.response?.data)
40
+ ErrorOperation.throwHTTP(error.response.status, error.response.data);
41
+ }
42
+ throw error;
43
+ }
44
+ }
45
+ protected async _get<ResData = any, ReqData = any>(sub: string, query?: { [name: string]: ParsedNameValue }, config?: AxiosRequestConfig<ReqData>): Promise<{ response: AxiosResponse<ResData>, data: ResData }>
46
+ {
47
+ return await this._request(async (url: string, _?: any, config?: AxiosRequestConfig<ReqData>) =>
48
+ {
49
+ return await axios.get(url, config);
50
+ }, sub, query, undefined, config);
51
+ }
52
+ protected async _post<ResData = any, ReqData = any>(sub: string, query?: { [name: string]: ParsedNameValue }, data?: ReqData, config?: AxiosRequestConfig<ReqData>, sign_header?: string, sign_key?: string): Promise<{ response: AxiosResponse<ResData>, data: ResData }>
53
+ {
54
+ return await this._request(async (url: string, data: ReqData, config?: AxiosRequestConfig<ReqData>) =>
55
+ {
56
+ return await axios.post(url, data, config);
57
+ }, sub, query, data, config, sign_header, sign_key);
58
+ }
59
+ protected async _put<ResData = any, ReqData = any>(sub: string, query?: { [name: string]: ParsedNameValue }, data?: ReqData, config?: AxiosRequestConfig<ReqData>, sign_header?: string, sign_key?: string): Promise<{ response: AxiosResponse<ResData>, data: ResData }>
60
+ {
61
+ return await this._request(async (url: string, data: ReqData, config?: AxiosRequestConfig<ReqData>) =>
62
+ {
63
+ return await axios.put(url, data, config);
64
+ }, sub, query, data, config, sign_header, sign_key);
65
+ }
66
+ protected async _delete<ResData = any, ReqData = any>(sub: string, query?: { [name: string]: ParsedNameValue }, config?: AxiosRequestConfig<ReqData>, sign_header?: string, sign_key?: string): Promise<{ response: AxiosResponse<ResData>, data: ResData }>
67
+ {
68
+ return await this._request(async (url: string, _?: any, config?: AxiosRequestConfig<ReqData>) =>
69
+ {
70
+ return await axios.delete(url, config);
71
+ }, sub, query, undefined, config, sign_header, sign_key);
72
+ }
73
73
  }
@@ -1,85 +1,85 @@
1
- import { ErrorOperation } from "./ErrorOperation";
2
-
3
- export abstract class ConvertService
4
- {
5
- private mandatory: boolean;
6
- constructor(mandatory: boolean = false)
7
- {
8
- this.mandatory = mandatory;
9
- }
10
- abstract getNullString(): string | null;
11
- private checkMandatory<D>(value: D): D
12
- {
13
- if (this.mandatory)
14
- if (value == null || value == undefined)
15
- this.onMandatoryError();
16
- return value;
17
- }
18
- protected onMandatoryError(): void
19
- {
20
- ErrorOperation.throwHTTP(500, "Object value can not be converted.");
21
- }
22
- getString(_default: string = ""): string
23
- {
24
- return this.checkMandatory(this.getNullString()) ?? _default;
25
- }
26
- getNullInt(): number | null
27
- {
28
- let str = this.getString();
29
- if (str == null)
30
- return null;
31
- let ans = parseInt(str);
32
- if (isNaN(ans))
33
- return null;
34
- return ans;
35
- }
36
- getInt(_default: number = 0): number
37
- {
38
- return this.checkMandatory(this.getNullInt()) ?? _default;
39
- }
40
- getNullFloat(): number | null
41
- {
42
- let str = this.getString();
43
- if (str == null)
44
- return null;
45
- let ans = parseFloat(str);
46
- if (isNaN(ans))
47
- return null;
48
- return ans;
49
- }
50
- getFloat(_default: number = 0): number
51
- {
52
- return this.checkMandatory(this.getNullFloat()) ?? _default;
53
- }
54
- getNullBoolean(): boolean | null
55
- {
56
- let str = this.getString();
57
- if (str == null)
58
- return null;
59
- let ans = str.toLowerCase();
60
- if (ans == "true")
61
- return true;
62
- if (ans == "false")
63
- return false;
64
- return null;
65
- }
66
- getBoolean(_default: boolean = false): boolean
67
- {
68
- return this.checkMandatory(this.getNullBoolean()) ?? _default;
69
- }
70
- getStringArray(delimiter: string = ","): string[]
71
- {
72
- let ans: string[] = this.getString("").split(delimiter);
73
- ans = ans.map(v => `${v}`);
74
- ans = ans.filter(x => x);
75
- return ans;
76
- }
77
- getIntArray(delimiter: string = ","): number[]
78
- {
79
- return this.getStringArray(delimiter).map(x => parseInt(x)).filter(x => !isNaN(x));
80
- }
81
- getFloatArray(delimiter: string = ","): number[]
82
- {
83
- return this.getStringArray(delimiter).map(x => parseFloat(x)).filter(x => !isNaN(x));
84
- }
1
+ import { ErrorOperation } from "./ErrorOperation";
2
+
3
+ export abstract class ConvertService
4
+ {
5
+ private mandatory: boolean;
6
+ constructor(mandatory: boolean = false)
7
+ {
8
+ this.mandatory = mandatory;
9
+ }
10
+ abstract getNullString(): string | null;
11
+ private checkMandatory<D>(value: D): D
12
+ {
13
+ if (this.mandatory)
14
+ if (value == null || value == undefined)
15
+ this.onMandatoryError();
16
+ return value;
17
+ }
18
+ protected onMandatoryError(): void
19
+ {
20
+ ErrorOperation.throwHTTP(500, "Object value can not be converted.");
21
+ }
22
+ getString(_default: string = ""): string
23
+ {
24
+ return this.checkMandatory(this.getNullString()) ?? _default;
25
+ }
26
+ getNullInt(): number | null
27
+ {
28
+ let str = this.getString();
29
+ if (str == null)
30
+ return null;
31
+ let ans = parseInt(str);
32
+ if (isNaN(ans))
33
+ return null;
34
+ return ans;
35
+ }
36
+ getInt(_default: number = 0): number
37
+ {
38
+ return this.checkMandatory(this.getNullInt()) ?? _default;
39
+ }
40
+ getNullFloat(): number | null
41
+ {
42
+ let str = this.getString();
43
+ if (str == null)
44
+ return null;
45
+ let ans = parseFloat(str);
46
+ if (isNaN(ans))
47
+ return null;
48
+ return ans;
49
+ }
50
+ getFloat(_default: number = 0): number
51
+ {
52
+ return this.checkMandatory(this.getNullFloat()) ?? _default;
53
+ }
54
+ getNullBoolean(): boolean | null
55
+ {
56
+ let str = this.getString();
57
+ if (str == null)
58
+ return null;
59
+ let ans = str.toLowerCase();
60
+ if (ans == "true")
61
+ return true;
62
+ if (ans == "false")
63
+ return false;
64
+ return null;
65
+ }
66
+ getBoolean(_default: boolean = false): boolean
67
+ {
68
+ return this.checkMandatory(this.getNullBoolean()) ?? _default;
69
+ }
70
+ getStringArray(delimiter: string = ","): string[]
71
+ {
72
+ let ans: string[] = this.getString("").split(delimiter);
73
+ ans = ans.map(v => `${v}`);
74
+ ans = ans.filter(x => x);
75
+ return ans;
76
+ }
77
+ getIntArray(delimiter: string = ","): number[]
78
+ {
79
+ return this.getStringArray(delimiter).map(x => parseInt(x)).filter(x => !isNaN(x));
80
+ }
81
+ getFloatArray(delimiter: string = ","): number[]
82
+ {
83
+ return this.getStringArray(delimiter).map(x => parseFloat(x)).filter(x => !isNaN(x));
84
+ }
85
85
  }