@cripty2001/utils 0.0.61 → 0.0.63
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.
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { Static, TSchema } from '@sinclair/typebox';
|
|
2
2
|
import { AppserverData } from './common';
|
|
3
|
-
export {
|
|
3
|
+
export type { AppserverData };
|
|
4
|
+
export { Static, TSchema, Type } from '@sinclair/typebox';
|
|
4
5
|
export { Value } from '@sinclair/typebox/value';
|
|
5
6
|
export type AppserverHandler<I extends AppserverData, U extends AppserverData, O extends AppserverData> = (input: I, user: U | null) => Promise<O> | O;
|
|
6
7
|
export type AppserverUsergetter<U extends AppserverData> = (token: string) => Promise<U | null>;
|
|
@@ -37,6 +38,7 @@ export declare class Appserver<U extends AppserverData> {
|
|
|
37
38
|
private getMetrics;
|
|
38
39
|
private registered;
|
|
39
40
|
constructor(port: number, parseUser: AppserverUsergetter<U>, getMetrics: () => Record<string, number>);
|
|
41
|
+
private registerAuth;
|
|
40
42
|
private handleMetricsRequest;
|
|
41
43
|
private parseInput;
|
|
42
44
|
/**
|
|
@@ -47,4 +49,5 @@ export declare class Appserver<U extends AppserverData> {
|
|
|
47
49
|
* @param handler business logic returning serializable data
|
|
48
50
|
*/
|
|
49
51
|
register<ISchema extends TSchema, O extends AppserverData, I extends Static<ISchema> & AppserverData = Static<ISchema> & AppserverData>(action: string, inputSchema: ISchema, auth: boolean, handler: AppserverHandler<I, U, O>): void;
|
|
52
|
+
private unsafeRegister;
|
|
50
53
|
}
|
package/dist/Appserver/server.js
CHANGED
|
@@ -4,12 +4,13 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
4
4
|
};
|
|
5
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
6
|
exports.Appserver = exports.AppserverHandledError = exports.AppserverAuthError = exports.Value = exports.Type = void 0;
|
|
7
|
-
const express_1 = __importDefault(require("express"));
|
|
8
|
-
const value_1 = require("@sinclair/typebox/value");
|
|
9
7
|
const msgpack_1 = require("@msgpack/msgpack");
|
|
8
|
+
const typebox_1 = require("@sinclair/typebox");
|
|
9
|
+
const value_1 = require("@sinclair/typebox/value");
|
|
10
|
+
const express_1 = __importDefault(require("express"));
|
|
10
11
|
// Helpful for avoiding sinclair version mismatch between this and the actual user of the package
|
|
11
|
-
var
|
|
12
|
-
Object.defineProperty(exports, "Type", { enumerable: true, get: function () { return
|
|
12
|
+
var typebox_2 = require("@sinclair/typebox");
|
|
13
|
+
Object.defineProperty(exports, "Type", { enumerable: true, get: function () { return typebox_2.Type; } });
|
|
13
14
|
var value_2 = require("@sinclair/typebox/value");
|
|
14
15
|
Object.defineProperty(exports, "Value", { enumerable: true, get: function () { return value_2.Value; } });
|
|
15
16
|
(0, msgpack_1.encode)({}); // Fixes issue with msgpack not being included in build
|
|
@@ -64,6 +65,15 @@ class Appserver {
|
|
|
64
65
|
this.app.get('/metrics', async (req, res) => {
|
|
65
66
|
await this.handleMetricsRequest(req, res);
|
|
66
67
|
});
|
|
68
|
+
this.registerAuth(this.app);
|
|
69
|
+
}
|
|
70
|
+
registerAuth(app) {
|
|
71
|
+
this.unsafeRegister('/auth/whoami', typebox_1.Type.Object({}), false, async (input, user) => {
|
|
72
|
+
return {
|
|
73
|
+
user: Object.fromEntries(Object.entries(user ?? {})
|
|
74
|
+
.filter(([key]) => !key.startsWith('_')))
|
|
75
|
+
};
|
|
76
|
+
});
|
|
67
77
|
}
|
|
68
78
|
async handleMetricsRequest(req, res) {
|
|
69
79
|
try {
|
|
@@ -119,10 +129,13 @@ class Appserver {
|
|
|
119
129
|
* @param handler business logic returning serializable data
|
|
120
130
|
*/
|
|
121
131
|
register(action, inputSchema, auth, handler) {
|
|
132
|
+
this.unsafeRegister(`/exec/${action}`, inputSchema, auth, handler);
|
|
133
|
+
}
|
|
134
|
+
unsafeRegister(action, inputSchema, auth, handler) {
|
|
122
135
|
if (this.registered.has(action))
|
|
123
136
|
throw new Error(`Action ${action} is already registered`);
|
|
124
137
|
this.registered.add(action);
|
|
125
|
-
this.app.post(
|
|
138
|
+
this.app.post(action, express_1.default.raw({ type: 'application/vnd.msgpack' }), async (req, res) => {
|
|
126
139
|
const { status, data } = await (async () => {
|
|
127
140
|
try {
|
|
128
141
|
const { data: unsafeData, user } = await this.parseInput(req);
|
package/package.json
CHANGED