miolo 2.0.0-beta.3 → 2.0.0-beta.30

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 (37) hide show
  1. package/bin/build-client.mjs +21 -0
  2. package/bin/build-server.mjs +57 -0
  3. package/bin/create-bin.mjs +38 -0
  4. package/bin/dev.mjs +77 -0
  5. package/bin/index.mjs +70 -0
  6. package/bin/restart.mjs +12 -0
  7. package/bin/start.mjs +28 -0
  8. package/bin/stop.mjs +22 -0
  9. package/bin/util.mjs +37 -0
  10. package/dist/cli/miolo.cli.umd.js +236 -463
  11. package/dist/cli/miolo.cli.umd.js.map +1 -1
  12. package/dist/cli-react/miolo.cli-react.umd.js +280 -503
  13. package/dist/cli-react/miolo.cli-react.umd.js.map +1 -1
  14. package/dist/server/miolo.server.node.mjs +1180 -1190
  15. package/package.json +21 -28
  16. package/src/cli/fetcher/utils.mjs +1 -1
  17. package/src/cli-react/context/MioloContextProvider.jsx +27 -19
  18. package/src/cli-react/context/MioloContextProvider.mjs +23 -13
  19. package/src/server/config/defaults.mjs +9 -2
  20. package/src/server/engines/cron/emails.mjs +2 -2
  21. package/src/server/engines/cron/index.mjs +16 -16
  22. package/src/server/engines/cron/init.mjs +4 -4
  23. package/src/server/engines/cron/ipsum.mjs +1 -1
  24. package/src/server/engines/cron/syscheck.mjs +1 -1
  25. package/src/server/index.mjs +2 -0
  26. package/src/server/middleware/http/custom_blacklist.mjs +2 -1
  27. package/src/server/middleware/routes/router/crud/attachCrudRoutes.mjs +1 -1
  28. package/src/server/middleware/routes/router/queries/attachQueriesRoutes.mjs +1 -1
  29. package/src/server/middleware/vite/devserver.mjs +9 -1
  30. package/src/server/middleware/vite/watcher.mjs +42 -0
  31. package/src/server/server-cron.mjs +40 -0
  32. package/src/server/server-dev.mjs +2 -0
  33. package/src/server/server.mjs +6 -3
  34. package/src/cli/fetcher/v1.tar.gz +0 -0
  35. package/src/cli-react/_jsx.tar.gz +0 -0
  36. package/src/cli-react/ssr/hooks.tar.gz +0 -0
  37. package/src/server/middleware/ssr/_old.tar.gz +0 -0
