@griddo/cx 11.7.5 → 11.7.6-rc.1

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 (300) hide show
  1. package/README.md +25 -228
  2. package/build/adapters/gatsby/actions/clean.js +10 -0
  3. package/build/adapters/gatsby/actions/clean.js.map +1 -0
  4. package/build/adapters/gatsby/actions/close.js +12 -0
  5. package/build/adapters/gatsby/actions/close.js.map +1 -0
  6. package/build/adapters/gatsby/actions/data.js +18 -0
  7. package/build/adapters/gatsby/actions/data.js.map +1 -0
  8. package/build/adapters/gatsby/actions/healthCheck.js +10 -0
  9. package/build/adapters/gatsby/actions/healthCheck.js.map +1 -0
  10. package/build/adapters/gatsby/actions/init.js +9 -0
  11. package/build/adapters/gatsby/actions/init.js.map +1 -0
  12. package/build/adapters/gatsby/actions/meta.js +14 -0
  13. package/build/adapters/gatsby/actions/meta.js.map +1 -0
  14. package/build/adapters/gatsby/actions/prepare.js +9 -0
  15. package/build/adapters/gatsby/actions/prepare.js.map +1 -0
  16. package/build/adapters/gatsby/actions/relocation.js +15 -0
  17. package/build/adapters/gatsby/actions/relocation.js.map +1 -0
  18. package/build/adapters/gatsby/actions/restore.js +26 -0
  19. package/build/adapters/gatsby/actions/restore.js.map +1 -0
  20. package/build/adapters/gatsby/actions/ssg.js +9 -0
  21. package/build/adapters/gatsby/actions/ssg.js.map +1 -0
  22. package/build/adapters/gatsby/actions/sync.js +50 -0
  23. package/build/adapters/gatsby/actions/sync.js.map +1 -0
  24. package/build/adapters/gatsby/index.js +74 -0
  25. package/build/adapters/gatsby/index.js.map +1 -0
  26. package/build/adapters/gatsby/shared/context.js +25 -0
  27. package/build/adapters/gatsby/shared/context.js.map +1 -0
  28. package/build/adapters/gatsby/shared/extract-assets.js +58 -0
  29. package/build/adapters/gatsby/shared/extract-assets.js.map +1 -0
  30. package/build/adapters/gatsby/shared/gatsby-build.js +49 -0
  31. package/build/adapters/gatsby/shared/gatsby-build.js.map +1 -0
  32. package/build/adapters/gatsby/shared/sync-render.js +208 -0
  33. package/build/adapters/gatsby/shared/sync-render.js.map +1 -0
  34. package/build/adapters/gatsby/shared/types.js +3 -0
  35. package/build/adapters/gatsby/shared/types.js.map +1 -0
  36. package/build/commands/end-render.js +63 -0
  37. package/build/commands/end-render.js.map +1 -0
  38. package/build/commands/prepare-assets-directory.js +32 -0
  39. package/build/commands/prepare-assets-directory.js.map +1 -0
  40. package/build/commands/prepare-domains-render.js +138 -0
  41. package/build/commands/prepare-domains-render.js.map +1 -0
  42. package/build/commands/reset-render.js +22 -0
  43. package/build/commands/reset-render.js.map +1 -0
  44. package/build/commands/start-render.js +35 -0
  45. package/build/commands/start-render.js.map +1 -0
  46. package/build/commands/upload-search-content.js +189 -0
  47. package/build/commands/upload-search-content.js.map +1 -0
  48. package/build/constants/endpoints.js +42 -0
  49. package/build/constants/endpoints.js.map +1 -0
  50. package/build/constants/envs.js +73 -0
  51. package/build/constants/envs.js.map +1 -0
  52. package/build/constants/errors.js +89 -0
  53. package/build/constants/errors.js.map +1 -0
  54. package/build/exporter/adapters/gatsby/actions/clean.d.ts +3 -0
  55. package/build/exporter/adapters/gatsby/actions/close.d.ts +3 -0
  56. package/build/exporter/adapters/gatsby/actions/data.d.ts +2 -0
  57. package/build/exporter/adapters/gatsby/actions/healthCheck.d.ts +2 -0
  58. package/build/exporter/adapters/gatsby/actions/init.d.ts +2 -0
  59. package/build/exporter/adapters/gatsby/actions/meta.d.ts +2 -0
  60. package/build/exporter/adapters/gatsby/actions/prepare.d.ts +2 -0
  61. package/build/exporter/adapters/gatsby/actions/relocation.d.ts +2 -0
  62. package/build/exporter/adapters/gatsby/actions/restore.d.ts +3 -0
  63. package/build/exporter/adapters/gatsby/actions/ssg.d.ts +3 -0
  64. package/build/exporter/adapters/gatsby/actions/sync.d.ts +3 -0
  65. package/build/exporter/adapters/gatsby/index.d.ts +9 -0
  66. package/build/exporter/adapters/gatsby/shared/context.d.ts +38 -0
  67. package/build/exporter/adapters/gatsby/shared/extract-assets.d.ts +7 -0
  68. package/build/exporter/adapters/gatsby/shared/gatsby-build.d.ts +7 -0
  69. package/build/exporter/adapters/gatsby/shared/sync-render.d.ts +36 -0
  70. package/build/exporter/adapters/gatsby/shared/types.d.ts +34 -0
  71. package/build/exporter/commands/start-render.d.ts +2 -0
  72. package/build/exporter/commands/upload-search-content.d.ts +2 -0
  73. package/build/{constants → exporter/constants}/envs.d.ts +1 -7
  74. package/build/{errors/errors-data.d.ts → exporter/constants/errors.d.ts} +5 -3
  75. package/build/{services → exporter/services}/auth.d.ts +1 -1
  76. package/build/exporter/services/db.d.ts +4 -0
  77. package/build/{services → exporter/services}/robots.d.ts +0 -6
  78. package/build/{services → exporter/services}/sites.d.ts +5 -2
  79. package/build/exporter/services/store.d.ts +15 -0
  80. package/build/{types → exporter/types}/api.d.ts +3 -4
  81. package/build/{types → exporter/types}/global.d.ts +6 -6
  82. package/build/{types → exporter/types}/navigation.d.ts +1 -1
  83. package/build/exporter/types/render.d.ts +50 -0
  84. package/build/{types → exporter/types}/sites.d.ts +1 -2
  85. package/build/exporter/utils/artifacts.d.ts +6 -0
  86. package/build/exporter/utils/brush.d.ts +18 -0
  87. package/build/{utils → exporter/utils}/cache.d.ts +7 -12
  88. package/build/{utils/health-checks.d.ts → exporter/utils/check-health.d.ts} +2 -2
  89. package/build/exporter/utils/core-utils.d.ts +77 -0
  90. package/build/{utils → exporter/utils}/domains.d.ts +1 -1
  91. package/build/{errors/index.d.ts → exporter/utils/errors.d.ts} +3 -3
  92. package/build/exporter/utils/folders.d.ts +66 -0
  93. package/build/{utils → exporter/utils}/loggin.d.ts +2 -16
  94. package/build/{utils → exporter/utils}/pages.d.ts +2 -2
  95. package/build/exporter/utils/render.d.ts +49 -0
  96. package/build/{utils → exporter/utils}/sites.d.ts +3 -3
  97. package/build/{utils → exporter/utils}/store.d.ts +10 -38
  98. package/build/services/auth.js +39 -0
  99. package/build/services/auth.js.map +1 -0
  100. package/build/services/db.js +34 -0
  101. package/build/services/db.js.map +1 -0
  102. package/build/services/navigation.js +93 -0
  103. package/build/services/navigation.js.map +1 -0
  104. package/build/services/reference-fields.js +131 -0
  105. package/build/services/reference-fields.js.map +1 -0
  106. package/build/services/robots.js +58 -0
  107. package/build/services/robots.js.map +1 -0
  108. package/build/services/sites.js +109 -0
  109. package/build/services/sites.js.map +1 -0
  110. package/build/services/store.js +282 -0
  111. package/build/services/store.js.map +1 -0
  112. package/build/types/api.js +3 -0
  113. package/build/types/api.js.map +1 -0
  114. package/build/types/global.js +3 -0
  115. package/build/types/global.js.map +1 -0
  116. package/build/types/navigation.js +3 -0
  117. package/build/types/navigation.js.map +1 -0
  118. package/build/types/pages.js +3 -0
  119. package/build/types/pages.js.map +1 -0
  120. package/build/types/render.js +10 -0
  121. package/build/types/render.js.map +1 -0
  122. package/build/types/sites.js +3 -0
  123. package/build/types/sites.js.map +1 -0
  124. package/build/types/templates.js +3 -0
  125. package/build/types/templates.js.map +1 -0
  126. package/build/utils/api.js +161 -0
  127. package/build/utils/api.js.map +1 -0
  128. package/build/utils/artifacts.js +34 -0
  129. package/build/utils/artifacts.js.map +1 -0
  130. package/build/utils/brush.js +30 -0
  131. package/build/utils/brush.js.map +1 -0
  132. package/build/utils/cache.js +106 -0
  133. package/build/utils/cache.js.map +1 -0
  134. package/build/utils/check-health.js +68 -0
  135. package/build/utils/check-health.js.map +1 -0
  136. package/build/utils/core-utils.js +251 -0
  137. package/build/utils/core-utils.js.map +1 -0
  138. package/build/utils/domains.js +37 -0
  139. package/build/utils/domains.js.map +1 -0
  140. package/build/utils/errors.js +30 -0
  141. package/build/utils/errors.js.map +1 -0
  142. package/build/utils/folders.js +339 -0
  143. package/build/utils/folders.js.map +1 -0
  144. package/build/utils/images.js +45 -0
  145. package/build/utils/images.js.map +1 -0
  146. package/build/utils/instance.js +66 -0
  147. package/build/utils/instance.js.map +1 -0
  148. package/build/utils/loggin.js +102 -0
  149. package/build/utils/loggin.js.map +1 -0
  150. package/build/utils/pages.js +359 -0
  151. package/build/utils/pages.js.map +1 -0
  152. package/build/utils/render.js +144 -0
  153. package/build/utils/render.js.map +1 -0
  154. package/build/utils/sites.js +239 -0
  155. package/build/utils/sites.js.map +1 -0
  156. package/build/utils/store.js +193 -0
  157. package/build/utils/store.js.map +1 -0
  158. package/exporter/adapters/gatsby/actions/clean.ts +14 -0
  159. package/exporter/adapters/gatsby/actions/close.ts +17 -0
  160. package/exporter/adapters/gatsby/actions/data.ts +25 -0
  161. package/exporter/adapters/gatsby/actions/healthCheck.ts +10 -0
  162. package/exporter/adapters/gatsby/actions/init.ts +12 -0
  163. package/exporter/adapters/gatsby/actions/meta.ts +18 -0
  164. package/exporter/adapters/gatsby/actions/prepare.ts +9 -0
  165. package/exporter/adapters/gatsby/actions/relocation.ts +15 -0
  166. package/exporter/adapters/gatsby/actions/restore.ts +36 -0
  167. package/exporter/adapters/gatsby/actions/ssg.ts +12 -0
  168. package/exporter/adapters/gatsby/actions/sync.ts +70 -0
  169. package/exporter/adapters/gatsby/index.ts +60 -146
  170. package/exporter/adapters/gatsby/shared/context.ts +50 -0
  171. package/exporter/adapters/gatsby/shared/extract-assets.ts +61 -0
  172. package/exporter/adapters/gatsby/shared/gatsby-build.ts +54 -0
  173. package/exporter/adapters/gatsby/shared/sync-render.ts +294 -0
  174. package/exporter/adapters/gatsby/shared/types.ts +35 -0
  175. package/exporter/build-esbuild.noop +42 -0
  176. package/exporter/build.sh +5 -38
  177. package/exporter/commands/end-render.ts +56 -81
  178. package/exporter/commands/prepare-assets-directory.ts +33 -0
  179. package/exporter/commands/prepare-domains-render.ts +149 -31
  180. package/exporter/commands/reset-render.ts +12 -3
  181. package/exporter/commands/start-render.ts +18 -47
  182. package/exporter/commands/upload-search-content.ts +206 -21
  183. package/exporter/constants/envs.ts +59 -51
  184. package/exporter/{errors/errors-data.ts → constants/errors.ts} +24 -15
  185. package/exporter/services/auth.ts +7 -6
  186. package/exporter/services/db.ts +32 -0
  187. package/exporter/services/navigation.ts +4 -10
  188. package/exporter/services/reference-fields.ts +8 -23
  189. package/exporter/services/robots.ts +8 -15
  190. package/exporter/services/sites.ts +35 -24
  191. package/exporter/services/store.ts +118 -76
  192. package/exporter/types/api.ts +24 -27
  193. package/exporter/types/global.ts +8 -10
  194. package/exporter/types/navigation.ts +1 -1
  195. package/exporter/types/pages.ts +2 -3
  196. package/exporter/types/render.ts +59 -0
  197. package/exporter/types/sites.ts +1 -2
  198. package/exporter/utils/api.ts +46 -82
  199. package/exporter/{artifacts/index.ts → utils/artifacts.ts} +9 -8
  200. package/exporter/utils/brush.ts +34 -0
  201. package/exporter/utils/cache.ts +34 -59
  202. package/exporter/utils/check-health.ts +79 -0
  203. package/exporter/utils/core-utils.ts +86 -247
  204. package/exporter/utils/domains.ts +10 -7
  205. package/exporter/{errors/index.ts → utils/errors.ts} +10 -9
  206. package/exporter/utils/folders.ts +161 -92
  207. package/exporter/utils/images.ts +1 -6
  208. package/exporter/utils/instance.ts +9 -12
  209. package/exporter/utils/loggin.ts +24 -89
  210. package/exporter/utils/pages.ts +23 -88
  211. package/exporter/utils/render.ts +147 -48
  212. package/exporter/utils/sites.ts +67 -77
  213. package/exporter/utils/store.ts +85 -178
  214. package/gatsby-browser.tsx +41 -58
  215. package/gatsby-config.ts +6 -12
  216. package/gatsby-node.ts +15 -77
  217. package/gatsby-ssr.tsx +2 -1
  218. package/package.json +33 -74
  219. package/plugins/gatsby-plugin-svgr-loader/gatsby-node.js +55 -0
  220. package/plugins/gatsby-plugin-svgr-loader/package.json +8 -0
  221. package/{exporter/react → react}/Favicon/index.tsx +1 -7
  222. package/{exporter/react → react}/GriddoIntegrations/index.tsx +6 -14
  223. package/{exporter/react → react}/GriddoIntegrations/utils.ts +4 -9
  224. package/{build/react/index.d.ts → react/index.tsx} +1 -0
  225. package/src/components/Head.tsx +13 -46
  226. package/src/components/template.tsx +8 -30
  227. package/src/gatsby-node-utils.ts +91 -2
  228. package/src/html.tsx +2 -11
  229. package/src/types.ts +5 -5
  230. package/start-render.js +1 -3
  231. package/tsconfig.json +3 -2
  232. package/build/adapters/gatsby/index.d.ts +0 -4
  233. package/build/adapters/gatsby/utils.d.ts +0 -22
  234. package/build/artifacts/index.d.ts +0 -6
  235. package/build/commands/move-assets.d.ts +0 -1
  236. package/build/commands/prepare-domains-render.d.ts +0 -1
  237. package/build/constants/index.d.ts +0 -57
  238. package/build/end-render.js +0 -74
  239. package/build/end-render.js.map +0 -7
  240. package/build/index.d.ts +0 -29
  241. package/build/index.js +0 -73
  242. package/build/index.js.map +0 -7
  243. package/build/prepare-domains-render.js +0 -73
  244. package/build/prepare-domains-render.js.map +0 -7
  245. package/build/react/Favicon/index.d.ts +0 -5
  246. package/build/react/Favicon/utils.d.ts +0 -9
  247. package/build/react/GriddoIntegrations/index.d.ts +0 -20
  248. package/build/react/GriddoIntegrations/utils.d.ts +0 -26
  249. package/build/react/index.js +0 -3
  250. package/build/registers/api.d.ts +0 -9
  251. package/build/registers/gatsby.d.ts +0 -9
  252. package/build/registers/index.d.ts +0 -3
  253. package/build/reset-render.js +0 -74
  254. package/build/reset-render.js.map +0 -7
  255. package/build/services/domains.d.ts +0 -6
  256. package/build/services/register.d.ts +0 -36
  257. package/build/services/settings.d.ts +0 -4
  258. package/build/services/store.d.ts +0 -6
  259. package/build/start-render.js +0 -100
  260. package/build/start-render.js.map +0 -7
  261. package/build/upload-search-content.js +0 -74
  262. package/build/upload-search-content.js.map +0 -7
  263. package/build/utils/alerts.d.ts +0 -3
  264. package/build/utils/core-utils.d.ts +0 -107
  265. package/build/utils/create-build-data.d.ts +0 -8
  266. package/build/utils/folders.d.ts +0 -53
  267. package/build/utils/render.d.ts +0 -13
  268. package/build/utils/searches.d.ts +0 -15
  269. package/cx.config.d.ts +0 -5
  270. package/cx.config.js +0 -36
  271. package/exporter/adapters/gatsby/utils.ts +0 -161
  272. package/exporter/artifacts/README.md +0 -34
  273. package/exporter/commands/move-assets.ts +0 -11
  274. package/exporter/constants/index.ts +0 -129
  275. package/exporter/index.ts +0 -82
  276. package/exporter/react/index.tsx +0 -11
  277. package/exporter/registers/api.ts +0 -14
  278. package/exporter/registers/gatsby.ts +0 -14
  279. package/exporter/registers/index.ts +0 -4
  280. package/exporter/services/domains.ts +0 -16
  281. package/exporter/services/register.ts +0 -113
  282. package/exporter/services/settings.ts +0 -17
  283. package/exporter/utils/alerts.ts +0 -29
  284. package/exporter/utils/create-build-data.ts +0 -17
  285. package/exporter/utils/health-checks.ts +0 -64
  286. package/exporter/utils/searches.ts +0 -179
  287. package/src/README.md +0 -7
  288. package/build/{commands → exporter/commands}/end-render.d.ts +0 -0
  289. package/build/{commands/reset-render.d.ts → exporter/commands/prepare-assets-directory.d.ts} +0 -0
  290. package/build/{commands/start-render.d.ts → exporter/commands/prepare-domains-render.d.ts} +0 -0
  291. package/build/{commands/upload-search-content.d.ts → exporter/commands/reset-render.d.ts} +0 -0
  292. package/build/{constants → exporter/constants}/endpoints.d.ts +0 -0
  293. package/build/{services → exporter/services}/navigation.d.ts +0 -0
  294. package/build/{services → exporter/services}/reference-fields.d.ts +0 -0
  295. package/build/{types → exporter/types}/pages.d.ts +1 -1
  296. /package/build/{types → exporter/types}/templates.d.ts +0 -0
  297. /package/build/{utils → exporter/utils}/api.d.ts +0 -0
  298. /package/build/{utils → exporter/utils}/images.d.ts +0 -0
  299. /package/build/{utils → exporter/utils}/instance.d.ts +0 -0
  300. /package/{exporter/react → react}/Favicon/utils.ts +0 -0
