@ruiapp/rapid-core 0.1.79 → 0.1.81
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/index.js +83 -42
- package/dist/plugins/dataManage/actionHandlers/deleteCollectionEntities.d.ts +8 -0
- package/package.json +1 -1
- package/rollup.config.js +16 -16
- package/src/core/actionHandler.ts +22 -22
- package/src/core/eventManager.ts +20 -20
- package/src/core/facility.ts +7 -7
- package/src/core/http/formDataParser.ts +89 -89
- package/src/core/pluginManager.ts +175 -175
- package/src/core/providers/runtimeProvider.ts +5 -5
- package/src/core/request.ts +86 -86
- package/src/core/response.ts +76 -76
- package/src/core/routeContext.ts +43 -43
- package/src/core/routesBuilder.ts +88 -88
- package/src/dataAccess/dataAccessor.ts +137 -137
- package/src/deno-std/datetime/to_imf.ts +32 -32
- package/src/deno-std/encoding/base64.ts +141 -141
- package/src/facilities/log/LogFacility.ts +35 -35
- package/src/helpers/entityHelpers.ts +76 -76
- package/src/plugins/auth/actionHandlers/changePassword.ts +54 -54
- package/src/plugins/auth/actionHandlers/createSession.ts +63 -63
- package/src/plugins/auth/actionHandlers/deleteSession.ts +18 -18
- package/src/plugins/auth/actionHandlers/getMyProfile.ts +35 -35
- package/src/plugins/auth/actionHandlers/index.ts +8 -8
- package/src/plugins/auth/actionHandlers/resetPassword.ts +38 -38
- package/src/plugins/auth/models/AccessToken.ts +56 -56
- package/src/plugins/auth/models/index.ts +3 -3
- package/src/plugins/auth/routes/changePassword.ts +15 -15
- package/src/plugins/auth/routes/getMyProfile.ts +15 -15
- package/src/plugins/auth/routes/index.ts +7 -7
- package/src/plugins/auth/routes/resetPassword.ts +15 -15
- package/src/plugins/auth/routes/signin.ts +15 -15
- package/src/plugins/auth/routes/signout.ts +15 -15
- package/src/plugins/cronJob/CronJobPluginTypes.ts +49 -49
- package/src/plugins/cronJob/actionHandlers/index.ts +4 -4
- package/src/plugins/cronJob/actionHandlers/runCronJob.ts +29 -29
- package/src/plugins/cronJob/routes/index.ts +3 -3
- package/src/plugins/cronJob/routes/runCronJob.ts +15 -15
- package/src/plugins/dataManage/DataManagePlugin.ts +8 -0
- package/src/plugins/dataManage/actionHandlers/addEntityRelations.ts +20 -20
- package/src/plugins/dataManage/actionHandlers/countCollectionEntities.ts +15 -15
- package/src/plugins/dataManage/actionHandlers/createCollectionEntitiesBatch.ts +42 -42
- package/src/plugins/dataManage/actionHandlers/createCollectionEntity.ts +24 -24
- package/src/plugins/dataManage/actionHandlers/deleteCollectionEntities.ts +38 -0
- package/src/plugins/dataManage/actionHandlers/findCollectionEntities.ts +26 -26
- package/src/plugins/dataManage/actionHandlers/findCollectionEntityById.ts +21 -21
- package/src/plugins/dataManage/actionHandlers/queryDatabase.ts +22 -22
- package/src/plugins/dataManage/actionHandlers/removeEntityRelations.ts +20 -20
- package/src/plugins/dataManage/actionHandlers/updateCollectionEntityById.ts +35 -35
- package/src/plugins/entityAccessControl/EntityAccessControlPlugin.ts +1 -1
- package/src/plugins/fileManage/actionHandlers/downloadDocument.ts +36 -36
- package/src/plugins/fileManage/actionHandlers/uploadFile.ts +33 -33
- package/src/plugins/fileManage/routes/downloadDocument.ts +15 -15
- package/src/plugins/fileManage/routes/downloadFile.ts +15 -15
- package/src/plugins/fileManage/routes/index.ts +5 -5
- package/src/plugins/fileManage/routes/uploadFile.ts +15 -15
- package/src/plugins/metaManage/actionHandlers/getMetaModelDetail.ts +10 -10
- package/src/plugins/metaManage/actionHandlers/listMetaModels.ts +9 -9
- package/src/plugins/metaManage/actionHandlers/listMetaRoutes.ts +9 -9
- package/src/plugins/routeManage/actionHandlers/httpProxy.ts +13 -13
- package/src/plugins/sequence/SequenceService.ts +81 -81
- package/src/plugins/sequence/actionHandlers/generateSn.ts +32 -32
- package/src/plugins/sequence/actionHandlers/index.ts +4 -4
- package/src/plugins/sequence/models/SequenceAutoIncrementRecord.ts +49 -49
- package/src/plugins/sequence/models/SequenceRule.ts +42 -42
- package/src/plugins/sequence/models/index.ts +4 -4
- package/src/plugins/sequence/routes/generateSn.ts +15 -15
- package/src/plugins/sequence/routes/index.ts +3 -3
- package/src/plugins/sequence/segment-utility.ts +11 -11
- package/src/plugins/sequence/segments/index.ts +9 -9
- package/src/plugins/serverOperation/ServerOperationPlugin.ts +91 -91
- package/src/plugins/serverOperation/ServerOperationPluginTypes.ts +15 -15
- package/src/plugins/serverOperation/actionHandlers/index.ts +4 -4
- package/src/plugins/setting/SettingService.ts +213 -213
- package/src/plugins/setting/actionHandlers/getSystemSettingValues.ts +30 -30
- package/src/plugins/setting/actionHandlers/getUserSettingValues.ts +38 -38
- package/src/plugins/setting/actionHandlers/index.ts +6 -6
- package/src/plugins/setting/actionHandlers/setSystemSettingValues.ts +30 -30
- package/src/plugins/setting/models/SystemSettingGroupSetting.ts +57 -57
- package/src/plugins/setting/models/SystemSettingItem.ts +42 -42
- package/src/plugins/setting/models/SystemSettingItemSetting.ts +73 -73
- package/src/plugins/setting/models/UserSettingGroupSetting.ts +57 -57
- package/src/plugins/setting/models/UserSettingItem.ts +49 -49
- package/src/plugins/setting/models/UserSettingItemSetting.ts +73 -73
- package/src/plugins/setting/models/index.ts +8 -8
- package/src/plugins/setting/routes/getSystemSettingValues.ts +15 -15
- package/src/plugins/setting/routes/getUserSettingValues.ts +15 -15
- package/src/plugins/setting/routes/index.ts +5 -5
- package/src/plugins/setting/routes/setSystemSettingValues.ts +15 -15
- package/src/plugins/stateMachine/actionHandlers/index.ts +4 -4
- package/src/plugins/stateMachine/actionHandlers/sendStateMachineEvent.ts +51 -51
- package/src/plugins/stateMachine/models/StateMachine.ts +42 -42
- package/src/plugins/stateMachine/models/index.ts +3 -3
- package/src/plugins/stateMachine/routes/index.ts +3 -3
- package/src/plugins/stateMachine/routes/sendStateMachineEvent.ts +15 -15
- package/src/polyfill.ts +5 -5
- package/src/proxy/mod.ts +38 -38
- package/src/queryBuilder/queryBuilder.ts +5 -1
- package/src/utilities/accessControlUtility.ts +33 -33
- package/src/utilities/fsUtility.ts +61 -61
- package/src/utilities/httpUtility.ts +19 -19
- package/src/utilities/jwtUtility.ts +26 -26
- package/src/utilities/timeUtility.ts +9 -9
- package/tsconfig.json +19 -19
|
@@ -1,137 +1,137 @@
|
|
|
1
|
-
import { CreateEntityOptions, IRpdDataAccessor, RpdDataModel, IDatabaseAccessor, DatabaseQuery } from "~/types";
|
|
2
|
-
import QueryBuilder from "~/queryBuilder/queryBuilder";
|
|
3
|
-
import { first, set } from "lodash";
|
|
4
|
-
import { IRpdServer } from "~/core/server";
|
|
5
|
-
import { Logger } from "~/facilities/log/LogFacility";
|
|
6
|
-
import { newDatabaseError } from "~/utilities/errorUtility";
|
|
7
|
-
import { CountRowOptions, FindRowOptions, UpdateRowOptions } from "./dataAccessTypes";
|
|
8
|
-
|
|
9
|
-
export interface IDataAccessorOptions {
|
|
10
|
-
model: RpdDataModel;
|
|
11
|
-
queryBuilder: QueryBuilder;
|
|
12
|
-
}
|
|
13
|
-
|
|
14
|
-
export default class DataAccessor<T = any> implements IRpdDataAccessor<T> {
|
|
15
|
-
#logger: Logger;
|
|
16
|
-
#model: RpdDataModel;
|
|
17
|
-
#queryBuilder: QueryBuilder;
|
|
18
|
-
#server: IRpdServer;
|
|
19
|
-
#databaseAccessor: IDatabaseAccessor;
|
|
20
|
-
|
|
21
|
-
constructor(server: IRpdServer, databaseAccessor: IDatabaseAccessor, options: IDataAccessorOptions) {
|
|
22
|
-
this.#server = server;
|
|
23
|
-
this.#logger = server.getLogger();
|
|
24
|
-
this.#databaseAccessor = databaseAccessor;
|
|
25
|
-
this.#queryBuilder = options.queryBuilder;
|
|
26
|
-
this.#model = options.model;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
getModel() {
|
|
30
|
-
return this.#model;
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
async create(entity: Partial<T>): Promise<T> {
|
|
34
|
-
const options: CreateEntityOptions = {
|
|
35
|
-
entity,
|
|
36
|
-
};
|
|
37
|
-
const query = this.#queryBuilder.insert(this.#model, options);
|
|
38
|
-
const result = await this.#databaseAccessor.queryDatabaseObject(query.command, query.params);
|
|
39
|
-
return first(result);
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
async updateById(id: any, entity: Partial<T>): Promise<{ count: number }> {
|
|
43
|
-
const options: UpdateRowOptions = {
|
|
44
|
-
entity,
|
|
45
|
-
filters: [
|
|
46
|
-
{
|
|
47
|
-
field: {
|
|
48
|
-
name: "id",
|
|
49
|
-
},
|
|
50
|
-
operator: "eq",
|
|
51
|
-
value: id,
|
|
52
|
-
},
|
|
53
|
-
],
|
|
54
|
-
};
|
|
55
|
-
const query = this.#queryBuilder.update(this.#model, options);
|
|
56
|
-
const result = await this.#databaseAccessor.queryDatabaseObject(query.command, query.params);
|
|
57
|
-
return first(result);
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
async find(options: FindRowOptions): Promise<T[]> {
|
|
61
|
-
this.#logger.debug(`Finding '${this.#model.singularCode}' entity.`, { options });
|
|
62
|
-
let query: DatabaseQuery;
|
|
63
|
-
if (this.#model.base) {
|
|
64
|
-
const baseModel = this.#server.getModel({
|
|
65
|
-
singularCode: this.#model.base,
|
|
66
|
-
});
|
|
67
|
-
query = this.#queryBuilder.selectDerived(this.#model, baseModel, options);
|
|
68
|
-
} else {
|
|
69
|
-
query = this.#queryBuilder.select(this.#model, options);
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
try {
|
|
73
|
-
return await this.#databaseAccessor.queryDatabaseObject(query.command, query.params);
|
|
74
|
-
} catch (err) {
|
|
75
|
-
throw newDatabaseError(`Failed to find entities. ${err.message}`, err);
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
async findOne(options: FindRowOptions): Promise<T> {
|
|
80
|
-
set(options, "pagination.limit", 1);
|
|
81
|
-
const list = await this.find(options);
|
|
82
|
-
return first(list);
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
async findById(id: any): Promise<T | null> {
|
|
86
|
-
const options: FindRowOptions = {
|
|
87
|
-
filters: [
|
|
88
|
-
{
|
|
89
|
-
field: {
|
|
90
|
-
name: "id",
|
|
91
|
-
},
|
|
92
|
-
operator: "eq",
|
|
93
|
-
value: id,
|
|
94
|
-
},
|
|
95
|
-
],
|
|
96
|
-
};
|
|
97
|
-
const result = await this.findOne(options);
|
|
98
|
-
return result;
|
|
99
|
-
}
|
|
100
|
-
|
|
101
|
-
async count(options: CountRowOptions): Promise<any> {
|
|
102
|
-
let query: DatabaseQuery;
|
|
103
|
-
if (this.#model.base) {
|
|
104
|
-
const baseModel = this.#server.getModel({
|
|
105
|
-
singularCode: this.#model.base,
|
|
106
|
-
});
|
|
107
|
-
query = this.#queryBuilder.countDerived(this.#model, baseModel, options);
|
|
108
|
-
} else {
|
|
109
|
-
query = this.#queryBuilder.count(this.#model, options);
|
|
110
|
-
}
|
|
111
|
-
const result = await this.#databaseAccessor.queryDatabaseObject(query.command, query.params);
|
|
112
|
-
|
|
113
|
-
const row = first(result);
|
|
114
|
-
if (row) {
|
|
115
|
-
return row;
|
|
116
|
-
}
|
|
117
|
-
return {
|
|
118
|
-
count: 0,
|
|
119
|
-
};
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
async deleteById(id: any) {
|
|
123
|
-
const options: FindRowOptions = {
|
|
124
|
-
filters: [
|
|
125
|
-
{
|
|
126
|
-
field: {
|
|
127
|
-
name: "id",
|
|
128
|
-
},
|
|
129
|
-
operator: "eq",
|
|
130
|
-
value: id,
|
|
131
|
-
},
|
|
132
|
-
],
|
|
133
|
-
};
|
|
134
|
-
const query = this.#queryBuilder.delete(this.#model, options);
|
|
135
|
-
await this.#databaseAccessor.queryDatabaseObject(query.command, query.params);
|
|
136
|
-
}
|
|
137
|
-
}
|
|
1
|
+
import { CreateEntityOptions, IRpdDataAccessor, RpdDataModel, IDatabaseAccessor, DatabaseQuery } from "~/types";
|
|
2
|
+
import QueryBuilder from "~/queryBuilder/queryBuilder";
|
|
3
|
+
import { first, set } from "lodash";
|
|
4
|
+
import { IRpdServer } from "~/core/server";
|
|
5
|
+
import { Logger } from "~/facilities/log/LogFacility";
|
|
6
|
+
import { newDatabaseError } from "~/utilities/errorUtility";
|
|
7
|
+
import { CountRowOptions, FindRowOptions, UpdateRowOptions } from "./dataAccessTypes";
|
|
8
|
+
|
|
9
|
+
export interface IDataAccessorOptions {
|
|
10
|
+
model: RpdDataModel;
|
|
11
|
+
queryBuilder: QueryBuilder;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export default class DataAccessor<T = any> implements IRpdDataAccessor<T> {
|
|
15
|
+
#logger: Logger;
|
|
16
|
+
#model: RpdDataModel;
|
|
17
|
+
#queryBuilder: QueryBuilder;
|
|
18
|
+
#server: IRpdServer;
|
|
19
|
+
#databaseAccessor: IDatabaseAccessor;
|
|
20
|
+
|
|
21
|
+
constructor(server: IRpdServer, databaseAccessor: IDatabaseAccessor, options: IDataAccessorOptions) {
|
|
22
|
+
this.#server = server;
|
|
23
|
+
this.#logger = server.getLogger();
|
|
24
|
+
this.#databaseAccessor = databaseAccessor;
|
|
25
|
+
this.#queryBuilder = options.queryBuilder;
|
|
26
|
+
this.#model = options.model;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
getModel() {
|
|
30
|
+
return this.#model;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
async create(entity: Partial<T>): Promise<T> {
|
|
34
|
+
const options: CreateEntityOptions = {
|
|
35
|
+
entity,
|
|
36
|
+
};
|
|
37
|
+
const query = this.#queryBuilder.insert(this.#model, options);
|
|
38
|
+
const result = await this.#databaseAccessor.queryDatabaseObject(query.command, query.params);
|
|
39
|
+
return first(result);
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
async updateById(id: any, entity: Partial<T>): Promise<{ count: number }> {
|
|
43
|
+
const options: UpdateRowOptions = {
|
|
44
|
+
entity,
|
|
45
|
+
filters: [
|
|
46
|
+
{
|
|
47
|
+
field: {
|
|
48
|
+
name: "id",
|
|
49
|
+
},
|
|
50
|
+
operator: "eq",
|
|
51
|
+
value: id,
|
|
52
|
+
},
|
|
53
|
+
],
|
|
54
|
+
};
|
|
55
|
+
const query = this.#queryBuilder.update(this.#model, options);
|
|
56
|
+
const result = await this.#databaseAccessor.queryDatabaseObject(query.command, query.params);
|
|
57
|
+
return first(result);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
async find(options: FindRowOptions): Promise<T[]> {
|
|
61
|
+
this.#logger.debug(`Finding '${this.#model.singularCode}' entity.`, { options });
|
|
62
|
+
let query: DatabaseQuery;
|
|
63
|
+
if (this.#model.base) {
|
|
64
|
+
const baseModel = this.#server.getModel({
|
|
65
|
+
singularCode: this.#model.base,
|
|
66
|
+
});
|
|
67
|
+
query = this.#queryBuilder.selectDerived(this.#model, baseModel, options);
|
|
68
|
+
} else {
|
|
69
|
+
query = this.#queryBuilder.select(this.#model, options);
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
try {
|
|
73
|
+
return await this.#databaseAccessor.queryDatabaseObject(query.command, query.params);
|
|
74
|
+
} catch (err) {
|
|
75
|
+
throw newDatabaseError(`Failed to find entities. ${err.message}`, err);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
async findOne(options: FindRowOptions): Promise<T> {
|
|
80
|
+
set(options, "pagination.limit", 1);
|
|
81
|
+
const list = await this.find(options);
|
|
82
|
+
return first(list);
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
async findById(id: any): Promise<T | null> {
|
|
86
|
+
const options: FindRowOptions = {
|
|
87
|
+
filters: [
|
|
88
|
+
{
|
|
89
|
+
field: {
|
|
90
|
+
name: "id",
|
|
91
|
+
},
|
|
92
|
+
operator: "eq",
|
|
93
|
+
value: id,
|
|
94
|
+
},
|
|
95
|
+
],
|
|
96
|
+
};
|
|
97
|
+
const result = await this.findOne(options);
|
|
98
|
+
return result;
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
async count(options: CountRowOptions): Promise<any> {
|
|
102
|
+
let query: DatabaseQuery;
|
|
103
|
+
if (this.#model.base) {
|
|
104
|
+
const baseModel = this.#server.getModel({
|
|
105
|
+
singularCode: this.#model.base,
|
|
106
|
+
});
|
|
107
|
+
query = this.#queryBuilder.countDerived(this.#model, baseModel, options);
|
|
108
|
+
} else {
|
|
109
|
+
query = this.#queryBuilder.count(this.#model, options);
|
|
110
|
+
}
|
|
111
|
+
const result = await this.#databaseAccessor.queryDatabaseObject(query.command, query.params);
|
|
112
|
+
|
|
113
|
+
const row = first(result);
|
|
114
|
+
if (row) {
|
|
115
|
+
return row;
|
|
116
|
+
}
|
|
117
|
+
return {
|
|
118
|
+
count: 0,
|
|
119
|
+
};
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
async deleteById(id: any) {
|
|
123
|
+
const options: FindRowOptions = {
|
|
124
|
+
filters: [
|
|
125
|
+
{
|
|
126
|
+
field: {
|
|
127
|
+
name: "id",
|
|
128
|
+
},
|
|
129
|
+
operator: "eq",
|
|
130
|
+
value: id,
|
|
131
|
+
},
|
|
132
|
+
],
|
|
133
|
+
};
|
|
134
|
+
const query = this.#queryBuilder.delete(this.#model, options);
|
|
135
|
+
await this.#databaseAccessor.queryDatabaseObject(query.command, query.params);
|
|
136
|
+
}
|
|
137
|
+
}
|
|
@@ -1,32 +1,32 @@
|
|
|
1
|
-
// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
|
|
2
|
-
// This module is browser compatible.
|
|
3
|
-
|
|
4
|
-
/**
|
|
5
|
-
* Formats the given date to IMF date time format. (Reference:
|
|
6
|
-
* https://tools.ietf.org/html/rfc7231#section-7.1.1.1).
|
|
7
|
-
* IMF is the time format to use when generating times in HTTP
|
|
8
|
-
* headers. The time being formatted must be in UTC for Format to
|
|
9
|
-
* generate the correct format.
|
|
10
|
-
*
|
|
11
|
-
* @example
|
|
12
|
-
* ```ts
|
|
13
|
-
* import { toIMF } from "https://deno.land/std@$STD_VERSION/datetime/to_imf.ts";
|
|
14
|
-
*
|
|
15
|
-
* toIMF(new Date(0)); // => returns "Thu, 01 Jan 1970 00:00:00 GMT"
|
|
16
|
-
* ```
|
|
17
|
-
* @param date Date to parse
|
|
18
|
-
* @return IMF date formatted string
|
|
19
|
-
*/
|
|
20
|
-
export function toIMF(date: Date): string {
|
|
21
|
-
function dtPad(v: string, lPad = 2): string {
|
|
22
|
-
return v.padStart(lPad, "0");
|
|
23
|
-
}
|
|
24
|
-
const d = dtPad(date.getUTCDate().toString());
|
|
25
|
-
const h = dtPad(date.getUTCHours().toString());
|
|
26
|
-
const min = dtPad(date.getUTCMinutes().toString());
|
|
27
|
-
const s = dtPad(date.getUTCSeconds().toString());
|
|
28
|
-
const y = date.getUTCFullYear();
|
|
29
|
-
const days = ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"];
|
|
30
|
-
const months = ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"];
|
|
31
|
-
return `${days[date.getUTCDay()]}, ${d} ${months[date.getUTCMonth()]} ${y} ${h}:${min}:${s} GMT`;
|
|
32
|
-
}
|
|
1
|
+
// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
|
|
2
|
+
// This module is browser compatible.
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Formats the given date to IMF date time format. (Reference:
|
|
6
|
+
* https://tools.ietf.org/html/rfc7231#section-7.1.1.1).
|
|
7
|
+
* IMF is the time format to use when generating times in HTTP
|
|
8
|
+
* headers. The time being formatted must be in UTC for Format to
|
|
9
|
+
* generate the correct format.
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* ```ts
|
|
13
|
+
* import { toIMF } from "https://deno.land/std@$STD_VERSION/datetime/to_imf.ts";
|
|
14
|
+
*
|
|
15
|
+
* toIMF(new Date(0)); // => returns "Thu, 01 Jan 1970 00:00:00 GMT"
|
|
16
|
+
* ```
|
|
17
|
+
* @param date Date to parse
|
|
18
|
+
* @return IMF date formatted string
|
|
19
|
+
*/
|
|
20
|
+
export function toIMF(date: Date): string {
|
|
21
|
+
function dtPad(v: string, lPad = 2): string {
|
|
22
|
+
return v.padStart(lPad, "0");
|
|
23
|
+
}
|
|
24
|
+
const d = dtPad(date.getUTCDate().toString());
|
|
25
|
+
const h = dtPad(date.getUTCHours().toString());
|
|
26
|
+
const min = dtPad(date.getUTCMinutes().toString());
|
|
27
|
+
const s = dtPad(date.getUTCSeconds().toString());
|
|
28
|
+
const y = date.getUTCFullYear();
|
|
29
|
+
const days = ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"];
|
|
30
|
+
const months = ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"];
|
|
31
|
+
return `${days[date.getUTCDay()]}, ${d} ${months[date.getUTCMonth()]} ${y} ${h}:${min}:${s} GMT`;
|
|
32
|
+
}
|
|
@@ -1,141 +1,141 @@
|
|
|
1
|
-
// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
|
|
2
|
-
// This module is browser compatible.
|
|
3
|
-
|
|
4
|
-
/**
|
|
5
|
-
* {@linkcode encode} and {@linkcode decode} for
|
|
6
|
-
* [base64](https://en.wikipedia.org/wiki/Base64) encoding.
|
|
7
|
-
*
|
|
8
|
-
* This module is browser compatible.
|
|
9
|
-
*
|
|
10
|
-
* @example
|
|
11
|
-
* ```ts
|
|
12
|
-
* import {
|
|
13
|
-
* decode,
|
|
14
|
-
* encode,
|
|
15
|
-
* } from "https://deno.land/std@$STD_VERSION/encoding/base64.ts";
|
|
16
|
-
*
|
|
17
|
-
* const b64Repr = "Zm9vYg==";
|
|
18
|
-
*
|
|
19
|
-
* const binaryData = decode(b64Repr);
|
|
20
|
-
* console.log(binaryData);
|
|
21
|
-
* // => Uint8Array [ 102, 111, 111, 98 ]
|
|
22
|
-
*
|
|
23
|
-
* console.log(encode(binaryData));
|
|
24
|
-
* // => Zm9vYg==
|
|
25
|
-
* ```
|
|
26
|
-
*
|
|
27
|
-
* @module
|
|
28
|
-
*/
|
|
29
|
-
|
|
30
|
-
const base64abc = [
|
|
31
|
-
"A",
|
|
32
|
-
"B",
|
|
33
|
-
"C",
|
|
34
|
-
"D",
|
|
35
|
-
"E",
|
|
36
|
-
"F",
|
|
37
|
-
"G",
|
|
38
|
-
"H",
|
|
39
|
-
"I",
|
|
40
|
-
"J",
|
|
41
|
-
"K",
|
|
42
|
-
"L",
|
|
43
|
-
"M",
|
|
44
|
-
"N",
|
|
45
|
-
"O",
|
|
46
|
-
"P",
|
|
47
|
-
"Q",
|
|
48
|
-
"R",
|
|
49
|
-
"S",
|
|
50
|
-
"T",
|
|
51
|
-
"U",
|
|
52
|
-
"V",
|
|
53
|
-
"W",
|
|
54
|
-
"X",
|
|
55
|
-
"Y",
|
|
56
|
-
"Z",
|
|
57
|
-
"a",
|
|
58
|
-
"b",
|
|
59
|
-
"c",
|
|
60
|
-
"d",
|
|
61
|
-
"e",
|
|
62
|
-
"f",
|
|
63
|
-
"g",
|
|
64
|
-
"h",
|
|
65
|
-
"i",
|
|
66
|
-
"j",
|
|
67
|
-
"k",
|
|
68
|
-
"l",
|
|
69
|
-
"m",
|
|
70
|
-
"n",
|
|
71
|
-
"o",
|
|
72
|
-
"p",
|
|
73
|
-
"q",
|
|
74
|
-
"r",
|
|
75
|
-
"s",
|
|
76
|
-
"t",
|
|
77
|
-
"u",
|
|
78
|
-
"v",
|
|
79
|
-
"w",
|
|
80
|
-
"x",
|
|
81
|
-
"y",
|
|
82
|
-
"z",
|
|
83
|
-
"0",
|
|
84
|
-
"1",
|
|
85
|
-
"2",
|
|
86
|
-
"3",
|
|
87
|
-
"4",
|
|
88
|
-
"5",
|
|
89
|
-
"6",
|
|
90
|
-
"7",
|
|
91
|
-
"8",
|
|
92
|
-
"9",
|
|
93
|
-
"+",
|
|
94
|
-
"/",
|
|
95
|
-
];
|
|
96
|
-
|
|
97
|
-
/**
|
|
98
|
-
* CREDIT: https://gist.github.com/enepomnyaschih/72c423f727d395eeaa09697058238727
|
|
99
|
-
* Encodes a given Uint8Array, ArrayBuffer or string into RFC4648 base64 representation
|
|
100
|
-
* @param data
|
|
101
|
-
*/
|
|
102
|
-
export function encode(data: ArrayBuffer | string): string {
|
|
103
|
-
const uint8 = typeof data === "string" ? new TextEncoder().encode(data) : data instanceof Uint8Array ? data : new Uint8Array(data);
|
|
104
|
-
let result = "",
|
|
105
|
-
i;
|
|
106
|
-
const l = uint8.length;
|
|
107
|
-
for (i = 2; i < l; i += 3) {
|
|
108
|
-
result += base64abc[uint8[i - 2] >> 2];
|
|
109
|
-
result += base64abc[((uint8[i - 2] & 0x03) << 4) | (uint8[i - 1] >> 4)];
|
|
110
|
-
result += base64abc[((uint8[i - 1] & 0x0f) << 2) | (uint8[i] >> 6)];
|
|
111
|
-
result += base64abc[uint8[i] & 0x3f];
|
|
112
|
-
}
|
|
113
|
-
if (i === l + 1) {
|
|
114
|
-
// 1 octet yet to write
|
|
115
|
-
result += base64abc[uint8[i - 2] >> 2];
|
|
116
|
-
result += base64abc[(uint8[i - 2] & 0x03) << 4];
|
|
117
|
-
result += "==";
|
|
118
|
-
}
|
|
119
|
-
if (i === l) {
|
|
120
|
-
// 2 octets yet to write
|
|
121
|
-
result += base64abc[uint8[i - 2] >> 2];
|
|
122
|
-
result += base64abc[((uint8[i - 2] & 0x03) << 4) | (uint8[i - 1] >> 4)];
|
|
123
|
-
result += base64abc[(uint8[i - 1] & 0x0f) << 2];
|
|
124
|
-
result += "=";
|
|
125
|
-
}
|
|
126
|
-
return result;
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
/**
|
|
130
|
-
* Decodes a given RFC4648 base64 encoded string
|
|
131
|
-
* @param b64
|
|
132
|
-
*/
|
|
133
|
-
export function decode(b64: string): Uint8Array {
|
|
134
|
-
const binString = atob(b64);
|
|
135
|
-
const size = binString.length;
|
|
136
|
-
const bytes = new Uint8Array(size);
|
|
137
|
-
for (let i = 0; i < size; i++) {
|
|
138
|
-
bytes[i] = binString.charCodeAt(i);
|
|
139
|
-
}
|
|
140
|
-
return bytes;
|
|
141
|
-
}
|
|
1
|
+
// Copyright 2018-2023 the Deno authors. All rights reserved. MIT license.
|
|
2
|
+
// This module is browser compatible.
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* {@linkcode encode} and {@linkcode decode} for
|
|
6
|
+
* [base64](https://en.wikipedia.org/wiki/Base64) encoding.
|
|
7
|
+
*
|
|
8
|
+
* This module is browser compatible.
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* ```ts
|
|
12
|
+
* import {
|
|
13
|
+
* decode,
|
|
14
|
+
* encode,
|
|
15
|
+
* } from "https://deno.land/std@$STD_VERSION/encoding/base64.ts";
|
|
16
|
+
*
|
|
17
|
+
* const b64Repr = "Zm9vYg==";
|
|
18
|
+
*
|
|
19
|
+
* const binaryData = decode(b64Repr);
|
|
20
|
+
* console.log(binaryData);
|
|
21
|
+
* // => Uint8Array [ 102, 111, 111, 98 ]
|
|
22
|
+
*
|
|
23
|
+
* console.log(encode(binaryData));
|
|
24
|
+
* // => Zm9vYg==
|
|
25
|
+
* ```
|
|
26
|
+
*
|
|
27
|
+
* @module
|
|
28
|
+
*/
|
|
29
|
+
|
|
30
|
+
const base64abc = [
|
|
31
|
+
"A",
|
|
32
|
+
"B",
|
|
33
|
+
"C",
|
|
34
|
+
"D",
|
|
35
|
+
"E",
|
|
36
|
+
"F",
|
|
37
|
+
"G",
|
|
38
|
+
"H",
|
|
39
|
+
"I",
|
|
40
|
+
"J",
|
|
41
|
+
"K",
|
|
42
|
+
"L",
|
|
43
|
+
"M",
|
|
44
|
+
"N",
|
|
45
|
+
"O",
|
|
46
|
+
"P",
|
|
47
|
+
"Q",
|
|
48
|
+
"R",
|
|
49
|
+
"S",
|
|
50
|
+
"T",
|
|
51
|
+
"U",
|
|
52
|
+
"V",
|
|
53
|
+
"W",
|
|
54
|
+
"X",
|
|
55
|
+
"Y",
|
|
56
|
+
"Z",
|
|
57
|
+
"a",
|
|
58
|
+
"b",
|
|
59
|
+
"c",
|
|
60
|
+
"d",
|
|
61
|
+
"e",
|
|
62
|
+
"f",
|
|
63
|
+
"g",
|
|
64
|
+
"h",
|
|
65
|
+
"i",
|
|
66
|
+
"j",
|
|
67
|
+
"k",
|
|
68
|
+
"l",
|
|
69
|
+
"m",
|
|
70
|
+
"n",
|
|
71
|
+
"o",
|
|
72
|
+
"p",
|
|
73
|
+
"q",
|
|
74
|
+
"r",
|
|
75
|
+
"s",
|
|
76
|
+
"t",
|
|
77
|
+
"u",
|
|
78
|
+
"v",
|
|
79
|
+
"w",
|
|
80
|
+
"x",
|
|
81
|
+
"y",
|
|
82
|
+
"z",
|
|
83
|
+
"0",
|
|
84
|
+
"1",
|
|
85
|
+
"2",
|
|
86
|
+
"3",
|
|
87
|
+
"4",
|
|
88
|
+
"5",
|
|
89
|
+
"6",
|
|
90
|
+
"7",
|
|
91
|
+
"8",
|
|
92
|
+
"9",
|
|
93
|
+
"+",
|
|
94
|
+
"/",
|
|
95
|
+
];
|
|
96
|
+
|
|
97
|
+
/**
|
|
98
|
+
* CREDIT: https://gist.github.com/enepomnyaschih/72c423f727d395eeaa09697058238727
|
|
99
|
+
* Encodes a given Uint8Array, ArrayBuffer or string into RFC4648 base64 representation
|
|
100
|
+
* @param data
|
|
101
|
+
*/
|
|
102
|
+
export function encode(data: ArrayBuffer | string): string {
|
|
103
|
+
const uint8 = typeof data === "string" ? new TextEncoder().encode(data) : data instanceof Uint8Array ? data : new Uint8Array(data);
|
|
104
|
+
let result = "",
|
|
105
|
+
i;
|
|
106
|
+
const l = uint8.length;
|
|
107
|
+
for (i = 2; i < l; i += 3) {
|
|
108
|
+
result += base64abc[uint8[i - 2] >> 2];
|
|
109
|
+
result += base64abc[((uint8[i - 2] & 0x03) << 4) | (uint8[i - 1] >> 4)];
|
|
110
|
+
result += base64abc[((uint8[i - 1] & 0x0f) << 2) | (uint8[i] >> 6)];
|
|
111
|
+
result += base64abc[uint8[i] & 0x3f];
|
|
112
|
+
}
|
|
113
|
+
if (i === l + 1) {
|
|
114
|
+
// 1 octet yet to write
|
|
115
|
+
result += base64abc[uint8[i - 2] >> 2];
|
|
116
|
+
result += base64abc[(uint8[i - 2] & 0x03) << 4];
|
|
117
|
+
result += "==";
|
|
118
|
+
}
|
|
119
|
+
if (i === l) {
|
|
120
|
+
// 2 octets yet to write
|
|
121
|
+
result += base64abc[uint8[i - 2] >> 2];
|
|
122
|
+
result += base64abc[((uint8[i - 2] & 0x03) << 4) | (uint8[i - 1] >> 4)];
|
|
123
|
+
result += base64abc[(uint8[i - 1] & 0x0f) << 2];
|
|
124
|
+
result += "=";
|
|
125
|
+
}
|
|
126
|
+
return result;
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
/**
|
|
130
|
+
* Decodes a given RFC4648 base64 encoded string
|
|
131
|
+
* @param b64
|
|
132
|
+
*/
|
|
133
|
+
export function decode(b64: string): Uint8Array {
|
|
134
|
+
const binString = atob(b64);
|
|
135
|
+
const size = binString.length;
|
|
136
|
+
const bytes = new Uint8Array(size);
|
|
137
|
+
for (let i = 0; i < size; i++) {
|
|
138
|
+
bytes[i] = binString.charCodeAt(i);
|
|
139
|
+
}
|
|
140
|
+
return bytes;
|
|
141
|
+
}
|