@platforma-sdk/block-tools 2.6.66 → 2.6.68
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.
- package/dist/cli.js +2 -2
- package/dist/cli.js.map +1 -1
- package/dist/cli.mjs +35 -40
- package/dist/cli.mjs.map +1 -1
- package/dist/v2/model/block_components.d.ts +85 -85
- package/dist/v2/model/block_description.d.ts +1304 -1304
- package/dist/v2/model/block_meta.d.ts +218 -218
- package/package.json +9 -9
- package/src/cmd/update-deps.ts +2 -10
package/dist/cli.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`./config-DXWEXkqY.js`);let t=require(`@oclif/core`),n=require(`node:path`);n=e.Ct(n);let r=require(`node:fs`);r=e.Ct(r);let i=require(`@milaboratories/pl-model-middle-layer`),a=require(`@milaboratories/ts-helpers-oclif`),o=require(`yaml`);o=e.Ct(o);let s=require(`
|
|
2
|
-
`)||` (none)`}`),!t[`skip-confirmation`]){let e=(await import(`node:readline`)).createInterface({input:process.stdin,output:process.stdout}),n=await new Promise(n=>{e.question(`⚠️ This will overwrite the current global overview with snapshot '${t.snapshot}'.\nAre you sure you want to continue? (y/N): `,n)});if(e.close(),n.toLowerCase()!==`y`&&n.toLowerCase()!==`yes`){this.log(`Restore cancelled.`);return}}try{await r.restoreGlobalOverviewFromSnapshot(t.snapshot),this.log(`✅ Successfully restored global overview from snapshot '${t.snapshot}'`)}catch(e){this.error(`Failed to restore from snapshot: ${String(e)}`)}}};function
|
|
1
|
+
Object.defineProperty(exports,Symbol.toStringTag,{value:`Module`});const e=require(`./config-DXWEXkqY.js`);let t=require(`@oclif/core`),n=require(`node:path`);n=e.Ct(n);let r=require(`node:fs`);r=e.Ct(r);let i=require(`@milaboratories/pl-model-middle-layer`),a=require(`@milaboratories/ts-helpers-oclif`),o=require(`yaml`);o=e.Ct(o);let s=require(`@platforma-sdk/blocks-deps-updater`);var c=class i extends t.Command{static description=`Extracts meta information from blocks package.json and outputs meta.json with embedded binary and textual information linked from the meta section.`;static flags={modulePath:t.Flags.string({char:`i`,summary:`input module path`,helpValue:`<path>`,default:`.`}),destination:t.Flags.string({char:`o`,summary:`output meta.json file`,helpValue:`<path>`,required:!0})};async run(){let{flags:t}=await this.parse(i),a=n.default.resolve(t.modulePath),o=await e.Y(a),s=await e.st.parseAsync(e.ot(a).parse(o.meta));await r.default.promises.writeFile(n.default.resolve(t.destination),JSON.stringify(s))}};async function l(e){try{return await r.default.promises.readFile(e,`utf8`)}catch(e){if(e instanceof Error&&`code`in e&&e.code===`ENOENT`)return;throw e}}var u=class e extends t.Command{static description=`Extracts and outputs block model JSON from pre-built block model module`;static flags={modulePath:t.Flags.string({char:`i`,summary:`input module path`,helpValue:`<path>`,default:`.`}),sourceBundle:t.Flags.string({char:`b`,summary:`bundled model code to embed into the model for callback-based rendering to work`,helpValue:`<path>`,default:`./dist/bundle.js`}),destination:t.Flags.string({char:`o`,summary:`output model file`,helpValue:`<path>`,default:`./dist/model.json`})};async run(){let{flags:t}=await this.parse(e),i=n.default.resolve(t.modulePath),{model:a,platforma:o}=require(i);if(a||=o,!a)throw Error(`"model" export not found`);let{config:s}=a;if(!s)throw Error(`Malformed "model" object, check it is created with "BlockModel" and ".done()" is executed as the call in the chain.`);if(!(`outputs`in s)||!(`sections`in s))throw Error(`"config" has unexpected structure`);let c=await l(t.sourceBundle);c!==void 0&&(s.code={type:`plain`,content:c}),await r.default.promises.writeFile(n.default.resolve(t.destination),JSON.stringify(s))}},d=class n extends t.Command{static description=`List all available global overview snapshots in the registry`;static flags={registry:t.Flags.string({char:`r`,summary:`full address of the registry`,helpValue:`<address>`,env:`PL_REGISTRY`,required:!0}),json:t.Flags.boolean({summary:`output in JSON format`,default:!1})};async run(){let{flags:t}=await this.parse(n),r=await new e.b(e._(t.registry),new a.OclifLoggerAdapter(this)).listGlobalOverviewSnapshots();if(t.json)this.log(JSON.stringify(r,null,2));else if(r.length===0)this.log(`No snapshots found.`);else{this.log(`Found ${r.length} snapshot(s):\n`);for(let e of r)this.log(` ${e.timestamp}`),this.log(` Path: ${e.path}`),this.log(``)}}},f=class r extends t.Command{static description=`Mark target block stable`;static flags={modulePath:t.Flags.string({char:`i`,summary:`input module path`,helpValue:`<path>`,default:`.`}),channel:t.Flags.string({char:`c`,hidden:!0,summary:`custom channel`,helpValue:`<channel name>`,default:i.StableChannel}),"version-override":t.Flags.file({char:`v`,summary:`override package version`}),registry:t.Flags.string({char:`r`,summary:`full address of the registry`,helpValue:`<address>`,env:`PL_REGISTRY`,required:!0}),refresh:t.Flags.boolean({summary:`refresh repository after adding the package`,default:!0,allowNo:!0,env:`PL_REGISTRY_REFRESH`}),unmark:t.Flags.boolean({summary:`reverses meaning of this command, flag can be used to remove "stable" flag from the package`,default:!1})};async run(){let{flags:t}=await this.parse(r),o=await e.Y(n.default.resolve(t.modulePath));t[`version-override`]&&(o=(0,i.overrideDescriptionVersion)(o,t[`version-override`]));let s=new e.b(e._(t.registry),new a.OclifLoggerAdapter(this));t.unmark?await s.removePackageFromChannel(o.id,t.channel):await s.addPackageToChannel(o.id,t.channel),t.refresh&&await s.updateIfNeeded()}},p=class r extends t.Command{static description=`Builds block pack and outputs a block pack manifest consolidating all references assets into a single folder`;static flags={modulePath:t.Flags.string({char:`i`,summary:`input module path`,helpValue:`<path>`,default:`.`}),destinationPath:t.Flags.string({char:`o`,summary:`output folder`,helpValue:`<path>`,default:`./block-pack`})};async run(){let{flags:t}=await this.parse(r);await e.Q(await e.J(n.default.resolve(t.modulePath)),n.default.resolve(t.destinationPath))}};function m(e,t){let n={...e};for(let e in t)t[e]&&typeof t[e]==`object`&&!Array.isArray(t[e])&&n[e]&&typeof n[e]==`object`&&!Array.isArray(n[e])?n[e]=m(n[e],t[e]):n[e]=t[e];return n}var h=class o extends t.Command{static description=`Publishes the block package and refreshes the registry (for v2 block-pack schema)`;static flags={registry:t.Flags.string({char:`r`,summary:`full address of the registry`,helpValue:`<address>`,env:`PL_REGISTRY`,required:!0}),manifest:t.Flags.file({char:`m`,summary:`manifest file path`,exists:!0,default:`./block-pack/${e.F}`}),"version-override":t.Flags.file({char:`v`,summary:`override package version`}),refresh:t.Flags.boolean({summary:`refresh repository after adding the package`,default:!0,allowNo:!0,env:`PL_REGISTRY_REFRESH`}),unstable:t.Flags.boolean({summary:`do not add the published package to stable channel`,default:!1,env:`PL_PUBLISH_UNSTABLE`})};async run(){let{flags:t}=await this.parse(o),s=n.default.resolve(t.manifest),c=JSON.parse(await r.default.promises.readFile(s,{encoding:`utf-8`})),l=i.BlockPackManifest.parse(c);l=m(c,l);let u=n.default.dirname(s);this.log(`Manifest root = ${u}`),t[`version-override`]&&(l=(0,i.overrideManifestVersion)(l,t[`version-override`]));let d=new e.b(e._(t.registry),new a.OclifLoggerAdapter(this));await d.publishPackage(l,async e=>Buffer.from(await r.default.promises.readFile(n.default.resolve(u,e)))),t.unstable||(this.log(`Adding package to ${i.StableChannel} channel...`),await d.addPackageToChannel(l.description.id,i.StableChannel)),t.refresh&&await d.updateIfNeeded()}},g=class n extends t.Command{static description=`Refresh overview files based on published but not proecessed artefacts`;static flags={registry:t.Flags.string({char:`r`,summary:`full address of the registry`,helpValue:`<address>`,env:`PL_REGISTRY`,required:!0}),mode:t.Flags.string({char:`m`,summary:`refresh mode (allowed valiues: "force", "normal", "dry-run")`,helpValue:`<mode>`,options:[`force`,`normal`,`dry-run`],env:`PL_REGISTRY_REFRESH_DRY_RUN`,default:`normal`})};async run(){let{flags:t}=await this.parse(n);await new e.b(e._(t.registry),new a.OclifLoggerAdapter(this)).updateIfNeeded(t.mode)}},_=class n extends t.Command{static description=`Restore global overview from a snapshot`;static flags={registry:t.Flags.string({char:`r`,summary:`full address of the registry`,helpValue:`<address>`,env:`PL_REGISTRY`,required:!0}),snapshot:t.Flags.string({char:`s`,summary:`snapshot timestamp ID to restore from`,helpValue:`<timestamp>`,required:!0}),"skip-confirmation":t.Flags.boolean({summary:`skip confirmation prompt (use with caution)`,default:!1})};async run(){let{flags:t}=await this.parse(n),r=new e.b(e._(t.registry),new a.OclifLoggerAdapter(this)),i=await r.listGlobalOverviewSnapshots();if(i.find(e=>e.timestamp===t.snapshot)||this.error(`Snapshot '${t.snapshot}' not found. Available snapshots:\n${i.map(e=>` - ${e.timestamp}`).join(`
|
|
2
|
+
`)||` (none)`}`),!t[`skip-confirmation`]){let e=(await import(`node:readline`)).createInterface({input:process.stdin,output:process.stdout}),n=await new Promise(n=>{e.question(`⚠️ This will overwrite the current global overview with snapshot '${t.snapshot}'.\nAre you sure you want to continue? (y/N): `,n)});if(e.close(),n.toLowerCase()!==`y`&&n.toLowerCase()!==`yes`){this.log(`Restore cancelled.`);return}}try{await r.restoreGlobalOverviewFromSnapshot(t.snapshot),this.log(`✅ Successfully restored global overview from snapshot '${t.snapshot}'`)}catch(e){this.error(`Failed to restore from snapshot: ${String(e)}`)}}};function v(e){let t=e.match(/(?<destName>[^/\\]+)=(?<src>.*)/);if(t){let{src:e,destName:n}=t.groups;return{src:e,destName:n}}else return{src:e,destName:n.default.basename(e)}}const y=t.Flags.custom({summary:`target files to upload`,helpValue:`file_path | package_name=file_path`,parse:async e=>v(e)});var b=[`registry`,`organization`,`package`,`version`],x=class n extends t.Command{static description=`Uploads V1 package and refreshes the registry`;static flags={registry:t.Flags.string({char:`r`,summary:`full address of the registry or alias from .pl.reg`,helpValue:`<address|alias>`,env:`PL_REGISTRY`}),organization:t.Flags.string({char:`o`,summary:`target organisation`,env:`PL_PACKAGE_ORGANIZATION`}),package:t.Flags.string({char:`p`,summary:`target package`,env:`PL_PACKAGE_NAME`}),version:t.Flags.string({char:`v`,summary:`target version`,env:`PL_PACKAGE_VERSION`}),meta:t.Flags.file({char:`m`,summary:`json file containing meta information to associate with tha package`,exists:!0}),file:y({char:`f`,summary:`package files`,multiple:!0,default:[]}),refresh:t.Flags.boolean({summary:`refresh repository after adding the package`,default:!0,allowNo:!0,env:`PL_REGISTRY_REFRESH`})};async run(){let{flags:t}=await this.parse(n),i=e.p.parse({});for(let e of b)t[e]&&(i[e]=t[e]);t.meta&&(t.meta.endsWith(`.json`)?i.meta=JSON.parse(await r.default.promises.readFile(t.meta,{encoding:`utf-8`})):t.meta.endsWith(`.yaml`)&&(i.meta=o.default.parse(await r.default.promises.readFile(t.meta,{encoding:`utf-8`}))));for(let e of t.file)i.files[e.destName]=e.src;let s=await e.n(i);this.log(o.default.stringify(s.conf));let c=s.createRegistry(new a.OclifLoggerAdapter(this)),l=s.fullPackageName,u=c.constructNewPackage(l);for(let[e,t]of Object.entries(s.conf.files)){this.log(`Uploading ${t} -> ${e} ...`);let n=await r.default.promises.readFile(t);await u.addFile(e,n)}this.log(`Uploading meta information...`),await u.writeMeta(s.conf.meta),await u.finish(),t.refresh&&await c.updateIfNeeded()}},S=class extends t.Command{static description=`Updates @platforma-sdk and @milaboratories packages in pnpm-workspace.yaml catalog to their latest versions from npm registry.`;static examples=[`<%= config.bin %> <%= command.id %>`];async run(){await(0,s.updatePackages)()}};const C={"build-meta":c,"build-model":u,"list-overview-snapshots":d,"mark-stable":f,pack:p,publish:h,"refresh-registry":g,"restore-overview-from-snapshot":_,"upload-package-v1":x,"update-deps":S};exports.COMMANDS=C;
|
|
3
3
|
//# sourceMappingURL=cli.js.map
|
package/dist/cli.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cli.js","names":[],"sources":["../src/cmd/build-meta.ts","../src/cmd/build-model.ts","../src/cmd/list-overview-snapshots.ts","../src/cmd/mark-stable.ts","../src/cmd/pack.ts","../src/cmd/publish.ts","../src/cmd/refresh-registry.ts","../src/cmd/restore-overview-from-snapshot.ts","../src/registry_v1/flags.ts","../src/cmd/upload-package-v1.ts","../src/cmd/update-deps.ts","../src/cmd/index.ts"],"sourcesContent":["import { Command, Flags } from \"@oclif/core\";\nimport path from \"node:path\";\nimport fs from \"node:fs\";\nimport { loadPackDescriptionRaw } from \"../v2\";\nimport { BlockPackMetaDescription, BlockPackMetaEmbedAbsoluteBase64 } from \"../v2/model/block_meta\";\n\nexport default class BuildMeta extends Command {\n static override description =\n \"Extracts meta information from blocks package.json and outputs meta.json with embedded binary \" +\n \"and textual information linked from the meta section.\";\n\n static flags = {\n modulePath: Flags.string({\n char: \"i\",\n summary: \"input module path\",\n helpValue: \"<path>\",\n default: \".\",\n }),\n\n destination: Flags.string({\n char: \"o\",\n summary: \"output meta.json file\",\n helpValue: \"<path>\",\n required: true,\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(BuildMeta);\n const modulePath = path.resolve(flags.modulePath);\n const descriptionRaw = await loadPackDescriptionRaw(modulePath);\n const metaEmbedded = await BlockPackMetaEmbedAbsoluteBase64.parseAsync(\n BlockPackMetaDescription(modulePath).parse(descriptionRaw.meta),\n );\n\n await fs.promises.writeFile(path.resolve(flags.destination), JSON.stringify(metaEmbedded));\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport fs from \"node:fs\";\nimport path from \"node:path\";\n\nasync function getFileContent(path: string) {\n try {\n return await fs.promises.readFile(path, \"utf8\");\n } catch (error: unknown) {\n if (error instanceof Error && \"code\" in error && error.code === \"ENOENT\") {\n return undefined;\n }\n throw error;\n }\n}\n\nexport default class BuildModel extends Command {\n static override description =\n \"Extracts and outputs block model JSON from pre-built block model module\";\n\n static flags = {\n modulePath: Flags.string({\n char: \"i\",\n summary: \"input module path\",\n helpValue: \"<path>\",\n default: \".\",\n }),\n\n sourceBundle: Flags.string({\n char: \"b\",\n summary: \"bundled model code to embed into the model for callback-based rendering to work\",\n helpValue: \"<path>\",\n default: \"./dist/bundle.js\",\n }),\n\n destination: Flags.string({\n char: \"o\",\n summary: \"output model file\",\n helpValue: \"<path>\",\n default: \"./dist/model.json\",\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(BuildModel);\n const modulePath = path.resolve(flags.modulePath); // i.e. folder with package.json file\n // eslint-disable-next-line prefer-const, @typescript-eslint/no-unsafe-assignment\n let { model, platforma } = require(modulePath);\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n if (!model) model = platforma;\n if (!model) throw new Error('\"model\" export not found');\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n const { config } = model;\n\n if (!config)\n throw new Error(\n 'Malformed \"model\" object, check it is created with \"BlockModel\" ' +\n 'and \".done()\" is executed as the call in the chain.',\n );\n\n if (!(\"outputs\" in config) || !(\"sections\" in config))\n throw new Error('\"config\" has unexpected structure');\n\n const code = await getFileContent(flags.sourceBundle);\n if (code !== undefined) {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n config.code = {\n type: \"plain\",\n content: code,\n };\n }\n\n await fs.promises.writeFile(path.resolve(flags.destination), JSON.stringify(config));\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport { BlockRegistryV2 } from \"../v2/registry/registry\";\nimport { storageByUrl } from \"../io/storage\";\nimport { OclifLoggerAdapter } from \"@milaboratories/ts-helpers-oclif\";\n\nexport default class ListOverviewSnapshots extends Command {\n static description = \"List all available global overview snapshots in the registry\";\n\n static flags = {\n registry: Flags.string({\n char: \"r\",\n summary: \"full address of the registry\",\n helpValue: \"<address>\",\n env: \"PL_REGISTRY\",\n required: true,\n }),\n\n json: Flags.boolean({\n summary: \"output in JSON format\",\n default: false,\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(ListOverviewSnapshots);\n const storage = storageByUrl(flags.registry);\n const registry = new BlockRegistryV2(storage, new OclifLoggerAdapter(this));\n\n const snapshots = await registry.listGlobalOverviewSnapshots();\n\n if (flags.json) {\n this.log(JSON.stringify(snapshots, null, 2));\n } else {\n if (snapshots.length === 0) {\n this.log(\"No snapshots found.\");\n } else {\n this.log(`Found ${snapshots.length} snapshot(s):\\n`);\n for (const snapshot of snapshots) {\n this.log(` ${snapshot.timestamp}`);\n this.log(` Path: ${snapshot.path}`);\n this.log(\"\");\n }\n }\n }\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport { BlockRegistryV2, loadPackDescriptionRaw } from \"../v2\";\nimport path from \"node:path\";\nimport { overrideDescriptionVersion, StableChannel } from \"@milaboratories/pl-model-middle-layer\";\nimport { storageByUrl } from \"../io\";\nimport { OclifLoggerAdapter } from \"@milaboratories/ts-helpers-oclif\";\n\nexport default class MarkStable extends Command {\n static description = \"Mark target block stable\";\n\n static flags = {\n modulePath: Flags.string({\n char: \"i\",\n summary: \"input module path\",\n helpValue: \"<path>\",\n default: \".\",\n }),\n\n channel: Flags.string({\n char: \"c\",\n hidden: true,\n summary: \"custom channel\",\n helpValue: \"<channel name>\",\n default: StableChannel,\n }),\n\n \"version-override\": Flags.file({\n char: \"v\",\n summary: \"override package version\",\n }),\n\n registry: Flags.string({\n char: \"r\",\n summary: \"full address of the registry\",\n helpValue: \"<address>\",\n env: \"PL_REGISTRY\",\n required: true,\n }),\n\n refresh: Flags.boolean({\n summary: \"refresh repository after adding the package\",\n default: true,\n allowNo: true,\n env: \"PL_REGISTRY_REFRESH\",\n }),\n\n unmark: Flags.boolean({\n summary:\n 'reverses meaning of this command, flag can be used to remove \"stable\" flag from the package',\n default: false,\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(MarkStable);\n let description = await loadPackDescriptionRaw(path.resolve(flags.modulePath));\n if (flags[\"version-override\"])\n description = overrideDescriptionVersion(description, flags[\"version-override\"]);\n const storage = storageByUrl(flags.registry);\n const registry = new BlockRegistryV2(storage, new OclifLoggerAdapter(this));\n\n if (flags.unmark) await registry.removePackageFromChannel(description.id, flags.channel);\n else await registry.addPackageToChannel(description.id, flags.channel);\n\n if (flags.refresh) await registry.updateIfNeeded();\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport { loadPackDescription } from \"../v2/source_package\";\nimport path from \"node:path\";\nimport { buildBlockPackDist } from \"../v2/build_dist\";\n\nexport default class PackBlock extends Command {\n static description =\n \"Builds block pack and outputs a block pack manifest consolidating all \" +\n \"references assets into a single folder\";\n\n static flags = {\n modulePath: Flags.string({\n char: \"i\",\n summary: \"input module path\",\n helpValue: \"<path>\",\n default: \".\",\n }),\n\n destinationPath: Flags.string({\n char: \"o\",\n summary: \"output folder\",\n helpValue: \"<path>\",\n default: \"./block-pack\",\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(PackBlock);\n const description = await loadPackDescription(path.resolve(flags.modulePath));\n await buildBlockPackDist(description, path.resolve(flags.destinationPath));\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport fs from \"node:fs\";\nimport { OclifLoggerAdapter } from \"@milaboratories/ts-helpers-oclif\";\nimport { ManifestFileName } from \"../v2/registry/schema_public\";\nimport {\n BlockPackManifest,\n overrideManifestVersion,\n StableChannel,\n} from \"@milaboratories/pl-model-middle-layer\";\nimport { storageByUrl } from \"../io/storage\";\nimport { BlockRegistryV2 } from \"../v2/registry/registry\";\nimport path from \"node:path\";\n\nfunction simpleDeepMerge<T extends Record<string, unknown>>(\n target: Record<string, unknown>,\n source: T,\n): T {\n const result = { ...target };\n\n for (const key in source) {\n if (source[key] && typeof source[key] === \"object\" && !Array.isArray(source[key])) {\n if (result[key] && typeof result[key] === \"object\" && !Array.isArray(result[key])) {\n result[key] = simpleDeepMerge(\n result[key] as Record<string, unknown>,\n source[key] as Record<string, unknown>,\n );\n } else {\n result[key] = source[key];\n }\n } else {\n result[key] = source[key];\n }\n }\n\n return result as T;\n}\n\nexport default class Publish extends Command {\n static description =\n \"Publishes the block package and refreshes the registry (for v2 block-pack schema)\";\n\n static flags = {\n registry: Flags.string({\n char: \"r\",\n summary: \"full address of the registry\",\n helpValue: \"<address>\",\n env: \"PL_REGISTRY\",\n required: true,\n }),\n\n manifest: Flags.file({\n char: \"m\",\n summary: \"manifest file path\",\n exists: true,\n default: `./block-pack/${ManifestFileName}`,\n }),\n\n \"version-override\": Flags.file({\n char: \"v\",\n summary: \"override package version\",\n }),\n\n refresh: Flags.boolean({\n summary: \"refresh repository after adding the package\",\n default: true,\n allowNo: true,\n env: \"PL_REGISTRY_REFRESH\",\n }),\n\n unstable: Flags.boolean({\n summary: \"do not add the published package to stable channel\",\n default: false,\n env: \"PL_PUBLISH_UNSTABLE\",\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(Publish);\n\n const manifestPath = path.resolve(flags.manifest);\n const rawManifest = JSON.parse(\n await fs.promises.readFile(manifestPath, { encoding: \"utf-8\" }),\n ) as Record<string, unknown>;\n let manifest = BlockPackManifest.parse(rawManifest);\n // To keep extra fields from the manifest and keep coerced fields\n manifest = simpleDeepMerge(\n rawManifest,\n manifest as BlockPackManifest & Record<string, unknown>,\n );\n const manifestRoot = path.dirname(manifestPath);\n\n this.log(`Manifest root = ${manifestRoot}`);\n\n if (flags[\"version-override\"])\n manifest = overrideManifestVersion(manifest, flags[\"version-override\"]);\n\n const storage = storageByUrl(flags.registry);\n const registry = new BlockRegistryV2(storage, new OclifLoggerAdapter(this));\n\n await registry.publishPackage(manifest, async (file) =>\n Buffer.from(await fs.promises.readFile(path.resolve(manifestRoot, file))),\n );\n\n if (!flags.unstable) {\n this.log(`Adding package to ${StableChannel} channel...`);\n await registry.addPackageToChannel(manifest.description.id, StableChannel);\n }\n\n if (flags.refresh) await registry.updateIfNeeded();\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport { BlockRegistryV2 } from \"../v2\";\nimport { storageByUrl } from \"../io\";\nimport { OclifLoggerAdapter } from \"@milaboratories/ts-helpers-oclif\";\n\nexport default class RefreshRegistry extends Command {\n static description = \"Refresh overview files based on published but not proecessed artefacts\";\n\n static flags = {\n registry: Flags.string({\n char: \"r\",\n summary: \"full address of the registry\",\n helpValue: \"<address>\",\n env: \"PL_REGISTRY\",\n required: true,\n }),\n\n mode: Flags.string({\n char: \"m\",\n summary: 'refresh mode (allowed valiues: \"force\", \"normal\", \"dry-run\")',\n helpValue: \"<mode>\",\n options: [\"force\", \"normal\", \"dry-run\"],\n env: \"PL_REGISTRY_REFRESH_DRY_RUN\",\n default: \"normal\",\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(RefreshRegistry);\n const storage = storageByUrl(flags.registry);\n const registry = new BlockRegistryV2(storage, new OclifLoggerAdapter(this));\n await registry.updateIfNeeded(flags.mode as \"force\" | \"normal\" | \"dry-run\");\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport { BlockRegistryV2 } from \"../v2/registry/registry\";\nimport { storageByUrl } from \"../io/storage\";\nimport { OclifLoggerAdapter } from \"@milaboratories/ts-helpers-oclif\";\n\nexport default class RestoreOverviewFromSnapshot extends Command {\n static description = \"Restore global overview from a snapshot\";\n\n static flags = {\n registry: Flags.string({\n char: \"r\",\n summary: \"full address of the registry\",\n helpValue: \"<address>\",\n env: \"PL_REGISTRY\",\n required: true,\n }),\n\n snapshot: Flags.string({\n char: \"s\",\n summary: \"snapshot timestamp ID to restore from\",\n helpValue: \"<timestamp>\",\n required: true,\n }),\n\n \"skip-confirmation\": Flags.boolean({\n summary: \"skip confirmation prompt (use with caution)\",\n default: false,\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(RestoreOverviewFromSnapshot);\n const storage = storageByUrl(flags.registry);\n const registry = new BlockRegistryV2(storage, new OclifLoggerAdapter(this));\n\n // Check if snapshot exists\n const snapshots = await registry.listGlobalOverviewSnapshots();\n const targetSnapshot = snapshots.find((s) => s.timestamp === flags.snapshot);\n\n if (!targetSnapshot) {\n this.error(\n `Snapshot '${flags.snapshot}' not found. Available snapshots:\\n${\n snapshots.map((s) => ` - ${s.timestamp}`).join(\"\\n\") || \" (none)\"\n }`,\n );\n }\n\n // Confirmation prompt (unless skipped)\n if (!flags[\"skip-confirmation\"]) {\n const readline = await import(\"node:readline\");\n const rl = readline.createInterface({\n input: process.stdin,\n output: process.stdout,\n });\n\n const answer = await new Promise<string>((resolve) => {\n rl.question(\n `⚠️ This will overwrite the current global overview with snapshot '${flags.snapshot}'.\\n` +\n `Are you sure you want to continue? (y/N): `,\n resolve,\n );\n });\n\n rl.close();\n\n if (answer.toLowerCase() !== \"y\" && answer.toLowerCase() !== \"yes\") {\n this.log(\"Restore cancelled.\");\n return;\n }\n }\n\n // Perform restore\n try {\n await registry.restoreGlobalOverviewFromSnapshot(flags.snapshot);\n this.log(`✅ Successfully restored global overview from snapshot '${flags.snapshot}'`);\n } catch (error) {\n this.error(`Failed to restore from snapshot: ${String(error)}`);\n }\n }\n}\n","import { Flags } from \"@oclif/core\";\nimport path from \"node:path\";\n\nexport interface TargetFile {\n src: string;\n destName: string;\n}\n\nfunction parseTargetFile(arg: string): TargetFile {\n const match = arg.match(/(?<destName>[^/\\\\]+)=(?<src>.*)/);\n if (match) {\n const { src, destName } = match.groups!;\n return { src, destName };\n } else {\n return { src: arg, destName: path.basename(arg) };\n }\n}\n\nexport const targetFile = Flags.custom<TargetFile>({\n summary: \"target files to upload\",\n helpValue: \"file_path | package_name=file_path\",\n // eslint-disable-next-line @typescript-eslint/require-await -- oclif requires async but parsing is sync\n parse: async (arg) => parseTargetFile(arg),\n});\n","import { Command, Flags } from \"@oclif/core\";\nimport { getConfig } from \"../registry_v1/config\";\nimport { targetFile } from \"../registry_v1/flags\";\nimport fs from \"node:fs\";\nimport YAML from \"yaml\";\nimport { PlRegPackageConfigDataShard } from \"../registry_v1/config_schema\";\nimport { OclifLoggerAdapter } from \"@milaboratories/ts-helpers-oclif\";\n\ntype BasicConfigField = keyof PlRegPackageConfigDataShard &\n (\"registry\" | \"organization\" | \"package\" | \"version\");\nconst BasicConfigFields: BasicConfigField[] = [\"registry\", \"organization\", \"package\", \"version\"];\n\nexport default class UploadPackageV1 extends Command {\n static description = \"Uploads V1 package and refreshes the registry\";\n\n static flags = {\n registry: Flags.string({\n char: \"r\",\n summary: \"full address of the registry or alias from .pl.reg\",\n helpValue: \"<address|alias>\",\n env: \"PL_REGISTRY\",\n }),\n\n organization: Flags.string({\n char: \"o\",\n summary: \"target organisation\",\n env: \"PL_PACKAGE_ORGANIZATION\",\n }),\n\n package: Flags.string({\n char: \"p\",\n summary: \"target package\",\n env: \"PL_PACKAGE_NAME\",\n }),\n\n version: Flags.string({\n char: \"v\",\n summary: \"target version\",\n env: \"PL_PACKAGE_VERSION\",\n }),\n\n meta: Flags.file({\n char: \"m\",\n summary: \"json file containing meta information to associate with tha package\",\n exists: true,\n }),\n\n file: targetFile({\n char: \"f\",\n summary: \"package files\",\n multiple: true,\n default: [],\n }),\n\n refresh: Flags.boolean({\n summary: \"refresh repository after adding the package\",\n default: true,\n allowNo: true,\n env: \"PL_REGISTRY_REFRESH\",\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(UploadPackageV1);\n const configFromFlags: PlRegPackageConfigDataShard = PlRegPackageConfigDataShard.parse({});\n\n for (const field of BasicConfigFields) if (flags[field]) configFromFlags[field] = flags[field];\n\n if (flags.meta) {\n if (flags.meta.endsWith(\".json\"))\n configFromFlags.meta = JSON.parse(\n await fs.promises.readFile(flags.meta, { encoding: \"utf-8\" }),\n ) as Record<string, unknown>;\n else if (flags.meta.endsWith(\".yaml\"))\n configFromFlags.meta = YAML.parse(\n await fs.promises.readFile(flags.meta, { encoding: \"utf-8\" }),\n ) as Record<string, unknown>;\n }\n\n for (const targetFile of flags.file) {\n configFromFlags.files[targetFile.destName] = targetFile.src;\n }\n\n const conf = await getConfig(configFromFlags);\n\n this.log(YAML.stringify(conf.conf));\n\n const registry = conf.createRegistry(new OclifLoggerAdapter(this));\n const name = conf.fullPackageName;\n\n const builder = registry.constructNewPackage(name);\n\n for (const [dst, src] of Object.entries(conf.conf.files)) {\n this.log(`Uploading ${src} -> ${dst} ...`);\n const content = await fs.promises.readFile(src);\n await builder.addFile(dst, content);\n }\n\n this.log(`Uploading meta information...`);\n await builder.writeMeta(conf.conf.meta);\n await builder.finish();\n\n if (flags.refresh) await registry.updateIfNeeded();\n }\n}\n","import { Command } from \"@oclif/core\";\nimport { execFileSync } from \"node:child_process\";\nimport { createRequire } from \"node:module\";\n\nexport default class UpdateDeps extends Command {\n static override description =\n \"Updates @platforma-sdk and @milaboratories packages in pnpm-workspace.yaml catalog to their latest versions from npm registry.\";\n\n static override examples = [\"<%= config.bin %> <%= command.id %>\"];\n\n // eslint-disable-next-line @typescript-eslint/require-await -- oclif requires async but implementation is sync\n public async run(): Promise<void> {\n const require = createRequire(import.meta.url);\n const updaterPath = require.resolve(\"@platforma-sdk/blocks-deps-updater/scripts/updater.js\");\n\n execFileSync(process.execPath, [updaterPath], {\n stdio: \"inherit\",\n cwd: process.cwd(),\n });\n }\n}\n","// DO NOT EDIT. This file was generated by oclif-index utility.\n\nimport Cmd0 from \"./build-meta\";\nimport Cmd1 from \"./build-model\";\nimport Cmd3 from \"./list-overview-snapshots\";\nimport Cmd4 from \"./mark-stable\";\nimport Cmd5 from \"./pack\";\nimport Cmd6 from \"./publish\";\nimport Cmd7 from \"./refresh-registry\";\nimport Cmd8 from \"./restore-overview-from-snapshot\";\nimport Cmd9 from \"./upload-package-v1\";\nimport Cmd10 from \"./update-deps\";\n\nexport const COMMANDS = {\n \"build-meta\": Cmd0,\n \"build-model\": Cmd1,\n \"list-overview-snapshots\": Cmd3,\n \"mark-stable\": Cmd4,\n pack: Cmd5,\n publish: Cmd6,\n \"refresh-registry\": Cmd7,\n \"restore-overview-from-snapshot\": Cmd8,\n \"upload-package-v1\": Cmd9,\n \"update-deps\": Cmd10,\n};\n"],"mappings":"0YAMA,IAAqB,EAArB,MAAqB,UAAkB,EAAA,OAAQ,CAC7C,OAAgB,YACd,sJAGF,OAAO,MAAQ,CACb,WAAY,EAAA,MAAM,OAAO,CACvB,KAAM,IACN,QAAS,oBACT,UAAW,SACX,QAAS,IACV,CAAC,CAEF,YAAa,EAAA,MAAM,OAAO,CACxB,KAAM,IACN,QAAS,wBACT,UAAW,SACX,SAAU,GACX,CAAC,CACH,CAED,MAAa,KAAqB,CAChC,GAAM,CAAE,SAAU,MAAM,KAAK,MAAM,EAAU,CACvC,EAAa,EAAA,QAAK,QAAQ,EAAM,WAAW,CAC3C,EAAiB,MAAM,EAAA,EAAuB,EAAW,CACzD,EAAe,MAAM,EAAA,GAAiC,WAC1D,EAAA,GAAyB,EAAW,CAAC,MAAM,EAAe,KAAK,CAChE,CAED,MAAM,EAAA,QAAG,SAAS,UAAU,EAAA,QAAK,QAAQ,EAAM,YAAY,CAAE,KAAK,UAAU,EAAa,CAAC,GC/B9F,eAAe,EAAe,EAAc,CAC1C,GAAI,CACF,OAAO,MAAM,EAAA,QAAG,SAAS,SAAS,EAAM,OAAO,OACxC,EAAgB,CACvB,GAAI,aAAiB,OAAS,SAAU,GAAS,EAAM,OAAS,SAC9D,OAEF,MAAM,GAIV,IAAqB,EAArB,MAAqB,UAAmB,EAAA,OAAQ,CAC9C,OAAgB,YACd,0EAEF,OAAO,MAAQ,CACb,WAAY,EAAA,MAAM,OAAO,CACvB,KAAM,IACN,QAAS,oBACT,UAAW,SACX,QAAS,IACV,CAAC,CAEF,aAAc,EAAA,MAAM,OAAO,CACzB,KAAM,IACN,QAAS,kFACT,UAAW,SACX,QAAS,mBACV,CAAC,CAEF,YAAa,EAAA,MAAM,OAAO,CACxB,KAAM,IACN,QAAS,oBACT,UAAW,SACX,QAAS,oBACV,CAAC,CACH,CAED,MAAa,KAAqB,CAChC,GAAM,CAAE,SAAU,MAAM,KAAK,MAAM,EAAW,CACxC,EAAa,EAAA,QAAK,QAAQ,EAAM,WAAW,CAE7C,CAAE,QAAO,aAAc,QAAQ,EAAW,CAI9C,GADA,AAAY,IAAQ,EAChB,CAAC,EAAO,MAAU,MAAM,2BAA2B,CAGvD,GAAM,CAAE,UAAW,EAEnB,GAAI,CAAC,EACH,MAAU,MACR,sHAED,CAEH,GAAI,EAAE,YAAa,IAAW,EAAE,aAAc,GAC5C,MAAU,MAAM,oCAAoC,CAEtD,IAAM,EAAO,MAAM,EAAe,EAAM,aAAa,CACjD,IAAS,IAAA,KAEX,EAAO,KAAO,CACZ,KAAM,QACN,QAAS,EACV,EAGH,MAAM,EAAA,QAAG,SAAS,UAAU,EAAA,QAAK,QAAQ,EAAM,YAAY,CAAE,KAAK,UAAU,EAAO,CAAC,GCpEnE,EAArB,MAAqB,UAA8B,EAAA,OAAQ,CACzD,OAAO,YAAc,+DAErB,OAAO,MAAQ,CACb,SAAU,EAAA,MAAM,OAAO,CACrB,KAAM,IACN,QAAS,+BACT,UAAW,YACX,IAAK,cACL,SAAU,GACX,CAAC,CAEF,KAAM,EAAA,MAAM,QAAQ,CAClB,QAAS,wBACT,QAAS,GACV,CAAC,CACH,CAED,MAAa,KAAqB,CAChC,GAAM,CAAE,SAAU,MAAM,KAAK,MAAM,EAAsB,CAInD,EAAY,MAFD,IAAI,EAAA,EADL,EAAA,EAAa,EAAM,SAAS,CACE,IAAI,EAAA,mBAAmB,KAAK,CAAC,CAE1C,6BAA6B,CAE9D,GAAI,EAAM,KACR,KAAK,IAAI,KAAK,UAAU,EAAW,KAAM,EAAE,CAAC,SAExC,EAAU,SAAW,EACvB,KAAK,IAAI,sBAAsB,KAC1B,CACL,KAAK,IAAI,SAAS,EAAU,OAAO,iBAAiB,CACpD,IAAK,IAAM,KAAY,EACrB,KAAK,IAAI,KAAK,EAAS,YAAY,CACnC,KAAK,IAAI,aAAa,EAAS,OAAO,CACtC,KAAK,IAAI,GAAG,ICjCD,EAArB,MAAqB,UAAmB,EAAA,OAAQ,CAC9C,OAAO,YAAc,2BAErB,OAAO,MAAQ,CACb,WAAY,EAAA,MAAM,OAAO,CACvB,KAAM,IACN,QAAS,oBACT,UAAW,SACX,QAAS,IACV,CAAC,CAEF,QAAS,EAAA,MAAM,OAAO,CACpB,KAAM,IACN,OAAQ,GACR,QAAS,iBACT,UAAW,iBACX,QAAS,EAAA,cACV,CAAC,CAEF,mBAAoB,EAAA,MAAM,KAAK,CAC7B,KAAM,IACN,QAAS,2BACV,CAAC,CAEF,SAAU,EAAA,MAAM,OAAO,CACrB,KAAM,IACN,QAAS,+BACT,UAAW,YACX,IAAK,cACL,SAAU,GACX,CAAC,CAEF,QAAS,EAAA,MAAM,QAAQ,CACrB,QAAS,8CACT,QAAS,GACT,QAAS,GACT,IAAK,sBACN,CAAC,CAEF,OAAQ,EAAA,MAAM,QAAQ,CACpB,QACE,8FACF,QAAS,GACV,CAAC,CACH,CAED,MAAa,KAAqB,CAChC,GAAM,CAAE,SAAU,MAAM,KAAK,MAAM,EAAW,CAC1C,EAAc,MAAM,EAAA,EAAuB,EAAA,QAAK,QAAQ,EAAM,WAAW,CAAC,CAC1E,EAAM,sBACR,GAAA,EAAA,EAAA,4BAAyC,EAAa,EAAM,oBAAoB,EAElF,IAAM,EAAW,IAAI,EAAA,EADL,EAAA,EAAa,EAAM,SAAS,CACE,IAAI,EAAA,mBAAmB,KAAK,CAAC,CAEvE,EAAM,OAAQ,MAAM,EAAS,yBAAyB,EAAY,GAAI,EAAM,QAAQ,CACnF,MAAM,EAAS,oBAAoB,EAAY,GAAI,EAAM,QAAQ,CAElE,EAAM,SAAS,MAAM,EAAS,gBAAgB,GC3DjC,EAArB,MAAqB,UAAkB,EAAA,OAAQ,CAC7C,OAAO,YACL,+GAGF,OAAO,MAAQ,CACb,WAAY,EAAA,MAAM,OAAO,CACvB,KAAM,IACN,QAAS,oBACT,UAAW,SACX,QAAS,IACV,CAAC,CAEF,gBAAiB,EAAA,MAAM,OAAO,CAC5B,KAAM,IACN,QAAS,gBACT,UAAW,SACX,QAAS,eACV,CAAC,CACH,CAED,MAAa,KAAqB,CAChC,GAAM,CAAE,SAAU,MAAM,KAAK,MAAM,EAAU,CAE7C,MAAM,EAAA,EADc,MAAM,EAAA,EAAoB,EAAA,QAAK,QAAQ,EAAM,WAAW,CAAC,CACvC,EAAA,QAAK,QAAQ,EAAM,gBAAgB,CAAC,GChB9E,SAAS,EACP,EACA,EACG,CACH,IAAM,EAAS,CAAE,GAAG,EAAQ,CAE5B,IAAK,IAAM,KAAO,EACZ,EAAO,IAAQ,OAAO,EAAO,IAAS,UAAY,CAAC,MAAM,QAAQ,EAAO,GAAK,EAC3E,EAAO,IAAQ,OAAO,EAAO,IAAS,UAAY,CAAC,MAAM,QAAQ,EAAO,GAAK,CAC/E,EAAO,GAAO,EACZ,EAAO,GACP,EAAO,GACR,CAED,EAAO,GAAO,EAAO,GAO3B,OAAO,EAGT,IAAqB,EAArB,MAAqB,UAAgB,EAAA,OAAQ,CAC3C,OAAO,YACL,oFAEF,OAAO,MAAQ,CACb,SAAU,EAAA,MAAM,OAAO,CACrB,KAAM,IACN,QAAS,+BACT,UAAW,YACX,IAAK,cACL,SAAU,GACX,CAAC,CAEF,SAAU,EAAA,MAAM,KAAK,CACnB,KAAM,IACN,QAAS,qBACT,OAAQ,GACR,QAAS,gBAAgB,EAAA,IAC1B,CAAC,CAEF,mBAAoB,EAAA,MAAM,KAAK,CAC7B,KAAM,IACN,QAAS,2BACV,CAAC,CAEF,QAAS,EAAA,MAAM,QAAQ,CACrB,QAAS,8CACT,QAAS,GACT,QAAS,GACT,IAAK,sBACN,CAAC,CAEF,SAAU,EAAA,MAAM,QAAQ,CACtB,QAAS,qDACT,QAAS,GACT,IAAK,sBACN,CAAC,CACH,CAED,MAAa,KAAqB,CAChC,GAAM,CAAE,SAAU,MAAM,KAAK,MAAM,EAAQ,CAErC,EAAe,EAAA,QAAK,QAAQ,EAAM,SAAS,CAC3C,EAAc,KAAK,MACvB,MAAM,EAAA,QAAG,SAAS,SAAS,EAAc,CAAE,SAAU,QAAS,CAAC,CAChE,CACG,EAAW,EAAA,kBAAkB,MAAM,EAAY,CAEnD,EAAW,EACT,EACA,EACD,CACD,IAAM,EAAe,EAAA,QAAK,QAAQ,EAAa,CAE/C,KAAK,IAAI,mBAAmB,IAAe,CAEvC,EAAM,sBACR,GAAA,EAAA,EAAA,yBAAmC,EAAU,EAAM,oBAAoB,EAGzE,IAAM,EAAW,IAAI,EAAA,EADL,EAAA,EAAa,EAAM,SAAS,CACE,IAAI,EAAA,mBAAmB,KAAK,CAAC,CAE3E,MAAM,EAAS,eAAe,EAAU,KAAO,IAC7C,OAAO,KAAK,MAAM,EAAA,QAAG,SAAS,SAAS,EAAA,QAAK,QAAQ,EAAc,EAAK,CAAC,CAAC,CAC1E,CAEI,EAAM,WACT,KAAK,IAAI,qBAAqB,EAAA,cAAc,aAAa,CACzD,MAAM,EAAS,oBAAoB,EAAS,YAAY,GAAI,EAAA,cAAc,EAGxE,EAAM,SAAS,MAAM,EAAS,gBAAgB,GCvGjC,EAArB,MAAqB,UAAwB,EAAA,OAAQ,CACnD,OAAO,YAAc,yEAErB,OAAO,MAAQ,CACb,SAAU,EAAA,MAAM,OAAO,CACrB,KAAM,IACN,QAAS,+BACT,UAAW,YACX,IAAK,cACL,SAAU,GACX,CAAC,CAEF,KAAM,EAAA,MAAM,OAAO,CACjB,KAAM,IACN,QAAS,+DACT,UAAW,SACX,QAAS,CAAC,QAAS,SAAU,UAAU,CACvC,IAAK,8BACL,QAAS,SACV,CAAC,CACH,CAED,MAAa,KAAqB,CAChC,GAAM,CAAE,SAAU,MAAM,KAAK,MAAM,EAAgB,CAGnD,MADiB,IAAI,EAAA,EADL,EAAA,EAAa,EAAM,SAAS,CACE,IAAI,EAAA,mBAAmB,KAAK,CAAC,CAC5D,eAAe,EAAM,KAAuC,GC1B1D,EAArB,MAAqB,UAAoC,EAAA,OAAQ,CAC/D,OAAO,YAAc,0CAErB,OAAO,MAAQ,CACb,SAAU,EAAA,MAAM,OAAO,CACrB,KAAM,IACN,QAAS,+BACT,UAAW,YACX,IAAK,cACL,SAAU,GACX,CAAC,CAEF,SAAU,EAAA,MAAM,OAAO,CACrB,KAAM,IACN,QAAS,wCACT,UAAW,cACX,SAAU,GACX,CAAC,CAEF,oBAAqB,EAAA,MAAM,QAAQ,CACjC,QAAS,8CACT,QAAS,GACV,CAAC,CACH,CAED,MAAa,KAAqB,CAChC,GAAM,CAAE,SAAU,MAAM,KAAK,MAAM,EAA4B,CAEzD,EAAW,IAAI,EAAA,EADL,EAAA,EAAa,EAAM,SAAS,CACE,IAAI,EAAA,mBAAmB,KAAK,CAAC,CAGrE,EAAY,MAAM,EAAS,6BAA6B,CAY9D,GAXuB,EAAU,KAAM,GAAM,EAAE,YAAc,EAAM,SAAS,EAG1E,KAAK,MACH,aAAa,EAAM,SAAS,qCAC1B,EAAU,IAAK,GAAM,OAAO,EAAE,YAAY,CAAC,KAAK;EAAK,EAAI,aAE5D,CAIC,CAAC,EAAM,qBAAsB,CAE/B,IAAM,GADW,MAAM,OAAO,kBACV,gBAAgB,CAClC,MAAO,QAAQ,MACf,OAAQ,QAAQ,OACjB,CAAC,CAEI,EAAS,MAAM,IAAI,QAAiB,GAAY,CACpD,EAAG,SACD,sEAAsE,EAAM,SAAS,gDAErF,EACD,EACD,CAIF,GAFA,EAAG,OAAO,CAEN,EAAO,aAAa,GAAK,KAAO,EAAO,aAAa,GAAK,MAAO,CAClE,KAAK,IAAI,qBAAqB,CAC9B,QAKJ,GAAI,CACF,MAAM,EAAS,kCAAkC,EAAM,SAAS,CAChE,KAAK,IAAI,0DAA0D,EAAM,SAAS,GAAG,OAC9E,EAAO,CACd,KAAK,MAAM,oCAAoC,OAAO,EAAM,GAAG,ICpErE,SAAS,EAAgB,EAAyB,CAChD,IAAM,EAAQ,EAAI,MAAM,kCAAkC,CAC1D,GAAI,EAAO,CACT,GAAM,CAAE,MAAK,YAAa,EAAM,OAChC,MAAO,CAAE,MAAK,WAAU,MAExB,MAAO,CAAE,IAAK,EAAK,SAAU,EAAA,QAAK,SAAS,EAAI,CAAE,CAIrD,MAAa,EAAa,EAAA,MAAM,OAAmB,CACjD,QAAS,yBACT,UAAW,qCAEX,MAAO,KAAO,IAAQ,EAAgB,EAAI,CAC3C,CAAC,CCbF,IAAM,EAAwC,CAAC,WAAY,eAAgB,UAAW,UAAU,CAE3E,EAArB,MAAqB,UAAwB,EAAA,OAAQ,CACnD,OAAO,YAAc,gDAErB,OAAO,MAAQ,CACb,SAAU,EAAA,MAAM,OAAO,CACrB,KAAM,IACN,QAAS,qDACT,UAAW,kBACX,IAAK,cACN,CAAC,CAEF,aAAc,EAAA,MAAM,OAAO,CACzB,KAAM,IACN,QAAS,sBACT,IAAK,0BACN,CAAC,CAEF,QAAS,EAAA,MAAM,OAAO,CACpB,KAAM,IACN,QAAS,iBACT,IAAK,kBACN,CAAC,CAEF,QAAS,EAAA,MAAM,OAAO,CACpB,KAAM,IACN,QAAS,iBACT,IAAK,qBACN,CAAC,CAEF,KAAM,EAAA,MAAM,KAAK,CACf,KAAM,IACN,QAAS,sEACT,OAAQ,GACT,CAAC,CAEF,KAAM,EAAW,CACf,KAAM,IACN,QAAS,gBACT,SAAU,GACV,QAAS,EAAE,CACZ,CAAC,CAEF,QAAS,EAAA,MAAM,QAAQ,CACrB,QAAS,8CACT,QAAS,GACT,QAAS,GACT,IAAK,sBACN,CAAC,CACH,CAED,MAAa,KAAqB,CAChC,GAAM,CAAE,SAAU,MAAM,KAAK,MAAM,EAAgB,CAC7C,EAA+C,EAAA,EAA4B,MAAM,EAAE,CAAC,CAE1F,IAAK,IAAM,KAAS,EAAuB,EAAM,KAAQ,EAAgB,GAAS,EAAM,IAEpF,EAAM,OACJ,EAAM,KAAK,SAAS,QAAQ,CAC9B,EAAgB,KAAO,KAAK,MAC1B,MAAM,EAAA,QAAG,SAAS,SAAS,EAAM,KAAM,CAAE,SAAU,QAAS,CAAC,CAC9D,CACM,EAAM,KAAK,SAAS,QAAQ,GACnC,EAAgB,KAAO,EAAA,QAAK,MAC1B,MAAM,EAAA,QAAG,SAAS,SAAS,EAAM,KAAM,CAAE,SAAU,QAAS,CAAC,CAC9D,GAGL,IAAK,IAAM,KAAc,EAAM,KAC7B,EAAgB,MAAM,EAAW,UAAY,EAAW,IAG1D,IAAM,EAAO,MAAM,EAAA,EAAU,EAAgB,CAE7C,KAAK,IAAI,EAAA,QAAK,UAAU,EAAK,KAAK,CAAC,CAEnC,IAAM,EAAW,EAAK,eAAe,IAAI,EAAA,mBAAmB,KAAK,CAAC,CAC5D,EAAO,EAAK,gBAEZ,EAAU,EAAS,oBAAoB,EAAK,CAElD,IAAK,GAAM,CAAC,EAAK,KAAQ,OAAO,QAAQ,EAAK,KAAK,MAAM,CAAE,CACxD,KAAK,IAAI,aAAa,EAAI,MAAM,EAAI,MAAM,CAC1C,IAAM,EAAU,MAAM,EAAA,QAAG,SAAS,SAAS,EAAI,CAC/C,MAAM,EAAQ,QAAQ,EAAK,EAAQ,CAGrC,KAAK,IAAI,gCAAgC,CACzC,MAAM,EAAQ,UAAU,EAAK,KAAK,KAAK,CACvC,MAAM,EAAQ,QAAQ,CAElB,EAAM,SAAS,MAAM,EAAS,gBAAgB,GClGjC,EAArB,cAAwC,EAAA,OAAQ,CAC9C,OAAgB,YACd,iIAEF,OAAgB,SAAW,CAAC,sCAAsC,CAGlE,MAAa,KAAqB,CAEhC,IAAM,GAAA,EAAA,EAAA,eAAA,EAAA,CADoC,IAAI,CAClB,QAAQ,wDAAwD,EAE5F,EAAA,EAAA,cAAa,QAAQ,SAAU,CAAC,EAAY,CAAE,CAC5C,MAAO,UACP,IAAK,QAAQ,KAAK,CACnB,CAAC,GCLN,MAAa,EAAW,CACtB,aAAc,EACd,cAAe,EACf,0BAA2B,EAC3B,cAAe,EACf,KAAM,EACN,QAAS,EACT,mBAAoB,EACpB,iCAAkC,EAClC,oBAAqB,EACrB,cAAe,EAChB"}
|
|
1
|
+
{"version":3,"file":"cli.js","names":[],"sources":["../src/cmd/build-meta.ts","../src/cmd/build-model.ts","../src/cmd/list-overview-snapshots.ts","../src/cmd/mark-stable.ts","../src/cmd/pack.ts","../src/cmd/publish.ts","../src/cmd/refresh-registry.ts","../src/cmd/restore-overview-from-snapshot.ts","../src/registry_v1/flags.ts","../src/cmd/upload-package-v1.ts","../src/cmd/update-deps.ts","../src/cmd/index.ts"],"sourcesContent":["import { Command, Flags } from \"@oclif/core\";\nimport path from \"node:path\";\nimport fs from \"node:fs\";\nimport { loadPackDescriptionRaw } from \"../v2\";\nimport { BlockPackMetaDescription, BlockPackMetaEmbedAbsoluteBase64 } from \"../v2/model/block_meta\";\n\nexport default class BuildMeta extends Command {\n static override description =\n \"Extracts meta information from blocks package.json and outputs meta.json with embedded binary \" +\n \"and textual information linked from the meta section.\";\n\n static flags = {\n modulePath: Flags.string({\n char: \"i\",\n summary: \"input module path\",\n helpValue: \"<path>\",\n default: \".\",\n }),\n\n destination: Flags.string({\n char: \"o\",\n summary: \"output meta.json file\",\n helpValue: \"<path>\",\n required: true,\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(BuildMeta);\n const modulePath = path.resolve(flags.modulePath);\n const descriptionRaw = await loadPackDescriptionRaw(modulePath);\n const metaEmbedded = await BlockPackMetaEmbedAbsoluteBase64.parseAsync(\n BlockPackMetaDescription(modulePath).parse(descriptionRaw.meta),\n );\n\n await fs.promises.writeFile(path.resolve(flags.destination), JSON.stringify(metaEmbedded));\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport fs from \"node:fs\";\nimport path from \"node:path\";\n\nasync function getFileContent(path: string) {\n try {\n return await fs.promises.readFile(path, \"utf8\");\n } catch (error: unknown) {\n if (error instanceof Error && \"code\" in error && error.code === \"ENOENT\") {\n return undefined;\n }\n throw error;\n }\n}\n\nexport default class BuildModel extends Command {\n static override description =\n \"Extracts and outputs block model JSON from pre-built block model module\";\n\n static flags = {\n modulePath: Flags.string({\n char: \"i\",\n summary: \"input module path\",\n helpValue: \"<path>\",\n default: \".\",\n }),\n\n sourceBundle: Flags.string({\n char: \"b\",\n summary: \"bundled model code to embed into the model for callback-based rendering to work\",\n helpValue: \"<path>\",\n default: \"./dist/bundle.js\",\n }),\n\n destination: Flags.string({\n char: \"o\",\n summary: \"output model file\",\n helpValue: \"<path>\",\n default: \"./dist/model.json\",\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(BuildModel);\n const modulePath = path.resolve(flags.modulePath); // i.e. folder with package.json file\n // eslint-disable-next-line prefer-const, @typescript-eslint/no-unsafe-assignment\n let { model, platforma } = require(modulePath);\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n if (!model) model = platforma;\n if (!model) throw new Error('\"model\" export not found');\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n const { config } = model;\n\n if (!config)\n throw new Error(\n 'Malformed \"model\" object, check it is created with \"BlockModel\" ' +\n 'and \".done()\" is executed as the call in the chain.',\n );\n\n if (!(\"outputs\" in config) || !(\"sections\" in config))\n throw new Error('\"config\" has unexpected structure');\n\n const code = await getFileContent(flags.sourceBundle);\n if (code !== undefined) {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n config.code = {\n type: \"plain\",\n content: code,\n };\n }\n\n await fs.promises.writeFile(path.resolve(flags.destination), JSON.stringify(config));\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport { BlockRegistryV2 } from \"../v2/registry/registry\";\nimport { storageByUrl } from \"../io/storage\";\nimport { OclifLoggerAdapter } from \"@milaboratories/ts-helpers-oclif\";\n\nexport default class ListOverviewSnapshots extends Command {\n static description = \"List all available global overview snapshots in the registry\";\n\n static flags = {\n registry: Flags.string({\n char: \"r\",\n summary: \"full address of the registry\",\n helpValue: \"<address>\",\n env: \"PL_REGISTRY\",\n required: true,\n }),\n\n json: Flags.boolean({\n summary: \"output in JSON format\",\n default: false,\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(ListOverviewSnapshots);\n const storage = storageByUrl(flags.registry);\n const registry = new BlockRegistryV2(storage, new OclifLoggerAdapter(this));\n\n const snapshots = await registry.listGlobalOverviewSnapshots();\n\n if (flags.json) {\n this.log(JSON.stringify(snapshots, null, 2));\n } else {\n if (snapshots.length === 0) {\n this.log(\"No snapshots found.\");\n } else {\n this.log(`Found ${snapshots.length} snapshot(s):\\n`);\n for (const snapshot of snapshots) {\n this.log(` ${snapshot.timestamp}`);\n this.log(` Path: ${snapshot.path}`);\n this.log(\"\");\n }\n }\n }\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport { BlockRegistryV2, loadPackDescriptionRaw } from \"../v2\";\nimport path from \"node:path\";\nimport { overrideDescriptionVersion, StableChannel } from \"@milaboratories/pl-model-middle-layer\";\nimport { storageByUrl } from \"../io\";\nimport { OclifLoggerAdapter } from \"@milaboratories/ts-helpers-oclif\";\n\nexport default class MarkStable extends Command {\n static description = \"Mark target block stable\";\n\n static flags = {\n modulePath: Flags.string({\n char: \"i\",\n summary: \"input module path\",\n helpValue: \"<path>\",\n default: \".\",\n }),\n\n channel: Flags.string({\n char: \"c\",\n hidden: true,\n summary: \"custom channel\",\n helpValue: \"<channel name>\",\n default: StableChannel,\n }),\n\n \"version-override\": Flags.file({\n char: \"v\",\n summary: \"override package version\",\n }),\n\n registry: Flags.string({\n char: \"r\",\n summary: \"full address of the registry\",\n helpValue: \"<address>\",\n env: \"PL_REGISTRY\",\n required: true,\n }),\n\n refresh: Flags.boolean({\n summary: \"refresh repository after adding the package\",\n default: true,\n allowNo: true,\n env: \"PL_REGISTRY_REFRESH\",\n }),\n\n unmark: Flags.boolean({\n summary:\n 'reverses meaning of this command, flag can be used to remove \"stable\" flag from the package',\n default: false,\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(MarkStable);\n let description = await loadPackDescriptionRaw(path.resolve(flags.modulePath));\n if (flags[\"version-override\"])\n description = overrideDescriptionVersion(description, flags[\"version-override\"]);\n const storage = storageByUrl(flags.registry);\n const registry = new BlockRegistryV2(storage, new OclifLoggerAdapter(this));\n\n if (flags.unmark) await registry.removePackageFromChannel(description.id, flags.channel);\n else await registry.addPackageToChannel(description.id, flags.channel);\n\n if (flags.refresh) await registry.updateIfNeeded();\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport { loadPackDescription } from \"../v2/source_package\";\nimport path from \"node:path\";\nimport { buildBlockPackDist } from \"../v2/build_dist\";\n\nexport default class PackBlock extends Command {\n static description =\n \"Builds block pack and outputs a block pack manifest consolidating all \" +\n \"references assets into a single folder\";\n\n static flags = {\n modulePath: Flags.string({\n char: \"i\",\n summary: \"input module path\",\n helpValue: \"<path>\",\n default: \".\",\n }),\n\n destinationPath: Flags.string({\n char: \"o\",\n summary: \"output folder\",\n helpValue: \"<path>\",\n default: \"./block-pack\",\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(PackBlock);\n const description = await loadPackDescription(path.resolve(flags.modulePath));\n await buildBlockPackDist(description, path.resolve(flags.destinationPath));\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport fs from \"node:fs\";\nimport { OclifLoggerAdapter } from \"@milaboratories/ts-helpers-oclif\";\nimport { ManifestFileName } from \"../v2/registry/schema_public\";\nimport {\n BlockPackManifest,\n overrideManifestVersion,\n StableChannel,\n} from \"@milaboratories/pl-model-middle-layer\";\nimport { storageByUrl } from \"../io/storage\";\nimport { BlockRegistryV2 } from \"../v2/registry/registry\";\nimport path from \"node:path\";\n\nfunction simpleDeepMerge<T extends Record<string, unknown>>(\n target: Record<string, unknown>,\n source: T,\n): T {\n const result = { ...target };\n\n for (const key in source) {\n if (source[key] && typeof source[key] === \"object\" && !Array.isArray(source[key])) {\n if (result[key] && typeof result[key] === \"object\" && !Array.isArray(result[key])) {\n result[key] = simpleDeepMerge(\n result[key] as Record<string, unknown>,\n source[key] as Record<string, unknown>,\n );\n } else {\n result[key] = source[key];\n }\n } else {\n result[key] = source[key];\n }\n }\n\n return result as T;\n}\n\nexport default class Publish extends Command {\n static description =\n \"Publishes the block package and refreshes the registry (for v2 block-pack schema)\";\n\n static flags = {\n registry: Flags.string({\n char: \"r\",\n summary: \"full address of the registry\",\n helpValue: \"<address>\",\n env: \"PL_REGISTRY\",\n required: true,\n }),\n\n manifest: Flags.file({\n char: \"m\",\n summary: \"manifest file path\",\n exists: true,\n default: `./block-pack/${ManifestFileName}`,\n }),\n\n \"version-override\": Flags.file({\n char: \"v\",\n summary: \"override package version\",\n }),\n\n refresh: Flags.boolean({\n summary: \"refresh repository after adding the package\",\n default: true,\n allowNo: true,\n env: \"PL_REGISTRY_REFRESH\",\n }),\n\n unstable: Flags.boolean({\n summary: \"do not add the published package to stable channel\",\n default: false,\n env: \"PL_PUBLISH_UNSTABLE\",\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(Publish);\n\n const manifestPath = path.resolve(flags.manifest);\n const rawManifest = JSON.parse(\n await fs.promises.readFile(manifestPath, { encoding: \"utf-8\" }),\n ) as Record<string, unknown>;\n let manifest = BlockPackManifest.parse(rawManifest);\n // To keep extra fields from the manifest and keep coerced fields\n manifest = simpleDeepMerge(\n rawManifest,\n manifest as BlockPackManifest & Record<string, unknown>,\n );\n const manifestRoot = path.dirname(manifestPath);\n\n this.log(`Manifest root = ${manifestRoot}`);\n\n if (flags[\"version-override\"])\n manifest = overrideManifestVersion(manifest, flags[\"version-override\"]);\n\n const storage = storageByUrl(flags.registry);\n const registry = new BlockRegistryV2(storage, new OclifLoggerAdapter(this));\n\n await registry.publishPackage(manifest, async (file) =>\n Buffer.from(await fs.promises.readFile(path.resolve(manifestRoot, file))),\n );\n\n if (!flags.unstable) {\n this.log(`Adding package to ${StableChannel} channel...`);\n await registry.addPackageToChannel(manifest.description.id, StableChannel);\n }\n\n if (flags.refresh) await registry.updateIfNeeded();\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport { BlockRegistryV2 } from \"../v2\";\nimport { storageByUrl } from \"../io\";\nimport { OclifLoggerAdapter } from \"@milaboratories/ts-helpers-oclif\";\n\nexport default class RefreshRegistry extends Command {\n static description = \"Refresh overview files based on published but not proecessed artefacts\";\n\n static flags = {\n registry: Flags.string({\n char: \"r\",\n summary: \"full address of the registry\",\n helpValue: \"<address>\",\n env: \"PL_REGISTRY\",\n required: true,\n }),\n\n mode: Flags.string({\n char: \"m\",\n summary: 'refresh mode (allowed valiues: \"force\", \"normal\", \"dry-run\")',\n helpValue: \"<mode>\",\n options: [\"force\", \"normal\", \"dry-run\"],\n env: \"PL_REGISTRY_REFRESH_DRY_RUN\",\n default: \"normal\",\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(RefreshRegistry);\n const storage = storageByUrl(flags.registry);\n const registry = new BlockRegistryV2(storage, new OclifLoggerAdapter(this));\n await registry.updateIfNeeded(flags.mode as \"force\" | \"normal\" | \"dry-run\");\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport { BlockRegistryV2 } from \"../v2/registry/registry\";\nimport { storageByUrl } from \"../io/storage\";\nimport { OclifLoggerAdapter } from \"@milaboratories/ts-helpers-oclif\";\n\nexport default class RestoreOverviewFromSnapshot extends Command {\n static description = \"Restore global overview from a snapshot\";\n\n static flags = {\n registry: Flags.string({\n char: \"r\",\n summary: \"full address of the registry\",\n helpValue: \"<address>\",\n env: \"PL_REGISTRY\",\n required: true,\n }),\n\n snapshot: Flags.string({\n char: \"s\",\n summary: \"snapshot timestamp ID to restore from\",\n helpValue: \"<timestamp>\",\n required: true,\n }),\n\n \"skip-confirmation\": Flags.boolean({\n summary: \"skip confirmation prompt (use with caution)\",\n default: false,\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(RestoreOverviewFromSnapshot);\n const storage = storageByUrl(flags.registry);\n const registry = new BlockRegistryV2(storage, new OclifLoggerAdapter(this));\n\n // Check if snapshot exists\n const snapshots = await registry.listGlobalOverviewSnapshots();\n const targetSnapshot = snapshots.find((s) => s.timestamp === flags.snapshot);\n\n if (!targetSnapshot) {\n this.error(\n `Snapshot '${flags.snapshot}' not found. Available snapshots:\\n${\n snapshots.map((s) => ` - ${s.timestamp}`).join(\"\\n\") || \" (none)\"\n }`,\n );\n }\n\n // Confirmation prompt (unless skipped)\n if (!flags[\"skip-confirmation\"]) {\n const readline = await import(\"node:readline\");\n const rl = readline.createInterface({\n input: process.stdin,\n output: process.stdout,\n });\n\n const answer = await new Promise<string>((resolve) => {\n rl.question(\n `⚠️ This will overwrite the current global overview with snapshot '${flags.snapshot}'.\\n` +\n `Are you sure you want to continue? (y/N): `,\n resolve,\n );\n });\n\n rl.close();\n\n if (answer.toLowerCase() !== \"y\" && answer.toLowerCase() !== \"yes\") {\n this.log(\"Restore cancelled.\");\n return;\n }\n }\n\n // Perform restore\n try {\n await registry.restoreGlobalOverviewFromSnapshot(flags.snapshot);\n this.log(`✅ Successfully restored global overview from snapshot '${flags.snapshot}'`);\n } catch (error) {\n this.error(`Failed to restore from snapshot: ${String(error)}`);\n }\n }\n}\n","import { Flags } from \"@oclif/core\";\nimport path from \"node:path\";\n\nexport interface TargetFile {\n src: string;\n destName: string;\n}\n\nfunction parseTargetFile(arg: string): TargetFile {\n const match = arg.match(/(?<destName>[^/\\\\]+)=(?<src>.*)/);\n if (match) {\n const { src, destName } = match.groups!;\n return { src, destName };\n } else {\n return { src: arg, destName: path.basename(arg) };\n }\n}\n\nexport const targetFile = Flags.custom<TargetFile>({\n summary: \"target files to upload\",\n helpValue: \"file_path | package_name=file_path\",\n // eslint-disable-next-line @typescript-eslint/require-await -- oclif requires async but parsing is sync\n parse: async (arg) => parseTargetFile(arg),\n});\n","import { Command, Flags } from \"@oclif/core\";\nimport { getConfig } from \"../registry_v1/config\";\nimport { targetFile } from \"../registry_v1/flags\";\nimport fs from \"node:fs\";\nimport YAML from \"yaml\";\nimport { PlRegPackageConfigDataShard } from \"../registry_v1/config_schema\";\nimport { OclifLoggerAdapter } from \"@milaboratories/ts-helpers-oclif\";\n\ntype BasicConfigField = keyof PlRegPackageConfigDataShard &\n (\"registry\" | \"organization\" | \"package\" | \"version\");\nconst BasicConfigFields: BasicConfigField[] = [\"registry\", \"organization\", \"package\", \"version\"];\n\nexport default class UploadPackageV1 extends Command {\n static description = \"Uploads V1 package and refreshes the registry\";\n\n static flags = {\n registry: Flags.string({\n char: \"r\",\n summary: \"full address of the registry or alias from .pl.reg\",\n helpValue: \"<address|alias>\",\n env: \"PL_REGISTRY\",\n }),\n\n organization: Flags.string({\n char: \"o\",\n summary: \"target organisation\",\n env: \"PL_PACKAGE_ORGANIZATION\",\n }),\n\n package: Flags.string({\n char: \"p\",\n summary: \"target package\",\n env: \"PL_PACKAGE_NAME\",\n }),\n\n version: Flags.string({\n char: \"v\",\n summary: \"target version\",\n env: \"PL_PACKAGE_VERSION\",\n }),\n\n meta: Flags.file({\n char: \"m\",\n summary: \"json file containing meta information to associate with tha package\",\n exists: true,\n }),\n\n file: targetFile({\n char: \"f\",\n summary: \"package files\",\n multiple: true,\n default: [],\n }),\n\n refresh: Flags.boolean({\n summary: \"refresh repository after adding the package\",\n default: true,\n allowNo: true,\n env: \"PL_REGISTRY_REFRESH\",\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(UploadPackageV1);\n const configFromFlags: PlRegPackageConfigDataShard = PlRegPackageConfigDataShard.parse({});\n\n for (const field of BasicConfigFields) if (flags[field]) configFromFlags[field] = flags[field];\n\n if (flags.meta) {\n if (flags.meta.endsWith(\".json\"))\n configFromFlags.meta = JSON.parse(\n await fs.promises.readFile(flags.meta, { encoding: \"utf-8\" }),\n ) as Record<string, unknown>;\n else if (flags.meta.endsWith(\".yaml\"))\n configFromFlags.meta = YAML.parse(\n await fs.promises.readFile(flags.meta, { encoding: \"utf-8\" }),\n ) as Record<string, unknown>;\n }\n\n for (const targetFile of flags.file) {\n configFromFlags.files[targetFile.destName] = targetFile.src;\n }\n\n const conf = await getConfig(configFromFlags);\n\n this.log(YAML.stringify(conf.conf));\n\n const registry = conf.createRegistry(new OclifLoggerAdapter(this));\n const name = conf.fullPackageName;\n\n const builder = registry.constructNewPackage(name);\n\n for (const [dst, src] of Object.entries(conf.conf.files)) {\n this.log(`Uploading ${src} -> ${dst} ...`);\n const content = await fs.promises.readFile(src);\n await builder.addFile(dst, content);\n }\n\n this.log(`Uploading meta information...`);\n await builder.writeMeta(conf.conf.meta);\n await builder.finish();\n\n if (flags.refresh) await registry.updateIfNeeded();\n }\n}\n","import { Command } from \"@oclif/core\";\nimport { updatePackages } from \"@platforma-sdk/blocks-deps-updater\";\n\nexport default class UpdateDeps extends Command {\n static override description =\n \"Updates @platforma-sdk and @milaboratories packages in pnpm-workspace.yaml catalog to their latest versions from npm registry.\";\n\n static override examples = [\"<%= config.bin %> <%= command.id %>\"];\n\n public async run(): Promise<void> {\n await updatePackages();\n }\n}\n","// DO NOT EDIT. This file was generated by oclif-index utility.\n\nimport Cmd0 from \"./build-meta\";\nimport Cmd1 from \"./build-model\";\nimport Cmd3 from \"./list-overview-snapshots\";\nimport Cmd4 from \"./mark-stable\";\nimport Cmd5 from \"./pack\";\nimport Cmd6 from \"./publish\";\nimport Cmd7 from \"./refresh-registry\";\nimport Cmd8 from \"./restore-overview-from-snapshot\";\nimport Cmd9 from \"./upload-package-v1\";\nimport Cmd10 from \"./update-deps\";\n\nexport const COMMANDS = {\n \"build-meta\": Cmd0,\n \"build-model\": Cmd1,\n \"list-overview-snapshots\": Cmd3,\n \"mark-stable\": Cmd4,\n pack: Cmd5,\n publish: Cmd6,\n \"refresh-registry\": Cmd7,\n \"restore-overview-from-snapshot\": Cmd8,\n \"upload-package-v1\": Cmd9,\n \"update-deps\": Cmd10,\n};\n"],"mappings":"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"}
|
package/dist/cli.mjs
CHANGED
|
@@ -5,9 +5,8 @@ import m from "node:fs";
|
|
|
5
5
|
import { BlockPackManifest as h, StableChannel as g, overrideDescriptionVersion as _, overrideManifestVersion as v } from "@milaboratories/pl-model-middle-layer";
|
|
6
6
|
import { OclifLoggerAdapter as y } from "@milaboratories/ts-helpers-oclif";
|
|
7
7
|
import b from "yaml";
|
|
8
|
-
import {
|
|
9
|
-
|
|
10
|
-
var C = class e extends d {
|
|
8
|
+
import { updatePackages as x } from "@platforma-sdk/blocks-deps-updater";
|
|
9
|
+
var S = class e extends d {
|
|
11
10
|
static description = "Extracts meta information from blocks package.json and outputs meta.json with embedded binary and textual information linked from the meta section.";
|
|
12
11
|
static flags = {
|
|
13
12
|
modulePath: f.string({
|
|
@@ -28,7 +27,7 @@ var C = class e extends d {
|
|
|
28
27
|
await m.promises.writeFile(p.resolve(t.destination), JSON.stringify(a));
|
|
29
28
|
}
|
|
30
29
|
};
|
|
31
|
-
async function
|
|
30
|
+
async function C(e) {
|
|
32
31
|
try {
|
|
33
32
|
return await m.promises.readFile(e, "utf8");
|
|
34
33
|
} catch (e) {
|
|
@@ -36,7 +35,7 @@ async function w(e) {
|
|
|
36
35
|
throw e;
|
|
37
36
|
}
|
|
38
37
|
}
|
|
39
|
-
var
|
|
38
|
+
var w = class t extends d {
|
|
40
39
|
static description = "Extracts and outputs block model JSON from pre-built block model module";
|
|
41
40
|
static flags = {
|
|
42
41
|
modulePath: f.string({
|
|
@@ -64,13 +63,13 @@ var T = class t extends d {
|
|
|
64
63
|
let { config: a } = r;
|
|
65
64
|
if (!a) throw Error("Malformed \"model\" object, check it is created with \"BlockModel\" and \".done()\" is executed as the call in the chain.");
|
|
66
65
|
if (!("outputs" in a) || !("sections" in a)) throw Error("\"config\" has unexpected structure");
|
|
67
|
-
let o = await
|
|
66
|
+
let o = await C(n.sourceBundle);
|
|
68
67
|
o !== void 0 && (a.code = {
|
|
69
68
|
type: "plain",
|
|
70
69
|
content: o
|
|
71
70
|
}), await m.promises.writeFile(p.resolve(n.destination), JSON.stringify(a));
|
|
72
71
|
}
|
|
73
|
-
},
|
|
72
|
+
}, T = class e extends d {
|
|
74
73
|
static description = "List all available global overview snapshots in the registry";
|
|
75
74
|
static flags = {
|
|
76
75
|
registry: f.string({
|
|
@@ -94,7 +93,7 @@ var T = class t extends d {
|
|
|
94
93
|
for (let e of n) this.log(` ${e.timestamp}`), this.log(` Path: ${e.path}`), this.log("");
|
|
95
94
|
}
|
|
96
95
|
}
|
|
97
|
-
},
|
|
96
|
+
}, E = class e extends d {
|
|
98
97
|
static description = "Mark target block stable";
|
|
99
98
|
static flags = {
|
|
100
99
|
modulePath: f.string({
|
|
@@ -138,7 +137,7 @@ var T = class t extends d {
|
|
|
138
137
|
let r = new o(a(t.registry), new y(this));
|
|
139
138
|
t.unmark ? await r.removePackageFromChannel(n.id, t.channel) : await r.addPackageToChannel(n.id, t.channel), t.refresh && await r.updateIfNeeded();
|
|
140
139
|
}
|
|
141
|
-
},
|
|
140
|
+
}, D = class e extends d {
|
|
142
141
|
static description = "Builds block pack and outputs a block pack manifest consolidating all references assets into a single folder";
|
|
143
142
|
static flags = {
|
|
144
143
|
modulePath: f.string({
|
|
@@ -159,12 +158,12 @@ var T = class t extends d {
|
|
|
159
158
|
await r(await n(p.resolve(t.modulePath)), p.resolve(t.destinationPath));
|
|
160
159
|
}
|
|
161
160
|
};
|
|
162
|
-
function
|
|
161
|
+
function O(e, t) {
|
|
163
162
|
let n = { ...e };
|
|
164
|
-
for (let e in t) t[e] && typeof t[e] == "object" && !Array.isArray(t[e]) && n[e] && typeof n[e] == "object" && !Array.isArray(n[e]) ? n[e] =
|
|
163
|
+
for (let e in t) t[e] && typeof t[e] == "object" && !Array.isArray(t[e]) && n[e] && typeof n[e] == "object" && !Array.isArray(n[e]) ? n[e] = O(n[e], t[e]) : n[e] = t[e];
|
|
165
164
|
return n;
|
|
166
165
|
}
|
|
167
|
-
var
|
|
166
|
+
var k = class e extends d {
|
|
168
167
|
static description = "Publishes the block package and refreshes the registry (for v2 block-pack schema)";
|
|
169
168
|
static flags = {
|
|
170
169
|
registry: f.string({
|
|
@@ -198,13 +197,13 @@ var A = class e extends d {
|
|
|
198
197
|
};
|
|
199
198
|
async run() {
|
|
200
199
|
let { flags: t } = await this.parse(e), n = p.resolve(t.manifest), r = JSON.parse(await m.promises.readFile(n, { encoding: "utf-8" })), i = h.parse(r);
|
|
201
|
-
i =
|
|
200
|
+
i = O(r, i);
|
|
202
201
|
let s = p.dirname(n);
|
|
203
202
|
this.log(`Manifest root = ${s}`), t["version-override"] && (i = v(i, t["version-override"]));
|
|
204
203
|
let c = new o(a(t.registry), new y(this));
|
|
205
204
|
await c.publishPackage(i, async (e) => Buffer.from(await m.promises.readFile(p.resolve(s, e)))), t.unstable || (this.log(`Adding package to ${g} channel...`), await c.addPackageToChannel(i.description.id, g)), t.refresh && await c.updateIfNeeded();
|
|
206
205
|
}
|
|
207
|
-
},
|
|
206
|
+
}, A = class e extends d {
|
|
208
207
|
static description = "Refresh overview files based on published but not proecessed artefacts";
|
|
209
208
|
static flags = {
|
|
210
209
|
registry: f.string({
|
|
@@ -231,7 +230,7 @@ var A = class e extends d {
|
|
|
231
230
|
let { flags: t } = await this.parse(e);
|
|
232
231
|
await new o(a(t.registry), new y(this)).updateIfNeeded(t.mode);
|
|
233
232
|
}
|
|
234
|
-
},
|
|
233
|
+
}, j = class e extends d {
|
|
235
234
|
static description = "Restore global overview from a snapshot";
|
|
236
235
|
static flags = {
|
|
237
236
|
registry: f.string({
|
|
@@ -273,7 +272,7 @@ var A = class e extends d {
|
|
|
273
272
|
}
|
|
274
273
|
}
|
|
275
274
|
};
|
|
276
|
-
function
|
|
275
|
+
function M(e) {
|
|
277
276
|
let t = e.match(/(?<destName>[^/\\]+)=(?<src>.*)/);
|
|
278
277
|
if (t) {
|
|
279
278
|
let { src: e, destName: n } = t.groups;
|
|
@@ -286,17 +285,17 @@ function N(e) {
|
|
|
286
285
|
destName: p.basename(e)
|
|
287
286
|
};
|
|
288
287
|
}
|
|
289
|
-
const
|
|
288
|
+
const N = f.custom({
|
|
290
289
|
summary: "target files to upload",
|
|
291
290
|
helpValue: "file_path | package_name=file_path",
|
|
292
|
-
parse: async (e) =>
|
|
291
|
+
parse: async (e) => M(e)
|
|
293
292
|
});
|
|
294
|
-
var
|
|
293
|
+
var P = [
|
|
295
294
|
"registry",
|
|
296
295
|
"organization",
|
|
297
296
|
"package",
|
|
298
297
|
"version"
|
|
299
|
-
],
|
|
298
|
+
], F = class e extends d {
|
|
300
299
|
static description = "Uploads V1 package and refreshes the registry";
|
|
301
300
|
static flags = {
|
|
302
301
|
registry: f.string({
|
|
@@ -325,7 +324,7 @@ var F = [
|
|
|
325
324
|
summary: "json file containing meta information to associate with tha package",
|
|
326
325
|
exists: !0
|
|
327
326
|
}),
|
|
328
|
-
file:
|
|
327
|
+
file: N({
|
|
329
328
|
char: "f",
|
|
330
329
|
summary: "package files",
|
|
331
330
|
multiple: !0,
|
|
@@ -340,7 +339,7 @@ var F = [
|
|
|
340
339
|
};
|
|
341
340
|
async run() {
|
|
342
341
|
let { flags: t } = await this.parse(e), n = l.parse({});
|
|
343
|
-
for (let e of
|
|
342
|
+
for (let e of P) t[e] && (n[e] = t[e]);
|
|
344
343
|
t.meta && (t.meta.endsWith(".json") ? n.meta = JSON.parse(await m.promises.readFile(t.meta, { encoding: "utf-8" })) : t.meta.endsWith(".yaml") && (n.meta = b.parse(await m.promises.readFile(t.meta, { encoding: "utf-8" }))));
|
|
345
344
|
for (let e of t.file) n.files[e.destName] = e.src;
|
|
346
345
|
let r = await s(n);
|
|
@@ -353,29 +352,25 @@ var F = [
|
|
|
353
352
|
}
|
|
354
353
|
this.log("Uploading meta information..."), await o.writeMeta(r.conf.meta), await o.finish(), t.refresh && await i.updateIfNeeded();
|
|
355
354
|
}
|
|
356
|
-
},
|
|
355
|
+
}, I = class extends d {
|
|
357
356
|
static description = "Updates @platforma-sdk and @milaboratories packages in pnpm-workspace.yaml catalog to their latest versions from npm registry.";
|
|
358
357
|
static examples = ["<%= config.bin %> <%= command.id %>"];
|
|
359
358
|
async run() {
|
|
360
|
-
|
|
361
|
-
x(process.execPath, [e], {
|
|
362
|
-
stdio: "inherit",
|
|
363
|
-
cwd: process.cwd()
|
|
364
|
-
});
|
|
359
|
+
await x();
|
|
365
360
|
}
|
|
366
361
|
};
|
|
367
|
-
const
|
|
368
|
-
"build-meta":
|
|
369
|
-
"build-model":
|
|
370
|
-
"list-overview-snapshots":
|
|
371
|
-
"mark-stable":
|
|
372
|
-
pack:
|
|
373
|
-
publish:
|
|
374
|
-
"refresh-registry":
|
|
375
|
-
"restore-overview-from-snapshot":
|
|
376
|
-
"upload-package-v1":
|
|
377
|
-
"update-deps":
|
|
362
|
+
const L = {
|
|
363
|
+
"build-meta": S,
|
|
364
|
+
"build-model": w,
|
|
365
|
+
"list-overview-snapshots": T,
|
|
366
|
+
"mark-stable": E,
|
|
367
|
+
pack: D,
|
|
368
|
+
publish: k,
|
|
369
|
+
"refresh-registry": A,
|
|
370
|
+
"restore-overview-from-snapshot": j,
|
|
371
|
+
"upload-package-v1": F,
|
|
372
|
+
"update-deps": I
|
|
378
373
|
};
|
|
379
|
-
export {
|
|
374
|
+
export { L as COMMANDS };
|
|
380
375
|
|
|
381
376
|
//# sourceMappingURL=cli.mjs.map
|
package/dist/cli.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cli.mjs","names":[],"sources":["../src/cmd/build-meta.ts","../src/cmd/build-model.ts","../src/cmd/list-overview-snapshots.ts","../src/cmd/mark-stable.ts","../src/cmd/pack.ts","../src/cmd/publish.ts","../src/cmd/refresh-registry.ts","../src/cmd/restore-overview-from-snapshot.ts","../src/registry_v1/flags.ts","../src/cmd/upload-package-v1.ts","../src/cmd/update-deps.ts","../src/cmd/index.ts"],"sourcesContent":["import { Command, Flags } from \"@oclif/core\";\nimport path from \"node:path\";\nimport fs from \"node:fs\";\nimport { loadPackDescriptionRaw } from \"../v2\";\nimport { BlockPackMetaDescription, BlockPackMetaEmbedAbsoluteBase64 } from \"../v2/model/block_meta\";\n\nexport default class BuildMeta extends Command {\n static override description =\n \"Extracts meta information from blocks package.json and outputs meta.json with embedded binary \" +\n \"and textual information linked from the meta section.\";\n\n static flags = {\n modulePath: Flags.string({\n char: \"i\",\n summary: \"input module path\",\n helpValue: \"<path>\",\n default: \".\",\n }),\n\n destination: Flags.string({\n char: \"o\",\n summary: \"output meta.json file\",\n helpValue: \"<path>\",\n required: true,\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(BuildMeta);\n const modulePath = path.resolve(flags.modulePath);\n const descriptionRaw = await loadPackDescriptionRaw(modulePath);\n const metaEmbedded = await BlockPackMetaEmbedAbsoluteBase64.parseAsync(\n BlockPackMetaDescription(modulePath).parse(descriptionRaw.meta),\n );\n\n await fs.promises.writeFile(path.resolve(flags.destination), JSON.stringify(metaEmbedded));\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport fs from \"node:fs\";\nimport path from \"node:path\";\n\nasync function getFileContent(path: string) {\n try {\n return await fs.promises.readFile(path, \"utf8\");\n } catch (error: unknown) {\n if (error instanceof Error && \"code\" in error && error.code === \"ENOENT\") {\n return undefined;\n }\n throw error;\n }\n}\n\nexport default class BuildModel extends Command {\n static override description =\n \"Extracts and outputs block model JSON from pre-built block model module\";\n\n static flags = {\n modulePath: Flags.string({\n char: \"i\",\n summary: \"input module path\",\n helpValue: \"<path>\",\n default: \".\",\n }),\n\n sourceBundle: Flags.string({\n char: \"b\",\n summary: \"bundled model code to embed into the model for callback-based rendering to work\",\n helpValue: \"<path>\",\n default: \"./dist/bundle.js\",\n }),\n\n destination: Flags.string({\n char: \"o\",\n summary: \"output model file\",\n helpValue: \"<path>\",\n default: \"./dist/model.json\",\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(BuildModel);\n const modulePath = path.resolve(flags.modulePath); // i.e. folder with package.json file\n // eslint-disable-next-line prefer-const, @typescript-eslint/no-unsafe-assignment\n let { model, platforma } = require(modulePath);\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n if (!model) model = platforma;\n if (!model) throw new Error('\"model\" export not found');\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n const { config } = model;\n\n if (!config)\n throw new Error(\n 'Malformed \"model\" object, check it is created with \"BlockModel\" ' +\n 'and \".done()\" is executed as the call in the chain.',\n );\n\n if (!(\"outputs\" in config) || !(\"sections\" in config))\n throw new Error('\"config\" has unexpected structure');\n\n const code = await getFileContent(flags.sourceBundle);\n if (code !== undefined) {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n config.code = {\n type: \"plain\",\n content: code,\n };\n }\n\n await fs.promises.writeFile(path.resolve(flags.destination), JSON.stringify(config));\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport { BlockRegistryV2 } from \"../v2/registry/registry\";\nimport { storageByUrl } from \"../io/storage\";\nimport { OclifLoggerAdapter } from \"@milaboratories/ts-helpers-oclif\";\n\nexport default class ListOverviewSnapshots extends Command {\n static description = \"List all available global overview snapshots in the registry\";\n\n static flags = {\n registry: Flags.string({\n char: \"r\",\n summary: \"full address of the registry\",\n helpValue: \"<address>\",\n env: \"PL_REGISTRY\",\n required: true,\n }),\n\n json: Flags.boolean({\n summary: \"output in JSON format\",\n default: false,\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(ListOverviewSnapshots);\n const storage = storageByUrl(flags.registry);\n const registry = new BlockRegistryV2(storage, new OclifLoggerAdapter(this));\n\n const snapshots = await registry.listGlobalOverviewSnapshots();\n\n if (flags.json) {\n this.log(JSON.stringify(snapshots, null, 2));\n } else {\n if (snapshots.length === 0) {\n this.log(\"No snapshots found.\");\n } else {\n this.log(`Found ${snapshots.length} snapshot(s):\\n`);\n for (const snapshot of snapshots) {\n this.log(` ${snapshot.timestamp}`);\n this.log(` Path: ${snapshot.path}`);\n this.log(\"\");\n }\n }\n }\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport { BlockRegistryV2, loadPackDescriptionRaw } from \"../v2\";\nimport path from \"node:path\";\nimport { overrideDescriptionVersion, StableChannel } from \"@milaboratories/pl-model-middle-layer\";\nimport { storageByUrl } from \"../io\";\nimport { OclifLoggerAdapter } from \"@milaboratories/ts-helpers-oclif\";\n\nexport default class MarkStable extends Command {\n static description = \"Mark target block stable\";\n\n static flags = {\n modulePath: Flags.string({\n char: \"i\",\n summary: \"input module path\",\n helpValue: \"<path>\",\n default: \".\",\n }),\n\n channel: Flags.string({\n char: \"c\",\n hidden: true,\n summary: \"custom channel\",\n helpValue: \"<channel name>\",\n default: StableChannel,\n }),\n\n \"version-override\": Flags.file({\n char: \"v\",\n summary: \"override package version\",\n }),\n\n registry: Flags.string({\n char: \"r\",\n summary: \"full address of the registry\",\n helpValue: \"<address>\",\n env: \"PL_REGISTRY\",\n required: true,\n }),\n\n refresh: Flags.boolean({\n summary: \"refresh repository after adding the package\",\n default: true,\n allowNo: true,\n env: \"PL_REGISTRY_REFRESH\",\n }),\n\n unmark: Flags.boolean({\n summary:\n 'reverses meaning of this command, flag can be used to remove \"stable\" flag from the package',\n default: false,\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(MarkStable);\n let description = await loadPackDescriptionRaw(path.resolve(flags.modulePath));\n if (flags[\"version-override\"])\n description = overrideDescriptionVersion(description, flags[\"version-override\"]);\n const storage = storageByUrl(flags.registry);\n const registry = new BlockRegistryV2(storage, new OclifLoggerAdapter(this));\n\n if (flags.unmark) await registry.removePackageFromChannel(description.id, flags.channel);\n else await registry.addPackageToChannel(description.id, flags.channel);\n\n if (flags.refresh) await registry.updateIfNeeded();\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport { loadPackDescription } from \"../v2/source_package\";\nimport path from \"node:path\";\nimport { buildBlockPackDist } from \"../v2/build_dist\";\n\nexport default class PackBlock extends Command {\n static description =\n \"Builds block pack and outputs a block pack manifest consolidating all \" +\n \"references assets into a single folder\";\n\n static flags = {\n modulePath: Flags.string({\n char: \"i\",\n summary: \"input module path\",\n helpValue: \"<path>\",\n default: \".\",\n }),\n\n destinationPath: Flags.string({\n char: \"o\",\n summary: \"output folder\",\n helpValue: \"<path>\",\n default: \"./block-pack\",\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(PackBlock);\n const description = await loadPackDescription(path.resolve(flags.modulePath));\n await buildBlockPackDist(description, path.resolve(flags.destinationPath));\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport fs from \"node:fs\";\nimport { OclifLoggerAdapter } from \"@milaboratories/ts-helpers-oclif\";\nimport { ManifestFileName } from \"../v2/registry/schema_public\";\nimport {\n BlockPackManifest,\n overrideManifestVersion,\n StableChannel,\n} from \"@milaboratories/pl-model-middle-layer\";\nimport { storageByUrl } from \"../io/storage\";\nimport { BlockRegistryV2 } from \"../v2/registry/registry\";\nimport path from \"node:path\";\n\nfunction simpleDeepMerge<T extends Record<string, unknown>>(\n target: Record<string, unknown>,\n source: T,\n): T {\n const result = { ...target };\n\n for (const key in source) {\n if (source[key] && typeof source[key] === \"object\" && !Array.isArray(source[key])) {\n if (result[key] && typeof result[key] === \"object\" && !Array.isArray(result[key])) {\n result[key] = simpleDeepMerge(\n result[key] as Record<string, unknown>,\n source[key] as Record<string, unknown>,\n );\n } else {\n result[key] = source[key];\n }\n } else {\n result[key] = source[key];\n }\n }\n\n return result as T;\n}\n\nexport default class Publish extends Command {\n static description =\n \"Publishes the block package and refreshes the registry (for v2 block-pack schema)\";\n\n static flags = {\n registry: Flags.string({\n char: \"r\",\n summary: \"full address of the registry\",\n helpValue: \"<address>\",\n env: \"PL_REGISTRY\",\n required: true,\n }),\n\n manifest: Flags.file({\n char: \"m\",\n summary: \"manifest file path\",\n exists: true,\n default: `./block-pack/${ManifestFileName}`,\n }),\n\n \"version-override\": Flags.file({\n char: \"v\",\n summary: \"override package version\",\n }),\n\n refresh: Flags.boolean({\n summary: \"refresh repository after adding the package\",\n default: true,\n allowNo: true,\n env: \"PL_REGISTRY_REFRESH\",\n }),\n\n unstable: Flags.boolean({\n summary: \"do not add the published package to stable channel\",\n default: false,\n env: \"PL_PUBLISH_UNSTABLE\",\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(Publish);\n\n const manifestPath = path.resolve(flags.manifest);\n const rawManifest = JSON.parse(\n await fs.promises.readFile(manifestPath, { encoding: \"utf-8\" }),\n ) as Record<string, unknown>;\n let manifest = BlockPackManifest.parse(rawManifest);\n // To keep extra fields from the manifest and keep coerced fields\n manifest = simpleDeepMerge(\n rawManifest,\n manifest as BlockPackManifest & Record<string, unknown>,\n );\n const manifestRoot = path.dirname(manifestPath);\n\n this.log(`Manifest root = ${manifestRoot}`);\n\n if (flags[\"version-override\"])\n manifest = overrideManifestVersion(manifest, flags[\"version-override\"]);\n\n const storage = storageByUrl(flags.registry);\n const registry = new BlockRegistryV2(storage, new OclifLoggerAdapter(this));\n\n await registry.publishPackage(manifest, async (file) =>\n Buffer.from(await fs.promises.readFile(path.resolve(manifestRoot, file))),\n );\n\n if (!flags.unstable) {\n this.log(`Adding package to ${StableChannel} channel...`);\n await registry.addPackageToChannel(manifest.description.id, StableChannel);\n }\n\n if (flags.refresh) await registry.updateIfNeeded();\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport { BlockRegistryV2 } from \"../v2\";\nimport { storageByUrl } from \"../io\";\nimport { OclifLoggerAdapter } from \"@milaboratories/ts-helpers-oclif\";\n\nexport default class RefreshRegistry extends Command {\n static description = \"Refresh overview files based on published but not proecessed artefacts\";\n\n static flags = {\n registry: Flags.string({\n char: \"r\",\n summary: \"full address of the registry\",\n helpValue: \"<address>\",\n env: \"PL_REGISTRY\",\n required: true,\n }),\n\n mode: Flags.string({\n char: \"m\",\n summary: 'refresh mode (allowed valiues: \"force\", \"normal\", \"dry-run\")',\n helpValue: \"<mode>\",\n options: [\"force\", \"normal\", \"dry-run\"],\n env: \"PL_REGISTRY_REFRESH_DRY_RUN\",\n default: \"normal\",\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(RefreshRegistry);\n const storage = storageByUrl(flags.registry);\n const registry = new BlockRegistryV2(storage, new OclifLoggerAdapter(this));\n await registry.updateIfNeeded(flags.mode as \"force\" | \"normal\" | \"dry-run\");\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport { BlockRegistryV2 } from \"../v2/registry/registry\";\nimport { storageByUrl } from \"../io/storage\";\nimport { OclifLoggerAdapter } from \"@milaboratories/ts-helpers-oclif\";\n\nexport default class RestoreOverviewFromSnapshot extends Command {\n static description = \"Restore global overview from a snapshot\";\n\n static flags = {\n registry: Flags.string({\n char: \"r\",\n summary: \"full address of the registry\",\n helpValue: \"<address>\",\n env: \"PL_REGISTRY\",\n required: true,\n }),\n\n snapshot: Flags.string({\n char: \"s\",\n summary: \"snapshot timestamp ID to restore from\",\n helpValue: \"<timestamp>\",\n required: true,\n }),\n\n \"skip-confirmation\": Flags.boolean({\n summary: \"skip confirmation prompt (use with caution)\",\n default: false,\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(RestoreOverviewFromSnapshot);\n const storage = storageByUrl(flags.registry);\n const registry = new BlockRegistryV2(storage, new OclifLoggerAdapter(this));\n\n // Check if snapshot exists\n const snapshots = await registry.listGlobalOverviewSnapshots();\n const targetSnapshot = snapshots.find((s) => s.timestamp === flags.snapshot);\n\n if (!targetSnapshot) {\n this.error(\n `Snapshot '${flags.snapshot}' not found. Available snapshots:\\n${\n snapshots.map((s) => ` - ${s.timestamp}`).join(\"\\n\") || \" (none)\"\n }`,\n );\n }\n\n // Confirmation prompt (unless skipped)\n if (!flags[\"skip-confirmation\"]) {\n const readline = await import(\"node:readline\");\n const rl = readline.createInterface({\n input: process.stdin,\n output: process.stdout,\n });\n\n const answer = await new Promise<string>((resolve) => {\n rl.question(\n `⚠️ This will overwrite the current global overview with snapshot '${flags.snapshot}'.\\n` +\n `Are you sure you want to continue? (y/N): `,\n resolve,\n );\n });\n\n rl.close();\n\n if (answer.toLowerCase() !== \"y\" && answer.toLowerCase() !== \"yes\") {\n this.log(\"Restore cancelled.\");\n return;\n }\n }\n\n // Perform restore\n try {\n await registry.restoreGlobalOverviewFromSnapshot(flags.snapshot);\n this.log(`✅ Successfully restored global overview from snapshot '${flags.snapshot}'`);\n } catch (error) {\n this.error(`Failed to restore from snapshot: ${String(error)}`);\n }\n }\n}\n","import { Flags } from \"@oclif/core\";\nimport path from \"node:path\";\n\nexport interface TargetFile {\n src: string;\n destName: string;\n}\n\nfunction parseTargetFile(arg: string): TargetFile {\n const match = arg.match(/(?<destName>[^/\\\\]+)=(?<src>.*)/);\n if (match) {\n const { src, destName } = match.groups!;\n return { src, destName };\n } else {\n return { src: arg, destName: path.basename(arg) };\n }\n}\n\nexport const targetFile = Flags.custom<TargetFile>({\n summary: \"target files to upload\",\n helpValue: \"file_path | package_name=file_path\",\n // eslint-disable-next-line @typescript-eslint/require-await -- oclif requires async but parsing is sync\n parse: async (arg) => parseTargetFile(arg),\n});\n","import { Command, Flags } from \"@oclif/core\";\nimport { getConfig } from \"../registry_v1/config\";\nimport { targetFile } from \"../registry_v1/flags\";\nimport fs from \"node:fs\";\nimport YAML from \"yaml\";\nimport { PlRegPackageConfigDataShard } from \"../registry_v1/config_schema\";\nimport { OclifLoggerAdapter } from \"@milaboratories/ts-helpers-oclif\";\n\ntype BasicConfigField = keyof PlRegPackageConfigDataShard &\n (\"registry\" | \"organization\" | \"package\" | \"version\");\nconst BasicConfigFields: BasicConfigField[] = [\"registry\", \"organization\", \"package\", \"version\"];\n\nexport default class UploadPackageV1 extends Command {\n static description = \"Uploads V1 package and refreshes the registry\";\n\n static flags = {\n registry: Flags.string({\n char: \"r\",\n summary: \"full address of the registry or alias from .pl.reg\",\n helpValue: \"<address|alias>\",\n env: \"PL_REGISTRY\",\n }),\n\n organization: Flags.string({\n char: \"o\",\n summary: \"target organisation\",\n env: \"PL_PACKAGE_ORGANIZATION\",\n }),\n\n package: Flags.string({\n char: \"p\",\n summary: \"target package\",\n env: \"PL_PACKAGE_NAME\",\n }),\n\n version: Flags.string({\n char: \"v\",\n summary: \"target version\",\n env: \"PL_PACKAGE_VERSION\",\n }),\n\n meta: Flags.file({\n char: \"m\",\n summary: \"json file containing meta information to associate with tha package\",\n exists: true,\n }),\n\n file: targetFile({\n char: \"f\",\n summary: \"package files\",\n multiple: true,\n default: [],\n }),\n\n refresh: Flags.boolean({\n summary: \"refresh repository after adding the package\",\n default: true,\n allowNo: true,\n env: \"PL_REGISTRY_REFRESH\",\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(UploadPackageV1);\n const configFromFlags: PlRegPackageConfigDataShard = PlRegPackageConfigDataShard.parse({});\n\n for (const field of BasicConfigFields) if (flags[field]) configFromFlags[field] = flags[field];\n\n if (flags.meta) {\n if (flags.meta.endsWith(\".json\"))\n configFromFlags.meta = JSON.parse(\n await fs.promises.readFile(flags.meta, { encoding: \"utf-8\" }),\n ) as Record<string, unknown>;\n else if (flags.meta.endsWith(\".yaml\"))\n configFromFlags.meta = YAML.parse(\n await fs.promises.readFile(flags.meta, { encoding: \"utf-8\" }),\n ) as Record<string, unknown>;\n }\n\n for (const targetFile of flags.file) {\n configFromFlags.files[targetFile.destName] = targetFile.src;\n }\n\n const conf = await getConfig(configFromFlags);\n\n this.log(YAML.stringify(conf.conf));\n\n const registry = conf.createRegistry(new OclifLoggerAdapter(this));\n const name = conf.fullPackageName;\n\n const builder = registry.constructNewPackage(name);\n\n for (const [dst, src] of Object.entries(conf.conf.files)) {\n this.log(`Uploading ${src} -> ${dst} ...`);\n const content = await fs.promises.readFile(src);\n await builder.addFile(dst, content);\n }\n\n this.log(`Uploading meta information...`);\n await builder.writeMeta(conf.conf.meta);\n await builder.finish();\n\n if (flags.refresh) await registry.updateIfNeeded();\n }\n}\n","import { Command } from \"@oclif/core\";\nimport { execFileSync } from \"node:child_process\";\nimport { createRequire } from \"node:module\";\n\nexport default class UpdateDeps extends Command {\n static override description =\n \"Updates @platforma-sdk and @milaboratories packages in pnpm-workspace.yaml catalog to their latest versions from npm registry.\";\n\n static override examples = [\"<%= config.bin %> <%= command.id %>\"];\n\n // eslint-disable-next-line @typescript-eslint/require-await -- oclif requires async but implementation is sync\n public async run(): Promise<void> {\n const require = createRequire(import.meta.url);\n const updaterPath = require.resolve(\"@platforma-sdk/blocks-deps-updater/scripts/updater.js\");\n\n execFileSync(process.execPath, [updaterPath], {\n stdio: \"inherit\",\n cwd: process.cwd(),\n });\n }\n}\n","// DO NOT EDIT. This file was generated by oclif-index utility.\n\nimport Cmd0 from \"./build-meta\";\nimport Cmd1 from \"./build-model\";\nimport Cmd3 from \"./list-overview-snapshots\";\nimport Cmd4 from \"./mark-stable\";\nimport Cmd5 from \"./pack\";\nimport Cmd6 from \"./publish\";\nimport Cmd7 from \"./refresh-registry\";\nimport Cmd8 from \"./restore-overview-from-snapshot\";\nimport Cmd9 from \"./upload-package-v1\";\nimport Cmd10 from \"./update-deps\";\n\nexport const COMMANDS = {\n \"build-meta\": Cmd0,\n \"build-model\": Cmd1,\n \"list-overview-snapshots\": Cmd3,\n \"mark-stable\": Cmd4,\n pack: Cmd5,\n publish: Cmd6,\n \"refresh-registry\": Cmd7,\n \"restore-overview-from-snapshot\": Cmd8,\n \"upload-package-v1\": Cmd9,\n \"update-deps\": Cmd10,\n};\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"cli.mjs","names":[],"sources":["../src/cmd/build-meta.ts","../src/cmd/build-model.ts","../src/cmd/list-overview-snapshots.ts","../src/cmd/mark-stable.ts","../src/cmd/pack.ts","../src/cmd/publish.ts","../src/cmd/refresh-registry.ts","../src/cmd/restore-overview-from-snapshot.ts","../src/registry_v1/flags.ts","../src/cmd/upload-package-v1.ts","../src/cmd/update-deps.ts","../src/cmd/index.ts"],"sourcesContent":["import { Command, Flags } from \"@oclif/core\";\nimport path from \"node:path\";\nimport fs from \"node:fs\";\nimport { loadPackDescriptionRaw } from \"../v2\";\nimport { BlockPackMetaDescription, BlockPackMetaEmbedAbsoluteBase64 } from \"../v2/model/block_meta\";\n\nexport default class BuildMeta extends Command {\n static override description =\n \"Extracts meta information from blocks package.json and outputs meta.json with embedded binary \" +\n \"and textual information linked from the meta section.\";\n\n static flags = {\n modulePath: Flags.string({\n char: \"i\",\n summary: \"input module path\",\n helpValue: \"<path>\",\n default: \".\",\n }),\n\n destination: Flags.string({\n char: \"o\",\n summary: \"output meta.json file\",\n helpValue: \"<path>\",\n required: true,\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(BuildMeta);\n const modulePath = path.resolve(flags.modulePath);\n const descriptionRaw = await loadPackDescriptionRaw(modulePath);\n const metaEmbedded = await BlockPackMetaEmbedAbsoluteBase64.parseAsync(\n BlockPackMetaDescription(modulePath).parse(descriptionRaw.meta),\n );\n\n await fs.promises.writeFile(path.resolve(flags.destination), JSON.stringify(metaEmbedded));\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport fs from \"node:fs\";\nimport path from \"node:path\";\n\nasync function getFileContent(path: string) {\n try {\n return await fs.promises.readFile(path, \"utf8\");\n } catch (error: unknown) {\n if (error instanceof Error && \"code\" in error && error.code === \"ENOENT\") {\n return undefined;\n }\n throw error;\n }\n}\n\nexport default class BuildModel extends Command {\n static override description =\n \"Extracts and outputs block model JSON from pre-built block model module\";\n\n static flags = {\n modulePath: Flags.string({\n char: \"i\",\n summary: \"input module path\",\n helpValue: \"<path>\",\n default: \".\",\n }),\n\n sourceBundle: Flags.string({\n char: \"b\",\n summary: \"bundled model code to embed into the model for callback-based rendering to work\",\n helpValue: \"<path>\",\n default: \"./dist/bundle.js\",\n }),\n\n destination: Flags.string({\n char: \"o\",\n summary: \"output model file\",\n helpValue: \"<path>\",\n default: \"./dist/model.json\",\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(BuildModel);\n const modulePath = path.resolve(flags.modulePath); // i.e. folder with package.json file\n // eslint-disable-next-line prefer-const, @typescript-eslint/no-unsafe-assignment\n let { model, platforma } = require(modulePath);\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n if (!model) model = platforma;\n if (!model) throw new Error('\"model\" export not found');\n\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n const { config } = model;\n\n if (!config)\n throw new Error(\n 'Malformed \"model\" object, check it is created with \"BlockModel\" ' +\n 'and \".done()\" is executed as the call in the chain.',\n );\n\n if (!(\"outputs\" in config) || !(\"sections\" in config))\n throw new Error('\"config\" has unexpected structure');\n\n const code = await getFileContent(flags.sourceBundle);\n if (code !== undefined) {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access\n config.code = {\n type: \"plain\",\n content: code,\n };\n }\n\n await fs.promises.writeFile(path.resolve(flags.destination), JSON.stringify(config));\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport { BlockRegistryV2 } from \"../v2/registry/registry\";\nimport { storageByUrl } from \"../io/storage\";\nimport { OclifLoggerAdapter } from \"@milaboratories/ts-helpers-oclif\";\n\nexport default class ListOverviewSnapshots extends Command {\n static description = \"List all available global overview snapshots in the registry\";\n\n static flags = {\n registry: Flags.string({\n char: \"r\",\n summary: \"full address of the registry\",\n helpValue: \"<address>\",\n env: \"PL_REGISTRY\",\n required: true,\n }),\n\n json: Flags.boolean({\n summary: \"output in JSON format\",\n default: false,\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(ListOverviewSnapshots);\n const storage = storageByUrl(flags.registry);\n const registry = new BlockRegistryV2(storage, new OclifLoggerAdapter(this));\n\n const snapshots = await registry.listGlobalOverviewSnapshots();\n\n if (flags.json) {\n this.log(JSON.stringify(snapshots, null, 2));\n } else {\n if (snapshots.length === 0) {\n this.log(\"No snapshots found.\");\n } else {\n this.log(`Found ${snapshots.length} snapshot(s):\\n`);\n for (const snapshot of snapshots) {\n this.log(` ${snapshot.timestamp}`);\n this.log(` Path: ${snapshot.path}`);\n this.log(\"\");\n }\n }\n }\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport { BlockRegistryV2, loadPackDescriptionRaw } from \"../v2\";\nimport path from \"node:path\";\nimport { overrideDescriptionVersion, StableChannel } from \"@milaboratories/pl-model-middle-layer\";\nimport { storageByUrl } from \"../io\";\nimport { OclifLoggerAdapter } from \"@milaboratories/ts-helpers-oclif\";\n\nexport default class MarkStable extends Command {\n static description = \"Mark target block stable\";\n\n static flags = {\n modulePath: Flags.string({\n char: \"i\",\n summary: \"input module path\",\n helpValue: \"<path>\",\n default: \".\",\n }),\n\n channel: Flags.string({\n char: \"c\",\n hidden: true,\n summary: \"custom channel\",\n helpValue: \"<channel name>\",\n default: StableChannel,\n }),\n\n \"version-override\": Flags.file({\n char: \"v\",\n summary: \"override package version\",\n }),\n\n registry: Flags.string({\n char: \"r\",\n summary: \"full address of the registry\",\n helpValue: \"<address>\",\n env: \"PL_REGISTRY\",\n required: true,\n }),\n\n refresh: Flags.boolean({\n summary: \"refresh repository after adding the package\",\n default: true,\n allowNo: true,\n env: \"PL_REGISTRY_REFRESH\",\n }),\n\n unmark: Flags.boolean({\n summary:\n 'reverses meaning of this command, flag can be used to remove \"stable\" flag from the package',\n default: false,\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(MarkStable);\n let description = await loadPackDescriptionRaw(path.resolve(flags.modulePath));\n if (flags[\"version-override\"])\n description = overrideDescriptionVersion(description, flags[\"version-override\"]);\n const storage = storageByUrl(flags.registry);\n const registry = new BlockRegistryV2(storage, new OclifLoggerAdapter(this));\n\n if (flags.unmark) await registry.removePackageFromChannel(description.id, flags.channel);\n else await registry.addPackageToChannel(description.id, flags.channel);\n\n if (flags.refresh) await registry.updateIfNeeded();\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport { loadPackDescription } from \"../v2/source_package\";\nimport path from \"node:path\";\nimport { buildBlockPackDist } from \"../v2/build_dist\";\n\nexport default class PackBlock extends Command {\n static description =\n \"Builds block pack and outputs a block pack manifest consolidating all \" +\n \"references assets into a single folder\";\n\n static flags = {\n modulePath: Flags.string({\n char: \"i\",\n summary: \"input module path\",\n helpValue: \"<path>\",\n default: \".\",\n }),\n\n destinationPath: Flags.string({\n char: \"o\",\n summary: \"output folder\",\n helpValue: \"<path>\",\n default: \"./block-pack\",\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(PackBlock);\n const description = await loadPackDescription(path.resolve(flags.modulePath));\n await buildBlockPackDist(description, path.resolve(flags.destinationPath));\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport fs from \"node:fs\";\nimport { OclifLoggerAdapter } from \"@milaboratories/ts-helpers-oclif\";\nimport { ManifestFileName } from \"../v2/registry/schema_public\";\nimport {\n BlockPackManifest,\n overrideManifestVersion,\n StableChannel,\n} from \"@milaboratories/pl-model-middle-layer\";\nimport { storageByUrl } from \"../io/storage\";\nimport { BlockRegistryV2 } from \"../v2/registry/registry\";\nimport path from \"node:path\";\n\nfunction simpleDeepMerge<T extends Record<string, unknown>>(\n target: Record<string, unknown>,\n source: T,\n): T {\n const result = { ...target };\n\n for (const key in source) {\n if (source[key] && typeof source[key] === \"object\" && !Array.isArray(source[key])) {\n if (result[key] && typeof result[key] === \"object\" && !Array.isArray(result[key])) {\n result[key] = simpleDeepMerge(\n result[key] as Record<string, unknown>,\n source[key] as Record<string, unknown>,\n );\n } else {\n result[key] = source[key];\n }\n } else {\n result[key] = source[key];\n }\n }\n\n return result as T;\n}\n\nexport default class Publish extends Command {\n static description =\n \"Publishes the block package and refreshes the registry (for v2 block-pack schema)\";\n\n static flags = {\n registry: Flags.string({\n char: \"r\",\n summary: \"full address of the registry\",\n helpValue: \"<address>\",\n env: \"PL_REGISTRY\",\n required: true,\n }),\n\n manifest: Flags.file({\n char: \"m\",\n summary: \"manifest file path\",\n exists: true,\n default: `./block-pack/${ManifestFileName}`,\n }),\n\n \"version-override\": Flags.file({\n char: \"v\",\n summary: \"override package version\",\n }),\n\n refresh: Flags.boolean({\n summary: \"refresh repository after adding the package\",\n default: true,\n allowNo: true,\n env: \"PL_REGISTRY_REFRESH\",\n }),\n\n unstable: Flags.boolean({\n summary: \"do not add the published package to stable channel\",\n default: false,\n env: \"PL_PUBLISH_UNSTABLE\",\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(Publish);\n\n const manifestPath = path.resolve(flags.manifest);\n const rawManifest = JSON.parse(\n await fs.promises.readFile(manifestPath, { encoding: \"utf-8\" }),\n ) as Record<string, unknown>;\n let manifest = BlockPackManifest.parse(rawManifest);\n // To keep extra fields from the manifest and keep coerced fields\n manifest = simpleDeepMerge(\n rawManifest,\n manifest as BlockPackManifest & Record<string, unknown>,\n );\n const manifestRoot = path.dirname(manifestPath);\n\n this.log(`Manifest root = ${manifestRoot}`);\n\n if (flags[\"version-override\"])\n manifest = overrideManifestVersion(manifest, flags[\"version-override\"]);\n\n const storage = storageByUrl(flags.registry);\n const registry = new BlockRegistryV2(storage, new OclifLoggerAdapter(this));\n\n await registry.publishPackage(manifest, async (file) =>\n Buffer.from(await fs.promises.readFile(path.resolve(manifestRoot, file))),\n );\n\n if (!flags.unstable) {\n this.log(`Adding package to ${StableChannel} channel...`);\n await registry.addPackageToChannel(manifest.description.id, StableChannel);\n }\n\n if (flags.refresh) await registry.updateIfNeeded();\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport { BlockRegistryV2 } from \"../v2\";\nimport { storageByUrl } from \"../io\";\nimport { OclifLoggerAdapter } from \"@milaboratories/ts-helpers-oclif\";\n\nexport default class RefreshRegistry extends Command {\n static description = \"Refresh overview files based on published but not proecessed artefacts\";\n\n static flags = {\n registry: Flags.string({\n char: \"r\",\n summary: \"full address of the registry\",\n helpValue: \"<address>\",\n env: \"PL_REGISTRY\",\n required: true,\n }),\n\n mode: Flags.string({\n char: \"m\",\n summary: 'refresh mode (allowed valiues: \"force\", \"normal\", \"dry-run\")',\n helpValue: \"<mode>\",\n options: [\"force\", \"normal\", \"dry-run\"],\n env: \"PL_REGISTRY_REFRESH_DRY_RUN\",\n default: \"normal\",\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(RefreshRegistry);\n const storage = storageByUrl(flags.registry);\n const registry = new BlockRegistryV2(storage, new OclifLoggerAdapter(this));\n await registry.updateIfNeeded(flags.mode as \"force\" | \"normal\" | \"dry-run\");\n }\n}\n","import { Command, Flags } from \"@oclif/core\";\nimport { BlockRegistryV2 } from \"../v2/registry/registry\";\nimport { storageByUrl } from \"../io/storage\";\nimport { OclifLoggerAdapter } from \"@milaboratories/ts-helpers-oclif\";\n\nexport default class RestoreOverviewFromSnapshot extends Command {\n static description = \"Restore global overview from a snapshot\";\n\n static flags = {\n registry: Flags.string({\n char: \"r\",\n summary: \"full address of the registry\",\n helpValue: \"<address>\",\n env: \"PL_REGISTRY\",\n required: true,\n }),\n\n snapshot: Flags.string({\n char: \"s\",\n summary: \"snapshot timestamp ID to restore from\",\n helpValue: \"<timestamp>\",\n required: true,\n }),\n\n \"skip-confirmation\": Flags.boolean({\n summary: \"skip confirmation prompt (use with caution)\",\n default: false,\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(RestoreOverviewFromSnapshot);\n const storage = storageByUrl(flags.registry);\n const registry = new BlockRegistryV2(storage, new OclifLoggerAdapter(this));\n\n // Check if snapshot exists\n const snapshots = await registry.listGlobalOverviewSnapshots();\n const targetSnapshot = snapshots.find((s) => s.timestamp === flags.snapshot);\n\n if (!targetSnapshot) {\n this.error(\n `Snapshot '${flags.snapshot}' not found. Available snapshots:\\n${\n snapshots.map((s) => ` - ${s.timestamp}`).join(\"\\n\") || \" (none)\"\n }`,\n );\n }\n\n // Confirmation prompt (unless skipped)\n if (!flags[\"skip-confirmation\"]) {\n const readline = await import(\"node:readline\");\n const rl = readline.createInterface({\n input: process.stdin,\n output: process.stdout,\n });\n\n const answer = await new Promise<string>((resolve) => {\n rl.question(\n `⚠️ This will overwrite the current global overview with snapshot '${flags.snapshot}'.\\n` +\n `Are you sure you want to continue? (y/N): `,\n resolve,\n );\n });\n\n rl.close();\n\n if (answer.toLowerCase() !== \"y\" && answer.toLowerCase() !== \"yes\") {\n this.log(\"Restore cancelled.\");\n return;\n }\n }\n\n // Perform restore\n try {\n await registry.restoreGlobalOverviewFromSnapshot(flags.snapshot);\n this.log(`✅ Successfully restored global overview from snapshot '${flags.snapshot}'`);\n } catch (error) {\n this.error(`Failed to restore from snapshot: ${String(error)}`);\n }\n }\n}\n","import { Flags } from \"@oclif/core\";\nimport path from \"node:path\";\n\nexport interface TargetFile {\n src: string;\n destName: string;\n}\n\nfunction parseTargetFile(arg: string): TargetFile {\n const match = arg.match(/(?<destName>[^/\\\\]+)=(?<src>.*)/);\n if (match) {\n const { src, destName } = match.groups!;\n return { src, destName };\n } else {\n return { src: arg, destName: path.basename(arg) };\n }\n}\n\nexport const targetFile = Flags.custom<TargetFile>({\n summary: \"target files to upload\",\n helpValue: \"file_path | package_name=file_path\",\n // eslint-disable-next-line @typescript-eslint/require-await -- oclif requires async but parsing is sync\n parse: async (arg) => parseTargetFile(arg),\n});\n","import { Command, Flags } from \"@oclif/core\";\nimport { getConfig } from \"../registry_v1/config\";\nimport { targetFile } from \"../registry_v1/flags\";\nimport fs from \"node:fs\";\nimport YAML from \"yaml\";\nimport { PlRegPackageConfigDataShard } from \"../registry_v1/config_schema\";\nimport { OclifLoggerAdapter } from \"@milaboratories/ts-helpers-oclif\";\n\ntype BasicConfigField = keyof PlRegPackageConfigDataShard &\n (\"registry\" | \"organization\" | \"package\" | \"version\");\nconst BasicConfigFields: BasicConfigField[] = [\"registry\", \"organization\", \"package\", \"version\"];\n\nexport default class UploadPackageV1 extends Command {\n static description = \"Uploads V1 package and refreshes the registry\";\n\n static flags = {\n registry: Flags.string({\n char: \"r\",\n summary: \"full address of the registry or alias from .pl.reg\",\n helpValue: \"<address|alias>\",\n env: \"PL_REGISTRY\",\n }),\n\n organization: Flags.string({\n char: \"o\",\n summary: \"target organisation\",\n env: \"PL_PACKAGE_ORGANIZATION\",\n }),\n\n package: Flags.string({\n char: \"p\",\n summary: \"target package\",\n env: \"PL_PACKAGE_NAME\",\n }),\n\n version: Flags.string({\n char: \"v\",\n summary: \"target version\",\n env: \"PL_PACKAGE_VERSION\",\n }),\n\n meta: Flags.file({\n char: \"m\",\n summary: \"json file containing meta information to associate with tha package\",\n exists: true,\n }),\n\n file: targetFile({\n char: \"f\",\n summary: \"package files\",\n multiple: true,\n default: [],\n }),\n\n refresh: Flags.boolean({\n summary: \"refresh repository after adding the package\",\n default: true,\n allowNo: true,\n env: \"PL_REGISTRY_REFRESH\",\n }),\n };\n\n public async run(): Promise<void> {\n const { flags } = await this.parse(UploadPackageV1);\n const configFromFlags: PlRegPackageConfigDataShard = PlRegPackageConfigDataShard.parse({});\n\n for (const field of BasicConfigFields) if (flags[field]) configFromFlags[field] = flags[field];\n\n if (flags.meta) {\n if (flags.meta.endsWith(\".json\"))\n configFromFlags.meta = JSON.parse(\n await fs.promises.readFile(flags.meta, { encoding: \"utf-8\" }),\n ) as Record<string, unknown>;\n else if (flags.meta.endsWith(\".yaml\"))\n configFromFlags.meta = YAML.parse(\n await fs.promises.readFile(flags.meta, { encoding: \"utf-8\" }),\n ) as Record<string, unknown>;\n }\n\n for (const targetFile of flags.file) {\n configFromFlags.files[targetFile.destName] = targetFile.src;\n }\n\n const conf = await getConfig(configFromFlags);\n\n this.log(YAML.stringify(conf.conf));\n\n const registry = conf.createRegistry(new OclifLoggerAdapter(this));\n const name = conf.fullPackageName;\n\n const builder = registry.constructNewPackage(name);\n\n for (const [dst, src] of Object.entries(conf.conf.files)) {\n this.log(`Uploading ${src} -> ${dst} ...`);\n const content = await fs.promises.readFile(src);\n await builder.addFile(dst, content);\n }\n\n this.log(`Uploading meta information...`);\n await builder.writeMeta(conf.conf.meta);\n await builder.finish();\n\n if (flags.refresh) await registry.updateIfNeeded();\n }\n}\n","import { Command } from \"@oclif/core\";\nimport { updatePackages } from \"@platforma-sdk/blocks-deps-updater\";\n\nexport default class UpdateDeps extends Command {\n static override description =\n \"Updates @platforma-sdk and @milaboratories packages in pnpm-workspace.yaml catalog to their latest versions from npm registry.\";\n\n static override examples = [\"<%= config.bin %> <%= command.id %>\"];\n\n public async run(): Promise<void> {\n await updatePackages();\n }\n}\n","// DO NOT EDIT. This file was generated by oclif-index utility.\n\nimport Cmd0 from \"./build-meta\";\nimport Cmd1 from \"./build-model\";\nimport Cmd3 from \"./list-overview-snapshots\";\nimport Cmd4 from \"./mark-stable\";\nimport Cmd5 from \"./pack\";\nimport Cmd6 from \"./publish\";\nimport Cmd7 from \"./refresh-registry\";\nimport Cmd8 from \"./restore-overview-from-snapshot\";\nimport Cmd9 from \"./upload-package-v1\";\nimport Cmd10 from \"./update-deps\";\n\nexport const COMMANDS = {\n \"build-meta\": Cmd0,\n \"build-model\": Cmd1,\n \"list-overview-snapshots\": Cmd3,\n \"mark-stable\": Cmd4,\n pack: Cmd5,\n publish: Cmd6,\n \"refresh-registry\": Cmd7,\n \"restore-overview-from-snapshot\": Cmd8,\n \"upload-package-v1\": Cmd9,\n \"update-deps\": Cmd10,\n};\n"],"mappings":"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"}
|