underpost 2.7.1 → 2.7.2

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.
Files changed (213) hide show
  1. package/.dockerignore +13 -13
  2. package/.env.development +7 -7
  3. package/.env.production +7 -7
  4. package/.env.test +7 -7
  5. package/.github/workflows/publish.yml +26 -0
  6. package/.nycrc +9 -9
  7. package/.prettierignore +12 -12
  8. package/.prettierrc +9 -9
  9. package/.vscode/extensions.json +72 -72
  10. package/.vscode/settings.json +100 -99
  11. package/Dockerfile +89 -89
  12. package/LICENSE +21 -21
  13. package/README.md +96 -96
  14. package/bin/db.js +172 -119
  15. package/bin/deploy.js +582 -661
  16. package/bin/dns.js +1 -1
  17. package/bin/file.js +92 -92
  18. package/bin/index.js +53 -53
  19. package/bin/install.js +398 -357
  20. package/bin/shortcut.js +44 -44
  21. package/bin/ssl.js +65 -64
  22. package/bin/util.js +182 -182
  23. package/bin/vs.js +35 -35
  24. package/conf.js +251 -249
  25. package/docker-compose.yml +67 -67
  26. package/jsconfig.json +7 -7
  27. package/jsdoc.json +32 -32
  28. package/nodemon.json +6 -6
  29. package/package.json +137 -132
  30. package/prometheus.yml +36 -36
  31. package/setup.sh +24 -24
  32. package/src/api/core/core.controller.js +69 -69
  33. package/src/api/core/core.model.js +11 -11
  34. package/src/api/core/core.router.js +23 -23
  35. package/src/api/core/core.service.js +29 -29
  36. package/src/api/crypto/crypto.controller.js +51 -51
  37. package/src/api/crypto/crypto.model.js +23 -23
  38. package/src/api/crypto/crypto.router.js +20 -20
  39. package/src/api/crypto/crypto.service.js +64 -64
  40. package/src/api/default/default.controller.js +69 -69
  41. package/src/api/default/default.model.js +20 -20
  42. package/src/api/default/default.router.js +23 -23
  43. package/src/api/default/default.service.js +31 -31
  44. package/src/api/file/file.controller.js +53 -51
  45. package/src/api/file/file.model.js +19 -19
  46. package/src/api/file/file.router.js +21 -20
  47. package/src/api/file/file.service.js +76 -70
  48. package/src/api/instance/instance.controller.js +69 -69
  49. package/src/api/instance/instance.model.js +36 -36
  50. package/src/api/instance/instance.router.js +33 -33
  51. package/src/api/instance/instance.service.js +48 -48
  52. package/src/api/test/test.controller.js +59 -59
  53. package/src/api/test/test.model.js +14 -14
  54. package/src/api/test/test.router.js +21 -21
  55. package/src/api/test/test.service.js +35 -35
  56. package/src/api/user/user.build.js +16 -0
  57. package/src/api/user/user.controller.js +70 -70
  58. package/src/api/user/user.model.js +65 -65
  59. package/src/api/user/user.router.js +345 -345
  60. package/src/api/user/user.service.js +479 -479
  61. package/src/api.js +23 -23
  62. package/src/client/Default.index.js +40 -40
  63. package/src/client/components/core/Account.js +290 -290
  64. package/src/client/components/core/AgGrid.js +160 -160
  65. package/src/client/components/core/Auth.js +19 -19
  66. package/src/client/components/core/Badge.js +32 -32
  67. package/src/client/components/core/BlockChain.js +41 -41
  68. package/src/client/components/core/Blog.js +9 -9
  69. package/src/client/components/core/BtnIcon.js +101 -94
  70. package/src/client/components/core/CalendarCore.js +458 -319
  71. package/src/client/components/core/Chat.js +64 -64
  72. package/src/client/components/core/ColorPalette.js +5267 -5267
  73. package/src/client/components/core/CommonJs.js +735 -732
  74. package/src/client/components/core/Content.js +193 -49
  75. package/src/client/components/core/Css.js +1064 -1027
  76. package/src/client/components/core/CssCore.js +817 -796
  77. package/src/client/components/core/D3Chart.js +44 -44
  78. package/src/client/components/core/Docs.js +229 -229
  79. package/src/client/components/core/DropDown.js +164 -164
  80. package/src/client/components/core/EventsUI.js +46 -54
  81. package/src/client/components/core/FileExplorer.js +699 -624
  82. package/src/client/components/core/FullScreen.js +45 -45
  83. package/src/client/components/core/Input.js +346 -259
  84. package/src/client/components/core/JoyStick.js +77 -77
  85. package/src/client/components/core/Keyboard.js +73 -73
  86. package/src/client/components/core/LoadingAnimation.js +179 -157
  87. package/src/client/components/core/LogIn.js +187 -181
  88. package/src/client/components/core/LogOut.js +58 -52
  89. package/src/client/components/core/Logger.js +26 -26
  90. package/src/client/components/core/Modal.js +1612 -1596
  91. package/src/client/components/core/NotificationManager.js +84 -84
  92. package/src/client/components/core/Panel.js +613 -413
  93. package/src/client/components/core/PanelForm.js +468 -0
  94. package/src/client/components/core/Polyhedron.js +162 -162
  95. package/src/client/components/core/Recover.js +204 -204
  96. package/src/client/components/core/Responsive.js +53 -53
  97. package/src/client/components/core/RichText.js +51 -27
  98. package/src/client/components/core/Router.js +76 -77
  99. package/src/client/components/core/Scroll.js +34 -0
  100. package/src/client/components/core/SignUp.js +125 -125
  101. package/src/client/components/core/SocketIo.js +72 -72
  102. package/src/client/components/core/Stream.js +113 -113
  103. package/src/client/components/core/ToggleSwitch.js +87 -87
  104. package/src/client/components/core/ToolTip.js +26 -26
  105. package/src/client/components/core/Translate.js +437 -408
  106. package/src/client/components/core/Validator.js +100 -100
  107. package/src/client/components/core/VanillaJs.js +460 -457
  108. package/src/client/components/core/Wallet.js +106 -106
  109. package/src/client/components/core/Webhook.js +25 -25
  110. package/src/client/components/core/Worker.js +272 -272
  111. package/src/client/components/default/CommonDefault.js +29 -29
  112. package/src/client/components/default/CssDefault.js +13 -13
  113. package/src/client/components/default/ElementsDefault.js +38 -38
  114. package/src/client/components/default/LogInDefault.js +41 -41
  115. package/src/client/components/default/LogOutDefault.js +28 -28
  116. package/src/client/components/default/MenuDefault.js +389 -389
  117. package/src/client/components/default/RoutesDefault.js +48 -48
  118. package/src/client/components/default/SettingsDefault.js +16 -16
  119. package/src/client/components/default/SignUpDefault.js +9 -9
  120. package/src/client/components/default/SocketIoDefault.js +54 -54
  121. package/src/client/components/default/TranslateDefault.js +7 -7
  122. package/src/client/public/default/assets/mailer/api-user-check.png +0 -0
  123. package/src/client/public/default/assets/mailer/api-user-invalid-token.png +0 -0
  124. package/src/client/public/default/assets/mailer/api-user-recover.png +0 -0
  125. package/src/client/public/default/browserconfig.xml +11 -11
  126. package/src/client/public/default/manifest.webmanifest +68 -68
  127. package/src/client/public/default/plantuml/client-conf.svg +1 -0
  128. package/src/client/public/default/plantuml/client-schema.svg +1 -0
  129. package/src/client/public/default/plantuml/cron-conf.svg +1 -0
  130. package/src/client/public/default/plantuml/cron-schema.svg +1 -0
  131. package/src/client/public/default/plantuml/server-conf.svg +1 -0
  132. package/src/client/public/default/plantuml/server-schema.svg +1 -0
  133. package/src/client/public/default/plantuml/ssr-conf.svg +1 -0
  134. package/src/client/public/default/plantuml/ssr-schema.svg +1 -0
  135. package/src/client/public/default/sitemap +147 -147
  136. package/src/client/public/default/yandex-browser-manifest.json +8 -8
  137. package/src/client/public/doc/sitemap +147 -147
  138. package/src/client/public/test/sitemap +147 -147
  139. package/src/client/services/core/core.service.js +170 -152
  140. package/src/client/services/crypto/crypto.service.js +70 -70
  141. package/src/client/services/default/default.management.js +345 -345
  142. package/src/client/services/default/default.service.js +89 -89
  143. package/src/client/services/file/file.service.js +70 -70
  144. package/src/client/services/instance/instance.management.js +74 -74
  145. package/src/client/services/instance/instance.service.js +89 -89
  146. package/src/client/services/test/test.service.js +70 -70
  147. package/src/client/services/user/user.management.js +50 -50
  148. package/src/client/services/user/user.service.js +89 -89
  149. package/src/client/ssr/Render.js +16 -16
  150. package/src/client/ssr/body-components/CacheControl.js +114 -113
  151. package/src/client/ssr/body-components/DefaultSplashScreen.js +79 -79
  152. package/src/client/ssr/email-components/DefaultRecoverEmail.js +21 -21
  153. package/src/client/ssr/email-components/DefaultVerifyEmail.js +17 -17
  154. package/src/client/ssr/head-components/Css.js +241 -241
  155. package/src/client/ssr/head-components/DefaultScripts.js +3 -3
  156. package/src/client/ssr/head-components/Microdata.js +11 -11
  157. package/src/client/ssr/head-components/Production.js +1 -1
  158. package/src/client/ssr/head-components/PwaDefault.js +59 -59
  159. package/src/client/ssr/head-components/Seo.js +14 -14
  160. package/src/client/sw/default.sw.js +201 -201
  161. package/src/client/sw/template.sw.js +84 -84
  162. package/src/client.build.js +22 -22
  163. package/src/client.dev.js +21 -21
  164. package/src/cron.js +25 -25
  165. package/src/db/DataBaseProvider.js +34 -34
  166. package/src/db/mariadb/MariaDB.js +33 -33
  167. package/src/db/mongo/MongooseDB.js +46 -46
  168. package/src/dns.js +22 -22
  169. package/src/index.js +42 -29
  170. package/src/mailer/EmailRender.js +69 -69
  171. package/src/mailer/MailerProvider.js +96 -96
  172. package/src/proxy.js +22 -22
  173. package/src/runtime/lampp/Lampp.js +69 -44
  174. package/src/runtime/nginx/Nginx.js +3 -3
  175. package/src/runtime/xampp/Xampp.js +49 -49
  176. package/src/server/auth.js +235 -204
  177. package/src/server/backup.js +101 -94
  178. package/src/server/client-build-live.js +72 -72
  179. package/src/server/client-build.js +705 -699
  180. package/src/server/client-dev-server.js +60 -58
  181. package/src/server/client-formatted.js +48 -48
  182. package/src/server/client-icons.js +149 -150
  183. package/src/server/conf.js +860 -611
  184. package/src/server/dns.js +98 -98
  185. package/src/server/downloader.js +42 -42
  186. package/src/server/logger.js +180 -180
  187. package/src/server/network.js +122 -122
  188. package/src/server/peer.js +33 -33
  189. package/src/server/process.js +66 -66
  190. package/src/server/prompt-optimizer.js +28 -28
  191. package/src/server/proxy.js +118 -118
  192. package/src/server/runtime.js +444 -393
  193. package/src/server/ssl.js +109 -107
  194. package/src/server.js +25 -25
  195. package/src/ws/IoInterface.js +45 -45
  196. package/src/ws/IoServer.js +39 -39
  197. package/src/ws/core/channels/core.ws.chat.js +23 -23
  198. package/src/ws/core/channels/core.ws.mailer.js +35 -35
  199. package/src/ws/core/channels/core.ws.stream.js +31 -31
  200. package/src/ws/core/core.ws.connection.js +28 -28
  201. package/src/ws/core/core.ws.emit.js +14 -14
  202. package/src/ws/core/core.ws.server.js +24 -24
  203. package/src/ws/core/management/core.ws.chat.js +8 -8
  204. package/src/ws/core/management/core.ws.mailer.js +16 -16
  205. package/src/ws/core/management/core.ws.stream.js +8 -8
  206. package/src/ws/default/channels/default.ws.main.js +16 -16
  207. package/src/ws/default/default.ws.connection.js +22 -22
  208. package/src/ws/default/default.ws.emit.js +14 -14
  209. package/src/ws/default/default.ws.server.js +20 -20
  210. package/src/ws/default/management/default.ws.main.js +8 -8
  211. package/startup.js +11 -11
  212. package/supervisord-openssh-server.conf +4 -4
  213. package/test/api.test.js +60 -60
