@platforma-sdk/bootstrap 3.5.21 → 4.0.0

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 (40) hide show
  1. package/assets/compose-backend.yaml +119 -49
  2. package/dist/commands/svc/create/arg-parser.cjs +175 -0
  3. package/dist/commands/svc/create/arg-parser.cjs.map +1 -0
  4. package/dist/commands/svc/create/arg-parser.d.ts +42 -0
  5. package/dist/commands/svc/create/arg-parser.js +173 -0
  6. package/dist/commands/svc/create/arg-parser.js.map +1 -0
  7. package/dist/commands/svc/create/docker/s3.cjs +26 -3
  8. package/dist/commands/svc/create/docker/s3.cjs.map +1 -1
  9. package/dist/commands/svc/create/docker/s3.js +26 -3
  10. package/dist/commands/svc/create/docker/s3.js.map +1 -1
  11. package/dist/commands/svc/create/docker.cjs +36 -3
  12. package/dist/commands/svc/create/docker.cjs.map +1 -1
  13. package/dist/commands/svc/create/docker.js +36 -3
  14. package/dist/commands/svc/create/docker.js.map +1 -1
  15. package/dist/commands/svc/create/local/s3.cjs +21 -3
  16. package/dist/commands/svc/create/local/s3.cjs.map +1 -1
  17. package/dist/commands/svc/create/local/s3.js +21 -3
  18. package/dist/commands/svc/create/local/s3.js.map +1 -1
  19. package/dist/commands/svc/create/local.cjs +51 -28
  20. package/dist/commands/svc/create/local.cjs.map +1 -1
  21. package/dist/commands/svc/create/local.js +51 -28
  22. package/dist/commands/svc/create/local.js.map +1 -1
  23. package/dist/core.cjs +174 -44
  24. package/dist/core.cjs.map +1 -1
  25. package/dist/core.d.ts +3 -0
  26. package/dist/core.js +174 -44
  27. package/dist/core.js.map +1 -1
  28. package/dist/index.cjs.map +1 -1
  29. package/dist/index.d.ts +8 -8
  30. package/dist/index.js.map +1 -1
  31. package/dist/templates/compose.cjs +3 -0
  32. package/dist/templates/compose.cjs.map +1 -1
  33. package/dist/templates/compose.d.ts +1 -0
  34. package/dist/templates/compose.js +3 -0
  35. package/dist/templates/compose.js.map +1 -1
  36. package/dist/templates/pl-config.cjs +2 -2
  37. package/dist/templates/pl-config.cjs.map +1 -1
  38. package/dist/templates/pl-config.js +2 -2
  39. package/dist/templates/pl-config.js.map +1 -1
  40. package/package.json +2 -2
@@ -8,6 +8,7 @@ var util = require('../../../util.cjs');
8
8
  var state = require('../../../state.cjs');
9
9
  var platforma = require('../../../platforma.cjs');
10
10
  var os = require('node:os');
11
+ var argParser = require('./arg-parser.cjs');
11
12
 
