@prestizni-software/client-dem 0.2.57 → 0.2.59
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/AutoUpdateClientManagerClass.ts +161 -0
- package/AutoUpdateManagerClass.ts +87 -0
- package/AutoUpdatedClientObjectClass.ts +674 -0
- package/CHANGELOG.md +4 -0
- package/CommonTypes.ts +105 -0
- package/client.ts +11 -0
- package/{AutoUpdateClientManagerClass.d.ts → dist/AutoUpdateClientManagerClass.d.ts} +3 -2
- package/{AutoUpdateClientManagerClass.js → dist/AutoUpdateClientManagerClass.js} +7 -5
- package/dist/AutoUpdateClientManagerClass.js.map +1 -0
- package/{AutoUpdatedClientObjectClass.d.ts → dist/AutoUpdatedClientObjectClass.d.ts} +3 -2
- package/{AutoUpdatedClientObjectClass.js → dist/AutoUpdatedClientObjectClass.js} +5 -3
- package/dist/AutoUpdatedClientObjectClass.js.map +1 -0
- package/{client.js → dist/client.js} +1 -1
- package/{client.js.map → dist/client.js.map} +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +11 -5
- package/tsconfig.json +113 -0
- package/AutoUpdateClientManagerClass.js.map +0 -1
- package/AutoUpdatedClientObjectClass.js.map +0 -1
- /package/{AutoUpdateManagerClass.d.ts → dist/AutoUpdateManagerClass.d.ts} +0 -0
- /package/{AutoUpdateManagerClass.js → dist/AutoUpdateManagerClass.js} +0 -0
- /package/{AutoUpdateManagerClass.js.map → dist/AutoUpdateManagerClass.js.map} +0 -0
- /package/{CommonTypes.d.ts → dist/CommonTypes.d.ts} +0 -0
- /package/{CommonTypes.js → dist/CommonTypes.js} +0 -0
- /package/{CommonTypes.js.map → dist/CommonTypes.js.map} +0 -0
- /package/{client.d.ts → dist/client.d.ts} +0 -0
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
import { Socket } from "socket.io-client";
|
|
2
|
+
import { AutoUpdateManager } from "./AutoUpdateManagerClass.js";
|
|
3
|
+
import { createAutoUpdatedClass } from "./AutoUpdatedClientObjectClass.js";
|
|
4
|
+
import { Constructor, IsData, LoggersType } from "./CommonTypes.js";
|
|
5
|
+
import EventEmitter from "eventemitter3";
|
|
6
|
+
export type WrappedInstances<T extends Record<string, Constructor<any>>> = {
|
|
7
|
+
[K in keyof T]: AutoUpdateClientManager<T[K]>;
|
|
8
|
+
};
|
|
9
|
+
// ---------------------- Factory ----------------------
|
|
10
|
+
export async function AUCManagerFactory<
|
|
11
|
+
T extends Record<string, Constructor<any>>
|
|
12
|
+
>(
|
|
13
|
+
defs: T,
|
|
14
|
+
loggers: LoggersType,
|
|
15
|
+
socket: Socket,
|
|
16
|
+
token: string,
|
|
17
|
+
emitter: EventEmitter = new EventEmitter()
|
|
18
|
+
): Promise<WrappedInstances<T>> {
|
|
19
|
+
const classers = {} as WrappedInstances<T>;
|
|
20
|
+
for (const key in defs) {
|
|
21
|
+
let message = `Creating manager for: ${key}`;
|
|
22
|
+
try {
|
|
23
|
+
const Model = defs[key];
|
|
24
|
+
const c = new AutoUpdateClientManager(
|
|
25
|
+
Model,
|
|
26
|
+
loggers,
|
|
27
|
+
socket,
|
|
28
|
+
classers,
|
|
29
|
+
emitter,
|
|
30
|
+
token
|
|
31
|
+
);
|
|
32
|
+
classers[key] = c;
|
|
33
|
+
} catch (error: any) {
|
|
34
|
+
message += "\n Error creating manager: " + key;
|
|
35
|
+
message += "\n " + error.message;
|
|
36
|
+
loggers.error(error.stack);
|
|
37
|
+
loggers.error(message);
|
|
38
|
+
continue;
|
|
39
|
+
}
|
|
40
|
+
try {
|
|
41
|
+
await classers[key].isLoadedAsync();
|
|
42
|
+
} catch (error: any) {
|
|
43
|
+
message += "\n Error creating manager: " + key;
|
|
44
|
+
message += "\n " + error.message;
|
|
45
|
+
loggers.error(error.stack);
|
|
46
|
+
loggers.error(message);
|
|
47
|
+
continue;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
return classers;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
export class AutoUpdateClientManager<
|
|
55
|
+
T extends Constructor<any>
|
|
56
|
+
> extends AutoUpdateManager<T> {
|
|
57
|
+
private readonly token;
|
|
58
|
+
constructor(
|
|
59
|
+
classParam: T,
|
|
60
|
+
loggers: LoggersType,
|
|
61
|
+
socket: Socket,
|
|
62
|
+
classers: Record<string, AutoUpdateManager<any>>,
|
|
63
|
+
emitter: EventEmitter,
|
|
64
|
+
token: string
|
|
65
|
+
) {
|
|
66
|
+
|
|
67
|
+
super(classParam, socket, loggers, classers, emitter);
|
|
68
|
+
this.token = token;
|
|
69
|
+
socket.emit("startup" + classParam.name, async (data: string[]) => {
|
|
70
|
+
this.loggers.debug(
|
|
71
|
+
"Loading manager DB " +
|
|
72
|
+
this.className +
|
|
73
|
+
" - [" +
|
|
74
|
+
data.length +
|
|
75
|
+
"] entries"
|
|
76
|
+
);
|
|
77
|
+
|
|
78
|
+
for (const id of data) {
|
|
79
|
+
try {
|
|
80
|
+
this.classes[id] = await this.handleGetMissingObject(id);
|
|
81
|
+
this.classesAsArray.push(this.classes[id]);
|
|
82
|
+
} catch (error: any) {
|
|
83
|
+
this.loggers.error(
|
|
84
|
+
"Error loading object " +
|
|
85
|
+
id +
|
|
86
|
+
" from manager " +
|
|
87
|
+
this.className +
|
|
88
|
+
" - " +
|
|
89
|
+
error.message
|
|
90
|
+
);
|
|
91
|
+
this.loggers.error(error.stack);
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
emitter.emit("ManagerLoaded" + this.classParam.name + this.className);
|
|
95
|
+
});
|
|
96
|
+
socket.on("new" + classParam.name, async (id: string) => {
|
|
97
|
+
this.loggers.debug(
|
|
98
|
+
"Applying new object from manager " + this.className + " - " + id
|
|
99
|
+
);
|
|
100
|
+
try {
|
|
101
|
+
this.classes[id] = await this.handleGetMissingObject(id);
|
|
102
|
+
this.classesAsArray.push(this.classes[id]);
|
|
103
|
+
} catch (error: any) {
|
|
104
|
+
this.loggers.error(
|
|
105
|
+
"Error loading object " +
|
|
106
|
+
id +
|
|
107
|
+
" from manager " +
|
|
108
|
+
this.className +
|
|
109
|
+
" - " +
|
|
110
|
+
error.message
|
|
111
|
+
);
|
|
112
|
+
this.loggers.error(error.stack);
|
|
113
|
+
}
|
|
114
|
+
});
|
|
115
|
+
socket.on("delete" + classParam.name, async (id: string) => {
|
|
116
|
+
this.loggers.debug(
|
|
117
|
+
"Applying object deletion from manager " + this.className + " - " + id
|
|
118
|
+
);
|
|
119
|
+
try {
|
|
120
|
+
await this.deleteObject(id);
|
|
121
|
+
} catch (error: any) {
|
|
122
|
+
this.loggers.error(
|
|
123
|
+
"Error applying object deletion from manager " +
|
|
124
|
+
this.className +
|
|
125
|
+
" - " +
|
|
126
|
+
id
|
|
127
|
+
);
|
|
128
|
+
this.loggers.error(error.message);
|
|
129
|
+
this.loggers.error(error.stack);
|
|
130
|
+
}
|
|
131
|
+
});
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
protected async handleGetMissingObject(_id: string) {
|
|
135
|
+
if (!this.classers) throw new Error(`No classers.`);
|
|
136
|
+
return await createAutoUpdatedClass(
|
|
137
|
+
this.classParam,
|
|
138
|
+
this.socket,
|
|
139
|
+
_id,
|
|
140
|
+
this.loggers,
|
|
141
|
+
this,
|
|
142
|
+
this.emitter,
|
|
143
|
+
this.token
|
|
144
|
+
);
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
public async createObject(data: Omit<IsData<InstanceType<T>>, "_id">) {
|
|
148
|
+
if (!this.classers) throw new Error(`No classers.`);
|
|
149
|
+
const object = await createAutoUpdatedClass(
|
|
150
|
+
this.classParam,
|
|
151
|
+
this.socket,
|
|
152
|
+
data as any,
|
|
153
|
+
this.loggers,
|
|
154
|
+
this,
|
|
155
|
+
this.emitter,
|
|
156
|
+
this.token
|
|
157
|
+
);
|
|
158
|
+
this.classes[object._id] = object;
|
|
159
|
+
return object;
|
|
160
|
+
}
|
|
161
|
+
}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
import { AutoUpdated } from "./AutoUpdatedClientObjectClass.js";
|
|
2
|
+
import { Constructor, EventEmitter3, IsData, LoggersType, LoggersTypeInternal } from "./CommonTypes.js";
|
|
3
|
+
import "reflect-metadata";
|
|
4
|
+
export abstract class AutoUpdateManager<T extends Constructor<any>> {
|
|
5
|
+
protected classes: { [_id: string]: AutoUpdated<T> } = {};
|
|
6
|
+
public socket: any;
|
|
7
|
+
protected classParam: T;
|
|
8
|
+
protected properties: (keyof T)[];
|
|
9
|
+
public readonly classers: Record<string, AutoUpdateManager<any>>;
|
|
10
|
+
protected loggers: LoggersTypeInternal = {
|
|
11
|
+
info: () => {},
|
|
12
|
+
debug: () => {},
|
|
13
|
+
error: () => {},
|
|
14
|
+
warn: () => {},
|
|
15
|
+
};
|
|
16
|
+
protected classesAsArray: AutoUpdated<T>[] = [];
|
|
17
|
+
protected emitter: EventEmitter3;
|
|
18
|
+
private isLoaded = false;
|
|
19
|
+
constructor(
|
|
20
|
+
classParam: T,
|
|
21
|
+
socket: any,
|
|
22
|
+
loggers: LoggersType,
|
|
23
|
+
classers: Record<string, AutoUpdateManager<any>>,
|
|
24
|
+
emitter: EventEmitter3
|
|
25
|
+
) {
|
|
26
|
+
this.emitter = emitter;
|
|
27
|
+
this.emitter.on("*",(e) =>
|
|
28
|
+
{
|
|
29
|
+
console.log("a");
|
|
30
|
+
|
|
31
|
+
})
|
|
32
|
+
this.classers = classers;
|
|
33
|
+
this.socket = socket;
|
|
34
|
+
this.classParam = classParam;
|
|
35
|
+
this.properties = Reflect.getMetadata(
|
|
36
|
+
"props",
|
|
37
|
+
Object.getPrototypeOf(classParam)
|
|
38
|
+
);
|
|
39
|
+
loggers.warn = loggers.warn ?? loggers.info;
|
|
40
|
+
this.loggers = loggers as LoggersTypeInternal;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
|
|
44
|
+
public getObject(
|
|
45
|
+
_id: string
|
|
46
|
+
): AutoUpdated<T> | null {
|
|
47
|
+
return this.classes[_id];
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
public async isLoadedAsync(): Promise<boolean> {
|
|
51
|
+
if (this.isLoaded) return this.isLoaded;
|
|
52
|
+
await new Promise((resolve) => this.emitter.on("ManagerLoaded"+this.classParam.name+this.className, resolve));
|
|
53
|
+
this.isLoaded = true;
|
|
54
|
+
return this.isLoaded;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
public async deleteObject(_id: string): Promise<void> {
|
|
58
|
+
if (typeof this.classes[_id] === "string")
|
|
59
|
+
this.classes[_id] = await this.handleGetMissingObject(this.classes[_id]);
|
|
60
|
+
(this.classes[_id]).destroy();
|
|
61
|
+
this.classesAsArray.splice(this.classesAsArray.indexOf(this.classes[_id]), 1);
|
|
62
|
+
delete this.classes[_id];
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
public get objectIDs(): string[] {
|
|
66
|
+
return Object.keys(this.classes);
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
public get objects(): { [_id: string]: AutoUpdated<T> | string } {
|
|
70
|
+
return this.classes;
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
public get objectsAsArray(): AutoUpdated<T>[] {
|
|
74
|
+
return this.classesAsArray;
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
public get className(): string {
|
|
78
|
+
return this.classParam.name;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
protected abstract handleGetMissingObject(
|
|
82
|
+
_id: string
|
|
83
|
+
): Promise<AutoUpdated<T>>;
|
|
84
|
+
public abstract createObject(
|
|
85
|
+
data: IsData<InstanceType<T>>
|
|
86
|
+
): Promise<AutoUpdated<T>>;
|
|
87
|
+
}
|