@volcanicminds/backend 0.1.2 → 0.1.4

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/NPM.md ADDED
@@ -0,0 +1,22 @@
1
+ # NPM
2
+
3
+ ## how to publish
4
+
5
+ ```ruby
6
+ npm install npm@latest -g
7
+ npm login
8
+ npm init --scope=volcanicminds
9
+ npm publish --access public
10
+ ```
11
+
12
+ ## local linking
13
+
14
+ ```ruby
15
+ yarn link
16
+ yarn link "@volcanicminds/backend"
17
+ ```
18
+
19
+ ```ruby
20
+ yarn unlink
21
+ yarn unlink "@volcanicminds/backend"
22
+ ```
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.demo = exports.isAdmin = exports.user = void 0;
4
+ async function user(req, reply) {
5
+ reply.send(req.user || {});
6
+ }
7
+ exports.user = user;
8
+ async function isAdmin(req, reply) {
9
+ reply.send({ isAdmin: (req.user?.roles || []).includes('admin') || false });
10
+ }
11
+ exports.isAdmin = isAdmin;
12
+ async function demo(req, reply) {
13
+ reply.send({ demo: true });
14
+ }
15
+ exports.demo = demo;
16
+ //# sourceMappingURL=me.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"me.js","sourceRoot":"","sources":["../../../../lib/api/me/controller/me.ts"],"names":[],"mappings":";;;AAEO,KAAK,UAAU,IAAI,CAAC,GAAmB,EAAE,KAAmB;IACjE,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC,CAAA;AAC5B,CAAC;AAFD,oBAEC;AAEM,KAAK,UAAU,OAAO,CAAC,GAAmB,EAAE,KAAmB;IACpE,KAAK,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,KAAK,EAAE,CAAC,CAAA;AAC7E,CAAC;AAFD,0BAEC;AAEM,KAAK,UAAU,IAAI,CAAC,GAAmB,EAAE,KAAmB;IACjE,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAA;AAC5B,CAAC;AAFD,oBAEC"}
@@ -0,0 +1,101 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.default = {
4
+ config: {
5
+ title: 'Useful functions',
6
+ description: 'Useful functions',
7
+ controller: 'controller',
8
+ tags: ['user', 'code'],
9
+ enable: true,
10
+ deprecated: false,
11
+ version: false // swagger
12
+ },
13
+ routes: [
14
+ {
15
+ method: 'GET',
16
+ path: '/',
17
+ roles: [],
18
+ handler: 'me.user',
19
+ middlewares: ['global.isAuthenticated'],
20
+ config: {
21
+ enable: true,
22
+ title: 'Me title',
23
+ description: 'Me description',
24
+ tags: ['user', 'code'],
25
+ deprecated: false,
26
+ version: false,
27
+ response: {
28
+ 403: {
29
+ description: 'Successful response',
30
+ type: 'object',
31
+ properties: {
32
+ hello: { type: 'string' }
33
+ }
34
+ },
35
+ 200: {
36
+ description: 'Default response',
37
+ type: 'object',
38
+ properties: {
39
+ id: { type: 'number' }
40
+ }
41
+ }
42
+ } // swagger
43
+ }
44
+ },
45
+ {
46
+ method: 'GET',
47
+ path: '/is-admin',
48
+ roles: [],
49
+ handler: 'me.isAdmin',
50
+ middlewares: ['global.isAuthenticated'],
51
+ config: {
52
+ title: 'Admin',
53
+ description: 'Admin',
54
+ enable: true,
55
+ deprecated: false,
56
+ version: false
57
+ }
58
+ },
59
+ {
60
+ method: 'GET',
61
+ path: '/demo',
62
+ roles: [],
63
+ handler: 'me.demo',
64
+ middlewares: ['global.isAdmin'],
65
+ config: {
66
+ enable: true,
67
+ title: 'Me title',
68
+ description: 'Me description',
69
+ tags: ['user', 'code'],
70
+ deprecated: false,
71
+ version: false,
72
+ params: {
73
+ type: 'object',
74
+ properties: {
75
+ id: {
76
+ type: 'string',
77
+ description: 'user id'
78
+ }
79
+ }
80
+ },
81
+ response: {
82
+ 201: {
83
+ description: 'Successful response',
84
+ type: 'object',
85
+ properties: {
86
+ hello: { type: 'string' }
87
+ }
88
+ },
89
+ 200: {
90
+ description: 'Default response',
91
+ type: 'object',
92
+ properties: {
93
+ foo: { type: 'string' }
94
+ }
95
+ }
96
+ } // swagger
97
+ }
98
+ }
99
+ ]
100
+ };
101
+ //# sourceMappingURL=routes.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"routes.js","sourceRoot":"","sources":["../../../lib/api/me/routes.ts"],"names":[],"mappings":";;AAAA,kBAAe;IACb,MAAM,EAAE;QACN,KAAK,EAAE,kBAAkB;QACzB,WAAW,EAAE,kBAAkB;QAC/B,UAAU,EAAE,YAAY;QACxB,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;QACtB,MAAM,EAAE,IAAI;QACZ,UAAU,EAAE,KAAK;QACjB,OAAO,EAAE,KAAK,CAAC,UAAU;KAC1B;IACD,MAAM,EAAE;QACN;YACE,MAAM,EAAE,KAAK;YACb,IAAI,EAAE,GAAG;YACT,KAAK,EAAE,EAAE;YACT,OAAO,EAAE,SAAS;YAClB,WAAW,EAAE,CAAC,wBAAwB,CAAC;YACvC,MAAM,EAAE;gBACN,MAAM,EAAE,IAAI;gBACZ,KAAK,EAAE,UAAU;gBACjB,WAAW,EAAE,gBAAgB;gBAC7B,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;gBACtB,UAAU,EAAE,KAAK;gBACjB,OAAO,EAAE,KAAK;gBACd,QAAQ,EAAE;oBACR,GAAG,EAAE;wBACH,WAAW,EAAE,qBAAqB;wBAClC,IAAI,EAAE,QAAQ;wBACd,UAAU,EAAE;4BACV,KAAK,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;yBAC1B;qBACF;oBACD,GAAG,EAAE;wBACH,WAAW,EAAE,kBAAkB;wBAC/B,IAAI,EAAE,QAAQ;wBACd,UAAU,EAAE;4BACV,EAAE,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;yBACvB;qBACF;iBACF,CAAC,UAAU;aACb;SACF;QACD;YACE,MAAM,EAAE,KAAK;YACb,IAAI,EAAE,WAAW;YACjB,KAAK,EAAE,EAAE;YACT,OAAO,EAAE,YAAY;YACrB,WAAW,EAAE,CAAC,wBAAwB,CAAC;YACvC,MAAM,EAAE;gBACN,KAAK,EAAE,OAAO;gBACd,WAAW,EAAE,OAAO;gBACpB,MAAM,EAAE,IAAI;gBACZ,UAAU,EAAE,KAAK;gBACjB,OAAO,EAAE,KAAK;aACf;SACF;QACD;YACE,MAAM,EAAE,KAAK;YACb,IAAI,EAAE,OAAO;YACb,KAAK,EAAE,EAAE;YACT,OAAO,EAAE,SAAS;YAClB,WAAW,EAAE,CAAC,gBAAgB,CAAC;YAC/B,MAAM,EAAE;gBACN,MAAM,EAAE,IAAI;gBACZ,KAAK,EAAE,UAAU;gBACjB,WAAW,EAAE,gBAAgB;gBAC7B,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;gBACtB,UAAU,EAAE,KAAK;gBACjB,OAAO,EAAE,KAAK;gBACd,MAAM,EAAE;oBACN,IAAI,EAAE,QAAQ;oBACd,UAAU,EAAE;wBACV,EAAE,EAAE;4BACF,IAAI,EAAE,QAAQ;4BACd,WAAW,EAAE,SAAS;yBACvB;qBACF;iBACF;gBACD,QAAQ,EAAE;oBACR,GAAG,EAAE;wBACH,WAAW,EAAE,qBAAqB;wBAClC,IAAI,EAAE,QAAQ;wBACd,UAAU,EAAE;4BACV,KAAK,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;yBAC1B;qBACF;oBACD,GAAG,EAAE;wBACH,WAAW,EAAE,kBAAkB;wBAC/B,IAAI,EAAE,QAAQ;wBACd,UAAU,EAAE;4BACV,GAAG,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE;yBACxB;qBACF;iBACF,CAAC,UAAU;aACb;SACF;KACF;CACF,CAAA"}
@@ -0,0 +1,8 @@
1
+ 'use strict';
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.myContextFunction = void 0;
4
+ const myContextFunction = async () => ({
5
+ greeting: 'Hello World!! ' + new Date().getTime()
6
+ });
7
+ exports.myContextFunction = myContextFunction;
8
+ //# sourceMappingURL=context.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"context.js","sourceRoot":"","sources":["../../lib/apollo/context.ts"],"names":[],"mappings":"AAAA,YAAY,CAAA;;;AAQL,MAAM,iBAAiB,GAA4C,KAAK,IAAI,EAAE,CAAC,CAAC;IACrF,QAAQ,EAAE,gBAAgB,GAAG,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE;CAClD,CAAC,CAAA;AAFW,QAAA,iBAAiB,qBAE5B"}
@@ -0,0 +1,9 @@
1
+ 'use strict';
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const resolvers = {
4
+ Query: {
5
+ helloWorld: (parent, args, context, info) => context.greeting
6
+ }
7
+ };
8
+ exports.default = resolvers;
9
+ //# sourceMappingURL=resolvers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"resolvers.js","sourceRoot":"","sources":["../../lib/apollo/resolvers.ts"],"names":[],"mappings":"AAAA,YAAY,CAAA;;AAIZ,MAAM,SAAS,GAAG;IAChB,KAAK,EAAE;QACL,UAAU,EAAE,CAAC,MAAW,EAAE,IAAS,EAAE,OAAkB,EAAE,IAAS,EAAE,EAAE,CAAC,OAAO,CAAC,QAAQ;KACxF;CACF,CAAA;AAED,kBAAe,SAAS,CAAA"}
@@ -0,0 +1,9 @@
1
+ 'use strict';
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const typeDefs = `
4
+ type Query {
5
+ helloWorld: String!
6
+ }
7
+ `;
8
+ exports.default = typeDefs;
9
+ //# sourceMappingURL=type-defs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"type-defs.js","sourceRoot":"","sources":["../../lib/apollo/type-defs.ts"],"names":[],"mappings":"AAAA,YAAY,CAAA;;AAEZ,MAAM,QAAQ,GAAG;;;;CAIhB,CAAA;AAED,kBAAe,QAAQ,CAAA"}
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.roles = void 0;
4
+ exports.roles = [
5
+ {
6
+ code: 'public',
7
+ name: 'Public',
8
+ description: 'Public role'
9
+ },
10
+ {
11
+ code: 'admin',
12
+ name: 'Admin',
13
+ description: 'Admin role'
14
+ },
15
+ {
16
+ code: 'backoffice',
17
+ name: 'Backoffice',
18
+ description: 'Backoffice role'
19
+ }
20
+ ];
21
+ //# sourceMappingURL=roles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"roles.js","sourceRoot":"","sources":["../../lib/config/roles.ts"],"names":[],"mappings":";;;AAQa,QAAA,KAAK,GAAW;IAC3B;QACE,IAAI,EAAE,QAAQ;QACd,IAAI,EAAE,QAAQ;QACd,WAAW,EAAE,aAAa;KAC3B;IACD;QACE,IAAI,EAAE,OAAO;QACb,IAAI,EAAE,OAAO;QACb,WAAW,EAAE,YAAY;KAC1B;IACD;QACE,IAAI,EAAE,YAAY;QAClB,IAAI,EAAE,YAAY;QAClB,WAAW,EAAE,iBAAiB;KAC/B;CACF,CAAA"}
package/dist/index.js ADDED
@@ -0,0 +1,246 @@
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
+ var __importDefault = (this && this.__importDefault) || function (mod) {
26
+ return (mod && mod.__esModule) ? mod : { "default": mod };
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ const dotenv_1 = __importDefault(require("dotenv"));
30
+ dotenv_1.default.config();
31
+ const yn_1 = __importDefault(require("./util/yn"));
32
+ const logger_1 = __importDefault(require("./util/logger"));
33
+ const mark = __importStar(require("./util/mark"));
34
+ const loaderRoles = __importStar(require("./loader/roles"));
35
+ const loaderRouter = __importStar(require("./loader/router"));
36
+ const fastify_1 = __importDefault(require("fastify"));
37
+ const swagger_1 = __importDefault(require("@fastify/swagger"));
38
+ const swagger_ui_1 = __importDefault(require("@fastify/swagger-ui"));
39
+ const cors_1 = __importDefault(require("@fastify/cors"));
40
+ const helmet_1 = __importDefault(require("@fastify/helmet"));
41
+ const compress_1 = __importDefault(require("@fastify/compress"));
42
+ const rate_limit_1 = __importDefault(require("@fastify/rate-limit"));
43
+ const server_1 = require("@apollo/server");
44
+ const fastify_2 = __importStar(require("@as-integrations/fastify"));
45
+ const context_1 = require("./apollo/context");
46
+ const resolvers_1 = __importDefault(require("./apollo/resolvers"));
47
+ const type_defs_1 = __importDefault(require("./apollo/type-defs"));
48
+ const begin = new Date().getTime();
49
+ mark.print(logger_1.default);
50
+ global.log = logger_1.default;
51
+ global.roles = loaderRoles.load();
52
+ async function attachApollo(fastify) {
53
+ log.info('Attach ApolloServer to Fastify');
54
+ const apollo = new server_1.ApolloServer({
55
+ typeDefs: type_defs_1.default,
56
+ resolvers: resolvers_1.default,
57
+ plugins: [(0, fastify_2.fastifyApolloDrainPlugin)(fastify)]
58
+ });
59
+ await apollo.start();
60
+ return apollo;
61
+ }
62
+ async function addApolloRouting(fastify, apollo) {
63
+ if (apollo) {
64
+ log.info('Add graphql routes');
65
+ await fastify.register((0, fastify_2.default)(apollo), {
66
+ context: context_1.myContextFunction
67
+ });
68
+ // // OR
69
+ // fastify.post(
70
+ // '/graphql-alt',
71
+ // fastifyApolloHandler(apollo, {
72
+ // context: myContextFunction
73
+ // })
74
+ // )
75
+ }
76
+ }
77
+ async function addFastifyRouting(fastify) {
78
+ log.info('Add fastify routes');
79
+ fastify.addHook('onSend', async (req, reply) => {
80
+ log.debug('onSend');
81
+ });
82
+ fastify.addHook('onResponse', async (req, reply) => {
83
+ log.debug('onResponse');
84
+ });
85
+ fastify.addHook('onTimeout', async (req, reply) => {
86
+ log.debug('onTimeout');
87
+ });
88
+ fastify.addHook('onReady', async () => {
89
+ log.debug('onReady');
90
+ });
91
+ fastify.addHook('onClose', async (instance) => {
92
+ log.debug('onClose');
93
+ });
94
+ fastify.addHook('onError', async (req, reply, error) => {
95
+ log.debug(`onError ${error}`);
96
+ });
97
+ fastify.addHook('onRequest', async (req, reply) => {
98
+ log.debug(`onRequest ${req.method} ${req.url}`);
99
+ req.user = {
100
+ id: 306,
101
+ name: 'Huseyin',
102
+ roles: ['admin', 'public']
103
+ };
104
+ });
105
+ fastify.addHook('preParsing', async (req) => {
106
+ log.debug(`preParsing ${req.method} ${req.url}`);
107
+ req.user = {
108
+ id: 42,
109
+ name: 'Jane Doe',
110
+ roles: ['admin', 'public']
111
+ };
112
+ });
113
+ const routes = loaderRouter.load();
114
+ routes && loaderRouter.apply(fastify, routes);
115
+ }
116
+ async function addFastifySwagger(fastify) {
117
+ const { NODE_ENV, SWAGGER, SWAGGER_TITLE, SWAGGER_DESCRIPTION, SWAGGER_VERSION } = process.env;
118
+ const loadSwagger = (0, yn_1.default)(SWAGGER, false);
119
+ if (loadSwagger && NODE_ENV !== 'production') {
120
+ log.info('Add swagger plugin');
121
+ await fastify.register(swagger_1.default, {
122
+ swagger: {
123
+ info: {
124
+ title: SWAGGER_TITLE || 'API Documentation',
125
+ description: SWAGGER_DESCRIPTION || 'List of available APIs and schemes to use',
126
+ version: SWAGGER_VERSION || '0.1.0'
127
+ },
128
+ consumes: ['application/json'],
129
+ produces: ['application/json']
130
+ }
131
+ });
132
+ await fastify.register(swagger_ui_1.default, {
133
+ routePrefix: '/documentation',
134
+ uiConfig: {
135
+ docExpansion: 'list',
136
+ deepLinking: true,
137
+ defaultModelsExpandDepth: 1
138
+ },
139
+ uiHooks: {
140
+ onRequest: function (request, reply, next) {
141
+ next();
142
+ },
143
+ preHandler: function (request, reply, next) {
144
+ next();
145
+ }
146
+ },
147
+ staticCSP: true,
148
+ transformStaticCSP: (header) => header
149
+ });
150
+ await fastify.put('/some-route/:id', {
151
+ schema: {
152
+ description: 'post some data',
153
+ tags: ['user', 'code'],
154
+ deprecated: true,
155
+ summary: 'qwerty',
156
+ params: {
157
+ type: 'object',
158
+ properties: {
159
+ id: {
160
+ type: 'string',
161
+ description: 'user id'
162
+ }
163
+ }
164
+ },
165
+ body: {
166
+ type: 'object',
167
+ properties: {
168
+ hello: { type: 'string' },
169
+ obj: {
170
+ type: 'object',
171
+ properties: {
172
+ some: { type: 'string' }
173
+ }
174
+ }
175
+ }
176
+ },
177
+ response: {
178
+ 201: {
179
+ description: 'Successful response',
180
+ type: 'object',
181
+ properties: {
182
+ hello: { type: 'string' }
183
+ }
184
+ },
185
+ default: {
186
+ description: 'Default response',
187
+ type: 'object',
188
+ properties: {
189
+ foo: { type: 'string' }
190
+ }
191
+ }
192
+ }
193
+ }
194
+ }, (req, reply) => { });
195
+ }
196
+ }
197
+ const opts = (0, yn_1.default)(process.env.LOG_FASTIFY, false) ? { logger: logger_1.default } : {};
198
+ (0, fastify_1.default)(opts).then(async (fastify) => {
199
+ const { HOST: host = '0.0.0.0', PORT: port = '2230', GRAPHQL } = process.env;
200
+ const { SRV_CORS, SRV_HELMET, SRV_RATELIMIT, SRV_COMPRESS } = process.env;
201
+ const loadApollo = (0, yn_1.default)(GRAPHQL, true);
202
+ const addPluginCors = (0, yn_1.default)(SRV_CORS, true);
203
+ const addPluginHelmet = (0, yn_1.default)(SRV_HELMET, true);
204
+ const addPluginRateLimit = (0, yn_1.default)(SRV_RATELIMIT, true);
205
+ const addPluginCompress = (0, yn_1.default)(SRV_COMPRESS, true);
206
+ log.t && log.trace(`Attach Apollo Server ${loadApollo}`);
207
+ log.t && log.trace(`Add plugin CORS: ${addPluginCors}`);
208
+ log.t && log.trace(`Add plugin HELMET: ${!loadApollo ? addPluginHelmet : 'Not usable with Apollo'}`);
209
+ log.t && log.trace(`Add plugin COMPRESS: ${addPluginCompress}`);
210
+ log.t && log.trace(`Add plugin RATELIMIT: ${addPluginRateLimit}`);
211
+ const apollo = loadApollo ? await attachApollo(fastify) : null;
212
+ // Helmet is not usable with Apollo Server
213
+ !loadApollo && addPluginHelmet && (await fastify.register(helmet_1.default));
214
+ // Usable with Apollo Server
215
+ addPluginRateLimit && (await fastify.register(rate_limit_1.default));
216
+ addPluginCors && (await fastify.register(cors_1.default));
217
+ addPluginCompress && (await fastify.register(compress_1.default));
218
+ await addFastifySwagger(fastify);
219
+ await addApolloRouting(fastify, apollo);
220
+ await addFastifyRouting(fastify);
221
+ fastify
222
+ .listen({
223
+ port: Number(port),
224
+ host: host
225
+ })
226
+ .then((address) => {
227
+ const elapsed = (new Date().getTime() - begin) / 100;
228
+ log.info(`All stuff loaded in ${elapsed} sec`);
229
+ log.info(`🚀 Server ready at ${address}`);
230
+ });
231
+ });
232
+ /**
233
+ * These export configurations enable JS and TS developers
234
+ * to consumer BE in whatever way best suits their needs.
235
+ * Some examples of supported import syntax includes:
236
+ * - `const server = require('@volcanicminds/backend')`
237
+ * - `const { server } = require('@volcanicminds/backend')`
238
+ * - `import * as Server from '@volcanicminds/backend'`
239
+ * - `import { server, TSC_definition } from '@volcanicminds/backend'`
240
+ * - `import server from '@volcanicminds/backend'`
241
+ * - `import server, { TSC_definition } from '@volcanicminds/backend'`
242
+ */
243
+ module.exports = this;
244
+ module.exports.server = this;
245
+ module.exports.default = this;
246
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../lib/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.load = void 0;
4
+ const roles_1 = require("../config/roles");
5
+ function load() {
6
+ const roles = {};
7
+ roles_1.roles.forEach((role) => {
8
+ roles[role.code] = role;
9
+ });
10
+ return { ...roles };
11
+ }
12
+ exports.load = load;
13
+ //# sourceMappingURL=roles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"roles.js","sourceRoot":"","sources":["../../lib/loader/roles.ts"],"names":[],"mappings":";;;AAAA,2CAAsD;AAEtD,SAAgB,IAAI;IAClB,MAAM,KAAK,GAEP,EAAE,CAAA;IAEN,aAAW,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;QAC3B,KAAK,CAAC,IAAI,CAAC,IAAe,CAAC,GAAG,IAAI,CAAA;IACpC,CAAC,CAAC,CAAA;IAEF,OAAO,EAAE,GAAG,KAAK,EAAW,CAAA;AAC9B,CAAC;AAVD,oBAUC"}
@@ -0,0 +1,148 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.apply = exports.load = void 0;
4
+ const glob = require('glob');
5
+ const path = require('path');
6
+ const methods = ['GET', 'POST', 'PUT', 'DELETE', 'HEAD', 'PATCH', 'OPTIONS'];
7
+ function load() {
8
+ const check = true, print = true, load = true;
9
+ const validRoutes = [];
10
+ const patterns = [`${__dirname}/../api/**/routes.{ts,js}`, `${process.cwd()}/src/api/**/routes.{ts,js}`];
11
+ patterns.forEach((pattern) => {
12
+ check && log.i && log.info('Looking for ' + pattern);
13
+ glob.sync(pattern).forEach((f, index, values) => {
14
+ const base = path.dirname(f);
15
+ const dir = path.basename(base);
16
+ const file = path.join(dir, path.basename(f));
17
+ // allow array or structure
18
+ const routesjs = require(f);
19
+ const { routes = [], config: defaultConfig = {} } = routesjs?.default;
20
+ // adjust default config
21
+ if (!defaultConfig.enable)
22
+ defaultConfig.enable = true;
23
+ if (defaultConfig.deprecated == null)
24
+ defaultConfig.deprecated = false;
25
+ if (defaultConfig.controller == null)
26
+ defaultConfig.controller = 'controller';
27
+ check && log.i && log.info(`Load ${file} with ${routes.length} routes defined`);
28
+ print && log.d && log.debug(`Valid routes loaded from ${file}`);
29
+ routes.forEach((route, index) => {
30
+ const errors = [];
31
+ const { method: methodCase, path: pathName = '/', handler, config, middlewares = [], roles = [] } = route;
32
+ // specific route config
33
+ const { title = '', description = '', enable = defaultConfig.enable || true, deprecated = defaultConfig.deprecated || false, version = defaultConfig.version || '', params, body, response } = config || {};
34
+ // adjust something
35
+ const endpoint = `${dir}${pathName.replace(/\/+$/, '')}`;
36
+ const method = methodCase.toUpperCase();
37
+ const num = index + 1;
38
+ const handlerParts = handler.split('.');
39
+ if (enable) {
40
+ if (!pathName.startsWith('/')) {
41
+ errors.push(`Error in [${file}] bad path [${pathName}] at route n. ${num}`);
42
+ }
43
+ if (!methods.includes(method)) {
44
+ errors.push(`Error in [${file}] bad method [${method}] at route n. ${num}`);
45
+ }
46
+ if (handlerParts.length !== 2) {
47
+ errors.push(`Error in [${file}] bad handler [${handler}] at route n. ${num}`);
48
+ }
49
+ const key = method + endpoint + version;
50
+ if (validRoutes.some((r) => `${r.method}${r.path}${r.doc?.version}` === key)) {
51
+ errors.push(`Error in [${file}] duplicated path [${pathName}] at route n. ${num}`);
52
+ }
53
+ if (errors.length > 0) {
54
+ check && log.e && errors.forEach((error) => log.error(error));
55
+ }
56
+ }
57
+ if (errors.length == 0) {
58
+ enable && print
59
+ ? log.d &&
60
+ log.debug(`* Method [${method}] path ${endpoint} handler ${handler}, has middleware? ${(middlewares && middlewares.length) || 'no'}`)
61
+ : !enable
62
+ ? log.w && log.warn(`* Method [${method}] path ${endpoint} handler ${handler} disabled. Skip.`)
63
+ : log.i && log.info(`* Method [${method}] path ${endpoint} handler ${handler} enabled.`);
64
+ validRoutes.push({
65
+ handler,
66
+ method,
67
+ path: '/' + endpoint,
68
+ middlewares,
69
+ roles,
70
+ enable,
71
+ base,
72
+ file: path.join(base, defaultConfig.controller, handlerParts[0]),
73
+ func: handlerParts[1],
74
+ // swagger
75
+ doc: {
76
+ summary: title,
77
+ description,
78
+ deprecated,
79
+ version,
80
+ params,
81
+ body,
82
+ response
83
+ }
84
+ });
85
+ }
86
+ });
87
+ });
88
+ });
89
+ return validRoutes;
90
+ }
91
+ exports.load = load;
92
+ function normalizeMiddlewarePath(base, middleware = '') {
93
+ const key = 'global.';
94
+ const idx = middleware.indexOf(key);
95
+ return idx == 0
96
+ ? path.resolve(__dirname + '/../middleware/' + middleware.substring(key.length))
97
+ : path.resolve(base + '/middleware/' + middleware);
98
+ }
99
+ function apply(server, routes) {
100
+ log.t && log.trace(`Apply ${routes.length} routes to server with pid ${process.pid}`);
101
+ routes.forEach(async ({ handler, method, path, middlewares, roles, enable, base, file, func, doc }) => {
102
+ if (enable) {
103
+ log.t && log.trace(`Add path ${method} ${path} on handle ${handler}`);
104
+ const allMiddlewares = middlewares?.length > 0 ? middlewares.map((m) => require(normalizeMiddlewarePath(base, m))) : [];
105
+ server.route({
106
+ method: method,
107
+ path: path,
108
+ schema: doc,
109
+ // preHandler: allMiddlewares,
110
+ handler: (request, reply) => {
111
+ try {
112
+ if (roles?.length > 0) {
113
+ const userRoles = request.user?.roles || [];
114
+ const resolvedRole = roles.filter((r) => userRoles.includes(r.code));
115
+ if (!resolvedRole || resolvedRole.length === 0) {
116
+ log.w && log.warn(`Not allowed to call ${method.toUpperCase()} ${path}`);
117
+ return reply.code(403).send();
118
+ }
119
+ }
120
+ return require(file + '.ts')[func](request, reply);
121
+ }
122
+ catch (err) {
123
+ log.e && log.error(`Cannot find ${file}.js or method ${func}: ${err}`);
124
+ return reply.code(500).send(`Invalid handler ${handler}`);
125
+ }
126
+ }
127
+ });
128
+ // server[method](path, (request: FastifyRequest, reply: FastifyReply) => {
129
+ // try {
130
+ // if (roles?.length > 0) {
131
+ // const userRoles = request.user?.roles || []
132
+ // const resolvedRole = roles.filter((r) => userRoles.includes(r.code))
133
+ // if (!resolvedRole || resolvedRole.length === 0) {
134
+ // log.w && log.warn(`Not allowed to call ${method.toUpperCase()} ${path}`)
135
+ // return reply.code(403).send()
136
+ // }
137
+ // }
138
+ // return require(file + '.ts')[func](request, reply)
139
+ // } catch (err) {
140
+ // log.e && log.error(`Cannot find ${file}.js or method ${func}: ${err}`)
141
+ // return reply.code(500).send(`Invalid handler ${handler}`)
142
+ // }
143
+ // })
144
+ }
145
+ });
146
+ }
147
+ exports.apply = apply;
148
+ //# sourceMappingURL=router.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"router.js","sourceRoot":"","sources":["../../lib/loader/router.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const log = global.log;
4
+ module.exports = (req, res, next) => {
5
+ try {
6
+ // TODO: do something and then you can throw an exception or call next()..
7
+ return next();
8
+ }
9
+ catch (err) {
10
+ log.e && log.error(`Upps, something just happened ${err}`);
11
+ res.code(403).send(err);
12
+ }
13
+ };
14
+ //# sourceMappingURL=example.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"example.js","sourceRoot":"","sources":["../../lib/middleware/example.ts"],"names":[],"mappings":";;AAEA,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,CAAA;AACtB,MAAM,CAAC,OAAO,GAAG,CAAC,GAAmB,EAAE,GAAiB,EAAE,IAAS,EAAE,EAAE;IACrE,IAAI;QACF,0EAA0E;QAC1E,OAAO,IAAI,EAAE,CAAA;KACd;IAAC,OAAO,GAAG,EAAE;QACZ,GAAG,CAAC,CAAC,IAAI,GAAG,CAAC,KAAK,CAAC,iCAAiC,GAAG,EAAE,CAAC,CAAA;QAC1D,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;KACxB;AACH,CAAC,CAAA"}
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const log = global.log;
4
+ module.exports = (req, res, next) => {
5
+ try {
6
+ if (!!req.user?.id && (req.user?.roles || []).includes(roles.admin.code)) {
7
+ log.d && log.trace('isAdmin - user id ' + req.user?.id);
8
+ return next();
9
+ }
10
+ throw new Error('User not valid');
11
+ }
12
+ catch (err) {
13
+ log.e && log.error(`Upps, something just happened ${err}`);
14
+ res.code(403).send(err);
15
+ }
16
+ };
17
+ //# sourceMappingURL=isAdmin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isAdmin.js","sourceRoot":"","sources":["../../lib/middleware/isAdmin.ts"],"names":[],"mappings":";;AAEA,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,CAAA;AACtB,MAAM,CAAC,OAAO,GAAG,CAAC,GAAmB,EAAE,GAAiB,EAAE,IAAS,EAAE,EAAE;IACrE,IAAI;QACF,IAAI,CAAC,CAAC,GAAG,CAAC,IAAI,EAAE,EAAE,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE;YACxE,GAAG,CAAC,CAAC,IAAI,GAAG,CAAC,KAAK,CAAC,oBAAoB,GAAG,GAAG,CAAC,IAAI,EAAE,EAAE,CAAC,CAAA;YACvD,OAAO,IAAI,EAAE,CAAA;SACd;QACD,MAAM,IAAI,KAAK,CAAC,gBAAgB,CAAC,CAAA;KAClC;IAAC,OAAO,GAAG,EAAE;QACZ,GAAG,CAAC,CAAC,IAAI,GAAG,CAAC,KAAK,CAAC,iCAAiC,GAAG,EAAE,CAAC,CAAA;QAC1D,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;KACxB;AACH,CAAC,CAAA"}
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const log = global.log;
4
+ module.exports = (req, res, next) => {
5
+ try {
6
+ // TODO: do something and then you can throw an exception or call next()..
7
+ if (!!req.user?.id) {
8
+ log.d && log.trace('isAuthenticated - user id ' + req.user?.id);
9
+ return next();
10
+ }
11
+ throw new Error('User not authenticated');
12
+ }
13
+ catch (err) {
14
+ log.e && log.error(`Upps, something just happened ${err}`);
15
+ res.code(403).send(err);
16
+ }
17
+ };
18
+ //# sourceMappingURL=isAuthenticated.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isAuthenticated.js","sourceRoot":"","sources":["../../lib/middleware/isAuthenticated.ts"],"names":[],"mappings":";;AAEA,MAAM,GAAG,GAAG,MAAM,CAAC,GAAG,CAAA;AACtB,MAAM,CAAC,OAAO,GAAG,CAAC,GAAmB,EAAE,GAAiB,EAAE,IAAS,EAAE,EAAE;IACrE,IAAI;QACF,0EAA0E;QAC1E,IAAI,CAAC,CAAC,GAAG,CAAC,IAAI,EAAE,EAAE,EAAE;YAClB,GAAG,CAAC,CAAC,IAAI,GAAG,CAAC,KAAK,CAAC,4BAA4B,GAAG,GAAG,CAAC,IAAI,EAAE,EAAE,CAAC,CAAA;YAC/D,OAAO,IAAI,EAAE,CAAA;SACd;QACD,MAAM,IAAI,KAAK,CAAC,wBAAwB,CAAC,CAAA;KAC1C;IAAC,OAAO,GAAG,EAAE;QACZ,GAAG,CAAC,CAAC,IAAI,GAAG,CAAC,KAAK,CAAC,iCAAiC,GAAG,EAAE,CAAC,CAAA;QAC1D,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;KACxB;AACH,CAAC,CAAA"}
@@ -0,0 +1,63 @@
1
+ 'use strict';
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ /**
7
+ * Minimal logger thanks to Pino
8
+ */
9
+ // log.debug('test log test log test log')
10
+ // log.error('test log test log test log')
11
+ // log.warn('test log test log test log')
12
+ // log.info('test log test log test log')
13
+ // log.fatal('test log test log test log')
14
+ // log.trace('test log test log test log')
15
+ const pino_1 = __importDefault(require("pino"));
16
+ const yn_1 = __importDefault(require("./yn"));
17
+ const logLevels = ['fatal', 'error', 'warn', 'info', 'debug', 'trace'];
18
+ const { LOG_LEVEL, LOG_COLORIZE, LOG_TIMESTAMP, LOG_TIMESTAMP_READABLE } = process.env;
19
+ function getLogLevel() {
20
+ const lvl = LOG_LEVEL?.toLowerCase();
21
+ return LOG_LEVEL && logLevels.includes(lvl) ? lvl : 'debug';
22
+ }
23
+ const logColorize = (0, yn_1.default)(LOG_COLORIZE, true);
24
+ const logTimestamp = (0, yn_1.default)(LOG_TIMESTAMP, true);
25
+ const logTimestampReadable = (0, yn_1.default)(LOG_TIMESTAMP_READABLE, true);
26
+ const loggerConfig = {
27
+ level: getLogLevel(),
28
+ timestamp: logTimestamp,
29
+ transport: {
30
+ target: 'pino-pretty',
31
+ options: {
32
+ translateTime: logTimestampReadable ? 'yyyymmdd HH:MM:ss.l' : false,
33
+ colorize: logColorize
34
+ }
35
+ }
36
+ };
37
+ let logger = (0, pino_1.default)(loggerConfig);
38
+ const logLevel = logger.levels.values[loggerConfig.level];
39
+ // Level: trace debug info warn error fatal silent
40
+ // Value: 10 20 30 40 50 60 Infinity
41
+ const loggerExt = Object.assign(logger, {
42
+ t: logLevel < 11,
43
+ d: logLevel < 21,
44
+ i: logLevel < 31,
45
+ w: logLevel < 41,
46
+ e: logLevel < 51,
47
+ f: logLevel < 61,
48
+ getLogLevel: getLogLevel,
49
+ loggerConfig: loggerConfig,
50
+ updateLevel: () => {
51
+ loggerExt.t = loggerExt.levelVal < 11;
52
+ loggerExt.d = loggerExt.levelVal < 21;
53
+ loggerExt.i = loggerExt.levelVal < 31;
54
+ loggerExt.w = loggerExt.levelVal < 41;
55
+ loggerExt.e = loggerExt.levelVal < 51;
56
+ loggerExt.f = loggerExt.levelVal < 61;
57
+ }
58
+ });
59
+ loggerExt.on('level-change', () => {
60
+ log.trace('Log level changed');
61
+ });
62
+ exports.default = loggerExt;
63
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../../lib/util/logger.ts"],"names":[],"mappings":"AAAA,YAAY,CAAA;;;;;AAEZ;;GAEG;AAEH,0CAA0C;AAC1C,0CAA0C;AAC1C,yCAAyC;AACzC,yCAAyC;AACzC,0CAA0C;AAC1C,0CAA0C;AAE1C,gDAAuB;AACvB,8CAAqB;AAErB,MAAM,SAAS,GAAG,CAAC,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,CAAC,CAAA;AAEtE,MAAM,EAAE,SAAS,EAAE,YAAY,EAAE,aAAa,EAAE,sBAAsB,EAAE,GAAG,OAAO,CAAC,GAAG,CAAA;AAEtF,SAAS,WAAW;IAClB,MAAM,GAAG,GAAG,SAAS,EAAE,WAAW,EAAE,CAAA;IACpC,OAAO,SAAS,IAAI,SAAS,CAAC,QAAQ,CAAC,GAAI,CAAC,CAAC,CAAC,CAAC,GAAI,CAAC,CAAC,CAAC,OAAO,CAAA;AAC/D,CAAC;AAED,MAAM,WAAW,GAAG,IAAA,YAAE,EAAC,YAAY,EAAE,IAAI,CAAC,CAAA;AAC1C,MAAM,YAAY,GAAG,IAAA,YAAE,EAAC,aAAa,EAAE,IAAI,CAAC,CAAA;AAC5C,MAAM,oBAAoB,GAAG,IAAA,YAAE,EAAC,sBAAsB,EAAE,IAAI,CAAC,CAAA;AAE7D,MAAM,YAAY,GAAG;IACnB,KAAK,EAAE,WAAW,EAAE;IACpB,SAAS,EAAE,YAAY;IACvB,SAAS,EAAE;QACT,MAAM,EAAE,aAAa;QACrB,OAAO,EAAE;YACP,aAAa,EAAE,oBAAoB,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,KAAK;YACnE,QAAQ,EAAE,WAAW;SACtB;KACF;CACF,CAAA;AAED,IAAI,MAAM,GAAG,IAAA,cAAI,EAAC,YAAY,CAAC,CAAA;AAC/B,MAAM,QAAQ,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,KAAK,CAAC,CAAA;AAEzD,kDAAkD;AAClD,oCAAoC;AAEpC,MAAM,SAAS,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE;IACtC,CAAC,EAAE,QAAQ,GAAG,EAAE;IAChB,CAAC,EAAE,QAAQ,GAAG,EAAE;IAChB,CAAC,EAAE,QAAQ,GAAG,EAAE;IAChB,CAAC,EAAE,QAAQ,GAAG,EAAE;IAChB,CAAC,EAAE,QAAQ,GAAG,EAAE;IAChB,CAAC,EAAE,QAAQ,GAAG,EAAE;IAChB,WAAW,EAAE,WAAW;IACxB,YAAY,EAAE,YAAY;IAC1B,WAAW,EAAE,GAAG,EAAE;QAChB,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC,QAAQ,GAAG,EAAE,CAAA;QACrC,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC,QAAQ,GAAG,EAAE,CAAA;QACrC,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC,QAAQ,GAAG,EAAE,CAAA;QACrC,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC,QAAQ,GAAG,EAAE,CAAA;QACrC,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC,QAAQ,GAAG,EAAE,CAAA;QACrC,SAAS,CAAC,CAAC,GAAG,SAAS,CAAC,QAAQ,GAAG,EAAE,CAAA;IACvC,CAAC;CACF,CAAC,CAAA;AAEF,SAAS,CAAC,EAAE,CAAC,cAAc,EAAE,GAAG,EAAE;IAChC,GAAG,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAA;AAChC,CAAC,CAAC,CAAA;AAEF,kBAAe,SAAS,CAAA"}
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.print = void 0;
4
+ const pkg = require('../../package.json');
5
+ /**
6
+ * Minimal mark printed at startup
7
+ */
8
+ function print(logg = log) {
9
+ logg.i && logg.info('Ciao');
10
+ logg.i && logg.info(` ,--. ,--. `);
11
+ logg.i && logg.info(`.--. ,--,---.| |,---.,--,--,--,--\\\`--',---. `);
12
+ logg.i && logg.info(` \\ '' | .-. | / .--' ,-. | ,--/ .--' `);
13
+ logg.i && logg.info(` \\ /' '-' | \\ \`--\\ '-' | || | \\ \`--. `);
14
+ logg.i && logg.info(` \`--' \`---'\`--'\`---'\`--\`--\`--''--\`--'\`---' `);
15
+ logg.i && logg.info('');
16
+ logg.t && logg.trace(`Package ${pkg.name}`);
17
+ logg.i && logg.info(`License ${pkg.license}`);
18
+ logg.i && logg.info(`Version ${pkg.version}`);
19
+ logg.i && logg.info(`Codename ${pkg.codename}`);
20
+ logg.i && logg.info(`Environment ${process.env.NODE_ENV}`);
21
+ logg.t && logg.trace(`Platform ${process.platform} ${process.arch}`);
22
+ logg.t && logg.trace(`Root path ${process.cwd()}`);
23
+ logg.t && logg.trace(`Node ${process.version}`);
24
+ logg.t && logg.trace(`Release ${JSON.stringify(process.release)}`);
25
+ logg.t && logg.trace(`Versions ${JSON.stringify(process.versions)}`);
26
+ }
27
+ exports.print = print;
28
+ //# sourceMappingURL=mark.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mark.js","sourceRoot":"","sources":["../../lib/util/mark.ts"],"names":[],"mappings":";;;AAAA,MAAM,GAAG,GAAG,OAAO,CAAC,oBAAoB,CAAC,CAAA;AAEzC;;GAEG;AAEH,SAAgB,KAAK,CAAC,OAAY,GAAG;IACnC,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;IAC3B,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,gDAAgD,CAAC,CAAA;IACrE,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,kDAAkD,CAAC,CAAA;IACvE,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,iDAAiD,CAAC,CAAA;IACtE,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,sDAAsD,CAAC,CAAA;IAC3E,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,yDAAyD,CAAC,CAAA;IAC9E,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAA;IACvB,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,CAAC,IAAI,EAAE,CAAC,CAAA;IAC3C,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,OAAO,EAAE,CAAC,CAAA;IAC7C,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,OAAO,EAAE,CAAC,CAAA;IAC7C,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAA;IAC/C,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,eAAe,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAA;IAC1D,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,YAAY,OAAO,CAAC,QAAQ,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC,CAAA;IACpE,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,aAAa,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAA;IAClD,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,OAAO,CAAC,OAAO,EAAE,CAAC,CAAA;IAC/C,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,WAAW,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,CAAA;IAClE,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,YAAY,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAA;AACtE,CAAC;AAlBD,sBAkBC"}
@@ -0,0 +1,17 @@
1
+ 'use strict';
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ function yn(value, defaultValue) {
4
+ if (value === undefined || value === null) {
5
+ return defaultValue;
6
+ }
7
+ const val = String(value).trim();
8
+ if (/^(?:y|yes|true|1|on)$/i.test(val)) {
9
+ return true;
10
+ }
11
+ if (/^(?:n|no|false|0|off)$/i.test(val)) {
12
+ return false;
13
+ }
14
+ return defaultValue || false;
15
+ }
16
+ exports.default = yn;
17
+ //# sourceMappingURL=yn.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"yn.js","sourceRoot":"","sources":["../../lib/util/yn.ts"],"names":[],"mappings":"AAAA,YAAY,CAAA;;AAEZ,SAAwB,EAAE,CAAC,KAAU,EAAE,YAAqB;IAC1D,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI,EAAE;QACzC,OAAO,YAAY,CAAA;KACpB;IAED,MAAM,GAAG,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,EAAE,CAAA;IAEhC,IAAI,wBAAwB,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE;QACtC,OAAO,IAAI,CAAA;KACZ;IAED,IAAI,yBAAyB,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE;QACvC,OAAO,KAAK,CAAA;KACb;IAED,OAAO,YAAY,IAAI,KAAK,CAAA;AAC9B,CAAC;AAhBD,qBAgBC"}
package/lib/index.ts CHANGED
@@ -252,4 +252,17 @@ Fastify(opts).then(async (fastify) => {
252
252
  })
253
253
  })
