zyket 1.0.2 → 1.0.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/README.md CHANGED
@@ -30,7 +30,7 @@ const { Handler } = require("zyket");
30
30
  module.exports = class MessageHandler extends Handler {
31
31
  middlewares = ["default"];
32
32
 
33
- async handle({ container, socket, data }) {
33
+ async handle({ container, socket, data, io }) {
34
34
  container.get("logger").info("Message handler");
35
35
  }
36
36
  };
@@ -48,7 +48,7 @@ Middlewares allow you to process data before it reaches the handler. They can be
48
48
  const { Middleware } = require("zyket");
49
49
 
50
50
  module.exports = class DefaultMiddleware extends Middleware {
51
- async handle({ container, socket }) {
51
+ async handle({ container, socket, io }) {
52
52
  container.get("logger").info("Default middleware");
53
53
  }
54
54
  };
package/bin/cli.js ADDED
@@ -0,0 +1,32 @@
1
+ const prompts = require('prompts');
2
+
3
+ (async () => {
4
+ process.stdout.write("\u001b[2J\u001b[0;0H");
5
+ const response = await prompts({
6
+ type: 'select',
7
+ name: 'value',
8
+ message: '[ZYKET] What do you want to do?',
9
+ choices: [
10
+ { title: 'Install Template', value: 'install-template', description: 'Install a new template', disabled: false },
11
+ { title: 'Remove Template', value: 'remove-template', description: 'Remove an existing template', disabled: false }
12
+ ],
13
+ initial: 0
14
+ });
15
+
16
+ const actions = {
17
+ 'install-template': async () => {
18
+ console.log('Installing template');
19
+ },
20
+ 'remove-template': async () => {
21
+ console.log('Removing template');
22
+ }
23
+ };
24
+
25
+ await actions[response.value]();
26
+
27
+ await new Promise((resolve) => {
28
+ setTimeout(() => {
29
+ resolve();
30
+ }, 2000);
31
+ });
32
+ })();
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "zyket",
3
- "version": "1.0.2",
3
+ "version": "1.0.4",
4
4
  "main": "index.js",
5
5
  "scripts": {
6
6
  "test": "echo \"Error: no test specified\" && exit 1"
@@ -16,6 +16,7 @@
16
16
  "mariadb": "^3.4.0",
17
17
  "minio": "^8.0.5",
18
18
  "node-dependency-injection": "^3.2.2",
19
+ "prompts": "^2.4.2",
19
20
  "redis": "^4.7.0",
20
21
  "sequelize": "^6.37.6",
21
22
  "socket.io": "^4.8.1"
@@ -18,7 +18,7 @@ module.exports = class Database extends Service {
18
18
 
19
19
  async boot() {
20
20
  this.#createModelsFolder();
21
- this.sequelize = new Sequelize(process.env.DATABASE_URL, {
21
+ this.sequelize = new Sequelize(this.#databaseUrl, {
22
22
  dialect: process.env.DATABASE_DIALECT || 'mariadb',
23
23
  logging: (msg) => this.#container.get('logger').debug(msg),
24
24
  operatorsAliases: 0,
@@ -1,10 +1,11 @@
1
- const Database = require("./Database");
2
- const Cache = require("./Cache");
3
- const S3 = require("./S3");
1
+ const Database = require("./database");
2
+ const Cache = require("./cache");
3
+ const S3 = require("./s3");
4
4
  const { SocketIO } = require("./socketio");
5
5
 
6
6
  module.exports = [
7
7
  ["logger", require("./Logger"), ["@service_container", process.env.LOG_DIRECTORY || `${process.cwd()}/logs`, process.env.DEBUG === "true"]],
8
+ ["template-manager", require("./template-manager"), ["@service_container"]],
8
9
  process.env.DATABASE_URL ? ["database", Database, ["@service_container", process.env.DATABASE_URL]] : null,
9
10
  process.env.CACHE_URL ? ["cache", Cache, ["@service_container", process.env.CACHE_URL]] : null,
10
11
  (process.env.S3_ENDPOINT && process.env.S3_ACCESS_KEY && process.env.S3_SECRET_KEY) ? ["s3", S3, ["@service_container", process.env.S3_ENDPOINT, process.env.S3_PORT, process.env.S3_USE_SSL === "true", process.env.S3_ACCESS_KEY, process.env.S3_SECRET_KEY]] : null,
@@ -40,9 +40,9 @@ module.exports = class SocketIO extends Service {
40
40
  this.#container.get('logger').warn(`You are using a middleware that does not exist`);
41
41
  continue;
42
42
  }
43
- middleware.handle({ container: this.#container, socket });
43
+ middleware.handle({ container: this.#container, socket, io: this.io });
44
44
  }
45
- connectionHandler.handle({ container: this.#container, socket });
45
+ connectionHandler.handle({ container: this.#container, socket, io: this.io });
46
46
  handlers.forEach((handler) => {
47
47
  const handlerMiddlewares = (handler?.middlewares || []).map(mdl => this.middlewares[mdl])
48
48
  socket.on(handler.event, async (data) => {
@@ -52,9 +52,9 @@ module.exports = class SocketIO extends Service {
52
52
  this.#container.get('logger').warn(`You are using a middleware that does not exist`);
53
53
  continue;
54
54
  }
55
- await middleware.handle({ container: this.#container, socket });
55
+ await middleware.handle({ container: this.#container, socket, io: this.io });
56
56
  }
57
- return await handler.handle({ container: this.#container, socket, data });
57
+ return await handler.handle({ container: this.#container, socket, data, io: this.io });
58
58
  });
59
59
  });
60
60
  });
@@ -65,15 +65,8 @@ module.exports = class SocketIO extends Service {
65
65
 
66
66
  async #loadConnectionHandler() {
67
67
  const connectionHandlerExists = fs.existsSync(path.join(process.cwd(), "src", "handlers", "connection.js"));
68
- /* if exists require, otherwise create a default one */
69
68
  if(!connectionHandlerExists) {
70
- fs.writeFileSync(path.join(process.cwd(), "src", "handlers", "connection.js"), `const { Handler } = require("zyket");
71
-
72
- module.exports = class ConnectionHandler extends Handler {
73
- async handle({ container, socket }) {
74
- container.get("logger").info("New connection");
75
- }
76
- };`);
69
+ this.#container.get('template-manager').installFile('default/src/handlers/connection', path.join(process.cwd(), "src", "handlers", "connection.js"));
77
70
  }
78
71
  return require(path.join(process.cwd(), "src", "handlers", "connection.js"));
79
72
  }
@@ -94,16 +87,7 @@ module.exports = class ConnectionHandler extends Handler {
94
87
  if (fs.existsSync(handlersFolder) && !overwrite) return;
95
88
  this.#container.get('logger').info(`Creating handlers folder at ${handlersFolder}`);
96
89
  fs.mkdirSync(handlersFolder);
97
- // create a default handler
98
- fs.writeFileSync(path.join(handlersFolder, "message.js"), `const { Handler } = require("zyket");
99
- module.exports = class MessageHandler extends Handler {
100
- event = "message";
101
- middlewares = ["default"];
102
-
103
- async handle({ container, socket, data }) {
104
- container.get("logger").info("Message handler");
105
- }
106
- };`);
90
+ this.#container.get('template-manager').installFile('default/src/handlers/message', path.join(handlersFolder, "message.js"));
107
91
  }
108
92
 
109
93
  async #loadMiddlewaresFromFolder(middlewaresFolder) {
@@ -123,13 +107,7 @@ module.exports = class MessageHandler extends Handler {
123
107
  if (fs.existsSync(middlewaresFolder) && !overwrite) return;
124
108
  this.#container.get('logger').info(`Creating middlewares folder at ${middlewaresFolder}`);
125
109
  fs.mkdirSync(middlewaresFolder);
126
- // create a default middleware
127
- fs.writeFileSync(path.join(middlewaresFolder, "default.js"), `const { Middleware } = require("zyket");
128
- module.exports = class DefaultMiddleware extends Middleware {
129
- async handle({ container, socket }) {
130
- container.get("logger").info("Default middleware");
131
- }
132
- };`);
110
+ this.#container.get('template-manager').installFile('default/src/middlewares/default', path.join(middlewaresFolder, "default.js"));
133
111
  }
134
112
 
135
113
  stop() {
@@ -0,0 +1,67 @@
1
+ const fg = require('fast-glob');
2
+ const Service = require('../Service');
3
+ const path = require('path');
4
+ const fs = require('fs');
5
+
6
+ module.exports = class TemplateManager extends Service {
7
+ #container;
8
+ templates = {}
9
+
10
+ constructor(container) {
11
+ super('template-manager');
12
+ this.#container = container;
13
+ }
14
+
15
+ async boot() {
16
+ const zyketTemplates = await fg(['**/*.js'], {
17
+ cwd: path.join(__dirname, '../../templates'),
18
+ });
19
+ for (const template of zyketTemplates) {
20
+ // need to copy full file and relation with the name on templates variable
21
+ const templatePath = path.join(__dirname, '../../templates', template);
22
+ const templateContent = fs.readFileSync(templatePath, 'utf-8');
23
+ this.templates[template.replace('.js', '')] = templateContent;
24
+ }
25
+
26
+ this.#container.get('logger').info(`Loaded ${this.templates.length} templates`);
27
+ }
28
+
29
+ installFile(fileName, location) {
30
+ const template = this.templates[fileName];
31
+ if (!template) throw new Error(`Template ${fileName} not found`);
32
+ return fs.writeFileSync(location, template);
33
+ }
34
+
35
+ installTemplate(templateName) {
36
+ const template = this.getTemplates().find((t) => t === templateName);
37
+ if (!template) throw new Error(`Template ${templateName} not found`);
38
+ const files = this.getTemplate(templateName);
39
+
40
+ for (const file of files) {
41
+ const fileName = file.split('/').slice(1).join('/');
42
+ const fileLocation = path.join(process.cwd(), fileName);
43
+ if (fs.existsSync(fileLocation)) throw new Error(`File ${file} already exists`);
44
+ }
45
+
46
+ for (const file of files) {
47
+ const fileName = file.split('/').slice(1).join('/');
48
+ const template = this.templates[file];
49
+ const fileLocation = path.join(process.cwd(), fileName);
50
+ fs.writeFileSync(fileLocation, template);
51
+ }
52
+ }
53
+
54
+ getTemplates() {
55
+ const uniqueTemplates = new Set();
56
+ for (const template of Object.keys(this.templates)) {
57
+ uniqueTemplates.add(template.split('/')[0]);
58
+ }
59
+ return Array.from(uniqueTemplates);
60
+ }
61
+
62
+ getTemplate(templateName) {
63
+ const files = Object.keys(this.templates).filter((t) => t.startsWith(templateName));
64
+ if (files.length === 0) throw new Error(`Template ${templateName} not found`);
65
+ return files
66
+ }
67
+ }
File without changes
File without changes
@@ -0,0 +1,7 @@
1
+ const { Handler } = require("zyket");
2
+
3
+ module.exports = class ConnectionHandler extends Handler {
4
+ async handle({ container, socket, io }) {
5
+ container.get("logger").info("New connection");
6
+ }
7
+ };
@@ -0,0 +1,9 @@
1
+ const { Handler } = require("zyket");
2
+
3
+ module.exports = class MessageHandler extends Handler {
4
+ middlewares = ["default"];
5
+
6
+ async handle({ container, socket, data, io }) {
7
+ container.get("logger").info("Message handler");
8
+ }
9
+ };
@@ -0,0 +1,6 @@
1
+ const { Middleware } = require("zyket");
2
+ module.exports = class DefaultMiddleware extends Middleware {
3
+ async handle({ container, socket, io }) {
4
+ container.get("logger").info("Default middleware");
5
+ }
6
+ };