@@ -1,46 +1,164 @@
1
- import fs from "node:fs";
1
+ #!/usr/bin/env node
2
+
3
+ import type { RenderDB } from "../types/render";
4
+
5
+ import fsp from "node:fs/promises";
2
6
  import path from "node:path";
3
7
 
4
- import { getConfig } from "../utils/core-utils";
8
+ import { version as griddoVersion } from "../../package.json";
9
+ import { AuthService } from "../services/auth";
10
+ import { readDB, writeDB } from "../services/db";
11
+ import { doLifeCycle } from "../utils/core-utils";
5
12
  import { getInstanceDomains } from "../utils/domains";
6
- import { infoLog, successLog } from "../utils/loggin";
13
+ import { pathExists, pkgDir, removeDirs } from "../utils/folders";
14
+ import { resolveComponentsPath } from "../utils/instance";
15
+ import { showExporterVersion } from "../utils/loggin";
16
+ import { resolveDomainRenderMode } from "../utils/render";
7
17
  import { getSitesToRender } from "../utils/sites";
8
18
 
9
- (async () => {
10
- infoLog("Checking domains size");
19
+ async function getDomainsWithNumberOfPages(domains: Array<string>) {
20
+ const results = await Promise.all(
21
+ domains.map(async (domain) => {
22
+ // Get the sites to render for the domain
23
+ const { sitesToPublish, sitesToUnpublish } = await getSitesToRender(domain);
11
24
 
12
- const { __cx } = getConfig().paths();
25
+ // Only count pages (offlinePending && publishPending) if sitesToPublish
26
+ // is not empty. Otherwise we set the domain has having 0 pages.
27
+ const pages: Array<number> = [];
13
28
 
14
- const domains = await getInstanceDomains();
15
- const domainsInfo = [];
16
- const domainsFilePath = path.join(__cx, "domains.json");
17
-
18
- for (const domain of domains) {
19
- const { sitesToPublish } = await getSitesToRender(domain);
20
-
21
- // Only count pages (changedPages) if sitesToPublish is not empty.
22
- // Otherwise we set the domain has having 0 pages.
23
- const pages = [];
24
- if (sitesToPublish.length > 0) {
25
- for (const site of sitesToPublish) {
26
- pages.push(site.changedPages.length);
29
+ if (sitesToPublish.length > 0) {
30
+ for (const site of sitesToPublish) {
31
+ // el site ya está publicado
32
+ if (site.isPublished && !site.shouldBeUpdated) {
33
+ const { pagesStatus } = site;
34
+ const { offlinePending, uploadPending } = pagesStatus;
35
+ const total = offlinePending.length + uploadPending.length;
36
+ pages.push(total);
37
+ }
38
+ // el site esta pendiente de publicar
39
+ if (site.isPublished && site.shouldBeUpdated) {
40
+ const { pagesStatus } = site;
41
+ const { offlinePending, uploadPending, active } = pagesStatus;
42
+ const total = offlinePending.length + uploadPending.length + active.length;
43
+ pages.push(total);
44
+ }
45
+ }
46
+ } else if (sitesToUnpublish.length > 0) {
47
+ // si tiene sites para despublicar marcamos el dominio como que tiene 1 página
48
+ pages.push(1);
49
+ } else {
50
+ // si eldominio no tiene nada ni para publicar ni despublicar lomarcamos como 0
51
+ pages.push(0);
27
52
  }
28
- } else {
29
- pages.push(0);
30
- }
31
53
 
32
- const totalPages = pages.reduce((a, b) => a + b);
33
- domainsInfo.push({ domain, totalPages });
34
- }
54
+ const totalPages = pages.reduce((a, b) => a + b);
55
+
56
+ return { domain, totalPages };
57
+ }),
58
+ );
59
+
60
+ return results;
61
+ }
35
62
 
36
- // sort domains, smaller first
63
+ function getDomainsSortedByNumberOfPages(
64
+ domainsInfo: Array<{
65
+ domain: string;
66
+ totalPages: number;
67
+ }>,
68
+ ) {
37
69
  domainsInfo.sort((a, b) => a.totalPages - b.totalPages);
38
- const domainSorted = domainsInfo.map(({ domain }) => domain);
39
70
 
40
- fs.writeFileSync(domainsFilePath, JSON.stringify(domainSorted));
71
+ return domainsInfo.map(({ domain }) => domain);
72
+ }
73
+
74
+ async function initRenderAction() {
75
+ const root = (await pkgDir({ cwd: path.resolve(__dirname, "../../..") })) || "";
76
+ const cx = root;
77
+ const ssg = path.resolve((await pkgDir({ cwd: __dirname })) || "");
78
+ const cxCache = path.resolve(cx, ".cx-cache");
79
+ const components = resolveComponentsPath();
80
+ const exportsDir = path.join(root, "exports/sites");
81
+
82
+ const data: RenderDB = {
83
+ proDomain: "pro-",
84
+ griddoVersion,
85
+ buildReportFileName: "build-report.json",
86
+ sortedDomains: [],
87
+ domains: {},
88
+ paths: {
89
+ components,
90
+ cx,
91
+ cxCache,
92
+ exportsDir,
93
+ root: root,
94
+ ssg,
95
+ },
96
+ };
97
+
98
+ // create the main cache folder for cx if it doesn't exist.
99
+ if (!(await pathExists(cxCache))) {
100
+ await fsp.mkdir(cxCache, { recursive: true });
101
+ }
102
+
103
+ await writeDB(data);
104
+ }
105
+
106
+ async function prepareDomainsAction() {
107
+ await AuthService.login();
108
+
109
+ // read paths from db
110
+ const __ssg = (await readDB()).paths.ssg;
111
+
112
+ const domains = await getInstanceDomains();
113
+ const domainsWithNumberOfPages = await getDomainsWithNumberOfPages(domains);
114
+ const domainSorted = getDomainsSortedByNumberOfPages(domainsWithNumberOfPages);
115
+
116
+ // @deprecated use db.json (only for infra)
117
+ await fsp.writeFile(path.join(__ssg, "domains.json"), JSON.stringify(domainSorted));
118
+
119
+ // new behavior
120
+ const db = await readDB();
121
+ db.sortedDomains = domainSorted;
122
+ db.domains = {};
123
+ await writeDB(db);
124
+
125
+ for (const { domain, totalPages } of domainsWithNumberOfPages) {
126
+ const shouldBeRendered = totalPages > 0;
127
+ const { renderMode, reason } = await resolveDomainRenderMode({
128
+ domain,
129
+ shouldBeRendered,
130
+ });
131
+
132
+ // Update DB
133
+ const db = await readDB();
134
+ db.domains[domain] = db.domains[domain] || {};
135
+ db.domains[domain].renderMode = renderMode;
136
+ db.domains[domain].shouldBeRendered = shouldBeRendered;
137
+ db.domains[domain].renderModeReason = reason;
138
+ await writeDB(db);
139
+ }
140
+ }
141
+
142
+ async function cleanAction() {
143
+ const db = await readDB();
144
+ const { cx: __cx } = db.paths;
145
+ await removeDirs([path.join(__cx, "apiCache")]);
146
+ }
147
+
148
+ /**
149
+ * Prepare domains to render.
150
+ * It creates a `domains.json` file with the sorted list of domains and writes a
151
+ * `RENDE-STATE.json` file to persist a state between all cx-infra commands.
152
+ */
153
+ async function main() {
154
+ await showExporterVersion();
155
+
156
+ await doLifeCycle("InitRender", initRenderAction);
157
+ await doLifeCycle("PrepareDomains", prepareDomainsAction);
158
+ await doLifeCycle("Clean", cleanAction);
159
+ }
41
160
 
42
- successLog(`Checking domains size`);
43
- })().catch((err) => {
44
- console.error(err);
161
+ main().catch((err) => {
162
+ console.error("Error", err?.stdout?.toString() || err);
45
163
  process.exit(1);
46
164
  });
@@ -1,11 +1,20 @@
1
1
  #!/usr/bin/env node
2
2
 
3
+ import { RESET_RENDER } from "../constants/endpoints";
3
4
  import { AuthService } from "../services/auth";
4
- import { resetRender } from "../services/settings";
5
+ import { post } from "../utils/api";
6
+ import { doLifeCycle } from "../utils/core-utils";
5
7
 
6
- async function main() {
8
+ async function resetRenderAction() {
7
9
  await AuthService.login();
8
- await resetRender();
10
+ await post({
11
+ endpoint: RESET_RENDER,
12
+ useApiCacheDir: false,
13
+ });
14
+ }
15
+
16
+ async function main() {
17
+ await doLifeCycle("ResetRender", resetRenderAction);
9
18
  }
10
19
 
11
20
  main().catch((err) => {
@@ -1,55 +1,22 @@
1
1
  #!/usr/bin/env node
2
- import { renderDomainsWithGatsbyAdapter } from "../adapters/gatsby";
3
- import { RenderError } from "../errors";
4
- import { getInstanceDomains } from "../utils/domains";
5
- import { errorLabelLog, showExporterVersion } from "../utils/loggin";
6
- import { sendGriddoDefaultAlerts } from "../utils/render";
7
2
 
8
- const GRIDDO_RENDER_DOMAINS = process.env.GRIDDO_RENDER_DOMAINS || "";
9
- const RENDER_BY_DOMAIN = process.env.GRIDDO_RENDER_BY_DOMAINS || "";
3
+ import { gatsbyRenderDomain } from "../adapters/gatsby";
4
+ import { AuthService } from "../services/auth";
5
+ import { checkHealth } from "../utils/check-health";
6
+ import { doLifeCycle } from "../utils/core-utils";
7
+ import { RenderError } from "../utils/errors";
8
+ import { errorLabelLog } from "../utils/loggin";
10
9
 
11
- async function startRender() {
12
- try {
13
- // DOMAINS
14
- // This block is just for the local instance renders.
15
- if (GRIDDO_RENDER_DOMAINS) {
16
- console.log("USANDO EL .ENV");
17
- showExporterVersion();
18
- for (const domain of GRIDDO_RENDER_DOMAINS.split(",")) {
19
- await renderDomainsWithGatsbyAdapter(domain);
20
- }
21
- await sendGriddoDefaultAlerts();
22
- process.exit(0);
23
- }
24
-
25
- // This will render every domain opposed to the new logic of render each
26
- // domain separately.
27
- if (RENDER_BY_DOMAIN) {
28
- const domain = process.argv.splice(2)[0];
29
-
30
- if (!domain) {
31
- console.log("Needs the domain name argument");
32
- throw new RenderError();
33
- }
34
-
35
- showExporterVersion();
36
- await renderDomainsWithGatsbyAdapter(domain);
37
- await sendGriddoDefaultAlerts();
10
+ async function startRenderAction() {
11
+ checkHealth();
38
12
 
39
- process.exit(0);
40
- } else {
41
- showExporterVersion();
13
+ await AuthService.login();
42
14
 
43
- console.log("( Legacy Render Mode )\n");
44
-
45
- const domains = await getInstanceDomains();
15
+ try {
16
+ const [domain] = process.argv.slice(2);
17
+ await gatsbyRenderDomain(domain);
46
18
 
47
- for (const domain of domains) {
48
- await renderDomainsWithGatsbyAdapter(domain);
49
- await sendGriddoDefaultAlerts();
50
- }
51
- process.exit(0);
52
- }
19
+ return;
53
20
  } catch (error) {
54
21
  if (error instanceof RenderError) {
55
22
  errorLabelLog("GRIDDO_ERROR InternalCXError");
@@ -62,7 +29,11 @@ async function startRender() {
62
29
  }
63
30
  }
64
31
 
65
- startRender().catch((err) => {
32
+ async function main() {
33
+ await doLifeCycle("StartRender", startRenderAction);
34
+ }
35
+
36
+ main().catch((err) => {
66
37
  console.error("Error", err?.stdout?.toString() || err);
67
38
  process.exit(1);
68
39
  });
@@ -1,38 +1,223 @@
1
1
  #!/usr/bin/env node
2
2
 
3
- import fs from "node:fs";
3
+ import type { GatsbyPageData } from "../adapters/gatsby/shared/types";
4
+ import type { PostSearchInfoResponse } from "../types/api";
5
+ import type { AIEmbeddingsResponse, PostSearchInfoProps } from "../types/global";
4
6
 
5
- import { envs } from "../constants";
6
- import { getConfig } from "../utils/core-utils";
7
- import { getInstanceDomains } from "../utils/domains";
8
- import {
9
- startAIEmbeddings,
10
- uploadRenderedSearchContentToAPI,
11
- } from "../utils/searches";
7
+ import fsp from "node:fs/promises";
8
+ import path from "node:path";
9
+
10
+ import { AI_EMBEDDINGS, SEARCH } from "../constants/endpoints";
11
+ import { GRIDDO_AI_EMBEDDINGS, GRIDDO_SEARCH_FEATURE } from "../constants/envs";
12
+ import { ReadFromStoreError, UploadSearchError } from "../constants/errors";
13
+ import { AuthService } from "../services/auth";
14
+ import { readDB } from "../services/db";
15
+ import { post } from "../utils/api";
16
+ import { doLifeCycle } from "../utils/core-utils";
17
+ import { throwError } from "../utils/errors";
18
+ import { pathExists } from "../utils/folders";
19
+ import { getRenderMode, getRenderPathsFromDB } from "../utils/render";
20
+
21
+ /**
22
+ * Save in the BBDD the content of a page parsed without HTML tags.
23
+ *
24
+ * @param props Object with parts of the final page object to be saved in the BBDD.
25
+ */
26
+ async function postSearchInfo(props: PostSearchInfoProps) {
27
+ const { title, description, image, pageId, languageId, siteId, url, content, template } = props;
28
+
29
+ const response = await post<PostSearchInfoResponse>({
30
+ endpoint: SEARCH,
31
+ body: {
32
+ title,
33
+ description,
34
+ image,
35
+ pageId,
36
+ languageId,
37
+ siteId,
38
+ url,
39
+ template,
40
+ content,
41
+ },
42
+ useApiCacheDir: false,
43
+ });
44
+
45
+ return response;
46
+ }
47
+
48
+ function prepareHTMLContentForSearch(content: string): string {
49
+ // 1. Remove script, style, and other unwanted block tags and their content.
50
+ // The regex looks for <tag...>...</tag> where tag is one of the specified ones.
51
+ const tagsToRemove = ["meta", "link", "style", "script", "noscript", "nav", "header", "footer"];
52
+ const removeTagsRegex = new RegExp(`<(${tagsToRemove.join("|")})\\b[^>]*>.*?<\\/\\1>`, "gis");
53
+ let processedContent = content.replace(removeTagsRegex, "");
54
+
55
+ // 2. Strip all remaining HTML tags.
56
+ processedContent = processedContent.replace(/<[^>]+>/g, " ");
57
+
58
+ // 3. Normalize whitespace: replace multiple spaces/newlines with a single space and trim.
59
+ processedContent = processedContent.replace(/\s+/g, " ").trim();
60
+
61
+ return processedContent;
62
+ }
63
+
64
+ /**
65
+ * Function that search in the `/public` dir the content info of the pages and
66
+ * send it to the search table in the ddbb using the API.
67
+ * @todo Utilizar la carpeta page-data en lugar de la carpeta store puesto que
68
+ * esta ya no es persistente.
69
+ */
70
+ async function uploadRenderedSearchContentToAPI(options: {
71
+ htmlContentDir: string;
72
+ jsonContentDir: string;
73
+ }) {
74
+ const { htmlContentDir, jsonContentDir } = options;
75
+
76
+ if (!(await pathExists(jsonContentDir)) || !(await pathExists(htmlContentDir))) {
77
+ console.log(
78
+ `Skipping uploading content to the search endpoint because it has not exported sites.`,
79
+ );
12
80
 
13
- async function main() {
14
- if (!envs.GRIDDO_SEARCH_FEATURE) {
15
81
  return;
16
82
  }
17
83
 
18
- const domains = await getInstanceDomains();
19
- const config = getConfig();
20
- for (const domain of domains) {
21
- const { __exports_dist } = config.paths(domain);
84
+ // Get pages from gatsby page-data dir
85
+ const gatsbyPageDataPages = getPageDataPagesFromExports(jsonContentDir);
86
+
87
+ for await (const pageData of gatsbyPageDataPages) {
88
+ const { result } = pageData;
89
+ const { pageContext } = result;
90
+ const { page, openGraph, pageMetadata } = pageContext;
91
+
92
+ const { compose } = page.fullPath;
93
+
94
+ const htmlPath = path.resolve(`${htmlContentDir}/${compose}/index.html`);
95
+ const htmlContent = await fsp.readFile(htmlPath, "utf-8");
22
96
 
23
- // If __exports_dist has not exported sites (directories), it does not
24
- // upload search content.
25
- if (fs.existsSync(__exports_dist)) {
26
- await uploadRenderedSearchContentToAPI(__exports_dist, domain);
97
+ const pageObject: PostSearchInfoProps = {
98
+ siteId: page.site,
99
+ pageId: page.id,
100
+ // `pageMetadata.title` has already a fallback `metatitle ||
101
+ // pageTitle` so probably `title` never will be take the
102
+ // `openGraph?.title` value. Only when the `metatitle` and
103
+ // `pageTitle` are empty.
104
+ title: pageMetadata?.title || openGraph?.title,
105
+ languageId: page.language,
106
+ url: page.fullUrl,
107
+ template: page.template.templateType || page.templateId,
108
+ description: pageMetadata?.description || openGraph?.description,
109
+ image: openGraph.image,
110
+ // _content: prepareHTMLContentForSearch(htmlContent),
111
+ content: prepareHTMLContentForSearch(htmlContent),
112
+ };
113
+
114
+ try {
115
+ await postSearchInfo(pageObject);
116
+ } catch (error) {
117
+ throwError(UploadSearchError, error);
27
118
  }
28
119
  }
120
+ }
121
+
122
+ /**
123
+ * Walk recursively in a basePath and return an array of pages with json
124
+ * extension with the full absolute path and the path includes "page-data".
125
+ *
126
+ * @param basePath The path to walk recursively.
127
+ * @returns An array of pages with json extension with the full absolute path
128
+ * and the path includes "page-data".
129
+ */
130
+ async function* walkRecursively(basePath: string): AsyncGenerator<string> {
131
+ const filesHandle = await fsp.opendir(basePath);
29
132
 
30
- // Solo una vez en cada render de todos los dominios...
31
- if (envs.GRIDDO_AI_EMBEDDINGS) {
32
- await startAIEmbeddings();
133
+ for await (const fileDirent of filesHandle) {
134
+ if (fileDirent.isDirectory()) {
135
+ yield* walkRecursively(path.join(basePath, fileDirent.name));
136
+ } else if (
137
+ fileDirent.isFile() &&
138
+ path.extname(fileDirent.name) === ".json" &&
139
+ fileDirent.name.includes("page-data")
140
+ ) {
141
+ yield path.join(basePath, fileDirent.name);
142
+ }
33
143
  }
34
144
  }
35
145
 
146
+ /**
147
+ * Walk recursively in a basePath and return an array of pages with json
148
+ * extension with the full absolute path and the path includes "page-data".
149
+ *
150
+ * @param basePath The path to walk recursively.
151
+ * @returns An array of pages with json extension with the full absolute path
152
+ * and the path includes "page-data".
153
+ */
154
+ async function* getPageDataPagesFromExports<PageType extends GatsbyPageData>(
155
+ basePath: string,
156
+ ): AsyncGenerator<PageType> {
157
+ const jsonFiles = walkRecursively(basePath);
158
+
159
+ for await (const filePath of jsonFiles) {
160
+ try {
161
+ const fileContent = await fsp.readFile(filePath, "utf8");
162
+ const page = JSON.parse(fileContent) as PageType;
163
+
164
+ if (page.path) {
165
+ yield page;
166
+ }
167
+ } catch (error) {
168
+ throwError(ReadFromStoreError, error);
169
+ }
170
+ }
171
+ }
172
+
173
+ async function getContentDirectories(domain: string) {
174
+ const { __exports } = await getRenderPathsFromDB({ domain });
175
+
176
+ return {
177
+ htmlContentDir: path.join(__exports, "dist"),
178
+ jsonContentDir: path.join(__exports, "dist", "page-data"),
179
+ };
180
+ }
181
+
182
+ async function uploadSearchContent() {
183
+ const db = await readDB();
184
+ const domains = db.sortedDomains;
185
+ for (const domain of domains) {
186
+ const { renderMode } = await getRenderMode(domain);
187
+ if (renderMode !== "IDLE" && GRIDDO_SEARCH_FEATURE) {
188
+ const { htmlContentDir, jsonContentDir } = await getContentDirectories(domain);
189
+ await uploadRenderedSearchContentToAPI({
190
+ htmlContentDir,
191
+ jsonContentDir,
192
+ });
193
+ }
194
+ }
195
+ }
196
+
197
+ // async function uploadSearchContentByDomain(domain: string) {
198
+ // const renderMode = await getRenderMode(domain);
199
+ // if (renderMode !== "IDLE" && GRIDDO_SEARCH_FEATURE) {
200
+ // const { htmlContentDir, jsonContentDir } = await getContentDirectories(domain);
201
+ // await uploadRenderedSearchContentToAPI({ htmlContentDir, jsonContentDir });
202
+ // }
203
+ // }
204
+
205
+ async function aiEmbeddingsAction() {
206
+ if (GRIDDO_SEARCH_FEATURE && GRIDDO_AI_EMBEDDINGS) {
207
+ await AuthService.login();
208
+
209
+ await post<AIEmbeddingsResponse>({
210
+ endpoint: AI_EMBEDDINGS,
211
+ useApiCacheDir: false,
212
+ });
213
+ }
214
+ }
215
+
216
+ async function main() {
217
+ await doLifeCycle("UploadSearch", () => uploadSearchContent());
218
+ await doLifeCycle("AIEmbeddings", aiEmbeddingsAction);
219
+ }
220
+
36
221
  main().catch((err) => {
37
222
  console.error("Error", err?.stdout?.toString() || err);
38
223
  process.exit(1);