@bprotsyk/aso-core 2.1.21 → 2.1.24

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 (243) hide show
  1. package/README.md +1 -1
  2. package/docs/assets/highlight.css +22 -22
  3. package/docs/assets/main.js +58 -58
  4. package/docs/assets/style.css +1279 -1279
  5. package/docs/enums/PanelUserAccessScope.html +126 -126
  6. package/docs/functions/ASO_v0.toDefault.html +80 -80
  7. package/docs/functions/ASO_v1.toDefault.html +80 -80
  8. package/docs/functions/ASO_v2.toDefault.html +78 -78
  9. package/docs/functions/ASO_v3.toDefault.html +77 -77
  10. package/docs/functions/ASO_v4.toDefault.html +75 -75
  11. package/docs/functions/ASO_v5.toDefault.html +76 -76
  12. package/docs/functions/ColoredText.html +92 -92
  13. package/docs/functions/ShapeDiv.html +109 -109
  14. package/docs/index.html +82 -82
  15. package/docs/interfaces/ASOConfigFetch.IUsageLogEntry.html +1413 -1413
  16. package/docs/interfaces/ASOConfigFetch.IUsageLogRequest.html +103 -103
  17. package/docs/interfaces/ASOConfigFetch.IUsageLogResponse.html +108 -108
  18. package/docs/interfaces/ASO_v0.IAuthorizationActionMapping.html +145 -145
  19. package/docs/interfaces/ASO_v0.IColoredSpan.html +89 -89
  20. package/docs/interfaces/ASO_v0.IColoredSpanMapping.html +89 -89
  21. package/docs/interfaces/ASO_v0.IColoredString.html +89 -89
  22. package/docs/interfaces/ASO_v0.IColoredStringMapping.html +89 -89
  23. package/docs/interfaces/ASO_v0.IConfig.html +556 -556
  24. package/docs/interfaces/ASO_v0.IConfigMapping.html +229 -229
  25. package/docs/interfaces/ASO_v0.ILocalization.html +516 -516
  26. package/docs/interfaces/ASO_v0.ILocalizationMap.html +77 -77
  27. package/docs/interfaces/ASO_v0.ILocalizationMapping.html +502 -502
  28. package/docs/interfaces/ASO_v0.IOfferResult.html +103 -103
  29. package/docs/interfaces/ASO_v0.IOfferResultEmoji.html +82 -82
  30. package/docs/interfaces/ASO_v0.IOfferResultMapping.html +117 -117
  31. package/docs/interfaces/ASO_v0.IOfferSectionMapping.html +108 -108
  32. package/docs/interfaces/ASO_v0.IOffersSection.html +96 -96
  33. package/docs/interfaces/ASO_v0.ISectionPalette.html +152 -152
  34. package/docs/interfaces/ASO_v0.ISectionPaletteMapping.html +152 -152
  35. package/docs/interfaces/ASO_v1.IAuthorizationActionMapping.html +145 -145
  36. package/docs/interfaces/ASO_v1.IColoredSpan.html +89 -89
  37. package/docs/interfaces/ASO_v1.IColoredSpanMapping.html +89 -89
  38. package/docs/interfaces/ASO_v1.IColoredString.html +89 -89
  39. package/docs/interfaces/ASO_v1.IColoredStringMapping.html +89 -89
  40. package/docs/interfaces/ASO_v1.IConfig.html +549 -549
  41. package/docs/interfaces/ASO_v1.IConfigMapping.html +229 -229
  42. package/docs/interfaces/ASO_v1.ILocalization.html +481 -481
  43. package/docs/interfaces/ASO_v1.ILocalizationMap.html +77 -77
  44. package/docs/interfaces/ASO_v1.ILocalizationMapping.html +481 -481
  45. package/docs/interfaces/ASO_v1.IOfferResult.html +103 -103
  46. package/docs/interfaces/ASO_v1.IOfferResultEmoji.html +82 -82
  47. package/docs/interfaces/ASO_v1.IOfferResultMapping.html +117 -117
  48. package/docs/interfaces/ASO_v1.IOfferSectionMapping.html +108 -108
  49. package/docs/interfaces/ASO_v1.IOffersSection.html +101 -101
  50. package/docs/interfaces/ASO_v1.ISectionPalette.html +152 -152
  51. package/docs/interfaces/ASO_v1.ISectionPaletteMapping.html +152 -152
  52. package/docs/interfaces/ASO_v2.IAuthorizationActionMapping.html +138 -138
  53. package/docs/interfaces/ASO_v2.IColoredSpanMapping.html +89 -89
  54. package/docs/interfaces/ASO_v2.IColoredString.html +89 -89
  55. package/docs/interfaces/ASO_v2.IColoredStringMapping.html +89 -89
  56. package/docs/interfaces/ASO_v2.IConfig.html +493 -493
  57. package/docs/interfaces/ASO_v2.IConfigMapping.html +201 -201
  58. package/docs/interfaces/ASO_v2.ILocalization.html +474 -474
  59. package/docs/interfaces/ASO_v2.ILocalizationMap.html +75 -75
  60. package/docs/interfaces/ASO_v2.ILocalizationMapping.html +362 -362
  61. package/docs/interfaces/ASO_v2.IOfferResult.html +110 -110
  62. package/docs/interfaces/ASO_v2.IOfferResultMapping.html +117 -117
  63. package/docs/interfaces/ASO_v2.IOfferSectionMapping.html +108 -108
  64. package/docs/interfaces/ASO_v2.IOffersSection.html +101 -101
  65. package/docs/interfaces/ASO_v2.ISectionPalette.html +152 -152
  66. package/docs/interfaces/ASO_v2.ISectionPaletteMapping.html +152 -152
  67. package/docs/interfaces/ASO_v3.IAuthorizationActionMapping.html +138 -138
  68. package/docs/interfaces/ASO_v3.IColoredSpanMapping.html +89 -89
  69. package/docs/interfaces/ASO_v3.IColoredString.html +89 -89
  70. package/docs/interfaces/ASO_v3.IColoredStringMapping.html +89 -89
  71. package/docs/interfaces/ASO_v3.IConfig.html +514 -514
  72. package/docs/interfaces/ASO_v3.IConfigMapping.html +208 -208
  73. package/docs/interfaces/ASO_v3.ILocalization.html +446 -446
  74. package/docs/interfaces/ASO_v3.ILocalizationMap.html +74 -74
  75. package/docs/interfaces/ASO_v3.ILocalizationMapping.html +341 -341
  76. package/docs/interfaces/ASO_v3.IOfferResultMapping.html +117 -117
  77. package/docs/interfaces/ASO_v3.IOfferSectionMapping.html +108 -108
  78. package/docs/interfaces/ASO_v3.IOffersSection.html +101 -101
  79. package/docs/interfaces/ASO_v3.ISectionPalette.html +152 -152
  80. package/docs/interfaces/ASO_v3.ISectionPaletteMapping.html +152 -152
  81. package/docs/interfaces/ASO_v4.IAuthorizationActionMapping.html +138 -138
  82. package/docs/interfaces/ASO_v4.IColoredSpanMapping.html +89 -89
  83. package/docs/interfaces/ASO_v4.IColoredString.html +89 -89
  84. package/docs/interfaces/ASO_v4.IColoredStringMapping.html +89 -89
  85. package/docs/interfaces/ASO_v4.IConfig.html +514 -514
  86. package/docs/interfaces/ASO_v4.IConfigMapping.html +131 -131
  87. package/docs/interfaces/ASO_v4.ILocalization.html +369 -369
  88. package/docs/interfaces/ASO_v4.ILocalizationMap.html +72 -72
  89. package/docs/interfaces/ASO_v4.ILocalizationMapping.html +257 -257
  90. package/docs/interfaces/ASO_v4.IOfferResultMapping.html +117 -117
  91. package/docs/interfaces/ASO_v4.IOfferSectionMapping.html +89 -89
  92. package/docs/interfaces/ASO_v4.LocalizedString.html +82 -82
  93. package/docs/interfaces/ASO_v5.IAuthorizationActionMapping.html +138 -138
  94. package/docs/interfaces/ASO_v5.IColoredSpan.html +89 -89
  95. package/docs/interfaces/ASO_v5.IColoredSpanMapping.html +89 -89
  96. package/docs/interfaces/ASO_v5.IColoredString.html +89 -89
  97. package/docs/interfaces/ASO_v5.IColoredStringMapping.html +89 -89
  98. package/docs/interfaces/ASO_v5.IConfig.html +542 -542
  99. package/docs/interfaces/ASO_v5.IConfigMapping.html +159 -159
  100. package/docs/interfaces/ASO_v5.ILocalization.html +411 -411
  101. package/docs/interfaces/ASO_v5.ILocalizationMap.html +73 -73
  102. package/docs/interfaces/ASO_v5.ILocalizationMapping.html +299 -299
  103. package/docs/interfaces/ASO_v5.IOfferResultMapping.html +117 -117
  104. package/docs/interfaces/ASO_v5.IOfferSectionMapping.html +89 -89
  105. package/docs/interfaces/ASO_v5.LocalizedString.html +82 -82
  106. package/docs/interfaces/IAsoConfigResponse.html +81 -81
  107. package/docs/interfaces/IAsoCustomizedOffer.html +116 -116
  108. package/docs/interfaces/IAsoDefaultConfig.html +443 -443
  109. package/docs/interfaces/IAsoOfferResponse.html +81 -81
  110. package/docs/interfaces/IAsoSection.html +88 -88
  111. package/docs/interfaces/IAsoSingleOffer.html +88 -88
  112. package/docs/interfaces/IAuthToken.html +102 -102
  113. package/docs/interfaces/IColoredTextProps.html +74 -74
  114. package/docs/interfaces/IFlashApp.html +144 -144
  115. package/docs/interfaces/IFlashAppListItem.html +88 -88
  116. package/docs/interfaces/IGradient.html +95 -95
  117. package/docs/interfaces/IOffer.html +137 -137
  118. package/docs/interfaces/IOfferWallAuthConfig.html +130 -130
  119. package/docs/interfaces/IOfferWallAuthLocalization.html +102 -102
  120. package/docs/interfaces/IOfferWallAuthSubmitRequest.html +74 -74
  121. package/docs/interfaces/IOfferWallAuthSubmitResponse.html +74 -74
  122. package/docs/interfaces/IOfferWallHomeDialogData.html +95 -95
  123. package/docs/interfaces/IOfferWallOffer.html +109 -109
  124. package/docs/interfaces/IOfferWallResponse.html +81 -81
  125. package/docs/interfaces/IOfferWallSection.html +88 -88
  126. package/docs/interfaces/IPanelUser.html +1405 -1405
  127. package/docs/interfaces/IPush.html +95 -95
  128. package/docs/interfaces/IShape.html +102 -102
  129. package/docs/interfaces/IStroke.html +81 -81
  130. package/docs/interfaces/IUpsertFlashAppRequest.html +214 -214
  131. package/docs/interfaces/IUpsertFlashAppResponse.html +81 -81
  132. package/docs/modules/ASOConfigFetch.html +63 -63
  133. package/docs/modules/ASO_v0.html +96 -96
  134. package/docs/modules/ASO_v1.html +96 -96
  135. package/docs/modules/ASO_v2.html +92 -92
  136. package/docs/modules/ASO_v3.html +90 -90
  137. package/docs/modules/ASO_v4.html +86 -86
  138. package/docs/modules/ASO_v5.html +88 -88
  139. package/docs/modules.html +133 -133
  140. package/docs/variables/FlashAppSchema.html +83 -83
  141. package/docs/variables/PanelUserSchema.html +83 -83
  142. package/lib/app/app-integration.d.ts +53 -53
  143. package/lib/app/app-integration.js +63 -63
  144. package/lib/app/app-list-item.d.ts +5 -5
  145. package/lib/app/app-list-item.js +2 -2
  146. package/lib/app/app-type.d.ts +4 -4
  147. package/lib/app/app-type.js +8 -8
  148. package/lib/app/app.d.ts +213 -206
  149. package/lib/app/app.js +184 -173
  150. package/lib/general/cloudflare-domain.d.ts +42 -42
  151. package/lib/general/cloudflare-domain.js +12 -12
  152. package/lib/general/domain.d.ts +108 -108
  153. package/lib/general/domain.js +61 -61
  154. package/lib/general/namecheap-domain.d.ts +85 -85
  155. package/lib/general/namecheap-domain.js +14 -14
  156. package/lib/general/push.d.ts +6 -6
  157. package/lib/general/push.js +2 -2
  158. package/lib/general/queue.d.ts +2 -2
  159. package/lib/general/queue.js +1 -1
  160. package/lib/general/shape.d.ts +18 -18
  161. package/lib/general/shape.js +36 -36
  162. package/lib/index.d.ts +26 -26
  163. package/lib/index.js +69 -69
  164. package/lib/keitaro/keitaro-campaign.d.ts +31 -31
  165. package/lib/keitaro/keitaro-campaign.js +5 -5
  166. package/lib/keitaro/keitaro-domain.d.ts +6 -6
  167. package/lib/keitaro/keitaro-domain.js +2 -2
  168. package/lib/keitaro/keitaro-offer.d.ts +7 -7
  169. package/lib/keitaro/keitaro-offer.js +2 -2
  170. package/lib/keitaro/keitaro-stream.d.ts +20 -20
  171. package/lib/keitaro/keitaro-stream.js +2 -2
  172. package/lib/network/keitaro/http.d.ts +2 -2
  173. package/lib/network/keitaro/http.js +12 -12
  174. package/lib/network/keitaro/keitaro-service.d.ts +50 -50
  175. package/lib/network/keitaro/keitaro-service.js +261 -261
  176. package/lib/offers/list.d.ts +37 -37
  177. package/lib/offers/list.js +12 -12
  178. package/lib/offers/offer.d.ts +91 -91
  179. package/lib/offers/offer.js +42 -42
  180. package/lib/offers/offerwall/offerwall-home-dialog-data.d.ts +6 -6
  181. package/lib/offers/offerwall/offerwall-home-dialog-data.js +2 -2
  182. package/lib/offers/offerwall/offerwall-offer.d.ts +12 -12
  183. package/lib/offers/offerwall/offerwall-offer.js +2 -2
  184. package/lib/offers/offerwall/offerwall-response.d.ts +6 -6
  185. package/lib/offers/offerwall/offerwall-response.js +2 -2
  186. package/lib/offers/offerwall/offerwall-section.d.ts +6 -6
  187. package/lib/offers/offerwall/offerwall-section.js +2 -2
  188. package/lib/offers/section.d.ts +47 -47
  189. package/lib/offers/section.js +20 -20
  190. package/lib/panel/auth.d.ts +9 -9
  191. package/lib/panel/auth.js +2 -2
  192. package/lib/panel/flash/upsert-flash-app-request.d.ts +31 -29
  193. package/lib/panel/flash/upsert-flash-app-request.js +2 -2
  194. package/lib/panel/user.d.ts +46 -46
  195. package/lib/panel/user.js +28 -28
  196. package/lib/templates/nginx-template.conf +35 -35
  197. package/lib/templates/nginx-template.d.ts +1 -1
  198. package/lib/templates/nginx-template.js +39 -39
  199. package/lib/templates/nginx-template.ts +35 -35
  200. package/lib/utils/general.d.ts +11 -11
  201. package/lib/utils/general.js +40 -40
  202. package/lib/utils/huawei/converter.d.ts +2 -2
  203. package/lib/utils/huawei/converter.js +53 -53
  204. package/lib/utils/keitaro-utils.d.ts +15 -15
  205. package/lib/utils/keitaro-utils.js +569 -569
  206. package/lib/utils/server-util.js +303 -303
  207. package/package.json +51 -51
  208. package/src/app/app-integration.ts +66 -66
  209. package/src/app/app-list-item.ts +4 -4
  210. package/src/app/app-type.ts +3 -3
  211. package/src/app/app.ts +346 -333
  212. package/src/general/cloudflare-domain.ts +44 -44
  213. package/src/general/domain.ts +105 -105
  214. package/src/general/namecheap-domain.ts +63 -63
  215. package/src/general/push.ts +5 -5
  216. package/src/general/queue.ts +4 -4
  217. package/src/general/shape.tsx +55 -55
  218. package/src/index.ts +32 -32
  219. package/src/keitaro/keitaro-campaign.ts +35 -35
  220. package/src/keitaro/keitaro-domain.ts +5 -5
  221. package/src/keitaro/keitaro-offer.ts +6 -6
  222. package/src/keitaro/keitaro-stream.ts +19 -19
  223. package/src/network/keitaro/http.ts +8 -8
  224. package/src/network/keitaro/keitaro-service.ts +323 -323
  225. package/src/offers/list.ts +19 -19
  226. package/src/offers/offer.ts +80 -80
  227. package/src/offers/offerwall/offerwall-home-dialog-data.ts +6 -6
  228. package/src/offers/offerwall/offerwall-offer.ts +12 -12
  229. package/src/offers/offerwall/offerwall-response.ts +7 -7
  230. package/src/offers/offerwall/offerwall-section.ts +7 -7
  231. package/src/offers/section.ts +29 -29
  232. package/src/panel/auth.ts +9 -9
  233. package/src/panel/flash/upsert-flash-app-request.ts +39 -37
  234. package/src/panel/user.ts +38 -38
  235. package/src/templates/nginx-template.ts +35 -35
  236. package/src/utils/data.csv +65 -65
  237. package/src/utils/general.ts +36 -36
  238. package/src/utils/huawei/converter.ts +55 -55
  239. package/src/utils/keitaro-utils.ts +661 -661
  240. package/src/utils/map-apps.json +4747 -4747
  241. package/src/utils/server-util.ts +368 -368
  242. package/src/utils/update-postbacks.js +27 -27
  243. package/tsconfig.json +20 -20