254
254
 
255
+ /**
256
+ * These export configurations enable JS and TS developers
257
+ * to consumer BE in whatever way best suits their needs.
258
+ * Some examples of supported import syntax includes:
259
+ * - `const server = require('@volcanicminds/backend')`
260
+ * - `const { server } = require('@volcanicminds/backend')`
261
+ * - `import * as Server from '@volcanicminds/backend'`
262
+ * - `import { server, TSC_definition } from '@volcanicminds/backend'`
263
+ * - `import server from '@volcanicminds/backend'`
264
+ * - `import server, { TSC_definition } from '@volcanicminds/backend'`
265
+ */
255
266
  module.exports = this
267
+ module.exports.server = this
268
+ module.exports.default = this
package/package.json CHANGED
@@ -1,11 +1,12 @@
1
1
  {
2
2
  "name": "@volcanicminds/backend",
3
- "version": "0.1.2",
3
+ "version": "0.1.4",
4
4
  "codename": "turin",
5
5
  "license": "MIT",
6
6
  "description": "The volcanic (minds) backend",
7
7
  "keywords": [],
8
- "main": "./lib/index.ts",
8
+ "main": "dist/index",
9
+ "typings": "dist/index",
9
10
  "engines": {
10
11
  "node": ">=16"
11
12
  },
package/tsconfig.json CHANGED
@@ -5,11 +5,11 @@
5
5
  "files": true
6
6
  },
