-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhelpers.ts
119 lines (102 loc) · 2.55 KB
/
helpers.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
import { Context } from "@oak/oak";
import { Client } from "mysql";
import { JWTPayload } from "./types/request.ts";
import { ZodError } from "zod";
import { ERROR_MESSAGE } from "./constants.ts";
import { create, Header, verify } from "djwt";
import { OrderError, RepositoryError, UserError } from "./exceptions.ts";
import { getLogger, Logger } from "@std/log";
import { APIResponse } from "./types/dto.ts";
const jwtHeader: Header = { alg: "HS512", typ: "JWT" };
const container: {
dbClient?: Client;
logger?: Logger;
} = {};
const getEnv = (key: string) => {
return Deno.env.get(key) || "";
};
const getDBClient = async () => {
if (!container.dbClient) {
container.dbClient = await new Client().connect({
hostname: getEnv("DB_HOST"),
username: getEnv("DB_USERNAME"),
db: getEnv("DB_NAME"),
password: getEnv("DB_PASSWORD"),
});
}
return container.dbClient;
};
const getAppLogger = () => {
if (!container.logger) {
container.logger = getLogger();
}
return container.logger;
};
const setAPIResponse = <T extends object>(
context: Context,
response: APIResponse<T>,
) => {
context.response.type = "application/json";
context.response.body = response;
return context;
};
/**
* Catch the error and turn into Error Response
*
* @param context
* @param f
*/
const wrapError = async (context: Context, f: () => unknown) => {
try {
await f();
} catch (e) {
if (
e instanceof RepositoryError ||
e instanceof UserError ||
e instanceof OrderError
) {
setAPIResponse(context, {
success: false,
error_message: e.message,
});
} else if (e instanceof ZodError) {
setAPIResponse(context, {
success: false,
error_message: e.issues[0].message,
});
} else {
setAPIResponse(context, {
success: false,
error_message: ERROR_MESSAGE.ERROR_UNKNOWN,
});
}
}
};
const JWTKey = await crypto.subtle.importKey(
"jwk",
JSON.parse(getEnv("JWT_SECRET")),
{ name: "HMAC", hash: "SHA-512" },
true,
["sign", "verify"],
);
const getJWTPayload = async (token: string) => {
const payload = await verify<JWTPayload>(token, JWTKey);
return payload;
};
export async function generateToken(payload: JWTPayload) {
const token = await create(jwtHeader, payload, JWTKey);
return token;
}
const getRequestBody = (context: Context) => {
return context.request.body.json();
};
export default {
getRequestBody,
getEnv,
getDBClient,
getAppLogger,
setAPIResponse,
wrapError,
getJWTPayload,
generateToken,
};