@@ -0,0 +1,21 @@
1
+
2
+ import {xeiraBundle} from 'xeira'
3
+ //import { cleanFolder } from './util.mjs'
4
+
5
+ process.env.NODE_ENV = 'production'
6
+
7
+ export default async function(appName, entry, dest) {
8
+ console.log(`[${appName}][prod] Building client from entry ${entry}`)
9
+ //cleanFolder(dest)
10
+
11
+ // fs.copyFileSync(proot('./cli/index.html'), proot('./build/cli/index.html'))
12
+ await xeiraBundle({
13
+ source_index: entry,
14
+ target: 'browser',
15
+ bundle_folder: dest,
16
+ bundle_name: appName,
17
+ bundle_extension: 'iife.bundle.min',
18
+ bundler: 'rollup',
19
+ bundle_node_polyfill: true
20
+ })
21
+ }
@@ -0,0 +1,57 @@
1
+
2
+ import path from 'node:path'
3
+ import { readFile, writeFile} from 'node:fs/promises'
4
+ import { build } from 'vite'
5
+ import {xeiraBundle} from 'xeira'
6
+ //import { cleanFolder } from './util.mjs'
7
+
8
+ process.env.NODE_ENV = 'production'
9
+
10
+ export async function _fixProdBuild(appName, filePath) {
11
+ try {
12
+ const content = await readFile(filePath, 'utf8')
13
+ const newContent = content.replace(
14
+ /var key = crypto\.pseudoRandomBytes\(32\)/g,
15
+ 'var key = crypto.randomBytes(32)'
16
+ )
17
+ await writeFile(filePath, newContent, 'utf8')
18
+ console.log(`[${appName}][prod] Fixed server build (prod)!`)
19
+ } catch (error) {
20
+ console.error(`[${appName}][prod] Error fixing server build (prod): ${error}`)
21
+ }
22
+ }
23
+
24
+ export default async function(appName, ssrEntry, ssrDest, entry, dest) {
25
+ //cleanFolder(dest)
26
+
27
+ console.log(`[${appName}][prod] Building first the SSR entry ${ssrEntry}`)
28
+ await build({
29
+ build: {
30
+ outDir: path.resolve(process.cwd(), ssrDest),
31
+ ssr: path.resolve(process.cwd(), ssrEntry),
32
+ rollupOptions: {
33
+ //
34
+ },
35
+ },
36
+ // server ssr's entry must bundle externals
37
+ ssr: {
38
+ noExternal: true
39
+ }
40
+ })
41
+
42
+ console.log(`[${appName}][prod] Building server from entry ${entry}`)
43
+ const serverExt = 'node.bundle.mjs'
44
+ await xeiraBundle({
45
+ source_index: entry,
46
+ target: 'node',
47
+ bundle_folder: dest,
48
+ bundle_name: appName,
49
+ bundle_extension: serverExt,
50
+ bundler: 'rollup',
51
+ bundle_node_polyfill: true,
52
+ })
53
+
54
+ console.log(`[${appName}][prod] Fixing server build (prod)...`)
55
+ const destFile = path.join(process.cwd(), `${dest}/${appName}.${serverExt}`)
56
+ await _fixProdBuild(appName, destFile)
57
+ }
@@ -0,0 +1,38 @@
1
+ import {readFileSync, writeFileSync} from 'node:fs'
2
+ import path from 'path'
3
+ import { fileURLToPath } from 'url'
4
+
5
+ const __my_filename = fileURLToPath(import.meta.url)
6
+ const __my_dirname = path.dirname(__my_filename)
7
+
8
+
9
+ export default async function(appName, dest, serverName) {
10
+ console.log(`[${appName}][prod][create-bin] Creating bin files...`)
11
+
12
+ const readSource = (f) => readFileSync(path.resolve(__my_dirname, f), {encoding:'utf8'})
13
+ const writeDest = (f, content) => writeFileSync(path.join(process.cwd(), dest, f), content, {encoding:'utf8',flag:'w'})
14
+
15
+ const utilContent = readSource('./util.mjs')
16
+ writeDest('util.mjs', utilContent)
17
+
18
+ let startContent = readSource('./start.mjs')
19
+ startContent = startContent.replace('export default async function', 'async function start')
20
+ startContent = startContent.replace('(appName, dest, serverName)', `(appName= '${appName}', dest= '${dest}', serverName= '${serverName}')`)
21
+ startContent+= '\n'
22
+ startContent+= 'start()'
23
+ writeDest('start.mjs', startContent)
24
+
25
+ let stopContent = readSource('./stop.mjs')
26
+ stopContent = stopContent.replace('export default async function', 'async function stop')
27
+ stopContent = stopContent.replace('(appName)', `(appName= '${appName}')`)
28
+ stopContent+= '\n'
29
+ stopContent+= 'stop()'
30
+ writeDest('stop.mjs', stopContent)
31
+
32
+ let restartContent = readSource('./restart.mjs')
33
+ restartContent = restartContent.replace('export default async function', 'async function restart')
34
+ restartContent = restartContent.replace('(appName, dest, serverName)', `(appName= '${appName}', dest= '${dest}', serverName= '${serverName}')`)
35
+ restartContent+= '\n'
36
+ restartContent+= 'restart()'
37
+ writeDest('restart.mjs', restartContent)
38
+ }
package/bin/dev.mjs ADDED
@@ -0,0 +1,77 @@
1
+ import path from 'node:path'
2
+ import { fork } from 'node:child_process'
3
+
4
+ process.env.NODE_ENV = 'development'
5
+
6
+ let serverProcess = null
7
+ // let retryCount = 0
8
+ // const maxRetries = 5
9
+
10
+ function _isProcessRunning(pid) {
11
+ try {
12
+ process.kill(pid, 0) // Sending a signal 0 does nothing but checks if the process exists
13
+ return true
14
+ } catch (error) {
15
+ return false
16
+ }
17
+ }
18
+
19
+ async function startDevServerProcess({ appName, entry }) {
20
+ const serverPath = path.join(process.cwd(), entry)
21
+ serverProcess = fork(serverPath)
22
+
23
+ console.log(`[${appName}][dev] Server process started with pid ${serverProcess.pid} from ${process.pid}`)
24
+
25
+ serverProcess.on('exit', (code, args) => {
26
+ console.log(`[${appName}][dev] Server process exited with code ${code} - ${args}`)
27
+ serverProcess = null
28
+ // Puedes implementar lógica de reintento aquí si es necesario
29
+ // if (code !== 0 && retryCount < maxRetries) {
30
+ // retryCount++
31
+ // console.log(`[${serverName}][dev] Attempting to restart server (${retryCount}/${maxRetries})...`)
32
+ // // Espera un breve tiempo antes de intentar reiniciar
33
+ // await new Promise(resolve => setTimeout(resolve, 2000))
34
+ // startDevServerProcess({ entry, serverName })
35
+ // } else if (code !== 0) {
36
+ // console.error(`[${serverName}][dev] Server failed to start after ${maxRetries} retries. Exiting.`)
37
+ // process.exit(1)
38
+ // }
39
+ })
40
+
41
+ serverProcess.on('message', (message) => {
42
+ if (message === 'miolo_restart') {
43
+ console.log(`[${appName}][dev] Received restart signal. Restarting server...`)
44
+
45
+ const pidToKill = serverProcess ? serverProcess.pid : null
46
+ if (pidToKill) {
47
+ console.log(`[${appName}][dev] Killing process with PID: ${pidToKill}`)
48
+ // Clean kill
49
+ process.kill(pidToKill, 'SIGTERM')
50
+
51
+ // Harder if still alive
52
+ setTimeout(() => {
53
+ if (_isProcessRunning(pidToKill)) {
54
+ process.kill(pidToKill, 'SIGKILL')
55
+ }
56
+ }, 2000)
57
+ }
58
+
59
+ startDevServerProcess({ appName, entry }) // Inicia un nuevo proceso
60
+ }
61
+ })
62
+ }
63
+
64
+
65
+ export default async function(appName, entry, serverName) {
66
+ console.log(`[${appName}][dev] Running DEV server ${serverName} from entry ${entry}`)
67
+ await startDevServerProcess({ appName, entry })
68
+ }
69
+
70
+
71
+
72
+ // export default async function({ appName, entry, serverName }) {
73
+ // console.log(`[${appName}][dev] Running DEV server ${serverName} from entry ${entry}`)
74
+ // const srv_module = await import(path.join(process.cwd(), entry))
75
+ // const server = srv_module[serverName]
76
+ // await server()
77
+ // }
package/bin/index.mjs ADDED
@@ -0,0 +1,70 @@
1
+ #!/usr/bin/env node
2
+ import yargs from 'yargs-parser'
3
+ import { getAppName } from './util.mjs'
4
+
5
+ async function main() {
6
+ const args = yargs(process.argv.slice(2))
7
+ const command = args._[0]
8
+
9
+ try {
10
+ const appName = await getAppName()
11
+ const serverName = args['server-name'] || 'miolo_server'
12
+
13
+ switch (command) {
14
+ case 'dev':
15
+ const devHandler = (await import ('./dev.mjs')).default
16
+ const devEntry = args.entry || './src/server/server-dev.mjs'
17
+ await devHandler(appName, /*entry*/ devEntry, serverName)
18
+ break
19
+
20
+ case 'build-client':
21
+ const buildClientHandler = (await import ('./build-client.mjs')).default
22
+ const clientEntry = args.entry || './cli/entry-cli.jsx'
23
+ const clientDest = args.dest || './dist/cli'
24
+ await buildClientHandler(appName, /*entry*/ clientEntry, /*dest*/ clientDest)
25
+ break
26
+
27
+ case 'build-server':
28
+ const buildServerHandler = (await import ('./build-server.mjs')).default
29
+ const ssrEntry = args['ssr-entry'] || './server/ssr/entry-server.jsx'
30
+ const ssrDest = args['ssr-dest'] || './dist/server'
31
+ const serverEntry = args.entry || './src/server/server-prod.mjs'
32
+ const serverDest = args.dest || './dist/server'
33
+ await buildServerHandler(appName, ssrEntry, ssrDest, /*entry*/ serverEntry, /*dest*/ serverDest)
34
+ break
35
+
36
+ case 'start':
37
+ const startHandler = (await import ('./start.mjs')).default
38
+ const startDest = args.dest || './dist/server'
39
+ await startHandler(appName, /*dest*/ startDest, serverName)
40
+ break
41
+
42
+ case 'stop':
43
+ const stopHandler = (await import ('./stop.mjs')).default
44
+ await stopHandler(appName)
45
+ break
46
+
47
+ case 'restart':
48
+ const restartHandler = (await import ('./restart.mjs')).default
49
+ const restartDest = args.dest || './dist/server'
50
+ await restartHandler({appName, /*dest*/ restartDest, serverName})
51
+ break
52
+
53
+ case 'create-bin':
54
+ const createHandler = (await import ('./create-bin.mjs')).default
55
+ const createDest = args.dest || './dist/server'
56
+ await createHandler(appName, /*dest*/ createDest, serverName)
57
+ break
58
+
59
+ default:
60
+ console.error(`[miolo] Unknown command: ${command}`)
61
+ console.log('[miolo] Available commands: dev, build-client, build-server, start, stop, restart')
62
+ process.exit(1)
63
+ }
64
+ } catch (error) {
65
+ console.error('[miolo] Error during command execution:', error)
66
+ process.exit(1)
67
+ }
68
+ }
69
+
70
+ main()
@@ -0,0 +1,12 @@
1
+ import start from "./start.mjs"
2
+ import stop from "./stop.mjs"
3
+
4
+ process.env.NODE_ENV = 'production'
5
+
6
+ export default async function(appName, dest, serverName) {
7
+ console.log(`[${appName}][prod][restart] Restarting server...`)
8
+
9
+ await stop(appName)
10
+ await start(appName, dest, serverName)
11
+
12
+ }
package/bin/start.mjs ADDED
@@ -0,0 +1,28 @@
1
+ import path from 'node:path'
2
+ import { pidFileCreate } from "./util.mjs"
3
+
4
+ process.env.NODE_ENV = 'production'
5
+
6
+ export default async function(appName, dest, serverName) {
7
+ // if (! fs.existsSync(CLI_DEST_MAIN)) {
8
+ // console.error(`[${appName}][prod][start] Cannot start server (prod): CLI bundle does not exist ${CLI_DEST_MAIN}`)
9
+ // return
10
+ // }
11
+ // if (! fs.existsSync(SRV_DEST_MAIN)) {
12
+ // console.error(`[${appName}][prod][start] Cannot start server (prod): SERVER bundle does not exist ${SRV_DEST_MAIN}`)
13
+ // return
14
+ // }
15
+
16
+ console.log(`[${appName}][prod][start] Starting server...`)
17
+
18
+ const serverExt = 'node.bundle.mjs'
19
+ const destFile = path.join(process.cwd(), `${dest}/${appName}.${serverExt}`)
20
+
21
+ const srv_module = await import(destFile)
22
+ const server = srv_module[serverName]
23
+
24
+ const pid = pidFileCreate(appName)
25
+ console.log(`[${appName}][prod][start] Starting server. PID is ${pid}...`)
26
+
27
+ await server()
28
+ }
package/bin/stop.mjs ADDED
@@ -0,0 +1,22 @@
1
+ import { pidFileRead } from "./util.mjs"
2
+
3
+ process.env.NODE_ENV = 'production'
4
+
5
+ export default async function(appName) {
6
+ console.log(`[${appName}][prod][stop] Stopping server...`)
7
+
8
+ try {
9
+ const pid = pidFileRead(appName)
10
+ console.log(`[${appName}][prod][stop] Killing current process with PID ${pid}`)
11
+
12
+ process.kill(pid, 'SIGKILL')
13
+
14
+ return 1
15
+ } catch(_) {
16
+ console.log(`[${appName}][prod][stop] No current process to kill`)
17
+ console.error(_)
18
+
19
+ return 0
20
+ }
21
+
22
+ }
package/bin/util.mjs ADDED
@@ -0,0 +1,37 @@
1
+ import {readdirSync, rmSync, writeFileSync, readFileSync} from 'node:fs'
2
+ import { readFile } from 'node:fs/promises'
3
+ import path from 'node:path'
4
+
5
+
6
+ export async function getAppName() {
7
+ try {
8
+ const packageJsonPath = path.join(process.cwd(), 'package.json')
9
+ const content = await readFile(packageJsonPath, 'utf8')
10
+ const packageData = JSON.parse(content)
11
+ return packageData.name
12
+ } catch (error) {
13
+ console.error('[miolo] Error reading package.json:', error)
14
+ return 'miolo'
15
+ }
16
+ }
17
+
18
+ export function cleanFolder(folder) {
19
+ readdirSync(folder).forEach(file => {
20
+ rmSync(`${folder}/${file}`, { recursive: true, force: true });
21
+ })
22
+ }
23
+
24
+
25
+ export function pidFileCreate(appName) {
26
+ const pidFilePath = `/tmp/${appName}.pid`
27
+ writeFileSync(pidFilePath, `${process.pid}`, {encoding:'utf8',flag:'w'})
28
+ return process.pid
29
+ }
30
+
31
+ export function pidFileRead(appName) {
32
+ const pidFilePath = `/tmp/${appName}.pid`
33
+ const pid = readFileSync(pidFilePath, {encoding:'utf8'})
34
+ return pid
35
+ }
36
+
37
+