7
7
  "compilerOptions": {
8
- "target": "es2022",
8
+ "target": "ESNext",
9
9
  "allowJs": true,
10
10
  "module": "CommonJS",
11
11
  "esModuleInterop": true,
12
- "lib": ["es2020"],
12
+ "lib": ["ES6"],
13
13
  "resolveJsonModule": true,
14
14
  "preserveConstEnums": true,
15
15
  "skipLibCheck": true /* Skip type checking of declaration files. */,
@@ -17,11 +17,15 @@
17
17
  "moduleResolution": "node",
18
18
  "allowSyntheticDefaultImports": true,
19
19
  "strict": true,
20
- // "sourceMap": true,
21
- // "types": ["node"],
20
+ "sourceMap": true,
21
+ "types": ["node"],
22
22
  "typeRoots": ["./node_modules/@types", "./types", "./lib/types"],
23
23
  "outDir": "dist",
24
- "rootDirs": ["lib", "config", "types"]
24
+ "rootDirs": ["lib", "config", "types"],
25
+ "baseUrl": ".",
26
+ "paths": {
27
+ "*": ["*", "components/*"]
28
+ }
25
29
  },
26
30
  "include": ["./lib/*", "./lib/**/*", "./config/*", "./config/**/*", "./types/*", "./types/**/*"],
27
31
  "exclude": ["node_modules"]
@@ -1,5 +1,3 @@
1
- export {}
2
-
3
1
  declare global {
4
2
  interface AuthenticatedUser {
5
3
  id: number
@@ -64,3 +62,5 @@ declare global {
64
62
  }
65
63
  }
66
64
  }
65
+
66
+ export { global }