@@ -1,303 +1,303 @@
1
- "use strict";
2
- // import { NodeSSH } from "node-ssh";
3
- // import ChildProcess from "child_process";
4
- // // import Client from "ssh2-sftp-client";
5
- // import fs from "fs";
6
- // import mustache from "mustache";
7
- // import path from "path";
8
- // import unzipper from 'unzipper';
9
- // const { promisify } = require("util");
10
- // const execPromise = promisify(ChildProcess.exec);
11
- // export let IP = "185.123.53.227";
12
- // export let PASSWORD = "xUA3oOX06Kfc9m12rZ";
13
- // export let HOST = "cg-main-server.com";
14
- // export let PORT = 56777;
15
- // interface FileObject {
16
- // name: string;
17
- // content: string; // Це буде Base64 закодовані дані
18
- // }
19
- // interface ISFTP {
20
- // host: string;
21
- // port: number;
22
- // username: string;
23
- // password: string;
24
- // }
25
- // export class ServerUtil {
26
- // DOMAIN_HOME = "/etc/nginx/sites-enabled";
27
- // ssh?: NodeSSH
28
- // sftpConfig?: ISFTP;
29
- // constructor(sftpConfig?: ISFTP) {
30
- // this.ssh = new NodeSSH();
31
- // this.sftpConfig = sftpConfig;
32
- // }
33
- // async connectSSH(): Promise<void> {
34
- // await this?.ssh?.connect({
35
- // host: this?.sftpConfig?.host,
36
- // port: this?.sftpConfig?.port,
37
- // username: this?.sftpConfig?.username,
38
- // password: this?.sftpConfig?.password,
39
- // });
40
- // }
41
- // async ensureConnected(): Promise<void> {
42
- // if (!this?.ssh?.isConnected()) {
43
- // await this.connectSSH(); // Підключення, якщо ще не підключено
44
- // }
45
- // }
46
- // // Выконує команду або по SSH або локально, повертаючи текст незалежно від результату (помилка чи успіх)
47
- // async exec(command: string, options?: any): Promise<string> {
48
- // await this.ensureConnected();
49
- // if (this?.ssh?.isConnected()) {
50
- // return (await this?.ssh?.execCommand(command, options)).stdout;
51
- // } else {
52
- // return await new Promise<string>((resolve) => {
53
- // execPromise(command, (err: string, stdout: string) => {
54
- // resolve(stdout);
55
- // });
56
- // });
57
- // }
58
- // }
59
- // // SSH
60
- // async generateSSHKey(): Promise<string> {
61
- // await this.exec(`ssh-keygen -t rsa -N '' -f ~/.ssh/id_rsa <<< n`);
62
- // let sshFingerprint = await this.exec(`cat ~/.ssh/id_rsa.pub`);
63
- // return sshFingerprint;
64
- // }
65
- // // create Directories in /Var
66
- // async createDirectories(): Promise<void> {
67
- // await this.exec(`mkdir -p /var/www/ai`);
68
- // }
69
- // // install git
70
- // async installGit(): Promise<void> {
71
- // await this.exec(`apt-get update; apt-get install -y git`);
72
- // }
73
- // // add ssh to bitbucket
74
- // async addBitbucketToKnownHosts(): Promise<void> {
75
- // await this.exec(`ssh-keyscan bitbucket.org >> ~/.ssh/known_hosts`);
76
- // }
77
- // // clone bitbucket Repository
78
- // async cloneRepository(repoName: string, targetPath: string): Promise<void> {
79
- // let gitResponse = await this.exec(
80
- // `git clone git@bitbucket.org:bprtsk/${repoName}.git`,
81
- // { cwd: targetPath }
82
- // );
83
- // if (
84
- // gitResponse.includes(
85
- // `Please make sure you have the correct access rights`
86
- // )
87
- // ) {
88
- // throw new Error(`No access to the remote repository!`);
89
- // }
90
- // }
91
- // // не знаю чи треба але додав ?
92
- // // async checkoutBranch(branch: string, repoPath: string): Promise<void> {
93
- // // await this.exec(`git checkout -b ${branch}; git branch --set-upstream-to=origin/${branch} ${branch}; git reset --hard origin/${branch};`, { cwd: repoPath });
94
- // // }
95
- // // не знаю чи треба але додав ?
96
- // // async installJava(): Promise<void> {
97
- // // await this.exec(`apt-get update; apt-get install -y default-jre default-jdk`);
98
- // // }
99
- // // install Nginx
100
- // async installNginx(): Promise<void> {
101
- // await this.exec(`apt-get update; apt-get install -y nginx`);
102
- // await this.exec(`systemctl enable nginx`);
103
- // await this.exec(`systemctl start nginx`);
104
- // }
105
- // // Nginx
106
- // async isNginxActive(): Promise<boolean> {
107
- // try {
108
- // let result = await this.exec("systemctl status nginx");
109
- // if (result.includes("Active: active")) return true;
110
- // } catch (e) {
111
- // console.error(e);
112
- // }
113
- // return false;
114
- // }
115
- // // Mongo
116
- // async isMongoActive(): Promise<boolean> {
117
- // try {
118
- // let result = await this.exec("systemctl status mongod");
119
- // if (result.includes("Active: active")) return true;
120
- // } catch (e) {
121
- // console.error(e);
122
- // }
123
- // return false;
124
- // }
125
- // mongoInstallCommand = `
126
- // echo "deb http://security.ubuntu.com/ubuntu focal-security main" | tee /etc/apt/sources.list.d/focal-security.list;
127
- // apt-get update;
128
- // apt-get install libssl1.1;
129
- // rm /etc/apt/sources.list.d/focal-security.list;
130
- // curl -fsSL https://www.mongodb.org/static/pgp/server-4.4.asc | apt-key add -;
131
- // echo "deb http://security.ubuntu.com/ubuntu impish-security main" | tee /etc/apt/sources.list.d/impish-security.list;
132
- // echo "deb [ arch=amd64,arm64 ] https://repo.mongodb.org/apt/ubuntu bionic/mongodb-org/4.4 multiverse" | tee /etc/apt/sources.list.d/mongodb-org-4.4.list;
133
- // apt-get update;
134
- // apt-get install -y mongodb-org;
135
- // systemctl enable mongod.service;
136
- // systemctl start mongod;
137
- // `;
138
- // // checking if nginx configuration exists
139
- // async domainNginxConfigExists(host: string): Promise<boolean> {
140
- // try {
141
- // let result = await this.exec(
142
- // `ls ${this.DOMAIN_HOME}/${host}.nginx.ssl.conf`
143
- // );
144
- // if (result.includes("No such file or directory")) return false;
145
- // } catch (e) {
146
- // console.error(e);
147
- // }
148
- // return true;
149
- // }
150
- // // checking if the ssl certificate exists
151
- // async domainNginxCertsExist(host: string): Promise<boolean> {
152
- // try {
153
- // let result = await this.exec(`ls /etc/letsencrypt/live/${host}`);
154
- // if (result.includes("No such file or directory")) return false;
155
- // } catch (e) {
156
- // console.error(e);
157
- // }
158
- // return true;
159
- // }
160
- // // Certbot CRON
161
- // async isCerbotActive(): Promise<boolean> {
162
- // try {
163
- // let result = await this.exec("which certbot");
164
- // if (result.includes("/usr/bin/certbot")) return true;
165
- // } catch (e) {
166
- // console.error(e);
167
- // }
168
- // return false;
169
- // }
170
- // // install certbot
171
- // async setupCertbot(): Promise<boolean> {
172
- // await this?.ssh?.execCommand(`apt-get install -y certbot python3-certbot-nginx;`);
173
- // return true;
174
- // }
175
- // async setupSSL(email: string, host: string): Promise<void> {
176
- // // Прямий виклик this?.ssh?.execCommand
177
- // let certbotResponse = await this?.ssh?.execCommand(
178
- // `certbot --non-interactive --agree-tos --nginx -m "${email}" -d "${host}"`
179
- // );
180
- // if (certbotResponse?.stdout.includes(`Some challenges have failed.`)) {
181
- // throw new Error("Certbot encountered an error");
182
- // }
183
- // await this?.ssh?.execCommand(
184
- // `echo "0 12 * * * /usr/bin/certbot renew --quiet" | crontab -`
185
- // );
186
- // }
187
- // // Git
188
- // async refresh(): Promise<boolean> {
189
- // await this.exec(`git stash; rm-rf built; git pull`);
190
- // return true;
191
- // }
192
- // async uploadDirectoryToSftp(
193
- // localPath: string,
194
- // remotePath: string,
195
- // sftpConfig: any) {
196
- // // const sftp = new Client();
197
- // try {
198
- // // await sftp.connect(sftpConfig);
199
- // const stats = fs.statSync(localPath);
200
- // if (stats.isDirectory()) {
201
- // // Якщо це директорія
202
- // // await sftp.mkdir(remotePath, true).catch(async (err) => {
203
- // // if (err.code !== 4) { // Ігноруємо помилку "Directory already exists"
204
- // // console.error(`Помилка під час створення папки: ${remotePath}`, err);
205
- // // throw err;
206
- // // }
207
- // // });
208
- // const items = fs.readdirSync(localPath, { withFileTypes: true });
209
- // for (const item of items) {
210
- // const localItemPath = path.join(localPath, item.name);
211
- // const remoteItemPath = `${remotePath}/${item.name}`;
212
- // if (item.isDirectory()) {
213
- // await this.uploadDirectoryToSftp(localItemPath, remoteItemPath, sftpConfig);
214
- // } else {
215
- // // await sftp.put(localItemPath, remoteItemPath);
216
- // console.log(`Передано файл: ${localItemPath} -> ${remoteItemPath}`);
217
- // }
218
- // }
219
- // } else if (stats.isFile()) {
220
- // // Якщо це файл
221
- // // await sftp.put(localPath, remotePath);
222
- // console.log(`Передано файл: ${localPath} -> ${remotePath}`);
223
- // }
224
- // console.log('Усі файли та папки успішно передані.');
225
- // } catch (err) {
226
- // console.error('Помилка під час передавання файлів через SFTP:', err);
227
- // } finally {
228
- // // await sftp.end();
229
- // }
230
- // }
231
- // ensureDirectoryExistence(dirPath: string) {
232
- // if (!fs.existsSync(dirPath)) {
233
- // fs.mkdirSync(dirPath, { recursive: true });
234
- // }
235
- // }
236
- // async generateNginxConfig(domain: string, rootPath: string): Promise<string> {
237
- // const templatePath = path.join(
238
- // __dirname,
239
- // "..",
240
- // "templates",
241
- // "nginx-template.conf"
242
- // );
243
- // const template = fs.readFileSync(templatePath, "utf8");
244
- // let config = mustache.render(template, { domain, rootPath });
245
- // // Заміна закодованих символів назад на їх оригінальні значення
246
- // config = config.replace(/&#x2F;/g, '/');
247
- // return config;
248
- // }
249
- // async extractUploadedZip(name: string, file: any, extractToPath: string) {
250
- // const zipFilePath = file.path;
251
- // const outputDir = path.join(extractToPath, name);
252
- // console.log('Looking for ZIP file at:', zipFilePath);
253
- // console.log('Extracting to:', outputDir);
254
- // this.ensureDirectoryExistence(outputDir);
255
- // if (!fs.existsSync(zipFilePath)) {
256
- // console.error('Error: File not found:', zipFilePath);
257
- // return;
258
- // }
259
- // try {
260
- // await new Promise((resolve, reject) => {
261
- // fs.createReadStream(zipFilePath)
262
- // .pipe(unzipper.Parse())
263
- // .on('entry', (entry) => {
264
- // // Видаляємо перший сегмент шляху, щоб уникнути кореневої директорії
265
- // const entryPath = path.join(
266
- // outputDir,
267
- // ...entry.path.split('/').slice(1)
268
- // );
269
- // if (entry.type === 'Directory') {
270
- // this.ensureDirectoryExistence(entryPath);
271
- // } else {
272
- // this.ensureDirectoryExistence(path.dirname(entryPath));
273
- // entry.pipe(fs.createWriteStream(entryPath));
274
- // }
275
- // })
276
- // .on('close', resolve)
277
- // .on('error', reject);
278
- // });
279
- // console.log('File successfully extracted.');
280
- // } catch (err) {
281
- // console.error('Error extracting file:', err);
282
- // }
283
- // }
284
- // async ensureDirectoryExistsViaSSH(remoteDir: string) {
285
- // try {
286
- // // Перевірка, чи існує директорія, і створення її, якщо вона не існує
287
- // const command = `if [ ! -d "${remoteDir}" ]; then mkdir -p "${remoteDir}"; fi`;
288
- // await this?.ssh?.execCommand(command);
289
- // console.log(`Перевірено або створено папку: ${remoteDir}`);
290
- // } catch (err) {
291
- // console.error(
292
- // 'Помилка під час перевірки або створення папки через SSH:',
293
- // err
294
- // );
295
- // throw err;
296
- // } finally {
297
- // this?.ssh?.dispose();
298
- // }
299
- // }
300
- // async disconnectSSH(): Promise<void> {
301
- // this?.ssh?.dispose();
302
- // }
303
- // }
1
+ "use strict";
2
+ // import { NodeSSH } from "node-ssh";
3
+ // import ChildProcess from "child_process";
4
+ // // import Client from "ssh2-sftp-client";
5
+ // import fs from "fs";
6
+ // import mustache from "mustache";
7
+ // import path from "path";
8
+ // import unzipper from 'unzipper';
9
+ // const { promisify } = require("util");
10
+ // const execPromise = promisify(ChildProcess.exec);
11
+ // export let IP = "185.123.53.227";
12
+ // export let PASSWORD = "xUA3oOX06Kfc9m12rZ";
13
+ // export let HOST = "cg-main-server.com";
14
+ // export let PORT = 56777;
15
+ // interface FileObject {
16
+ // name: string;
17
+ // content: string; // Це буде Base64 закодовані дані
18
+ // }
19
+ // interface ISFTP {
20
+ // host: string;
21
+ // port: number;
22
+ // username: string;
23
+ // password: string;
24
+ // }
25
+ // export class ServerUtil {
26
+ // DOMAIN_HOME = "/etc/nginx/sites-enabled";
27
+ // ssh?: NodeSSH
28
+ // sftpConfig?: ISFTP;
29
+ // constructor(sftpConfig?: ISFTP) {
30
+ // this.ssh = new NodeSSH();
31
+ // this.sftpConfig = sftpConfig;
32
+ // }
33
+ // async connectSSH(): Promise<void> {
34
+ // await this?.ssh?.connect({
35
+ // host: this?.sftpConfig?.host,
36
+ // port: this?.sftpConfig?.port,
37
+ // username: this?.sftpConfig?.username,
38
+ // password: this?.sftpConfig?.password,
39
+ // });
40
+ // }
41
+ // async ensureConnected(): Promise<void> {
42
+ // if (!this?.ssh?.isConnected()) {
43
+ // await this.connectSSH(); // Підключення, якщо ще не підключено
44
+ // }
45
+ // }
46
+ // // Выконує команду або по SSH або локально, повертаючи текст незалежно від результату (помилка чи успіх)
47
+ // async exec(command: string, options?: any): Promise<string> {
48
+ // await this.ensureConnected();
49
+ // if (this?.ssh?.isConnected()) {
50
+ // return (await this?.ssh?.execCommand(command, options)).stdout;
51
+ // } else {
52
+ // return await new Promise<string>((resolve) => {
53
+ // execPromise(command, (err: string, stdout: string) => {
54
+ // resolve(stdout);
55
+ // });
56
+ // });
57
+ // }
58
+ // }
59
+ // // SSH
60
+ // async generateSSHKey(): Promise<string> {
61
+ // await this.exec(`ssh-keygen -t rsa -N '' -f ~/.ssh/id_rsa <<< n`);
62
+ // let sshFingerprint = await this.exec(`cat ~/.ssh/id_rsa.pub`);
63
+ // return sshFingerprint;
64
+ // }
65
+ // // create Directories in /Var
66
+ // async createDirectories(): Promise<void> {
67
+ // await this.exec(`mkdir -p /var/www/ai`);
68
+ // }
69
+ // // install git
70
+ // async installGit(): Promise<void> {
71
+ // await this.exec(`apt-get update; apt-get install -y git`);
72
+ // }
73
+ // // add ssh to bitbucket
74
+ // async addBitbucketToKnownHosts(): Promise<void> {
75
+ // await this.exec(`ssh-keyscan bitbucket.org >> ~/.ssh/known_hosts`);
76
+ // }
77
+ // // clone bitbucket Repository
78
+ // async cloneRepository(repoName: string, targetPath: string): Promise<void> {
79
+ // let gitResponse = await this.exec(
80
+ // `git clone git@bitbucket.org:bprtsk/${repoName}.git`,
81
+ // { cwd: targetPath }
82
+ // );
83
+ // if (
84
+ // gitResponse.includes(
85
+ // `Please make sure you have the correct access rights`
86
+ // )
87
+ // ) {
88
+ // throw new Error(`No access to the remote repository!`);
89
+ // }
90
+ // }
91
+ // // не знаю чи треба але додав ?
92
+ // // async checkoutBranch(branch: string, repoPath: string): Promise<void> {
93
+ // // await this.exec(`git checkout -b ${branch}; git branch --set-upstream-to=origin/${branch} ${branch}; git reset --hard origin/${branch};`, { cwd: repoPath });
94
+ // // }
95
+ // // не знаю чи треба але додав ?
96
+ // // async installJava(): Promise<void> {
97
+ // // await this.exec(`apt-get update; apt-get install -y default-jre default-jdk`);
98
+ // // }
99
+ // // install Nginx
100
+ // async installNginx(): Promise<void> {
101
+ // await this.exec(`apt-get update; apt-get install -y nginx`);
102
+ // await this.exec(`systemctl enable nginx`);
103
+ // await this.exec(`systemctl start nginx`);
104
+ // }
105
+ // // Nginx
106
+ // async isNginxActive(): Promise<boolean> {
107
+ // try {
108
+ // let result = await this.exec("systemctl status nginx");
109
+ // if (result.includes("Active: active")) return true;
110
+ // } catch (e) {
111
+ // console.error(e);
112
+ // }
113
+ // return false;
114
+ // }
115
+ // // Mongo
116
+ // async isMongoActive(): Promise<boolean> {
117
+ // try {
118
+ // let result = await this.exec("systemctl status mongod");
119
+ // if (result.includes("Active: active")) return true;
120
+ // } catch (e) {
121
+ // console.error(e);
122
+ // }
123
+ // return false;
124
+ // }
125
+ // mongoInstallCommand = `
126
+ // echo "deb http://security.ubuntu.com/ubuntu focal-security main" | tee /etc/apt/sources.list.d/focal-security.list;
127
+ // apt-get update;
128
+ // apt-get install libssl1.1;
129
+ // rm /etc/apt/sources.list.d/focal-security.list;
130
+ // curl -fsSL https://www.mongodb.org/static/pgp/server-4.4.asc | apt-key add -;
131
+ // echo "deb http://security.ubuntu.com/ubuntu impish-security main" | tee /etc/apt/sources.list.d/impish-security.list;
132
+ // echo "deb [ arch=amd64,arm64 ] https://repo.mongodb.org/apt/ubuntu bionic/mongodb-org/4.4 multiverse" | tee /etc/apt/sources.list.d/mongodb-org-4.4.list;
133
+ // apt-get update;
134
+ // apt-get install -y mongodb-org;
135
+ // systemctl enable mongod.service;
136
+ // systemctl start mongod;
137
+ // `;
138
+ // // checking if nginx configuration exists
139
+ // async domainNginxConfigExists(host: string): Promise<boolean> {
140
+ // try {
141
+ // let result = await this.exec(
142
+ // `ls ${this.DOMAIN_HOME}/${host}.nginx.ssl.conf`
143
+ // );
144
+ // if (result.includes("No such file or directory")) return false;
145
+ // } catch (e) {
146
+ // console.error(e);
147
+ // }
148
+ // return true;
149
+ // }
150
+ // // checking if the ssl certificate exists
151
+ // async domainNginxCertsExist(host: string): Promise<boolean> {
152
+ // try {
153
+ // let result = await this.exec(`ls /etc/letsencrypt/live/${host}`);
154
+ // if (result.includes("No such file or directory")) return false;
155
+ // } catch (e) {
156
+ // console.error(e);
157
+ // }
158
+ // return true;
159
+ // }
160
+ // // Certbot CRON
161
+ // async isCerbotActive(): Promise<boolean> {
162
+ // try {
163
+ // let result = await this.exec("which certbot");
164
+ // if (result.includes("/usr/bin/certbot")) return true;
165
+ // } catch (e) {
166
+ // console.error(e);
167
+ // }
168
+ // return false;
169
+ // }
170
+ // // install certbot
171
+ // async setupCertbot(): Promise<boolean> {
172
+ // await this?.ssh?.execCommand(`apt-get install -y certbot python3-certbot-nginx;`);
173
+ // return true;
174
+ // }
175
+ // async setupSSL(email: string, host: string): Promise<void> {
176
+ // // Прямий виклик this?.ssh?.execCommand
177
+ // let certbotResponse = await this?.ssh?.execCommand(
178
+ // `certbot --non-interactive --agree-tos --nginx -m "${email}" -d "${host}"`
179
+ // );
180
+ // if (certbotResponse?.stdout.includes(`Some challenges have failed.`)) {
181
+ // throw new Error("Certbot encountered an error");
182
+ // }
183
+ // await this?.ssh?.execCommand(
184
+ // `echo "0 12 * * * /usr/bin/certbot renew --quiet" | crontab -`
185
+ // );
186
+ // }
187
+ // // Git
188
+ // async refresh(): Promise<boolean> {
189
+ // await this.exec(`git stash; rm-rf built; git pull`);
190
+ // return true;
191
+ // }
192
+ // async uploadDirectoryToSftp(
193
+ // localPath: string,
194
+ // remotePath: string,
195
+ // sftpConfig: any) {
196
+ // // const sftp = new Client();
197
+ // try {
198
+ // // await sftp.connect(sftpConfig);
199
+ // const stats = fs.statSync(localPath);
200
+ // if (stats.isDirectory()) {
201
+ // // Якщо це директорія
202
+ // // await sftp.mkdir(remotePath, true).catch(async (err) => {
203
+ // // if (err.code !== 4) { // Ігноруємо помилку "Directory already exists"
204
+ // // console.error(`Помилка під час створення папки: ${remotePath}`, err);
205
+ // // throw err;
206
+ // // }
207
+ // // });
208
+ // const items = fs.readdirSync(localPath, { withFileTypes: true });
209
+ // for (const item of items) {
210
+ // const localItemPath = path.join(localPath, item.name);
211
+ // const remoteItemPath = `${remotePath}/${item.name}`;
212
+ // if (item.isDirectory()) {
213
+ // await this.uploadDirectoryToSftp(localItemPath, remoteItemPath, sftpConfig);
214
+ // } else {
215
+ // // await sftp.put(localItemPath, remoteItemPath);
216
+ // console.log(`Передано файл: ${localItemPath} -> ${remoteItemPath}`);
217
+ // }
218
+ // }
219
+ // } else if (stats.isFile()) {
220
+ // // Якщо це файл
221
+ // // await sftp.put(localPath, remotePath);
222
+ // console.log(`Передано файл: ${localPath} -> ${remotePath}`);
223
+ // }
224
+ // console.log('Усі файли та папки успішно передані.');
225
+ // } catch (err) {
226
+ // console.error('Помилка під час передавання файлів через SFTP:', err);
227
+ // } finally {
228
+ // // await sftp.end();
229
+ // }
230
+ // }
231
+ // ensureDirectoryExistence(dirPath: string) {
232
+ // if (!fs.existsSync(dirPath)) {
233
+ // fs.mkdirSync(dirPath, { recursive: true });
234
+ // }
235
+ // }
236
+ // async generateNginxConfig(domain: string, rootPath: string): Promise<string> {
237
+ // const templatePath = path.join(
238
+ // __dirname,
239
+ // "..",
240
+ // "templates",
241
+ // "nginx-template.conf"
242
+ // );
243
+ // const template = fs.readFileSync(templatePath, "utf8");
244
+ // let config = mustache.render(template, { domain, rootPath });
245
+ // // Заміна закодованих символів назад на їх оригінальні значення
246
+ // config = config.replace(/&#x2F;/g, '/');
247
+ // return config;
248
+ // }
249
+ // async extractUploadedZip(name: string, file: any, extractToPath: string) {
250
+ // const zipFilePath = file.path;
251
+ // const outputDir = path.join(extractToPath, name);
252
+ // console.log('Looking for ZIP file at:', zipFilePath);
253
+ // console.log('Extracting to:', outputDir);
254
+ // this.ensureDirectoryExistence(outputDir);
255
+ // if (!fs.existsSync(zipFilePath)) {
256
+ // console.error('Error: File not found:', zipFilePath);
257
+ // return;
258
+ // }
259
+ // try {
260
+ // await new Promise((resolve, reject) => {
261
+ // fs.createReadStream(zipFilePath)
262
+ // .pipe(unzipper.Parse())
263
+ // .on('entry', (entry) => {
264
+ // // Видаляємо перший сегмент шляху, щоб уникнути кореневої директорії
265
+ // const entryPath = path.join(
266
+ // outputDir,
267
+ // ...entry.path.split('/').slice(1)
268
+ // );
269
+ // if (entry.type === 'Directory') {
270
+ // this.ensureDirectoryExistence(entryPath);
271
+ // } else {
272
+ // this.ensureDirectoryExistence(path.dirname(entryPath));
273
+ // entry.pipe(fs.createWriteStream(entryPath));
274
+ // }
275
+ // })
276
+ // .on('close', resolve)
277
+ // .on('error', reject);
278
+ // });
279
+ // console.log('File successfully extracted.');
280
+ // } catch (err) {
281
+ // console.error('Error extracting file:', err);
282
+ // }
283
+ // }
284
+ // async ensureDirectoryExistsViaSSH(remoteDir: string) {
285
+ // try {
286
+ // // Перевірка, чи існує директорія, і створення її, якщо вона не існує
287
+ // const command = `if [ ! -d "${remoteDir}" ]; then mkdir -p "${remoteDir}"; fi`;
288
+ // await this?.ssh?.execCommand(command);
289
+ // console.log(`Перевірено або створено папку: ${remoteDir}`);
290
+ // } catch (err) {
291
+ // console.error(
292
+ // 'Помилка під час перевірки або створення папки через SSH:',
293
+ // err
294
+ // );
295
+ // throw err;
296
+ // } finally {
297
+ // this?.ssh?.dispose();
298
+ // }
299
+ // }
300
+ // async disconnectSSH(): Promise<void> {
301
+ // this?.ssh?.dispose();
302
+ // }
303
+ // }