@inobeta/api 0.6.0 → 0.7.0
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/auth/auth.plugin.d.ts.map +1 -1
- package/dist/auth/auth.plugin.js +5 -4
- package/dist/auth/auth.plugin.js.map +1 -1
- package/dist/auth/auth.types.d.ts +0 -2
- package/dist/auth/auth.types.d.ts.map +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/users/users.plugin.d.ts.map +1 -1
- package/dist/users/users.plugin.js +3 -2
- package/dist/users/users.plugin.js.map +1 -1
- package/dist/users/users.types.d.ts +0 -2
- package/dist/users/users.types.d.ts.map +1 -1
- package/dist/utils/date-utility.d.ts +2 -0
- package/dist/utils/date-utility.d.ts.map +1 -0
- package/dist/utils/date-utility.js +31 -0
- package/dist/utils/date-utility.js.map +1 -0
- package/dist/utils/email.d.ts +26 -0
- package/dist/utils/email.d.ts.map +1 -0
- package/dist/utils/email.js +56 -0
- package/dist/utils/email.js.map +1 -0
- package/dist/utils/http-utils.d.ts +3 -0
- package/dist/utils/http-utils.d.ts.map +1 -0
- package/dist/utils/http-utils.js +18 -0
- package/dist/utils/http-utils.js.map +1 -0
- package/dist/utils/index.d.ts +4 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +20 -0
- package/dist/utils/index.js.map +1 -0
- package/package.json +7 -4
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"auth.plugin.d.ts","sourceRoot":"","sources":["../../src/auth/auth.plugin.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAClD,OAAO,KAAK,EACR,iBAAiB,EAGpB,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"auth.plugin.d.ts","sourceRoot":"","sources":["../../src/auth/auth.plugin.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAClD,OAAO,KAAK,EACR,iBAAiB,EAGpB,MAAM,cAAc,CAAC;AAItB,wBAAgB,gBAAgB,CAC5B,OAAO,EAAE,iBAAiB,GAC3B,kBAAkB,CAiEpB"}
|
package/dist/auth/auth.plugin.js
CHANGED
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.createAuthPlugin = void 0;
|
|
4
4
|
const auth_service_1 = require("./auth.service");
|
|
5
|
+
const http_utils_1 = require("../utils/http-utils");
|
|
5
6
|
function createAuthPlugin(options) {
|
|
6
7
|
const plugin = async (server) => {
|
|
7
8
|
server.route({
|
|
@@ -22,13 +23,13 @@ function createAuthPlugin(options) {
|
|
|
22
23
|
})
|
|
23
24
|
});
|
|
24
25
|
if (!tokens) {
|
|
25
|
-
return
|
|
26
|
+
return (0, http_utils_1.httpResponse)(reply, 401, "Invalid credentials");
|
|
26
27
|
}
|
|
27
28
|
return tokens;
|
|
28
29
|
}
|
|
29
30
|
catch (error) {
|
|
30
31
|
console.error("Login error", error);
|
|
31
|
-
return
|
|
32
|
+
return (0, http_utils_1.httpResponse)(reply, 500, "Internal server error");
|
|
32
33
|
}
|
|
33
34
|
}
|
|
34
35
|
});
|
|
@@ -49,13 +50,13 @@ function createAuthPlugin(options) {
|
|
|
49
50
|
})
|
|
50
51
|
});
|
|
51
52
|
if (!tokens) {
|
|
52
|
-
return
|
|
53
|
+
return (0, http_utils_1.httpResponse)(reply, 401, "Invalid credentials");
|
|
53
54
|
}
|
|
54
55
|
return tokens;
|
|
55
56
|
}
|
|
56
57
|
catch (error) {
|
|
57
58
|
console.error("Refresh token error", error);
|
|
58
|
-
return
|
|
59
|
+
return (0, http_utils_1.httpResponse)(reply, 500, "Internal server error");
|
|
59
60
|
}
|
|
60
61
|
}
|
|
61
62
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"auth.plugin.js","sourceRoot":"","sources":["../../src/auth/auth.plugin.ts"],"names":[],"mappings":";;;AAMA,iDAA+C;
|
|
1
|
+
{"version":3,"file":"auth.plugin.js","sourceRoot":"","sources":["../../src/auth/auth.plugin.ts"],"names":[],"mappings":";;;AAMA,iDAA+C;AAC/C,oDAAmD;AAEnD,SAAgB,gBAAgB,CAC5B,OAA0B;IAE1B,MAAM,MAAM,GAAuB,KAAK,EAAE,MAAM,EAAE,EAAE;QAChD,MAAM,CAAC,KAAK,CAAsB;YAC9B,MAAM,EAAE,MAAM;YACd,GAAG,EAAE,WAAW;YAChB,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE;gBAC9B,IAAI;oBACA,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;oBAE5C,MAAM,MAAM,GAAG,MAAM,IAAA,4BAAa,EAAC;wBAC/B,OAAO,EAAE,OAAO,CAAC,OAAO;wBACxB,IAAI,EAAE,OAAO,CAAC,IAAI;wBAClB,QAAQ,EAAE,IAAI,eAAe,CAAC;4BAC1B,SAAS,EAAE,OAAO,CAAC,QAAQ;4BAC3B,aAAa,EAAE,OAAO,CAAC,YAAY;4BACnC,UAAU,EAAE,UAAU;4BACtB,QAAQ;4BACR,QAAQ;yBACX,CAAC;qBACL,CAAC,CAAC;oBAEH,IAAI,CAAC,MAAM,EAAE;wBACT,OAAO,IAAA,yBAAY,EAAC,KAAK,EAAE,GAAG,EAAE,qBAAqB,CAAC,CAAC;qBAC1D;oBAED,OAAO,MAAM,CAAC;iBACjB;gBAAC,OAAO,KAAK,EAAE;oBACZ,OAAO,CAAC,KAAK,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;oBACpC,OAAO,IAAA,yBAAY,EAAC,KAAK,EAAE,GAAG,EAAE,uBAAuB,CAAC,CAAC;iBAC5D;YACL,CAAC;SACJ,CAAC,CAAC;QAEH,MAAM,CAAC,KAAK,CAA6B;YACrC,MAAM,EAAE,MAAM;YACd,GAAG,EAAE,mBAAmB;YACxB,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE;gBAC9B,IAAI;oBACA,MAAM,EAAE,aAAa,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;oBAEvC,MAAM,MAAM,GAAG,MAAM,IAAA,4BAAa,EAAC;wBAC/B,OAAO,EAAE,OAAO,CAAC,OAAO;wBACxB,IAAI,EAAE,OAAO,CAAC,IAAI;wBAClB,QAAQ,EAAE,IAAI,eAAe,CAAC;4BAC1B,SAAS,EAAE,OAAO,CAAC,QAAQ;4BAC3B,aAAa,EAAE,OAAO,CAAC,YAAY;4BACnC,UAAU,EAAE,eAAe;4BAC3B,aAAa;yBAChB,CAAC;qBACL,CAAC,CAAC;oBAEH,IAAI,CAAC,MAAM,EAAE;wBACT,OAAO,IAAA,yBAAY,EAAC,KAAK,EAAE,GAAG,EAAE,qBAAqB,CAAC,CAAC;qBAC1D;oBAED,OAAO,MAAM,CAAC;iBACjB;gBAAC,OAAO,KAAK,EAAE;oBACZ,OAAO,CAAC,KAAK,CAAC,qBAAqB,EAAE,KAAK,CAAC,CAAC;oBAC5C,OAAO,IAAA,yBAAY,EAAC,KAAK,EAAE,GAAG,EAAE,uBAAuB,CAAC,CAAC;iBAC5D;YACL,CAAC;SACJ,CAAC,CAAC;IACP,CAAC,CAAC;IAEF,OAAO,MAAM,CAAC;AAClB,CAAC;AAnED,4CAmEC"}
|
|
@@ -1,11 +1,9 @@
|
|
|
1
|
-
import type { FastifyReply } from "fastify";
|
|
2
1
|
import type { Knex } from "knex";
|
|
3
2
|
export interface AuthPluginOptions {
|
|
4
3
|
authUrl: string;
|
|
5
4
|
clientId: string;
|
|
6
5
|
clientSecret: string;
|
|
7
6
|
knex: Knex;
|
|
8
|
-
httpResponse: (reply: FastifyReply, statusCode: number, message: string) => unknown;
|
|
9
7
|
}
|
|
10
8
|
export interface LoginBody {
|
|
11
9
|
username: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"auth.types.d.ts","sourceRoot":"","sources":["../../src/auth/auth.types.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"auth.types.d.ts","sourceRoot":"","sources":["../../src/auth/auth.types.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAEjC,MAAM,WAAW,iBAAiB;IAChC,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,EAAE,MAAM,CAAC;IACrB,IAAI,EAAE,IAAI,CAAC;CACZ;AAED,MAAM,WAAW,SAAS;IACxB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,WAAW,gBAAgB;IAC/B,aAAa,EAAE,MAAM,CAAC;CACvB;AAED,MAAM,WAAW,qBAAqB;IACpC,YAAY,EAAE,MAAM,CAAC;IACrB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC;CACxB"}
|
package/dist/index.d.ts
CHANGED
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAC;AACvB,cAAc,SAAS,CAAC;AACxB,cAAc,oBAAoB,CAAC;AACnC,cAAc,0BAA0B,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,QAAQ,CAAC;AACvB,cAAc,SAAS,CAAC;AACxB,cAAc,SAAS,CAAC;AACxB,cAAc,oBAAoB,CAAC;AACnC,cAAc,0BAA0B,CAAC"}
|
package/dist/index.js
CHANGED
|
@@ -16,6 +16,7 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
17
|
__exportStar(require("./auth"), exports);
|
|
18
18
|
__exportStar(require("./users"), exports);
|
|
19
|
+
__exportStar(require("./utils"), exports);
|
|
19
20
|
__exportStar(require("./plugins/auth-jwt"), exports);
|
|
20
21
|
__exportStar(require("./plugins/keycloak-admin"), exports);
|
|
21
22
|
//# sourceMappingURL=index.js.map
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,yCAAuB;AACvB,0CAAwB;AACxB,qDAAmC;AACnC,2DAAyC"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,yCAAuB;AACvB,0CAAwB;AACxB,0CAAwB;AACxB,qDAAmC;AACnC,2DAAyC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"users.plugin.d.ts","sourceRoot":"","sources":["../../src/users/users.plugin.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAUlD,OAAO,KAAK,EAKR,kBAAkB,EACrB,MAAM,eAAe,CAAC;
|
|
1
|
+
{"version":3,"file":"users.plugin.d.ts","sourceRoot":"","sources":["../../src/users/users.plugin.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAUlD,OAAO,KAAK,EAKR,kBAAkB,EACrB,MAAM,eAAe,CAAC;AAGvB,wBAAgB,iBAAiB,CAC7B,OAAO,EAAE,kBAAkB,GAC5B,kBAAkB,CAoGpB"}
|
|
@@ -3,6 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.createUsersPlugin = void 0;
|
|
4
4
|
const users_service_1 = require("./users.service");
|
|
5
5
|
const users_gql_1 = require("./users.gql");
|
|
6
|
+
const http_utils_1 = require("../utils/http-utils");
|
|
6
7
|
function createUsersPlugin(options) {
|
|
7
8
|
const plugin = async (server) => {
|
|
8
9
|
const prefix = options.prefix ?? "/v1";
|
|
@@ -50,7 +51,7 @@ function createUsersPlugin(options) {
|
|
|
50
51
|
body: request.body
|
|
51
52
|
});
|
|
52
53
|
if (!result.ok) {
|
|
53
|
-
return
|
|
54
|
+
return (0, http_utils_1.httpResponse)(reply, result.statusCode, result.message);
|
|
54
55
|
}
|
|
55
56
|
return {
|
|
56
57
|
errors: false,
|
|
@@ -70,7 +71,7 @@ function createUsersPlugin(options) {
|
|
|
70
71
|
body: request.body
|
|
71
72
|
});
|
|
72
73
|
if (!result.ok) {
|
|
73
|
-
return
|
|
74
|
+
return (0, http_utils_1.httpResponse)(reply, result.statusCode, result.message);
|
|
74
75
|
}
|
|
75
76
|
return {
|
|
76
77
|
errors: false,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"users.plugin.js","sourceRoot":"","sources":["../../src/users/users.plugin.ts"],"names":[],"mappings":";;;AACA,mDAOyB;AACzB,2CAAkD;
|
|
1
|
+
{"version":3,"file":"users.plugin.js","sourceRoot":"","sources":["../../src/users/users.plugin.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import type { FastifyReply } from "fastify";
|
|
2
1
|
export type GetUserByIdRoute = {
|
|
3
2
|
Params: {
|
|
4
3
|
id: string;
|
|
@@ -48,7 +47,6 @@ export interface UsersAuthConfig {
|
|
|
48
47
|
clientSecret: string;
|
|
49
48
|
}
|
|
50
49
|
export interface UsersPluginOptions {
|
|
51
|
-
httpResponse: (reply: FastifyReply, statusCode: number, message: string) => unknown;
|
|
52
50
|
authConfig: UsersAuthConfig;
|
|
53
51
|
graphql?: {
|
|
54
52
|
enabled?: boolean;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"users.types.d.ts","sourceRoot":"","sources":["../../src/users/users.types.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"users.types.d.ts","sourceRoot":"","sources":["../../src/users/users.types.ts"],"names":[],"mappings":"AAEA,MAAM,MAAM,gBAAgB,GAAG;IAC3B,MAAM,EAAE;QAAE,EAAE,EAAE,MAAM,CAAA;KAAE,CAAC;CAC1B,CAAC;AAEF,MAAM,MAAM,uBAAuB,GAAG,gBAAgB,GAAG;IACrD,IAAI,EAAE;QACF,QAAQ,EAAE,MAAM,CAAC;KACpB,CAAC;CACL,CAAC;AAEF,MAAM,MAAM,sBAAsB,GAAG;IACjC,IAAI,EAAE;QACF,eAAe,EAAE,MAAM,CAAC;QACxB,WAAW,EAAE,MAAM,CAAC;KACvB,CAAC;CACL,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG,gBAAgB,GAAG;IAC7C,IAAI,EAAE;QACF,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,OAAO,CAAC,EAAE,OAAO,CAAC;QAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;KACrB,CAAC;CACL,CAAC;AAEF,MAAM,MAAM,IAAI,GAAG;IACf,EAAE,EAAE,MAAM,CAAC;IACX,QAAQ,EAAE,MAAM,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,OAAO,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,EAAE,CAAC;CACxB,CAAC;AAEF,MAAM,MAAM,YAAY,GAAG,IAAI,GAAG;IAC9B,UAAU,EAAE,MAAM,EAAE,CAAC;CACxB,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG,OAAO,GAAG,WAAW,GAAG,UAAU,CAAC;AAChE,MAAM,MAAM,aAAa,GAAG,KAAK,GAAG,MAAM,CAAC;AAE3C,MAAM,MAAM,gBAAgB,GAAG;IAC3B,GAAG,EAAE,cAAc,CAAC;IACpB,SAAS,CAAC,EAAE,aAAa,CAAC;CAC7B,CAAC;AAEF,MAAM,WAAW,eAAe;IAC5B,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,EAAE,MAAM,CAAC;CACxB;AAED,MAAM,WAAW,kBAAkB;IAC/B,UAAU,EAAE,eAAe,CAAC;IAC5B,OAAO,CAAC,EAAE;QACN,OAAO,CAAC,EAAE,OAAO,CAAC;QAClB,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,QAAQ,CAAC,EAAE,OAAO,CAAC;KACtB,CAAC;IACF,MAAM,CAAC,EAAE,MAAM,CAAC;CACnB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"date-utility.d.ts","sourceRoot":"","sources":["../../src/utils/date-utility.ts"],"names":[],"mappings":"AAAA,wBAAgB,UAAU,CAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,UAenD"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.dateFormat = void 0;
|
|
4
|
+
function dateFormat(date, fstr) {
|
|
5
|
+
return fstr.replace(/%[YmdHMS]/g, (m) => {
|
|
6
|
+
let c = 0;
|
|
7
|
+
switch (m) {
|
|
8
|
+
case '%Y': return date.getFullYear().toString(); // no leading zeros required
|
|
9
|
+
case '%m':
|
|
10
|
+
c = 1 + date.getMonth();
|
|
11
|
+
break;
|
|
12
|
+
case '%d':
|
|
13
|
+
c = date.getDate();
|
|
14
|
+
break;
|
|
15
|
+
case '%H':
|
|
16
|
+
c = date.getHours();
|
|
17
|
+
break;
|
|
18
|
+
case '%M':
|
|
19
|
+
c = date.getMinutes();
|
|
20
|
+
break;
|
|
21
|
+
case '%S':
|
|
22
|
+
c = date.getSeconds();
|
|
23
|
+
break;
|
|
24
|
+
default: return m.slice(1); // unknown code, remove %
|
|
25
|
+
}
|
|
26
|
+
// add leading zero if required
|
|
27
|
+
return c.toString().padStart(2, '0');
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
exports.dateFormat = dateFormat;
|
|
31
|
+
//# sourceMappingURL=date-utility.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"date-utility.js","sourceRoot":"","sources":["../../src/utils/date-utility.ts"],"names":[],"mappings":";;;AAAA,SAAgB,UAAU,CAAE,IAAU,EAAE,IAAY;IAClD,OAAO,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC,EAAE,EAAE;QACtC,IAAI,CAAC,GAAG,CAAC,CAAA;QACT,QAAQ,CAAC,EAAE;YACT,KAAK,IAAI,CAAC,CAAC,OAAO,IAAI,CAAC,WAAW,EAAE,CAAC,QAAQ,EAAE,CAAA,CAAC,4BAA4B;YAC5E,KAAK,IAAI;gBAAE,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAAC,MAAK;YACzC,KAAK,IAAI;gBAAE,CAAC,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;gBAAC,MAAK;YACpC,KAAK,IAAI;gBAAE,CAAC,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAAC,MAAK;YACrC,KAAK,IAAI;gBAAE,CAAC,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;gBAAC,MAAK;YACvC,KAAK,IAAI;gBAAE,CAAC,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;gBAAC,MAAK;YACvC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA,CAAC,yBAAyB;SACrD;QACD,+BAA+B;QAC/B,OAAO,CAAC,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAA;IACtC,CAAC,CAAC,CAAA;AACJ,CAAC;AAfD,gCAeC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
export interface EmailConfig {
|
|
2
|
+
smtp: {
|
|
3
|
+
host: string;
|
|
4
|
+
port: number;
|
|
5
|
+
secure: boolean;
|
|
6
|
+
auth: {
|
|
7
|
+
user: string;
|
|
8
|
+
pass: string;
|
|
9
|
+
};
|
|
10
|
+
};
|
|
11
|
+
data: {
|
|
12
|
+
from: string;
|
|
13
|
+
};
|
|
14
|
+
}
|
|
15
|
+
export declare const sendEmail: (params: EmailParams, emailConfig: EmailConfig) => Promise<boolean>;
|
|
16
|
+
export type EmailParams = {
|
|
17
|
+
to: string;
|
|
18
|
+
subject: string;
|
|
19
|
+
html: string;
|
|
20
|
+
attachments?: {
|
|
21
|
+
filename: string;
|
|
22
|
+
path: string;
|
|
23
|
+
contentType: string;
|
|
24
|
+
}[];
|
|
25
|
+
};
|
|
26
|
+
//# sourceMappingURL=email.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"email.d.ts","sourceRoot":"","sources":["../../src/utils/email.ts"],"names":[],"mappings":"AAKA,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE;QACJ,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;QACb,MAAM,EAAE,OAAO,CAAC;QAChB,IAAI,EAAE;YACJ,IAAI,EAAE,MAAM,CAAC;YACb,IAAI,EAAE,MAAM,CAAC;SACd,CAAC;KACH,CAAC;IACF,IAAI,EAAE;QACJ,IAAI,EAAE,MAAM,CAAC;KACd,CAAC;CACH;AAED,eAAO,MAAM,SAAS,WAAY,WAAW,eAAe,WAAW,KAAG,QAAQ,OAAO,CA4BxF,CAAA;AAED,MAAM,MAAM,WAAW,GAAG;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,CAAC,EAAE;QAAE,QAAQ,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAA;KAAE,EAAE,CAAA;CACxE,CAAA"}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.sendEmail = void 0;
|
|
27
|
+
const nodemailer = __importStar(require("nodemailer"));
|
|
28
|
+
process.env.NODE_TLS_REJECT_UNAUTHORIZED = '0';
|
|
29
|
+
const sendEmail = (params, emailConfig) => {
|
|
30
|
+
// create reusable transporter object using the default SMTP transport
|
|
31
|
+
const transporter = nodemailer.createTransport(emailConfig.smtp);
|
|
32
|
+
const defaultData = emailConfig.data;
|
|
33
|
+
console.log(params.html);
|
|
34
|
+
const mailOptions = {
|
|
35
|
+
from: defaultData.from,
|
|
36
|
+
to: params.to,
|
|
37
|
+
subject: params.subject,
|
|
38
|
+
html: params.html,
|
|
39
|
+
attachments: params.attachments
|
|
40
|
+
};
|
|
41
|
+
return new Promise((resolve, reject) => {
|
|
42
|
+
transporter.sendMail(mailOptions, (error, info) => {
|
|
43
|
+
if (error && process.env.NODE_ENV === 'production') {
|
|
44
|
+
console.log(error);
|
|
45
|
+
reject(error.message);
|
|
46
|
+
return;
|
|
47
|
+
}
|
|
48
|
+
console.log('Message sent: %s', info?.messageId);
|
|
49
|
+
// Preview only available when sending through an Ethereal account
|
|
50
|
+
console.log('Preview URL: %s', nodemailer.getTestMessageUrl(info));
|
|
51
|
+
resolve(true);
|
|
52
|
+
});
|
|
53
|
+
});
|
|
54
|
+
};
|
|
55
|
+
exports.sendEmail = sendEmail;
|
|
56
|
+
//# sourceMappingURL=email.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"email.js","sourceRoot":"","sources":["../../src/utils/email.ts"],"names":[],"mappings":"AAAA,YAAY,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;AACZ,uDAAwC;AAExC,OAAO,CAAC,GAAG,CAAC,4BAA4B,GAAG,GAAG,CAAA;AAiBvC,MAAM,SAAS,GAAG,CAAC,MAAmB,EAAE,WAAwB,EAAoB,EAAE;IAC3F,sEAAsE;IACtE,MAAM,WAAW,GAAG,UAAU,CAAC,eAAe,CAAC,WAAW,CAAC,IAAI,CAAC,CAAA;IAEhE,MAAM,WAAW,GAAG,WAAW,CAAC,IAAI,CAAA;IAEpC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;IAExB,MAAM,WAAW,GAAG;QAClB,IAAI,EAAE,WAAW,CAAC,IAAI;QACtB,EAAE,EAAE,MAAM,CAAC,EAAE;QACb,OAAO,EAAE,MAAM,CAAC,OAAO;QACvB,IAAI,EAAE,MAAM,CAAC,IAAI;QACjB,WAAW,EAAE,MAAM,CAAC,WAAW;KAChC,CAAA;IACD,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACrC,WAAW,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;YAChD,IAAI,KAAK,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,YAAY,EAAE;gBAClD,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAA;gBAClB,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;gBACrB,OAAM;aACP;YACD,OAAO,CAAC,GAAG,CAAC,kBAAkB,EAAE,IAAI,EAAE,SAAS,CAAC,CAAA;YAChD,kEAAkE;YAClE,OAAO,CAAC,GAAG,CAAC,iBAAiB,EAAE,UAAU,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAA;YAClE,OAAO,CAAC,IAAI,CAAC,CAAA;QACf,CAAC,CAAC,CAAA;IACJ,CAAC,CAAC,CAAA;AACJ,CAAC,CAAA;AA5BY,QAAA,SAAS,aA4BrB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"http-utils.d.ts","sourceRoot":"","sources":["../../src/utils/http-utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAA;AAUtC,wBAAgB,YAAY,CAAC,KAAK,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,QAMpF"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.httpResponse = void 0;
|
|
4
|
+
const errorCodes = {
|
|
5
|
+
400: 'Bad Request',
|
|
6
|
+
401: 'Unauthorized',
|
|
7
|
+
403: 'Forbidden',
|
|
8
|
+
500: 'API Failure'
|
|
9
|
+
};
|
|
10
|
+
function httpResponse(reply, statusCode, message) {
|
|
11
|
+
reply.code(statusCode).send({
|
|
12
|
+
statusCode: statusCode,
|
|
13
|
+
error: errorCodes[statusCode] ?? statusCode,
|
|
14
|
+
message: message
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
exports.httpResponse = httpResponse;
|
|
18
|
+
//# sourceMappingURL=http-utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"http-utils.js","sourceRoot":"","sources":["../../src/utils/http-utils.ts"],"names":[],"mappings":";;;AAEA,MAAM,UAAU,GAAG;IACf,GAAG,EAAE,aAAa;IAClB,GAAG,EAAE,cAAc;IACnB,GAAG,EAAE,WAAW;IAChB,GAAG,EAAE,aAAa;CACrB,CAAA;AAGD,SAAgB,YAAY,CAAC,KAAmB,EAAE,UAAkB,EAAE,OAAe;IACjF,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC;QACxB,UAAU,EAAE,UAAU;QACtB,KAAK,EAAE,UAAU,CAAC,UAAmC,CAAC,IAAI,UAAU;QACpE,OAAO,EAAE,OAAO;KACnB,CAAC,CAAA;AACN,CAAC;AAND,oCAMC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC;AAC/B,cAAc,cAAc,CAAC;AAC7B,cAAc,SAAS,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./date-utility"), exports);
|
|
18
|
+
__exportStar(require("./http-utils"), exports);
|
|
19
|
+
__exportStar(require("./email"), exports);
|
|
20
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,iDAA+B;AAC/B,+CAA6B;AAC7B,0CAAwB"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@inobeta/api",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.7.0",
|
|
4
4
|
"description": "Shared backend library for Inobeta projects",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"type": "commonjs",
|
|
@@ -26,21 +26,24 @@
|
|
|
26
26
|
"@keycloak/keycloak-admin-client": "^26.3.5",
|
|
27
27
|
"@types/jsonwebtoken": "^9.0.10",
|
|
28
28
|
"@types/node": "^25.5.0",
|
|
29
|
+
"@types/nodemailer": "^7.0.11",
|
|
29
30
|
"fastify": "^5.6.0",
|
|
30
31
|
"fastify-plugin": "^5.1.0",
|
|
31
32
|
"jsonwebtoken": "^9.0.3",
|
|
32
33
|
"knex": "^2.3.0",
|
|
33
34
|
"mercurius": "^16.8.0",
|
|
35
|
+
"nodemailer": "^6.7.2",
|
|
34
36
|
"rimraf": "^6.1.3",
|
|
35
37
|
"typescript": "^5.2.2"
|
|
36
38
|
},
|
|
37
39
|
"peerDependencies": {
|
|
40
|
+
"@keycloak/keycloak-admin-client": "^26.3.5",
|
|
38
41
|
"fastify": "^5.6.0",
|
|
42
|
+
"fastify-plugin": "^5.0.1",
|
|
43
|
+
"jsonwebtoken": "^9.0.0",
|
|
39
44
|
"knex": "^2.3.0",
|
|
40
45
|
"mercurius": "^16.0.0",
|
|
41
|
-
"
|
|
42
|
-
"fastify-plugin": "^5.0.1",
|
|
43
|
-
"jsonwebtoken": "^9.0.0"
|
|
46
|
+
"nodemailer": "^6.7.2"
|
|
44
47
|
},
|
|
45
48
|
"engines": {
|
|
46
49
|
"node": ">=20"
|