package/bin/shortcut.js CHANGED
@@ -1,44 +1,44 @@
1
- import fs from 'fs';
2
- import { getRootDirectory, shellExec } from '../src/server/process.js';
3
- import os from 'os';
4
-
5
- const [exe, dir, oS, env] = process.argv;
6
-
7
- switch (oS) {
8
- case 'windows':
9
- switch (env) {
10
- case 'development':
11
- (() => {
12
- const desktopDir = `${os.homedir()}/desktop`.replaceAll('\\', '/');
13
- fs.writeFileSync(
14
- `./bin/shortcut.ps1`,
15
- `
16
- $DesktopPath = [Environment]::GetFolderPath("Desktop") + "/${env}-engine.lnk"
17
-
18
- $WshShell = New-Object -comObject WScript.Shell
19
-
20
- $Shortcut = $WshShell.CreateShortcut($DesktopPath)
21
-
22
- $Shortcut.TargetPath = "cmd.exe"
23
-
24
- $Shortcut.Arguments = "PowerShell Start-Process cmd -Verb RunAs -ArgumentList '/k cd ${getRootDirectory()} && npm run dev"
25
-
26
- $Shortcut.IconLocation = "${getRootDirectory()}/src/client/public/doc/favicon.ico"
27
-
28
- $Shortcut.Save()
29
- `,
30
- );
31
- shellExec(`PowerShell bin/shortcut.ps1`);
32
- fs.unlinkSync(`./bin/shortcut.ps1`);
33
- })();
34
- break;
35
-
36
- default:
37
- break;
38
- }
39
-
40
- break;
41
-
42
- default:
43
- break;
44
- }
1
+ import fs from 'fs';
2
+ import { getRootDirectory, shellExec } from '../src/server/process.js';
3
+ import os from 'os';
4
+
5
+ const [exe, dir, oS, env] = process.argv;
6
+
7
+ switch (oS) {
8
+ case 'windows':
9
+ switch (env) {
10
+ case 'development':
11
+ (() => {
12
+ const desktopDir = `${os.homedir()}/desktop`.replaceAll('\\', '/');
13
+ fs.writeFileSync(
14
+ `./bin/shortcut.ps1`,
15
+ `
16
+ $DesktopPath = [Environment]::GetFolderPath("Desktop") + "/${env}-engine.lnk"
17
+
18
+ $WshShell = New-Object -comObject WScript.Shell
19
+
20
+ $Shortcut = $WshShell.CreateShortcut($DesktopPath)
21
+
22
+ $Shortcut.TargetPath = "cmd.exe"
23
+
24
+ $Shortcut.Arguments = "PowerShell Start-Process cmd -Verb RunAs -ArgumentList '/k cd ${getRootDirectory()} && npm run dev"
25
+
26
+ $Shortcut.IconLocation = "${getRootDirectory()}/src/client/public/doc/favicon.ico"
27
+
28
+ $Shortcut.Save()
29
+ `,
30
+ );
31
+ shellExec(`PowerShell bin/shortcut.ps1`);
32
+ fs.unlinkSync(`./bin/shortcut.ps1`);
33
+ })();
34
+ break;
35
+
36
+ default:
37
+ break;
38
+ }
39
+
40
+ break;
41
+
42
+ default:
43
+ break;
44
+ }
package/bin/ssl.js CHANGED
@@ -1,64 +1,65 @@
1
- import fs from 'fs';
2
- import read from 'read';
3
- import ncp from 'copy-paste';
4
- import dotenv from 'dotenv';
5
-
6
- import { getRootDirectory } from '../src/server/process.js';
7
- import { loggerFactory } from '../src/server/logger.js';
8
- import { loadConf } from '../src/server/conf.js';
9
- import { buildSSL } from '../src/server/ssl.js';
10
-
11
- dotenv.config();
12
-
13
- const logger = loggerFactory(import.meta);
14
-
15
- await logger.setUpInfo();
16
-
17
- // usage
18
- // node bin/ssl windows <deploy-id> www.example.com
19
-
20
- const [exe, dir, os, deployId, hosts] = process.argv;
21
-
22
- try {
23
- let cmd;
24
- await loadConf(deployId);
25
- const confServer = JSON.parse(fs.readFileSync(`./conf/conf.server.json`, 'utf8'));
26
- for (const host of hosts.split(',')) {
27
- if (host in confServer) {
28
- const directory = confServer[host]['/']?.['directory'] ? confServer[host]['/']['directory'] : undefined;
29
- cmd = `certbot certonly --webroot --webroot-path ${
30
- directory ? directory : `${getRootDirectory()}/public/${host}`
31
- } -d ${host}`;
32
- // directory ? directory : `${getRootDirectory()}/public/${host}`
33
- // directory ? directory : `${getRootDirectory()}/public/www.${host.split('.').slice(-2).join('.')}`
34
-
35
- // You can get multi domain cert by specifying (extra) -d
36
- // For example
37
- // certbot -d example.com -d example.net -d www.example.org
38
-
39
- // delete all file (no increment live folder)
40
- // certbot delete --cert-name <domain>
41
-
42
- logger.info(`Run the following command`, cmd);
43
- await ncp.copy(cmd);
44
- await read({ prompt: 'Command copy to clipboard, press enter to continue.\n' });
45
- // Certificate
46
- switch (os) {
47
- case 'windows':
48
- await buildSSL(host);
49
- break;
50
-
51
- default:
52
- break;
53
- }
54
- logger.info('Certificate saved', host);
55
- } else throw new Error(`host not found: ${host}`);
56
- }
57
-
58
- cmd = `certbot renew --dry-run`;
59
- await ncp.copy(cmd);
60
- logger.info(`run the following command for renewal. Command copy to clipboard`, cmd);
61
- logger.info(`success install SLL`, hosts);
62
- } catch (error) {
63
- logger.error(error, error.stack);
64
- }
1
+ import fs from 'fs';
2
+ import read from 'read';
3
+ import ncp from 'copy-paste';
4
+ import dotenv from 'dotenv';
5
+
6
+ import { getRootDirectory, shellExec } from '../src/server/process.js';
7
+ import { loggerFactory } from '../src/server/logger.js';
8
+ import { Cmd, loadConf } from '../src/server/conf.js';
9
+ import { buildSSL } from '../src/server/ssl.js';
10
+
11
+ dotenv.config();
12
+
13
+ const logger = loggerFactory(import.meta);
14
+
15
+ await logger.setUpInfo();
16
+
17
+ // usage
18
+ // node bin/ssl windows <deploy-id> www.example.com
19
+
20
+ const [exe, dir, os, deployId, hosts] = process.argv;
21
+
22
+ try {
23
+ let cmd;
24
+ await loadConf(deployId);
25
+ shellExec(Cmd.conf(deployId));
26
+ const confServer = JSON.parse(fs.readFileSync(`./conf/conf.server.json`, 'utf8'));
27
+ for (const host of hosts.split(',')) {
28
+ if (host in confServer) {
29
+ const directory = confServer[host]['/']?.['directory'] ? confServer[host]['/']['directory'] : undefined;
30
+ cmd = `certbot certonly --webroot --webroot-path ${
31
+ directory ? directory : `${getRootDirectory()}/public/${host}`
32
+ } -d ${host}`;
33
+ // directory ? directory : `${getRootDirectory()}/public/${host}`
34
+ // directory ? directory : `${getRootDirectory()}/public/www.${host.split('.').slice(-2).join('.')}`
35
+
36
+ // You can get multi domain cert by specifying (extra) -d
37
+ // For example
38
+ // certbot -d example.com -d example.net -d www.example.org
39
+
40
+ // delete all file (no increment live folder)
41
+ // certbot delete --cert-name <domain>
42
+
43
+ logger.info(`Run the following command`, cmd);
44
+ await ncp.copy(cmd);
45
+ await read({ prompt: 'Command copy to clipboard, press enter to continue.\n' });
46
+ // Certificate
47
+ switch (os) {
48
+ case 'windows':
49
+ await buildSSL(host);
50
+ break;
51
+
52
+ default:
53
+ break;
54
+ }
55
+ logger.info('Certificate saved', host);
56
+ } else throw new Error(`host not found: ${host}`);
57
+ }
58
+
59
+ cmd = `certbot renew --dry-run`;
60
+ await ncp.copy(cmd);
61
+ logger.info(`run the following command for renewal. Command copy to clipboard`, cmd);
62
+ logger.info(`success install SLL`, hosts);
63
+ } catch (error) {
64
+ logger.error(error, error.stack);
65
+ }
package/bin/util.js CHANGED
@@ -1,182 +1,182 @@
1
- import fs from 'fs-extra';
2
- import merge from 'deepmerge';
3
- import si from 'systeminformation';
4
- import * as dir from 'path';
5
- import { svg } from 'font-awesome-assets';
6
-
7
- import { loggerFactory } from '../src/server/logger.js';
8
- import { shellCd, shellExec } from '../src/server/process.js';
9
- import { range, s4 } from '../src/client/components/core/CommonJs.js';
10
- import { network } from '../src/server/network.js';
11
- import { Config } from '../src/server/conf.js';
12
- import { FileFactory } from '../src/api/file/file.service.js';
13
- import { buildTextImg, faBase64Png, getBufferPngText } from '../src/server/client-icons.js';
14
-
15
- const logger = loggerFactory(import.meta);
16
-
17
- logger.info('argv', process.argv);
18
-
19
- const operator = process.argv[2];
20
-
21
- try {
22
- // let cmd;
23
- switch (operator) {
24
- case 'cls':
25
- fs.removeSync('./public');
26
- fs.removeSync('./logs');
27
- fs.removeSync('./conf');
28
- // fs.removeSync('./engine-private');
29
- // fs.removeSync('./node_modules');
30
- break;
31
- case 'log':
32
- (() => {
33
- const logPath = `./logs/${process.argv[3]}/${process.argv[4]}.log`;
34
- logger.info('Read', logPath);
35
- console.log(fs.readFileSync(logPath, 'utf8'));
36
- })();
37
- break;
38
- case 'kill-ports':
39
- if (!process.argv[3]) process.argv[3] = '22,80,443,3000-3020';
40
- for (const port of process.argv[3].split(',')) {
41
- const rangePort = port.split('-');
42
- if (rangePort[1])
43
- for (const port of range(parseInt(rangePort[0]), parseInt(rangePort[1]))) {
44
- logger.info('clean port', port);
45
- await network.port.portClean(port);
46
- }
47
- else {
48
- logger.info('clean port', parseInt(port));
49
- await network.port.portClean(port);
50
- }
51
- }
52
- break;
53
- case 'system-info':
54
- await (async () => {
55
- for (const infoKey of Object.keys(si)) {
56
- if (typeof si[infoKey] === 'function') {
57
- // 'dockerInfo', 'vboxInfo'
58
- if (!['osInfo', 'graphics', 'cpu'].includes(infoKey)) continue;
59
- try {
60
- const infoInstance = await si[infoKey]();
61
- logger.info(infoKey, infoInstance);
62
- } catch (error) {
63
- logger.info('Not valid info function', infoKey);
64
- }
65
- }
66
- }
67
- })();
68
- break;
69
- case 'export-git-changes':
70
- {
71
- const baseFrom = process.argv[3];
72
- const baseTo = process.argv[4];
73
- // if (fs.existsSync(baseTo)) fs.removeSync(baseTo);
74
- shellCd(baseFrom);
75
- {
76
- try {
77
- let output = shellExec('git status', { silent: true, stdout: true });
78
- console.log('output:', output);
79
- output = output
80
- .split(`to discard changes in working directory)`)[1]
81
- .split(`Untracked files:`)[0]
82
- .split('modified:')
83
- .map((c) => c.trim().replaceAll(`\n`, ''));
84
- output[output.length - 1] = output[output.length - 1].split('no changes added to commit')[0];
85
- output.shift();
86
- for (const fromPath of output) {
87
- const from = `${baseFrom}/${fromPath}`;
88
- const to = `${baseTo}/${fromPath}`;
89
- logger.info('Copy path', { from, to });
90
- fs.copySync(from, to);
91
- }
92
- } catch (error) {
93
- logger.error(error);
94
- }
95
- }
96
- {
97
- try {
98
- let output = shellExec('git status', { silent: true, stdout: true });
99
- console.log('output:', output);
100
- output = output
101
- .split(`to include in what will be committed)`)[1]
102
- .split(`no changes added to commit`)[0]
103
- .split(`\n`)
104
- .map((l) => l.trim())
105
- .filter((l) => l);
106
-
107
- for (const fromPath of output) {
108
- const from = `${baseFrom}/${fromPath}`;
109
- const to = `${baseTo}/${fromPath}`;
110
- logger.info('Copy path', { from, to });
111
- fs.copySync(from, to);
112
- }
113
- } catch (error) {
114
- logger.error(error);
115
- }
116
- }
117
- }
118
- break;
119
- case 'delete-empty-folder':
120
- function cleanEmptyFoldersRecursively(folder) {
121
- const isDir = fs.statSync(folder).isDirectory();
122
- if (!isDir) return;
123
-
124
- let files = fs.readdirSync(folder);
125
- if (files.length > 0) {
126
- files.forEach(function (file) {
127
- const fullPath = dir.join(folder, file);
128
- cleanEmptyFoldersRecursively(fullPath);
129
- });
130
-
131
- // re-evaluate files; after deleting subfolder
132
- // we may have parent folder empty now
133
- files = fs.readdirSync(folder);
134
- }
135
-
136
- if (files.length === 0) {
137
- console.log('removing: ', folder);
138
- fs.rmdirSync(folder);
139
- return;
140
- }
141
- }
142
- cleanEmptyFoldersRecursively('./');
143
- break;
144
-
145
- case 'text-to-image': {
146
- const buffer = await getBufferPngText({
147
- text: process.argv[3],
148
- textColor: process.argv[4],
149
- bgColor: process.argv[5],
150
- size: process.argv[6],
151
- debugFilename: process.argv[7],
152
- });
153
- fs.writeFileSync(`./text-to-image.png`, buffer);
154
- break;
155
- }
156
- case 'fa-image':
157
- const faId = process.argv[3] ? process.argv[3] : 'user';
158
- const color = process.argv[4] ? process.argv[4] : '#5f5f5f';
159
- const path = process.argv[5] ? process.argv[5] : './';
160
-
161
- {
162
- fs.writeFileSync(`./tmp/${faId}.svg`, svg(faId, color), 'utf8');
163
- const data = fs.readFileSync(`./tmp/${faId}.svg`);
164
- console.log(FileFactory.svg(data, `${faId}.svg`));
165
- fs.removeSync(`${path}${faId}.svg`);
166
- }
167
- {
168
- fs.writeFileSync(`${path}${faId}.png`, Buffer.from(faBase64Png(faId, 100, 100, color), 'base64'));
169
- }
170
-
171
- break;
172
-
173
- case 'b64-image':
174
- fs.writeFileSync('b64-image', `data:image/jpg;base64,${fs.readFileSync(process.argv[3]).toString('base64')}`);
175
- break;
176
-
177
- default:
178
- break;
179
- }
180
- } catch (error) {
181
- logger.error(error, error.stack);
182
- }
1
+ import fs from 'fs-extra';
2
+ import merge from 'deepmerge';
3
+ import si from 'systeminformation';
4
+ import * as dir from 'path';
5
+ import { svg } from 'font-awesome-assets';
6
+
7
+ import { loggerFactory } from '../src/server/logger.js';
8
+ import { shellCd, shellExec } from '../src/server/process.js';
9
+ import { range, s4 } from '../src/client/components/core/CommonJs.js';
10
+ import { network } from '../src/server/network.js';
11
+ import { Config } from '../src/server/conf.js';
12
+ import { FileFactory } from '../src/api/file/file.service.js';
13
+ import { buildTextImg, faBase64Png, getBufferPngText } from '../src/server/client-icons.js';
14
+
15
+ const logger = loggerFactory(import.meta);
16
+
17
+ logger.info('argv', process.argv);
18
+
19
+ const operator = process.argv[2];
20
+
21
+ try {
22
+ // let cmd;
23
+ switch (operator) {
24
+ case 'cls':
25
+ fs.removeSync('./public');
26
+ fs.removeSync('./logs');
27
+ fs.removeSync('./conf');
28
+ // fs.removeSync('./engine-private');
29
+ // fs.removeSync('./node_modules');
30
+ break;
31
+ case 'log':
32
+ (() => {
33
+ const logPath = `./logs/${process.argv[3]}/${process.argv[4]}.log`;
34
+ logger.info('Read', logPath);
35
+ console.log(fs.readFileSync(logPath, 'utf8'));
36
+ })();
37
+ break;
38
+ case 'kill-ports':
39
+ if (!process.argv[3]) process.argv[3] = '22,80,443,3000-3020';
40
+ for (const port of process.argv[3].split(',')) {
41
+ const rangePort = port.split('-');
42
+ if (rangePort[1])
43
+ for (const port of range(parseInt(rangePort[0]), parseInt(rangePort[1]))) {
44
+ logger.info('clean port', port);
45
+ await network.port.portClean(port);
46
+ }
47
+ else {
48
+ logger.info('clean port', parseInt(port));
49
+ await network.port.portClean(port);
50
+ }
51
+ }
52
+ break;
53
+ case 'system-info':
54
+ await (async () => {
55
+ for (const infoKey of Object.keys(si)) {
56
+ if (typeof si[infoKey] === 'function') {
57
+ // 'dockerInfo', 'vboxInfo'
58
+ if (!['osInfo', 'graphics', 'cpu'].includes(infoKey)) continue;
59
+ try {
60
+ const infoInstance = await si[infoKey]();
61
+ logger.info(infoKey, infoInstance);
62
+ } catch (error) {
63
+ logger.info('Not valid info function', infoKey);
64
+ }
65
+ }
66
+ }
67
+ })();
68
+ break;
69
+ case 'export-git-changes':
70
+ {
71
+ const baseFrom = process.argv[3];
72
+ const baseTo = process.argv[4];
73
+ // if (fs.existsSync(baseTo)) fs.removeSync(baseTo);
74
+ shellCd(baseFrom);
75
+ {
76
+ try {
77
+ let output = shellExec('git status', { silent: true, stdout: true });
78
+ console.log('output:', output);
79
+ output = output
80
+ .split(`to discard changes in working directory)`)[1]
81
+ .split(`Untracked files:`)[0]
82
+ .split('modified:')
83
+ .map((c) => c.trim().replaceAll(`\n`, ''));
84
+ output[output.length - 1] = output[output.length - 1].split('no changes added to commit')[0];
85
+ output.shift();
86
+ for (const fromPath of output) {
87
+ const from = `${baseFrom}/${fromPath}`;
88
+ const to = `${baseTo}/${fromPath}`;
89
+ logger.info('Copy path', { from, to });
90
+ fs.copySync(from, to);
91
+ }
92
+ } catch (error) {
93
+ logger.error(error);
94
+ }
95
+ }
96
+ {
97
+ try {
98
+ let output = shellExec('git status', { silent: true, stdout: true });
99
+ console.log('output:', output);
100
+ output = output
101
+ .split(`to include in what will be committed)`)[1]
102
+ .split(`no changes added to commit`)[0]
103
+ .split(`\n`)
104
+ .map((l) => l.trim())
105
+ .filter((l) => l);
106
+
107
+ for (const fromPath of output) {
108
+ const from = `${baseFrom}/${fromPath}`;
109
+ const to = `${baseTo}/${fromPath}`;
110
+ logger.info('Copy path', { from, to });
111
+ fs.copySync(from, to);
112
+ }
113
+ } catch (error) {
114
+ logger.error(error);
115
+ }
116
+ }
117
+ }
118
+ break;
119
+ case 'delete-empty-folder':
120
+ function cleanEmptyFoldersRecursively(folder) {
121
+ const isDir = fs.statSync(folder).isDirectory();
122
+ if (!isDir) return;
123
+
124
+ let files = fs.readdirSync(folder);
125
+ if (files.length > 0) {
126
+ files.forEach(function (file) {
127
+ const fullPath = dir.join(folder, file);
128
+ cleanEmptyFoldersRecursively(fullPath);
129
+ });
130
+
131
+ // re-evaluate files; after deleting subfolder
132
+ // we may have parent folder empty now
133
+ files = fs.readdirSync(folder);
134
+ }
135
+
136
+ if (files.length === 0) {
137
+ console.log('removing: ', folder);
138
+ fs.rmdirSync(folder);
139
+ return;
140
+ }
141
+ }
142
+ cleanEmptyFoldersRecursively('./');
143
+ break;
144
+
145
+ case 'text-to-image': {
146
+ const buffer = await getBufferPngText({
147
+ text: process.argv[3],
148
+ textColor: process.argv[4],
149
+ bgColor: process.argv[5],
150
+ size: process.argv[6],
151
+ debugFilename: process.argv[7],
152
+ });
153
+ fs.writeFileSync(`./text-to-image.png`, buffer);
154
+ break;
155
+ }
156
+ case 'fa-image':
157
+ const faId = process.argv[3] ? process.argv[3] : 'user';
158
+ const color = process.argv[4] ? process.argv[4] : '#5f5f5f';
159
+ const path = process.argv[5] ? process.argv[5] : './';
160
+
161
+ {
162
+ fs.writeFileSync(`./tmp/${faId}.svg`, svg(faId, color), 'utf8');
163
+ const data = fs.readFileSync(`./tmp/${faId}.svg`);
164
+ console.log(FileFactory.svg(data, `${faId}.svg`));
165
+ fs.removeSync(`${path}${faId}.svg`);
166
+ }
167
+ {
168
+ fs.writeFileSync(`${path}${faId}.png`, Buffer.from(faBase64Png(faId, 100, 100, color), 'base64'));
169
+ }
170
+
171
+ break;
172
+
173
+ case 'b64-image':
174
+ fs.writeFileSync('b64-image', `data:image/jpg;base64,${fs.readFileSync(process.argv[3]).toString('base64')}`);
175
+ break;
176
+
177
+ default:
178
+ break;
179
+ }
180
+ } catch (error) {
181
+ logger.error(error, error.stack);
182
+ }
package/bin/vs.js CHANGED
@@ -1,35 +1,35 @@
1
- import fs from 'fs-extra';
2
- import { shellExec } from '../src/server/process.js';
3
-
4
- switch (process.argv[2]) {
5
- case 'import':
6
- {
7
- const extensions = JSON.parse(fs.readFileSync(`./.vscode/extensions.json`, 'utf8'));
8
- extensions.recommendations.map((extension) => {
9
- if (extension) shellExec(`code --install-extension ${extension}`);
10
- });
11
- }
12
- break;
13
- case 'export':
14
- {
15
- shellExec(`code --list-extensions > vs-extensions.txt`);
16
- fs.writeFileSync(
17
- `./.vscode/extensions.json`,
18
- JSON.stringify(
19
- {
20
- recommendations: fs
21
- .readFileSync(`./vs-extensions.txt`, 'utf8')
22
- .split(`\n`)
23
- .filter((ext) => ext.trim()),
24
- },
25
- null,
26
- 4,
27
- ),
28
- 'utf8',
29
- );
30
- fs.removeSync(`./vs-extensions.txt`);
31
- }
32
- break;
33
- default:
34
- break;
35
- }
1
+ import fs from 'fs-extra';
2
+ import { shellExec } from '../src/server/process.js';
3
+
4
+ switch (process.argv[2]) {
5
+ case 'import':
6
+ {
7
+ const extensions = JSON.parse(fs.readFileSync(`./.vscode/extensions.json`, 'utf8'));
8
+ extensions.recommendations.map((extension) => {
9
+ if (extension) shellExec(`code --install-extension ${extension}`);
10
+ });
11
+ }
12
+ break;
13
+ case 'export':
14
+ {
15
+ shellExec(`code --list-extensions > vs-extensions.txt`);
16
+ fs.writeFileSync(
17
+ `./.vscode/extensions.json`,
18
+ JSON.stringify(
19
+ {
20
+ recommendations: fs
21
+ .readFileSync(`./vs-extensions.txt`, 'utf8')
22
+ .split(`\n`)
23
+ .filter((ext) => ext.trim()),
24
+ },
25
+ null,
26
+ 4,
27
+ ),
28
+ 'utf8',
29
+ );
30
+ fs.removeSync(`./vs-extensions.txt`);
31
+ }
32
+ break;
33
+ default:
34
+ break;
35
+ }