12
13
  function _interopNamespaceDefault(e) {
13
14
  var n = Object.create(null);
@@ -51,31 +52,48 @@ class Local extends core.Command {
51
52
  name: core.Args.string({ required: true }),
52
53
  };
53
54
  async run() {
54
- const { flags, args } = await this.parse(Local);
55
- const logger = util.createLogger(flags['log-level']);
55
+ // Use custom parser instead of OCLIF parse
56
+ const parser = new argParser.ArgParser(Local.flags);
57
+ const parsed = parser.parse(this.argv);
58
+ // Validate required flags
59
+ const errors = parser.validateRequired(parsed.knownFlags);
60
+ if (errors.length > 0) {
61
+ throw new Error(`Validation errors:\n${errors.join('\n')}`);
62
+ }
63
+ const instanceName = parsed.instanceName;
64
+ const flags = parsed.knownFlags;
65
+ const backendCommands = parsed.unknownFlags;
66
+ if (flags['log-level']) {
67
+ backendCommands.push(`--log-level=${flags['log-level']}`);
68
+ }
69
+ // Set default values for flags that weren't specified
70
+ if (!flags['log-level'])
71
+ flags['log-level'] = 'info';
72
+ if (!flags['grpc-port'])
73
+ flags['grpc-port'] = 6345;
74
+ if (!flags['grpc-listen'])
75
+ flags['grpc-listen'] = '127.0.0.1:6345';
76
+ if (!flags['monitoring-port'])
77
+ flags['monitoring-port'] = 9090;
78
+ if (!flags['monitoring-listen'])
79
+ flags['monitoring-listen'] = '127.0.0.1:9090';
80
+ if (!flags['debug-port'])
81
+ flags['debug-port'] = 9091;
82
+ if (!flags['debug-listen'])
83
+ flags['debug-listen'] = '127.0.0.1:9091';
84
+ const logger = util.createLogger(flags['log-level'] || 'info');
56
85
  const core = new core$1.default(logger);
57
86
  core.mergeLicenseEnvs(flags);
58
- const instanceName = args.name;
59
- const workdir = flags['pl-workdir'] ?? '.';
60
- const storage = flags.storage ? path.join(workdir, flags.storage) : state.instanceDir(instanceName);
61
- const logFile = flags['pl-log-file'] ? path.join(workdir, flags['pl-log-file']) : undefined;
62
- const authDrivers = core.initAuthDriversList(flags, workdir);
63
- const authEnabled = flags['auth-enabled'] ?? authDrivers !== undefined;
64
- let listenGrpc = '127.0.0.1:6345';
65
- if (flags['grpc-listen'])
66
- listenGrpc = flags['grpc-listen'];
67
- else if (flags['grpc-port'])
68
- listenGrpc = `127.0.0.1:${flags['grpc-port']}`;
69
- let listenMon = '127.0.0.1:9090';
70
- if (flags['monitoring-listen'])
71
- listenMon = flags['monitoring-listen'];
72
- else if (flags['monitoring-port'])
73
- listenMon = `127.0.0.1:${flags['monitoring-port']}`;
74
- let listenDbg = '127.0.0.1:9091';
75
- if (flags['debug-listen'])
76
- listenDbg = flags['debug-listen'];
77
- else if (flags['debug-port'])
78
- listenDbg = `127.0.0.1:${flags['debug-port']}`;
87
+ const authEnabled = flags['auth-enabled'];
88
+ const authOptions = authEnabled
89
+ ? {
90
+ enabled: authEnabled,
91
+ drivers: core.initAuthDriversList(flags, '.'),
92
+ }
93
+ : undefined;
94
+ const storage = flags.storage ? path.join('.', flags.storage) : state.instanceDir(instanceName);
95
+ for (const p of flags.mount ?? []) {
96
+ }
79
97
  const createOptions = {
80
98
  sourcesPath: flags['pl-sources'],
81
99
  binaryPath: flags['pl-binary'],
@@ -84,14 +102,15 @@ class Local extends core.Command {
84
102
  workdir: flags['pl-workdir'],
85
103
  primaryURL: flags['storage-primary'],
86
104
  libraryURL: flags['storage-library'],
105
+ backendCommands: backendCommands,
87
106
  configOptions: {
88
- grpc: { listen: listenGrpc },
89
- monitoring: { listen: listenMon },
90
- debug: { listen: listenDbg },
107
+ grpc: { listen: flags['grpc-listen'] },
108
+ monitoring: { listen: flags['monitoring-listen'] },
109
+ debug: { listen: flags['debug-listen'] },
91
110
  license: { value: flags['license'], file: flags['license-file'] },
92
- log: { path: logFile },
111
+ log: { path: flags['pl-log-file'] },
93
112
  localRoot: storage,
94
- core: { auth: { enabled: authEnabled, drivers: authDrivers } },
113
+ core: { auth: authOptions },
95
114
  storages: {
96
115
  work: { type: 'FS', rootPath: flags['storage-work'] },
97
116
  },
@@ -110,6 +129,10 @@ class Local extends core.Command {
110
129
  .catch(function (err) {
111
130
  logger.error(err.message);
112
131
  });
132
+ // Log unknown flags that will be passed to backend
133
+ if (backendCommands.length > 0) {
134
+ logger.info(`Unknown flags will be passed to backend: ${backendCommands.join(' ')}`);
135
+ }
113
136
  }
114
137
  }
115
138
 
@@ -1 +1 @@
1
- {"version":3,"file":"local.cjs","sources":["../../../../src/commands/svc/create/local.ts"],"sourcesContent":["import { Command, Args } from '@oclif/core';\nimport path from 'node:path';\nimport type { createLocalOptions } from '../../../core';\nimport Core from '../../../core';\nimport * as cmdOpts from '../../../cmd-opts';\nimport * as util from '../../../util';\nimport state from '../../../state';\nimport * as platforma from '../../../platforma';\nimport * as os from 'node:os';\n\nexport default class Local extends Command {\n static override description = 'Run Platforma Backend service as local process on current host (no docker container)';\n\n static override examples = ['<%= config.bin %> <%= command.id %>'];\n\n static override flags = {\n ...cmdOpts.GlobalFlags,\n ...cmdOpts.VersionFlag,\n\n ...cmdOpts.AddressesFlags,\n ...cmdOpts.PlBinaryFlag,\n ...cmdOpts.PlSourcesFlag,\n\n ...cmdOpts.ConfigFlag,\n\n ...cmdOpts.LicenseFlags,\n\n ...cmdOpts.StorageFlag,\n ...cmdOpts.StoragePrimaryURLFlag,\n ...cmdOpts.StorageWorkPathFlag,\n ...cmdOpts.StorageLibraryURLFlag,\n\n ...cmdOpts.PlLogFileFlag,\n ...cmdOpts.PlWorkdirFlag,\n ...cmdOpts.AuthFlags,\n };\n\n static args = {\n name: Args.string({ required: true }),\n };\n\n public async run(): Promise<void> {\n const { flags, args } = await this.parse(Local);\n\n const logger = util.createLogger(flags['log-level']);\n const core = new Core(logger);\n core.mergeLicenseEnvs(flags);\n\n const instanceName = args.name;\n\n const workdir = flags['pl-workdir'] ?? '.';\n const storage = flags.storage ? path.join(workdir, flags.storage) : state.instanceDir(instanceName);\n const logFile = flags['pl-log-file'] ? path.join(workdir, flags['pl-log-file']) : undefined;\n\n const authDrivers = core.initAuthDriversList(flags, workdir);\n const authEnabled = flags['auth-enabled'] ?? authDrivers !== undefined;\n\n let listenGrpc: string = '127.0.0.1:6345';\n if (flags['grpc-listen']) listenGrpc = flags['grpc-listen'];\n else if (flags['grpc-port']) listenGrpc = `127.0.0.1:${flags['grpc-port']}`;\n\n let listenMon: string = '127.0.0.1:9090';\n if (flags['monitoring-listen']) listenMon = flags['monitoring-listen'];\n else if (flags['monitoring-port']) listenMon = `127.0.0.1:${flags['monitoring-port']}`;\n\n let listenDbg: string = '127.0.0.1:9091';\n if (flags['debug-listen']) listenDbg = flags['debug-listen'];\n else if (flags['debug-port']) listenDbg = `127.0.0.1:${flags['debug-port']}`;\n\n const createOptions: createLocalOptions = {\n sourcesPath: flags['pl-sources'],\n binaryPath: flags['pl-binary'],\n\n version: flags.version,\n configPath: flags.config,\n workdir: flags['pl-workdir'],\n\n primaryURL: flags['storage-primary'],\n libraryURL: flags['storage-library'],\n\n configOptions: {\n grpc: { listen: listenGrpc },\n monitoring: { listen: listenMon },\n debug: { listen: listenDbg },\n license: { value: flags['license'], file: flags['license-file'] },\n log: { path: logFile },\n localRoot: storage,\n core: { auth: { enabled: authEnabled, drivers: authDrivers } },\n storages: {\n work: { type: 'FS', rootPath: flags['storage-work'] },\n },\n\n // Backend could consume a lot of CPU power,\n // we want to keep at least a couple for UI and other apps to work.\n numCpu: Math.max(os.cpus().length - 2, 1),\n },\n };\n\n core.createLocal(instanceName, createOptions);\n\n if (createOptions.binaryPath || createOptions.sourcesPath) {\n logger.info(`Instance '${instanceName}' was created. To start it run 'up' command`);\n return;\n }\n\n platforma\n .getBinary(logger, { version: flags.version })\n .then(() => logger.info(`Instance '${instanceName}' was created. To start it run 'svc up' command`))\n .catch(function (err: Error) {\n logger.error(err.message);\n });\n }\n}\n"],"names":["Command","cmdOpts.GlobalFlags","cmdOpts.VersionFlag","cmdOpts.AddressesFlags","cmdOpts.PlBinaryFlag","cmdOpts.PlSourcesFlag","cmdOpts.ConfigFlag","cmdOpts.LicenseFlags","cmdOpts.StorageFlag","cmdOpts.StoragePrimaryURLFlag","cmdOpts.StorageWorkPathFlag","cmdOpts.StorageLibraryURLFlag","cmdOpts.PlLogFileFlag","cmdOpts.PlWorkdirFlag","cmdOpts.AuthFlags","Args","util.createLogger","Core","os","platforma\n .getBinary"],"mappings":"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"}
1
+ {"version":3,"file":"local.cjs","sources":["../../../../src/commands/svc/create/local.ts"],"sourcesContent":["import { Command, Args } from '@oclif/core';\nimport path from 'node:path';\nimport type { createLocalOptions } from '../../../core';\nimport Core from '../../../core';\nimport * as cmdOpts from '../../../cmd-opts';\nimport * as util from '../../../util';\nimport state from '../../../state';\nimport * as platforma from '../../../platforma';\nimport * as os from 'node:os';\nimport type * as types from '../../../templates/types';\nimport { ArgParser } from './arg-parser';\n\nexport default class Local extends Command {\n static override description = 'Run Platforma Backend service as local process on current host (no docker container)';\n\n static override examples = ['<%= config.bin %> <%= command.id %>'];\n\n static override flags = {\n ...cmdOpts.GlobalFlags,\n ...cmdOpts.VersionFlag,\n\n ...cmdOpts.AddressesFlags,\n ...cmdOpts.PlBinaryFlag,\n ...cmdOpts.PlSourcesFlag,\n\n ...cmdOpts.ConfigFlag,\n\n ...cmdOpts.LicenseFlags,\n\n ...cmdOpts.StorageFlag,\n ...cmdOpts.StoragePrimaryURLFlag,\n ...cmdOpts.StorageWorkPathFlag,\n ...cmdOpts.StorageLibraryURLFlag,\n\n ...cmdOpts.PlLogFileFlag,\n ...cmdOpts.PlWorkdirFlag,\n ...cmdOpts.AuthFlags,\n };\n\n static override args = {\n name: Args.string({ required: true }),\n };\n\n public async run(): Promise<void> {\n // Use custom parser instead of OCLIF parse\n const parser = new ArgParser(Local.flags);\n const parsed = parser.parse(this.argv);\n\n // Validate required flags\n const errors = parser.validateRequired(parsed.knownFlags);\n if (errors.length > 0) {\n throw new Error(`Validation errors:\\n${errors.join('\\n')}`);\n }\n\n const instanceName = parsed.instanceName;\n const flags = parsed.knownFlags;\n const backendCommands = parsed.unknownFlags;\n if (flags['log-level']){\n backendCommands.push(`--log-level=${flags['log-level']}`);\n }\n\n // Set default values for flags that weren't specified\n if (!flags['log-level']) flags['log-level'] = 'info';\n if (!flags['grpc-port']) flags['grpc-port'] = 6345;\n if (!flags['grpc-listen']) flags['grpc-listen'] = '127.0.0.1:6345';\n if (!flags['monitoring-port']) flags['monitoring-port'] = 9090;\n if (!flags['monitoring-listen']) flags['monitoring-listen'] = '127.0.0.1:9090';\n if (!flags['debug-port']) flags['debug-port'] = 9091;\n if (!flags['debug-listen']) flags['debug-listen'] = '127.0.0.1:9091';\n\n const logger = util.createLogger(flags['log-level'] || 'info');\n const core = new Core(logger);\n core.mergeLicenseEnvs(flags);\n\n const authEnabled = flags['auth-enabled'];\n const authOptions: types.authOptions | undefined = authEnabled\n ? {\n enabled: authEnabled,\n drivers: core.initAuthDriversList(flags, '.'),\n }\n : undefined;\n\n const storage = flags.storage ? path.join('.', flags.storage) : state.instanceDir(instanceName);\n\n const mounts: { hostPath: string; containerPath?: string }[] = [];\n for (const p of flags.mount ?? []) {\n mounts.push({ hostPath: p });\n }\n\n const createOptions: createLocalOptions = {\n sourcesPath: flags['pl-sources'],\n binaryPath: flags['pl-binary'],\n\n version: flags.version,\n configPath: flags.config,\n workdir: flags['pl-workdir'],\n\n primaryURL: flags['storage-primary'],\n libraryURL: flags['storage-library'],\n\n backendCommands: backendCommands,\n\n configOptions: {\n grpc: { listen: flags['grpc-listen'] },\n monitoring: { listen: flags['monitoring-listen'] },\n debug: { listen: flags['debug-listen'] },\n license: { value: flags['license'], file: flags['license-file'] },\n log: { path: flags['pl-log-file'] },\n localRoot: storage,\n core: { auth: authOptions },\n storages: {\n work: { type: 'FS', rootPath: flags['storage-work'] },\n },\n\n // Backend could consume a lot of CPU power,\n // we want to keep at least a couple for UI and other apps to work.\n numCpu: Math.max(os.cpus().length - 2, 1),\n },\n };\n\n core.createLocal(instanceName, createOptions);\n\n if (createOptions.binaryPath || createOptions.sourcesPath) {\n logger.info(`Instance '${instanceName}' was created. To start it run 'up' command`);\n return;\n }\n\n platforma\n .getBinary(logger, { version: flags.version })\n .then(() => logger.info(`Instance '${instanceName}' was created. To start it run 'svc up' command`))\n .catch(function (err: Error) {\n logger.error(err.message);\n });\n\n // Log unknown flags that will be passed to backend\n if (backendCommands.length > 0) {\n logger.info(`Unknown flags will be passed to backend: ${backendCommands.join(' ')}`);\n }\n }\n}\n"],"names":["Command","cmdOpts.GlobalFlags","cmdOpts.VersionFlag","cmdOpts.AddressesFlags","cmdOpts.PlBinaryFlag","cmdOpts.PlSourcesFlag","cmdOpts.ConfigFlag","cmdOpts.LicenseFlags","cmdOpts.StorageFlag","cmdOpts.StoragePrimaryURLFlag","cmdOpts.StorageWorkPathFlag","cmdOpts.StorageLibraryURLFlag","cmdOpts.PlLogFileFlag","cmdOpts.PlWorkdirFlag","cmdOpts.AuthFlags","Args","ArgParser","util.createLogger","Core","os","platforma\n .getBinary"],"mappings":"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"}
@@ -6,6 +6,7 @@ import { createLogger } from '../../../util.js';
6
6
  import state from '../../../state.js';
7
7
  import { getBinary } from '../../../platforma.js';
8
8
  import * as os from 'node:os';
9
+ import { ArgParser } from './arg-parser.js';
9
10
 
10
11
  class Local extends Command {
11
12
  static description = 'Run Platforma Backend service as local process on current host (no docker container)';
@@ -30,31 +31,48 @@ class Local extends Command {
30
31
  name: Args.string({ required: true }),
31
32
  };
32
33
  async run() {
33
- const { flags, args } = await this.parse(Local);
34
- const logger = createLogger(flags['log-level']);
34
+ // Use custom parser instead of OCLIF parse
35
+ const parser = new ArgParser(Local.flags);
36
+ const parsed = parser.parse(this.argv);
37
+ // Validate required flags
38
+ const errors = parser.validateRequired(parsed.knownFlags);
39
+ if (errors.length > 0) {
40
+ throw new Error(`Validation errors:\n${errors.join('\n')}`);
41
+ }
42
+ const instanceName = parsed.instanceName;
43
+ const flags = parsed.knownFlags;
44
+ const backendCommands = parsed.unknownFlags;
45
+ if (flags['log-level']) {
46
+ backendCommands.push(`--log-level=${flags['log-level']}`);
47
+ }
48
+ // Set default values for flags that weren't specified
49
+ if (!flags['log-level'])
50
+ flags['log-level'] = 'info';
51
+ if (!flags['grpc-port'])
52
+ flags['grpc-port'] = 6345;
53
+ if (!flags['grpc-listen'])
54
+ flags['grpc-listen'] = '127.0.0.1:6345';
55
+ if (!flags['monitoring-port'])
56
+ flags['monitoring-port'] = 9090;
57
+ if (!flags['monitoring-listen'])
58
+ flags['monitoring-listen'] = '127.0.0.1:9090';
59
+ if (!flags['debug-port'])
60
+ flags['debug-port'] = 9091;
61
+ if (!flags['debug-listen'])
62
+ flags['debug-listen'] = '127.0.0.1:9091';
63
+ const logger = createLogger(flags['log-level'] || 'info');
35
64
  const core = new Core(logger);
36
65
  core.mergeLicenseEnvs(flags);
37
- const instanceName = args.name;
38
- const workdir = flags['pl-workdir'] ?? '.';
39
- const storage = flags.storage ? path.join(workdir, flags.storage) : state.instanceDir(instanceName);
40
- const logFile = flags['pl-log-file'] ? path.join(workdir, flags['pl-log-file']) : undefined;
41
- const authDrivers = core.initAuthDriversList(flags, workdir);
42
- const authEnabled = flags['auth-enabled'] ?? authDrivers !== undefined;
43
- let listenGrpc = '127.0.0.1:6345';
44
- if (flags['grpc-listen'])
45
- listenGrpc = flags['grpc-listen'];
46
- else if (flags['grpc-port'])
47
- listenGrpc = `127.0.0.1:${flags['grpc-port']}`;
48
- let listenMon = '127.0.0.1:9090';
49
- if (flags['monitoring-listen'])
50
- listenMon = flags['monitoring-listen'];
51
- else if (flags['monitoring-port'])
52
- listenMon = `127.0.0.1:${flags['monitoring-port']}`;
53
- let listenDbg = '127.0.0.1:9091';
54
- if (flags['debug-listen'])
55
- listenDbg = flags['debug-listen'];
56
- else if (flags['debug-port'])
57
- listenDbg = `127.0.0.1:${flags['debug-port']}`;
66
+ const authEnabled = flags['auth-enabled'];
67
+ const authOptions = authEnabled
68
+ ? {
69
+ enabled: authEnabled,
70
+ drivers: core.initAuthDriversList(flags, '.'),
71
+ }
72
+ : undefined;
73
+ const storage = flags.storage ? path.join('.', flags.storage) : state.instanceDir(instanceName);
74
+ for (const p of flags.mount ?? []) {
75
+ }
58
76
  const createOptions = {
59
77
  sourcesPath: flags['pl-sources'],
60
78
  binaryPath: flags['pl-binary'],
@@ -63,14 +81,15 @@ class Local extends Command {
63
81
  workdir: flags['pl-workdir'],
64
82
  primaryURL: flags['storage-primary'],
65
83
  libraryURL: flags['storage-library'],
84
+ backendCommands: backendCommands,
66
85
  configOptions: {
67
- grpc: { listen: listenGrpc },
68
- monitoring: { listen: listenMon },
69
- debug: { listen: listenDbg },
86
+ grpc: { listen: flags['grpc-listen'] },
87
+ monitoring: { listen: flags['monitoring-listen'] },
88
+ debug: { listen: flags['debug-listen'] },
70
89
  license: { value: flags['license'], file: flags['license-file'] },
71
- log: { path: logFile },
90
+ log: { path: flags['pl-log-file'] },
72
91
  localRoot: storage,
73
- core: { auth: { enabled: authEnabled, drivers: authDrivers } },
92
+ core: { auth: authOptions },
74
93
  storages: {
75
94
  work: { type: 'FS', rootPath: flags['storage-work'] },
76
95
  },
@@ -89,6 +108,10 @@ class Local extends Command {
89
108
  .catch(function (err) {
90
109
  logger.error(err.message);
91
110
  });
111
+ // Log unknown flags that will be passed to backend
112
+ if (backendCommands.length > 0) {
113
+ logger.info(`Unknown flags will be passed to backend: ${backendCommands.join(' ')}`);
114
+ }
92
115
  }
93
116
  }
94
117
 
@@ -1 +1 @@
1
- {"version":3,"file":"local.js","sources":["../../../../src/commands/svc/create/local.ts"],"sourcesContent":["import { Command, Args } from '@oclif/core';\nimport path from 'node:path';\nimport type { createLocalOptions } from '../../../core';\nimport Core from '../../../core';\nimport * as cmdOpts from '../../../cmd-opts';\nimport * as util from '../../../util';\nimport state from '../../../state';\nimport * as platforma from '../../../platforma';\nimport * as os from 'node:os';\n\nexport default class Local extends Command {\n static override description = 'Run Platforma Backend service as local process on current host (no docker container)';\n\n static override examples = ['<%= config.bin %> <%= command.id %>'];\n\n static override flags = {\n ...cmdOpts.GlobalFlags,\n ...cmdOpts.VersionFlag,\n\n ...cmdOpts.AddressesFlags,\n ...cmdOpts.PlBinaryFlag,\n ...cmdOpts.PlSourcesFlag,\n\n ...cmdOpts.ConfigFlag,\n\n ...cmdOpts.LicenseFlags,\n\n ...cmdOpts.StorageFlag,\n ...cmdOpts.StoragePrimaryURLFlag,\n ...cmdOpts.StorageWorkPathFlag,\n ...cmdOpts.StorageLibraryURLFlag,\n\n ...cmdOpts.PlLogFileFlag,\n ...cmdOpts.PlWorkdirFlag,\n ...cmdOpts.AuthFlags,\n };\n\n static args = {\n name: Args.string({ required: true }),\n };\n\n public async run(): Promise<void> {\n const { flags, args } = await this.parse(Local);\n\n const logger = util.createLogger(flags['log-level']);\n const core = new Core(logger);\n core.mergeLicenseEnvs(flags);\n\n const instanceName = args.name;\n\n const workdir = flags['pl-workdir'] ?? '.';\n const storage = flags.storage ? path.join(workdir, flags.storage) : state.instanceDir(instanceName);\n const logFile = flags['pl-log-file'] ? path.join(workdir, flags['pl-log-file']) : undefined;\n\n const authDrivers = core.initAuthDriversList(flags, workdir);\n const authEnabled = flags['auth-enabled'] ?? authDrivers !== undefined;\n\n let listenGrpc: string = '127.0.0.1:6345';\n if (flags['grpc-listen']) listenGrpc = flags['grpc-listen'];\n else if (flags['grpc-port']) listenGrpc = `127.0.0.1:${flags['grpc-port']}`;\n\n let listenMon: string = '127.0.0.1:9090';\n if (flags['monitoring-listen']) listenMon = flags['monitoring-listen'];\n else if (flags['monitoring-port']) listenMon = `127.0.0.1:${flags['monitoring-port']}`;\n\n let listenDbg: string = '127.0.0.1:9091';\n if (flags['debug-listen']) listenDbg = flags['debug-listen'];\n else if (flags['debug-port']) listenDbg = `127.0.0.1:${flags['debug-port']}`;\n\n const createOptions: createLocalOptions = {\n sourcesPath: flags['pl-sources'],\n binaryPath: flags['pl-binary'],\n\n version: flags.version,\n configPath: flags.config,\n workdir: flags['pl-workdir'],\n\n primaryURL: flags['storage-primary'],\n libraryURL: flags['storage-library'],\n\n configOptions: {\n grpc: { listen: listenGrpc },\n monitoring: { listen: listenMon },\n debug: { listen: listenDbg },\n license: { value: flags['license'], file: flags['license-file'] },\n log: { path: logFile },\n localRoot: storage,\n core: { auth: { enabled: authEnabled, drivers: authDrivers } },\n storages: {\n work: { type: 'FS', rootPath: flags['storage-work'] },\n },\n\n // Backend could consume a lot of CPU power,\n // we want to keep at least a couple for UI and other apps to work.\n numCpu: Math.max(os.cpus().length - 2, 1),\n },\n };\n\n core.createLocal(instanceName, createOptions);\n\n if (createOptions.binaryPath || createOptions.sourcesPath) {\n logger.info(`Instance '${instanceName}' was created. To start it run 'up' command`);\n return;\n }\n\n platforma\n .getBinary(logger, { version: flags.version })\n .then(() => logger.info(`Instance '${instanceName}' was created. To start it run 'svc up' command`))\n .catch(function (err: Error) {\n logger.error(err.message);\n });\n }\n}\n"],"names":["cmdOpts.GlobalFlags","cmdOpts.VersionFlag","cmdOpts.AddressesFlags","cmdOpts.PlBinaryFlag","cmdOpts.PlSourcesFlag","cmdOpts.ConfigFlag","cmdOpts.LicenseFlags","cmdOpts.StorageFlag","cmdOpts.StoragePrimaryURLFlag","cmdOpts.StorageWorkPathFlag","cmdOpts.StorageLibraryURLFlag","cmdOpts.PlLogFileFlag","cmdOpts.PlWorkdirFlag","cmdOpts.AuthFlags","util.createLogger","platforma\n .getBinary"],"mappings":"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"}
1
+ {"version":3,"file":"local.js","sources":["../../../../src/commands/svc/create/local.ts"],"sourcesContent":["import { Command, Args } from '@oclif/core';\nimport path from 'node:path';\nimport type { createLocalOptions } from '../../../core';\nimport Core from '../../../core';\nimport * as cmdOpts from '../../../cmd-opts';\nimport * as util from '../../../util';\nimport state from '../../../state';\nimport * as platforma from '../../../platforma';\nimport * as os from 'node:os';\nimport type * as types from '../../../templates/types';\nimport { ArgParser } from './arg-parser';\n\nexport default class Local extends Command {\n static override description = 'Run Platforma Backend service as local process on current host (no docker container)';\n\n static override examples = ['<%= config.bin %> <%= command.id %>'];\n\n static override flags = {\n ...cmdOpts.GlobalFlags,\n ...cmdOpts.VersionFlag,\n\n ...cmdOpts.AddressesFlags,\n ...cmdOpts.PlBinaryFlag,\n ...cmdOpts.PlSourcesFlag,\n\n ...cmdOpts.ConfigFlag,\n\n ...cmdOpts.LicenseFlags,\n\n ...cmdOpts.StorageFlag,\n ...cmdOpts.StoragePrimaryURLFlag,\n ...cmdOpts.StorageWorkPathFlag,\n ...cmdOpts.StorageLibraryURLFlag,\n\n ...cmdOpts.PlLogFileFlag,\n ...cmdOpts.PlWorkdirFlag,\n ...cmdOpts.AuthFlags,\n };\n\n static override args = {\n name: Args.string({ required: true }),\n };\n\n public async run(): Promise<void> {\n // Use custom parser instead of OCLIF parse\n const parser = new ArgParser(Local.flags);\n const parsed = parser.parse(this.argv);\n\n // Validate required flags\n const errors = parser.validateRequired(parsed.knownFlags);\n if (errors.length > 0) {\n throw new Error(`Validation errors:\\n${errors.join('\\n')}`);\n }\n\n const instanceName = parsed.instanceName;\n const flags = parsed.knownFlags;\n const backendCommands = parsed.unknownFlags;\n if (flags['log-level']){\n backendCommands.push(`--log-level=${flags['log-level']}`);\n }\n\n // Set default values for flags that weren't specified\n if (!flags['log-level']) flags['log-level'] = 'info';\n if (!flags['grpc-port']) flags['grpc-port'] = 6345;\n if (!flags['grpc-listen']) flags['grpc-listen'] = '127.0.0.1:6345';\n if (!flags['monitoring-port']) flags['monitoring-port'] = 9090;\n if (!flags['monitoring-listen']) flags['monitoring-listen'] = '127.0.0.1:9090';\n if (!flags['debug-port']) flags['debug-port'] = 9091;\n if (!flags['debug-listen']) flags['debug-listen'] = '127.0.0.1:9091';\n\n const logger = util.createLogger(flags['log-level'] || 'info');\n const core = new Core(logger);\n core.mergeLicenseEnvs(flags);\n\n const authEnabled = flags['auth-enabled'];\n const authOptions: types.authOptions | undefined = authEnabled\n ? {\n enabled: authEnabled,\n drivers: core.initAuthDriversList(flags, '.'),\n }\n : undefined;\n\n const storage = flags.storage ? path.join('.', flags.storage) : state.instanceDir(instanceName);\n\n const mounts: { hostPath: string; containerPath?: string }[] = [];\n for (const p of flags.mount ?? []) {\n mounts.push({ hostPath: p });\n }\n\n const createOptions: createLocalOptions = {\n sourcesPath: flags['pl-sources'],\n binaryPath: flags['pl-binary'],\n\n version: flags.version,\n configPath: flags.config,\n workdir: flags['pl-workdir'],\n\n primaryURL: flags['storage-primary'],\n libraryURL: flags['storage-library'],\n\n backendCommands: backendCommands,\n\n configOptions: {\n grpc: { listen: flags['grpc-listen'] },\n monitoring: { listen: flags['monitoring-listen'] },\n debug: { listen: flags['debug-listen'] },\n license: { value: flags['license'], file: flags['license-file'] },\n log: { path: flags['pl-log-file'] },\n localRoot: storage,\n core: { auth: authOptions },\n storages: {\n work: { type: 'FS', rootPath: flags['storage-work'] },\n },\n\n // Backend could consume a lot of CPU power,\n // we want to keep at least a couple for UI and other apps to work.\n numCpu: Math.max(os.cpus().length - 2, 1),\n },\n };\n\n core.createLocal(instanceName, createOptions);\n\n if (createOptions.binaryPath || createOptions.sourcesPath) {\n logger.info(`Instance '${instanceName}' was created. To start it run 'up' command`);\n return;\n }\n\n platforma\n .getBinary(logger, { version: flags.version })\n .then(() => logger.info(`Instance '${instanceName}' was created. To start it run 'svc up' command`))\n .catch(function (err: Error) {\n logger.error(err.message);\n });\n\n // Log unknown flags that will be passed to backend\n if (backendCommands.length > 0) {\n logger.info(`Unknown flags will be passed to backend: ${backendCommands.join(' ')}`);\n }\n }\n}\n"],"names":["cmdOpts.GlobalFlags","cmdOpts.VersionFlag","cmdOpts.AddressesFlags","cmdOpts.PlBinaryFlag","cmdOpts.PlSourcesFlag","cmdOpts.ConfigFlag","cmdOpts.LicenseFlags","cmdOpts.StorageFlag","cmdOpts.StoragePrimaryURLFlag","cmdOpts.StorageWorkPathFlag","cmdOpts.StorageLibraryURLFlag","cmdOpts.PlLogFileFlag","cmdOpts.PlWorkdirFlag","cmdOpts.AuthFlags","util.createLogger","platforma\n .getBinary"],"mappings":"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"}