contensis-cli 1.5.1-beta.4 → 1.5.1-beta.6

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/README.md CHANGED
@@ -2132,7 +2132,7 @@ The required inputs for using `copy field` are:
2132
2132
  - `fieldId`: the field id containing the source data
2133
2133
  - `destinationId`: the target field id where the data will be copied to
2134
2134
 
2135
- Copying field data from one field to another can only be done with fields that exist in the content type, and with the source and destination field types are metioned in the [transformation matrix](docs/copy_field_transformation_matrix.md)
2135
+ Copying field data from one field to another can only be done with fields that exist in the content type, and with the source and destination field types are metioned in the [transformation matrix](https://github.com/contensis/cli/blob/main/packages/contensis-cli/docs/copy_field_transformation_matrix.md)
2136
2136
 
2137
2137
  Similar to the `import` commands, the `copy` command is safe to run again and again for testing and reviewing the output. The changes are made to the entries permanently when the `--commit` option is added.
2138
2138
 
@@ -2254,7 +2254,7 @@ Adding a template containing html? Attributes can be wrapped in single quotes.
2254
2254
 
2255
2255
  Escape characters and new lines can be introduced inside templates when calling `contensis copy field` from your system shell as a cli command. This is OS/shell dependent and does not work in the Contensis shell (due to the combined layers of command parsing)
2256
2256
 
2257
- Further documentation on using [templates](docs/copy_field_templates.md)
2257
+ Further documentation on using [templates](https://github.com/contensis/cli/blob/main/packages/contensis-cli/docs/copy_field_templates.md)
2258
2258
 
2259
2259
  ### Copy a hard-coded entry link into a field using a template
2260
2260
 
@@ -34,6 +34,7 @@ __export(globalOptions_exports, {
34
34
  fromProject: () => fromProject,
35
35
  ignoreErrors: () => ignoreErrors,
36
36
  latest: () => latest,
37
+ logLevel: () => logLevel,
37
38
  mapContensisOpts: () => mapContensisOpts,
38
39
  noCache: () => noCache,
39
40
  noPublish: () => noPublish,
@@ -77,8 +78,9 @@ const mapContensisOpts = (opts = {}) => ({
77
78
  includeDefaults: opts.defaults,
78
79
  // arg is inverted automatically from `--no-defaults` to `defaults: false`
79
80
  concurrency: opts.concurrency ? Number(opts.concurrency) : void 0,
80
- noPublish: !opts.publish
81
+ noPublish: !opts.publish,
81
82
  // arg is inverted automatically from `--no-publish` to `publish: false`
83
+ outputLogs: opts.logLevel
82
84
  });
83
85
  const output = new import_commander.Option(
84
86
  "-o --output <output>",
@@ -166,6 +168,10 @@ const ignoreErrors = new import_commander.Option(
166
168
  "-ignore --ignore-errors",
167
169
  "commit the import ignoring any reported errors"
168
170
  ).default(false);
171
+ const logLevel = new import_commander.Option(
172
+ "-ll --log-level <logLevel>",
173
+ "set the logging level to output more detailed logs"
174
+ ).choices(["debug", "info", "warning", "error", "none"]).default("warning");
169
175
  const outputDetail = new import_commander.Option(
170
176
  "-od --output-detail <outputDetail>",
171
177
  "how much detail to output from the import"
@@ -197,6 +203,7 @@ const addImportOptions = (program) => {
197
203
  };
198
204
  const addGlobalOptions = (program) => {
199
205
  for (const command of program.commands) {
206
+ command.addOption(logLevel.hideHelp());
200
207
  addOutputAndFormatOptions(command);
201
208
  addConnectOptions(command);
202
209
  addAuthenticationOptions(command);
@@ -221,6 +228,7 @@ const addGlobalOptions = (program) => {
221
228
  fromProject,
222
229
  ignoreErrors,
223
230
  latest,
231
+ logLevel,
224
232
  mapContensisOpts,
225
233
  noCache,
226
234
  noPublish,
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../src/commands/globalOptions.ts"],
4
- "sourcesContent": ["import { Command, Option } from 'commander';\nimport { MigrateRequest } from 'migratortron';\nimport { url } from '~/util';\n\n// Map various input options into a request to be processed\n// by Migratortron / Contensis import library\nexport const mapContensisOpts = (opts: any = {}): MigrateRequest => ({\n source:\n opts.sourceAlias || opts.sourceProjectId\n ? {\n url: opts.sourceAlias\n ? url(opts.sourceAlias, 'website').cms\n : (undefined as any),\n project: opts.sourceProjectId || (undefined as any),\n }\n : undefined,\n models: opts.modelIds,\n copyField: opts.copyField,\n updateField: opts.updateField,\n // convert various cli options into MigrateRequest.query format\n query:\n opts.id ||\n opts.entryIds ||\n opts.search ||\n opts.fields ||\n opts.orderBy ||\n opts.paths ||\n opts.assetType ||\n opts.contentType ||\n opts.dataFormat ||\n opts.deliveryApi ||\n opts.latest ||\n opts.versionStatus\n ? {\n assetTypes: opts.assetType,\n contentTypeIds: opts.contentType,\n dataFormats: opts.dataFormat ? [opts.dataFormat] : undefined,\n fields: opts.fields,\n includeIds: opts.id || opts.entryIds,\n includePaths: opts.paths,\n orderBy: opts.orderBy,\n searchTerm: opts.search,\n useDelivery: opts.deliveryApi,\n versionStatus: opts.latest ? 'latest' : opts.versionStatus,\n }\n : undefined,\n zenQL: opts.zenql,\n transformGuids: !opts.preserveGuids,\n ignoreErrors: opts.ignoreErrors,\n noCache: !opts.cache, // arg is inverted automatically from `--no-cache` to `cache: false`\n includeDefaults: opts.defaults, // arg is inverted automatically from `--no-defaults` to `defaults: false`\n concurrency: opts.concurrency ? Number(opts.concurrency) : undefined,\n noPublish: !opts.publish, // arg is inverted automatically from `--no-publish` to `publish: false`\n});\n\n/* Output options */\nconst output = new Option(\n '-o --output <output>',\n 'save output to a file e.g. --output ./output.txt'\n);\n\nconst format = new Option(\n '-f --format <format>',\n 'format output as csv, json, html, xml or default'\n).choices(['csv', 'json', 'html', 'xml', 'table']);\n\n/* Connect options */\nconst alias = new Option(\n '-a --alias <alias>',\n 'the cloud CMS alias to connect your request with'\n);\n\nexport const project = new Option(\n '-p --project-id <projectId>',\n 'the projectId to make your request with'\n);\n\n/* Authentication options */\nconst user = new Option(\n '-u --user <user>',\n 'the username to authenticate your request with'\n);\nconst password = new Option(\n '-pw --password <password>',\n 'the password to use to login with (optional/insecure)'\n);\nconst clientId = new Option(\n '-id --client-id <clientId>',\n 'the clientId to authenticate your request with'\n);\nconst sharedSecret = new Option(\n '-s --shared-secret <sharedSecret>',\n 'the shared secret to use when logging in with a client id'\n);\n\n/* Model get options */\nexport const requiredBy = new Option(\n '--required-by',\n 'shows the id(s) that created each dependency'\n);\nexport const exportOption = new Option(\n '--export',\n 'export the raw resources that make up the content model(s) (used with --output)'\n);\n\n/* Entry get options */\nexport const delivery = new Option(\n '-delivery --delivery-api',\n 'use delivery api to get the entries'\n);\nexport const search = new Option(\n '--search <phrase>',\n 'get entries with the search phrase, use quotes for multiple words'\n);\nexport const zenql = new Option(\n '-q --zenql <zenql>',\n 'get entries with a supplied ZenQL statement'\n);\n\nexport const entryId = new Option('-i --id <id...>', 'the entry id(s) to get');\nexport const contentTypes = new Option(\n '-c --content-type <contentType...>',\n 'get entries of these content type(s)'\n);\nexport const assetTypes = new Option(\n '-at --asset-type <assetType...>',\n 'get assets of given content type(s) e.g. image word pdf'\n);\nexport const versionStatus = new Option(\n '-vs --version-status <versionStatus>',\n 'the entry versions to get'\n)\n .choices(['latest', 'published'])\n .default('published');\n\nexport const latest = new Option('--latest', 'get the latest entry versions');\n\n/* Import options */\nexport const fromFile = new Option(\n '-file --from-file <fromFile>',\n 'file path to import asset(s) from'\n);\n\nexport const fromCms = new Option(\n '-source --source-alias <fromCms>',\n 'the cloud CMS alias to import asset(s) from'\n);\nexport const fromProject = new Option(\n '-sp --source-project-id <fromProject>',\n 'the id of the Contensis project to import asset(s) from (Default: [last connected project])'\n);\n\nexport const commit = new Option(\n '--commit',\n 'add this flag only after you have run a preview of the import and agree with the analysis'\n).default(false);\n\nexport const ignoreErrors = new Option(\n '-ignore --ignore-errors',\n 'commit the import ignoring any reported errors'\n).default(false);\n\nexport const outputDetail = new Option(\n '-od --output-detail <outputDetail>',\n 'how much detail to output from the import'\n)\n .choices(['errors', 'changes', 'all'])\n .default('errors');\n\nexport const saveEntries = new Option(\n '-save --save-entries',\n \"save the entries we're migrating instead of the migration preview (used with --output)\"\n);\n\nexport const concurrency = new Option(\n '-conc --concurrency <concurrency>',\n 'the number of entries to load in parallel'\n).default(2);\n\nexport const noCache = new Option(\n '--no-cache',\n 'ignore internal cache and rebuild all resources from scratch'\n);\n\nexport const noPublish = new Option(\n '--no-publish',\n \"don't publish created or updated entries\"\n);\n\nexport const addConnectOptions = (program: Command) =>\n program.addOption(alias.hideHelp()).addOption(project.hideHelp());\n\nexport const addAuthenticationOptions = (program: Command) =>\n program\n .addOption(user.hideHelp())\n .addOption(password.hideHelp())\n .addOption(clientId.hideHelp())\n .addOption(sharedSecret.hideHelp());\n\nconst addOutputAndFormatOptions = (program: Command) =>\n program.addOption(output).addOption(format);\n\nexport const addImportOptions = (program: Command) => {\n for (const command of program.commands) {\n command.addOption(fromCms).addOption(fromProject).addOption(fromFile);\n }\n return program;\n};\n\nexport const addGlobalOptions = (program: Command) => {\n for (const command of program.commands) {\n addOutputAndFormatOptions(command);\n addConnectOptions(command);\n addAuthenticationOptions(command);\n }\n return program;\n};\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["import { Command, Option } from 'commander';\nimport { MigrateRequest } from 'migratortron';\nimport { url } from '~/util';\n\n// Map various input options into a request to be processed\n// by Migratortron / Contensis import library\nexport const mapContensisOpts = (opts: any = {}): MigrateRequest => ({\n source:\n opts.sourceAlias || opts.sourceProjectId\n ? {\n url: opts.sourceAlias\n ? url(opts.sourceAlias, 'website').cms\n : (undefined as any),\n project: opts.sourceProjectId || (undefined as any),\n }\n : undefined,\n models: opts.modelIds,\n copyField: opts.copyField,\n updateField: opts.updateField,\n // convert various cli options into MigrateRequest.query format\n query:\n opts.id ||\n opts.entryIds ||\n opts.search ||\n opts.fields ||\n opts.orderBy ||\n opts.paths ||\n opts.assetType ||\n opts.contentType ||\n opts.dataFormat ||\n opts.deliveryApi ||\n opts.latest ||\n opts.versionStatus\n ? {\n assetTypes: opts.assetType,\n contentTypeIds: opts.contentType,\n dataFormats: opts.dataFormat ? [opts.dataFormat] : undefined,\n fields: opts.fields,\n includeIds: opts.id || opts.entryIds,\n includePaths: opts.paths,\n orderBy: opts.orderBy,\n searchTerm: opts.search,\n useDelivery: opts.deliveryApi,\n versionStatus: opts.latest ? 'latest' : opts.versionStatus,\n }\n : undefined,\n zenQL: opts.zenql,\n transformGuids: !opts.preserveGuids,\n ignoreErrors: opts.ignoreErrors,\n noCache: !opts.cache, // arg is inverted automatically from `--no-cache` to `cache: false`\n includeDefaults: opts.defaults, // arg is inverted automatically from `--no-defaults` to `defaults: false`\n concurrency: opts.concurrency ? Number(opts.concurrency) : undefined,\n noPublish: !opts.publish, // arg is inverted automatically from `--no-publish` to `publish: false`\n outputLogs: opts.logLevel,\n});\n\n/* Output options */\nconst output = new Option(\n '-o --output <output>',\n 'save output to a file e.g. --output ./output.txt'\n);\n\nconst format = new Option(\n '-f --format <format>',\n 'format output as csv, json, html, xml or default'\n).choices(['csv', 'json', 'html', 'xml', 'table']);\n\n/* Connect options */\nconst alias = new Option(\n '-a --alias <alias>',\n 'the cloud CMS alias to connect your request with'\n);\n\nexport const project = new Option(\n '-p --project-id <projectId>',\n 'the projectId to make your request with'\n);\n\n/* Authentication options */\nconst user = new Option(\n '-u --user <user>',\n 'the username to authenticate your request with'\n);\nconst password = new Option(\n '-pw --password <password>',\n 'the password to use to login with (optional/insecure)'\n);\nconst clientId = new Option(\n '-id --client-id <clientId>',\n 'the clientId to authenticate your request with'\n);\nconst sharedSecret = new Option(\n '-s --shared-secret <sharedSecret>',\n 'the shared secret to use when logging in with a client id'\n);\n\n/* Model get options */\nexport const requiredBy = new Option(\n '--required-by',\n 'shows the id(s) that created each dependency'\n);\nexport const exportOption = new Option(\n '--export',\n 'export the raw resources that make up the content model(s) (used with --output)'\n);\n\n/* Entry get options */\nexport const delivery = new Option(\n '-delivery --delivery-api',\n 'use delivery api to get the entries'\n);\nexport const search = new Option(\n '--search <phrase>',\n 'get entries with the search phrase, use quotes for multiple words'\n);\nexport const zenql = new Option(\n '-q --zenql <zenql>',\n 'get entries with a supplied ZenQL statement'\n);\n\nexport const entryId = new Option('-i --id <id...>', 'the entry id(s) to get');\nexport const contentTypes = new Option(\n '-c --content-type <contentType...>',\n 'get entries of these content type(s)'\n);\nexport const assetTypes = new Option(\n '-at --asset-type <assetType...>',\n 'get assets of given content type(s) e.g. image word pdf'\n);\nexport const versionStatus = new Option(\n '-vs --version-status <versionStatus>',\n 'the entry versions to get'\n)\n .choices(['latest', 'published'])\n .default('published');\n\nexport const latest = new Option('--latest', 'get the latest entry versions');\n\n/* Import options */\nexport const fromFile = new Option(\n '-file --from-file <fromFile>',\n 'file path to import asset(s) from'\n);\n\nexport const fromCms = new Option(\n '-source --source-alias <fromCms>',\n 'the cloud CMS alias to import asset(s) from'\n);\nexport const fromProject = new Option(\n '-sp --source-project-id <fromProject>',\n 'the id of the Contensis project to import asset(s) from (Default: [last connected project])'\n);\n\nexport const commit = new Option(\n '--commit',\n 'add this flag only after you have run a preview of the import and agree with the analysis'\n).default(false);\n\nexport const ignoreErrors = new Option(\n '-ignore --ignore-errors',\n 'commit the import ignoring any reported errors'\n).default(false);\n\nexport const logLevel = new Option(\n '-ll --log-level <logLevel>',\n 'set the logging level to output more detailed logs'\n)\n .choices(['debug', 'info', 'warning', 'error', 'none'])\n .default('warning');\n\nexport const outputDetail = new Option(\n '-od --output-detail <outputDetail>',\n 'how much detail to output from the import'\n)\n .choices(['errors', 'changes', 'all'])\n .default('errors');\n\nexport const saveEntries = new Option(\n '-save --save-entries',\n \"save the entries we're migrating instead of the migration preview (used with --output)\"\n);\n\nexport const concurrency = new Option(\n '-conc --concurrency <concurrency>',\n 'the number of entries to load in parallel'\n).default(2);\n\nexport const noCache = new Option(\n '--no-cache',\n 'ignore internal cache and rebuild all resources from scratch'\n);\n\nexport const noPublish = new Option(\n '--no-publish',\n \"don't publish created or updated entries\"\n);\n\nexport const addConnectOptions = (program: Command) =>\n program.addOption(alias.hideHelp()).addOption(project.hideHelp());\n\nexport const addAuthenticationOptions = (program: Command) =>\n program\n .addOption(user.hideHelp())\n .addOption(password.hideHelp())\n .addOption(clientId.hideHelp())\n .addOption(sharedSecret.hideHelp());\n\nconst addOutputAndFormatOptions = (program: Command) =>\n program.addOption(output).addOption(format);\n\nexport const addImportOptions = (program: Command) => {\n for (const command of program.commands) {\n command.addOption(fromCms).addOption(fromProject).addOption(fromFile);\n }\n return program;\n};\n\nexport const addGlobalOptions = (program: Command) => {\n for (const command of program.commands) {\n command.addOption(logLevel.hideHelp());\n addOutputAndFormatOptions(command);\n addConnectOptions(command);\n addAuthenticationOptions(command);\n }\n return program;\n};\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }
@@ -215,7 +215,8 @@ ${import_logger.Logger.errorText(">>")} Available commands:`,
215
215
  },
216
216
  removed: (env, commit) => `[${env}] ${commit ? `Deleted` : `Will delete`} entries`,
217
217
  failedRemove: (env) => `[${env}] Unable to delete entries`,
218
- notFound: (env) => `[${env}] Entries were not found`
218
+ notFound: (env) => `[${env}] Entries were not found`,
219
+ noChange: (env) => `[${env}] No changes to be made`
219
220
  },
220
221
  keys: {
221
222
  list: (env) => `[${env}] API keys:`,
@@ -331,7 +332,8 @@ ${import_logger.Logger.errorText(">>")} Available commands:`,
331
332
  failedCreate: (env, name) => `[${env}] Unable to create ${name ? `tag ${import_logger.Logger.highlightText(name)}` : "tags"}`,
332
333
  removed: (env, length, commit) => `[${env}] ${!length ? "No tags to delete" : `${commit ? `Deleted` : `Will delete`} ${(0, import_pluralize.default)("tag", length, true)}
333
334
  `}`,
334
- failedRemove: (env, length) => `[${env}] Unable to delete tags with ${(0, import_pluralize.default)("error", length)}`
335
+ failedRemove: (env, length) => `[${env}] Unable to delete tags with ${(0, import_pluralize.default)("error", length)}`,
336
+ noChange: (env) => `[${env}] No changes to be made`
335
337
  },
336
338
  blocks: {
337
339
  runningStatus: (status) => {
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../src/localisation/en-GB.ts"],
4
- "sourcesContent": ["import {\n BlockActionType,\n BlockRunningStatus,\n MigrateModelsResult,\n MigrateStatus,\n} from 'migratortron';\nimport pl from 'pluralize';\nimport { GitHelper } from '~/util/git';\nimport { Logger } from '~/util/logger';\nimport { winSlash } from '~/util/os';\n\nexport const LogMessages = {\n app: {\n contensis: () => 'Contensis',\n quit: () => `Goodbye \uD83D\uDC4B\\n`,\n startup: (version: string) =>\n `v${version} \u00A9 2001-${new Date().getFullYear()} Zengenti \uD83C\uDDEC\uD83C\uDDE7. \\n - Creators of Contensis and purveyors of other fine software\\n\\n\uD83D\uDC4B Welcome to the contensis-cli\\n`,\n help: () =>\n 'Press [CTRL]+[C] or type \"quit\" to return to your system shell\\nPress [TAB] for suggestions\\n',\n suggestions: () =>\n `\\n${Logger.errorText('>>')} Press [TAB] for suggestions\\n`,\n autocomplete: () => `\\n${Logger.errorText('>>')} Available commands:`,\n unknownError: () => `Something went wrong...`,\n fileOutput: (format = 'json', path?: string) =>\n `Output ${format} file: ${Logger.infoText(path)}\\n`,\n noFileOutput: () => `No output written\\n`,\n },\n command: {\n notKnown: (command: string) => `${command} is not known`,\n },\n envs: {\n found: (num: number) =>\n `Environments store found containing ${pl('environment', num, true)}`,\n notFound: (alias: string) =>\n `Environment ${Logger.highlightText(alias)} was not found in session cache`,\n removed: (alias: string) =>\n `Removed environment ${Logger.highlightText(alias)} from session cache`,\n tip: () =>\n `Connect to a Contensis cloud instance using \"contensis connect {cms alias}\"`,\n },\n connect: {\n command: {\n name: () => 'connect',\n example: () => `Example call:\\n > connect example-dev`,\n },\n args: {\n alias: {\n name: () => '<alias>',\n description: () => 'the Contensis Cloud alias to connect with',\n },\n },\n noEnv: () => `Cannot connect - no environment alias specified`,\n unreachable: (url: string, status: number) =>\n `Cannot reach ${url}${status ? ` - status ${status}` : ''}`,\n connected: (env: string) => `Current environment set to \"${env}\"`,\n help: () =>\n `Connect to a Contensis cloud instance using \"contensis connect {cms alias}\"`,\n projects: () => `Available projects:`,\n noProjects: () => `Cannot retrieve projects list`,\n tip: () =>\n `Introduce yourself with \"login {username}\" or \"login {clientId} -s {secret}\" or by passing credentials as options with your command`,\n },\n login: {\n command: {\n name: () => 'login',\n usage: () => `<user/clientId> [password] [-s <sharedSecret>]`,\n example: () =>\n `Example call:\\n > login myuserid\\n -- or --\\n > login {clientId} -s {sharedSecret}`,\n },\n args: {\n user: {\n name: () => '<user/clientId>',\n description: () => 'the username to login with',\n },\n password: {\n name: () => '[password]',\n description: () =>\n 'the password to use to login with (optional/insecure)',\n },\n secret: {\n name: () => '-s --sharedSecret <sharedSecret>',\n description: () =>\n 'the shared secret to use when logging in with a client id',\n },\n },\n passwordPrompt: (env?: string, userId?: string) =>\n userId\n ? `Enter password for ${userId}@${env}:`\n : `Please enter a password`,\n failed: (env: string, userId: string) =>\n `Unable to login to ${env} as ${userId}`,\n success: (env: string, userId: string) =>\n `User ${userId} connected to ${env} successfully\\n`,\n insecurePassword: () =>\n `Could not connect to local keystore - your password could be stored unencrypted!`,\n noEnv: () => `No environment set, use \"contensis connect {alias}\" first`,\n noUserId: () => `No user id specified`,\n },\n projects: {\n list: () => `Available projects:`,\n noList: () => `Cannot retrieve projects list`,\n set: (projectId: string) =>\n `Current project is set to ${Logger.highlightText(projectId)}`,\n failedSet: (projectId: string) =>\n `Project ${Logger.highlightText(projectId)} not found`,\n tip: () =>\n `You need to set your current working project with \"set project {projectId}\"`,\n created: (env: string, id: string) =>\n `[${env}] Created project ${Logger.highlightText(id)}`,\n failedCreate: (env: string, id: string) =>\n `[${env}] Unable to create project ${Logger.highlightText(id)}`,\n updated: (env: string, id: string) =>\n `[${env}] Updated project ${Logger.highlightText(id)}`,\n failedUpdate: (env: string, id: string) =>\n `[${env}] Unable to update project ${Logger.highlightText(id)}`,\n },\n migrate: {\n commitTip: () => `Add --commit flag to commit the previewed changes`,\n preview: (verb = 'IMPORT') => `\uD83D\uDD0D ${verb} PREVIEW \uD83D\uDD2D`,\n commit: (verb = 'IMPORT') => `COMMITTING ${verb} \u2728\u2604\uFE0F `,\n imported: (\n env: string,\n commit: boolean,\n entities: { [noun: string]: number }\n ) =>\n `${commit ? `Imported` : `Will import`} ${Object.entries(entities)\n .map(([noun, count]) => pl(noun, count, true))\n .join(' and ')} into ${env} environment`,\n\n models: {\n result: (\n status: keyof MigrateModelsResult['project']['contentTypes']\n ) => {\n switch (status) {\n case 'created':\n case 'updated':\n return Logger.successText;\n case 'errors':\n return Logger.errorText;\n default:\n return Logger.infoText;\n }\n },\n },\n status: (status: MigrateStatus) => {\n switch (status) {\n case 'no change':\n return Logger.successText;\n case 'create':\n case 'two-pass':\n case 'update':\n case 'delete':\n return Logger.warningText;\n case 'error':\n case 'not found':\n return Logger.errorText;\n default:\n return Logger.infoText;\n }\n },\n },\n models: {\n list: (projectId: string) =>\n `Content models in ${Logger.highlightText(projectId)}:`,\n noList: (projectId: string) =>\n `[${projectId}] Cannot retrieve content models`,\n get: (projectId: string, id: string) =>\n `[${projectId}] Content models ${Logger.infoText(`[ ${id} ]`)}`,\n failedGet: (projectId: string, id: string) =>\n `[${projectId}] Unable to get content models ${Logger.highlightText(id)}`,\n },\n nodes: {\n imported: (env: string, commit: boolean, count: number) =>\n LogMessages.migrate.imported(env, commit, { node: count }),\n failedImport: (env: string) => `[${env}] Unable to import nodes`,\n removed: (env: string, commit: boolean, root: string) =>\n `[${env}] ${commit ? `Deleted` : `Will delete`} nodes at ${root}`,\n failedRemove: (env: string) => `[${env}] Unable to delete nodes`,\n notFound: (env: string) => `[${env}] Nodes were not found `,\n commitTip: () => `Add --commit flag to commit the previewed changes`,\n failedGet: (projectId: string) =>\n `[${projectId}] Cannot retrieve nodes from Site view`,\n get: (projectId: string, root: string, depth: number) =>\n `[${projectId}] Site view nodes at: ${Logger.highlightText(root)}${\n depth ? ` to a depth of ${depth}` : ``\n }\\n`,\n noChange: (env: string) => `[${env}] No changes to be made`,\n },\n contenttypes: {\n list: (projectId: string) =>\n `Content types in ${Logger.highlightText(projectId)}:`,\n get: (projectId: string, id: string) =>\n `[${projectId}] Content type ${Logger.highlightText(id)}`,\n failedGet: (projectId: string, id: string) =>\n `[${projectId}] Unable to get content type ${Logger.highlightText(id)}`,\n created: (projectId: string, id: string, status?: string) =>\n `[${projectId}] Content type ${status}d ${Logger.highlightText(id)}`,\n removed: (env: string, id: string, commit: boolean) =>\n `[${env}] ${\n commit ? `Deleted` : `Will delete`\n } content type(s) ${Logger.highlightText(id)}`,\n failedRemove: (env: string, id: string) =>\n `[${env}] Unable to delete content type(s) ${Logger.highlightText(id)}`,\n },\n components: {\n list: (projectId: string) =>\n `Components in ${Logger.highlightText(projectId)}:`,\n get: (projectId: string, id: string) =>\n `[${projectId}] Component ${Logger.highlightText(id)}`,\n failedGet: (projectId: string, id: string) =>\n `[${projectId}] Unable to get component ${Logger.highlightText(id)}`,\n created: (projectId: string, id: string, status?: string) =>\n `[${projectId}] Component ${status}d ${Logger.highlightText(id)}`,\n removed: (env: string, id: string, commit: boolean) =>\n `[${env}] ${\n commit ? `Deleted` : `Will delete`\n } component(s) ${Logger.highlightText(id)}`,\n failedRemove: (env: string, id: string) =>\n `[${env}] Unable to delete component(s) ${Logger.highlightText(id)}`,\n },\n version: {\n set: (env: string, versionStatus: string) =>\n `[${env}] Content version status set to \"${versionStatus}\"`,\n invalid: (versionStatus: string) =>\n `Content version status \"${versionStatus}\" is not valid, allowed values are \"published\" or \"latest\".`,\n noEnv: () =>\n `No Contensis environment set, connect to your Contensis cloud instance using \"contensis connect {cms alias}\"`,\n },\n entries: {\n imported: (env: string, commit: boolean, entries: number, nodes = 0) =>\n LogMessages.migrate.imported(env, commit, {\n entry: entries,\n node: nodes,\n }),\n failedImport: (env: string) => `[${env}] Unable to import entries`,\n update: {\n preview: () => LogMessages.migrate.preview('UPDATE FIELD'),\n commit: () => LogMessages.migrate.preview('FIELD UPDATES'),\n success: (env: string, commit: boolean, entries: number, nodes = 0) =>\n `${commit ? `Updated` : `Will update`} ${pl('entry', entries, true)}${\n nodes > 0 ? ` and ${pl('node', nodes, true)}` : ''\n } in ${env} environment`,\n failed: (env: string) => `[${env}] Unable to update any entries`,\n },\n removed: (env: string, commit: boolean) =>\n `[${env}] ${commit ? `Deleted` : `Will delete`} entries`,\n failedRemove: (env: string) => `[${env}] Unable to delete entries`,\n notFound: (env: string) => `[${env}] Entries were not found`,\n },\n keys: {\n list: (env: string) => `[${env}] API keys:`,\n noList: (env: string) => `[${env}] Cannot retrieve API keys`,\n created: (env: string, name: string) =>\n `[${env}] Created API key ${Logger.highlightText(name)}`,\n tip: () =>\n `Assign your new key to a role with \"set role assignments\", or create a new role with \"create role\"`,\n failedCreate: (env: string, name: string) =>\n `[${env}] Unable to create API key ${Logger.highlightText(name)}`,\n failedUpdate: (env: string, name: string) =>\n `[${env}] Unable to update API key ${Logger.highlightText(name)}`,\n removed: (env: string, id: string) =>\n `[${env}] Deleted API key ${Logger.highlightText(id)}`,\n failedRemove: (env: string, id: string) =>\n `[${env}] Unable to delete API key ${Logger.highlightText(id)}`,\n },\n proxies: {\n list: (env: string, projectId: string | undefined) =>\n `[${env}] Retrieved proxies in project ${projectId}:`,\n noList: (env: string, projectId: string | undefined) =>\n `[${env}] Cannot retrieve proxies in project ${projectId}`,\n // noneExist: () => `Create a role with \"create renderer\"`,\n failedGet: (env: string, name: string, projectId: string) =>\n `[${env}] Unable to find proxy ${Logger.highlightText(\n name\n )} in project ${projectId}`,\n created: (env: string, name: string, projectId: string) =>\n `[${env}] Created proxy ${Logger.highlightText(\n name\n )} in project ${projectId}\\n`,\n failedCreate: (env: string, name: string, projectId: string) =>\n `[${env}] Unable to create proxy ${Logger.highlightText(\n name\n )} in project ${projectId}`,\n setPayload: () => `Updating proxy with details\\n`,\n set: () => `Succesfully updated proxy\\n`,\n failedSet: (env: string, name: string, projectId: string) =>\n `[${env}] Unable to update proxy ${Logger.highlightText(\n name\n )} in project ${projectId}`,\n removed: (env: string, id: string, projectId: string) =>\n `[${env}] Deleted proxy ${Logger.highlightText(\n id\n )} in project ${projectId}\\n`,\n failedRemove: (env: string, id: string, projectId: string) =>\n `[${env}] Unable to delete proxy ${Logger.highlightText(\n id\n )} in project ${projectId}`,\n },\n renderers: {\n list: (env: string, projectId: string | undefined) =>\n `[${env}] Retrieved renderers in project ${projectId}:`,\n noList: (env: string, projectId: string | undefined) =>\n `[${env}] Cannot retrieve renderers in project ${projectId}`,\n // noneExist: () => `Create a role with \"create renderer\"`,\n failedGet: (env: string, name: string, projectId: string) =>\n `[${env}] Unable to find renderer ${Logger.highlightText(\n name\n )} in project ${projectId}`,\n created: (env: string, name: string, projectId: string) =>\n `[${env}] Created renderer ${Logger.highlightText(\n name\n )} in project ${projectId}\\n`,\n failedCreate: (env: string, name: string, projectId: string) =>\n `[${env}] Unable to create renderer ${Logger.highlightText(\n name\n )} in project ${projectId}`,\n setPayload: () => `Updating renderer with details\\n`,\n set: () => `Succesfully updated renderer\\n`,\n failedSet: (env: string, name: string, projectId: string) =>\n `[${env}] Unable to update renderer ${Logger.highlightText(\n name\n )} in project ${projectId}`,\n removed: (env: string, id: string, projectId: string) =>\n `[${env}] Deleted renderer ${Logger.highlightText(\n id\n )} in project ${projectId}\\n`,\n failedRemove: (env: string, id: string, projectId: string) =>\n `[${env}] Unable to delete renderer ${Logger.highlightText(\n id\n )} in project ${projectId}`,\n },\n roles: {\n list: (env: string) => `[${env}] Retrieved roles`,\n noList: (env: string) => `[${env}] Cannot retrieve roles`,\n noneExist: () => `Create a role with \"create role\"`,\n failedGet: (env: string, name: string) =>\n `[${env}] Unable to find role ${Logger.highlightText(name)}`,\n created: (env: string, name: string) =>\n `[${env}] Created role ${Logger.highlightText(name)}\\n`,\n tip: () =>\n `Give access to your role with \"set role assignments\", allow your role to do things with \"set role permissions\"`,\n failedCreate: (env: string, name?: string) =>\n `[${env}] Unable to create role ${Logger.highlightText(name)}`,\n setPayload: () => `Updating role with details\\n`,\n set: () => `Succesfully updated role\\n`,\n failedSet: (env: string, name?: string) =>\n `[${env}] Unable to update role ${Logger.highlightText(name)}`,\n removed: (env: string, id: string) =>\n `[${env}] Deleted role ${Logger.highlightText(id)}\\n`,\n failedRemove: (env: string, id: string) =>\n `[${env}] Unable to delete role ${Logger.highlightText(id)}`,\n },\n taggroups: {\n list: (env: string, length: number) =>\n `[${env}] Retrieved ${pl('tag group', length, true)}`,\n noList: (env: string) => `[${env}] Cannot retrieve tag groups`,\n noneExist: () => `Create a tag group with \"create taggroup <name>\"`,\n imported: (env: string, commit: boolean, groups: number, tags: number) =>\n LogMessages.migrate.imported(env, commit, {\n 'tag group': groups,\n tag: tags,\n }),\n failedGet: (env: string, name: string) =>\n `[${env}] Unable to find a tag group ${Logger.highlightText(name)}`,\n created: (env: string, name: string) =>\n `[${env}] Created tag group ${Logger.highlightText(name)}\\n`,\n tip: () =>\n `Give access to your role with \"set role assignments\", allow your role to do things with \"set role permissions\"`,\n failedCreate: (env: string, name?: string) =>\n `[${env}] Unable to create ${name ? `tag group ${Logger.highlightText(name)}` : 'tag groups'}`,\n removed: (env: string, id: string, commit: boolean) =>\n `[${env}] ${\n commit ? `Deleted` : `Will delete`\n } tag group ${Logger.highlightText(id)}\\n`,\n failedRemove: (env: string, id: string) =>\n `[${env}] Unable to delete tag group ${Logger.highlightText(id)}`,\n },\n tags: {\n list: (env: string, length: number) =>\n `[${env}] Retrieved ${pl('tag', length, true)}`,\n noList: (env: string) => `[${env}] Cannot retrieve tags`,\n noneExist: () =>\n `Create a tag with \"create tag in <groupId> <tag label(s)...>\"`,\n imported: (env: string, commit: boolean, tags: number) =>\n LogMessages.migrate.imported(env, commit, { tag: tags }),\n failedGet: (env: string) => `[${env}] Unable to find tags`,\n created: (env: string, name: string) =>\n `[${env}] Created tag ${Logger.highlightText(name)}\\n`,\n failedCreate: (env: string, name?: string) =>\n `[${env}] Unable to create ${name ? `tag ${Logger.highlightText(name)}` : 'tags'}`,\n removed: (env: string, length: number, commit: boolean) =>\n `[${env}] ${\n !length\n ? 'No tags to delete'\n : `${commit ? `Deleted` : `Will delete`} ${pl('tag', length, true)}\\n`\n }`,\n failedRemove: (env: string, length: number) =>\n `[${env}] Unable to delete tags with ${pl('error', length)}`,\n },\n blocks: {\n runningStatus: (status: BlockRunningStatus | 'broken') => {\n switch (status) {\n case 'available':\n return Logger.successText(status);\n case 'pending':\n case 'starting':\n case 'stopped':\n return Logger.warningText(status);\n case 'degraded':\n case 'faulted':\n case 'broken':\n return Logger.errorText(status);\n default:\n return Logger.infoText(status);\n }\n },\n get: (\n id: string,\n branch: string,\n version: string,\n env: string,\n projectId?: string\n ) =>\n `[${env}] ${\n version && version !== 'latest'\n ? `Found v${version}`\n : 'Latest block versions'\n } for ${Logger.infoText(`${branch}/`)}${Logger.highlightText(\n id\n )} in project ${projectId}\\n`,\n noGet: (\n id: string,\n branch: string,\n version: string,\n env: string,\n projectId?: string\n ) =>\n `[${env}] Did not find ${\n version ? `v${version}` : 'any block versions'\n } for ${Logger.highlightText(id)} in branch ${Logger.infoText(\n branch\n )} in ${Logger.infoText(projectId)} project`,\n noGetTip: () =>\n `Check the available blocks and branches in this project by running \"list blocks\"`,\n list: (env: string, projectId?: string) =>\n `[${env}] Blocks in project ${projectId}\\n`,\n noList: (env: string, projectId?: string) =>\n `[${env}] Cannot retrieve blocks in project ${projectId}`,\n getLogs: (id: string, branch: string, env: string, projectId?: string) =>\n `[${env}] Requesting logs from block ${Logger.highlightText(\n id\n )} in branch ${branch} in project ${projectId}`,\n failedGetLogs: (id: string, env: string, projectId?: string) =>\n `[${env}] Unable to fetch block logs for ${Logger.highlightText(\n id\n )} in project ${projectId}`,\n tryPush: (id: string, branch: string, env: string, projectId?: string) =>\n `[${env}] Request to push block ${Logger.highlightText(\n id\n )} in branch ${branch} in project ${projectId}`,\n pushed: (id: string, branch: string, env: string, projectId?: string) =>\n `[${env}] Pushed block ${Logger.highlightText(\n id\n )} in branch ${branch} in project ${projectId}`,\n failedPush: (id: string, env: string, projectId?: string) =>\n `[${env}] Unable to push block ${Logger.highlightText(\n id\n )} in project ${projectId}`,\n failedParsingVersion: () =>\n `Did not find a \"version.versionNo\" in response`,\n actionComplete: (\n action: BlockActionType,\n id: string,\n env: string,\n projectId?: string\n ) =>\n `[${env}] Action ${Logger.highlightText(\n action\n )} on ${Logger.highlightText(\n id\n )} in project ${projectId} requested successfully`,\n actionFailed: (\n action: BlockActionType,\n id: string,\n env: string,\n projectId?: string\n ) =>\n `[${env}] Problem executing ${action} on block ${Logger.highlightText(\n id\n )} in project ${projectId}`,\n deleted: (id: string, env: string, projectId?: string) =>\n `[${env}] Deleted block ${Logger.highlightText(\n id\n )} in project ${projectId}`,\n failedDelete: (id: string, env: string, projectId?: string) =>\n `[${env}] Unable to delete block ${Logger.highlightText(\n id\n )} in project ${projectId}`,\n stopFollow: (id: string, env: string, projectId?: string) =>\n `[${env}]\\n\\n \uD83D\uDC4C stop fetching new ${Logger.highlightText(\n id\n )} logs in project ${projectId}`,\n timeoutFollow: (id: string, env: string, projectId?: string) =>\n `[${env}]\\n\\n \uD83E\uDD0F pausing fetching new ${Logger.highlightText(\n id\n )} logs in project ${projectId} due to too many requests`,\n },\n webhooks: {\n list: (env: string) => `[${env}] Webhook subscriptions:`,\n noList: (env: string) => `[${env}] Cannot retrieve webhook subscriptions`,\n noneExist: () => `No webhook subscriptions exist`,\n created: (env: string, name: string) =>\n `[${env}] Created Webhook subscription ${Logger.highlightText(name)}`,\n failedCreate: (env: string, name: string) =>\n `[${env}] Unable to create Webhook subscription ${Logger.highlightText(\n name\n )}`,\n deleted: (env: string, id: string) =>\n `[${env}] Deleted Webhook subscription ${Logger.highlightText(id)}`,\n failedDelete: (env: string, id: string) =>\n `[${env}] Unable to delete Webhook subscription ${Logger.highlightText(\n id\n )}`,\n },\n workflows: {\n list: (env: string) => `[${env}] Retrieved workflows`,\n noList: (env: string) => `[${env}] Cannot retrieve workflows`,\n noneExist: () => `No workflows found`,\n failedGet: (env: string, name: string) =>\n `[${env}] Unable to find workflow ${Logger.highlightText(name)}`,\n },\n devinit: {\n intro: () => `Contensis developer environment initialisation`,\n //`This will initialise your local working directory to develop with the current connected Contensis project`,\n projectDetails: (\n name: string,\n env: string,\n projectId: string,\n blockId: string,\n git: GitHelper\n ) =>\n `\n Project: ${Logger.standardText(name)}\n - Home: ${Logger.standardText(git.gitcwd())}\n - Repository: ${Logger.standardText(git.home)} \n - Block id: ${Logger.highlightText(blockId)}\n \n Connect to Contensis instance: ${Logger.standardText(env)}\n - Project id: ${Logger.standardText(projectId)}\n `,\n developmentKey: (name: string, existing: boolean) =>\n ` - ${\n !existing ? 'Create development API key' : 'Development API key found'\n }: ${Logger[!existing ? 'highlightText' : 'standardText'](name)}`,\n deploymentKey: (name: string, existing: boolean) =>\n ` - ${\n !existing ? 'Create deployment API key' : 'Deployment API key found'\n }: ${Logger[!existing ? 'highlightText' : 'standardText'](name)}`,\n ciIntro: (git: GitHelper, location: 'git' | 'env') =>\n `We will create API keys with permissions to use this project with Contensis, and add a job to your CI that will deploy a container build.\n ${\n location === 'git'\n ? `We will ask you to add secrets/variables to your git repository to give your workflow permission to push a Block to Contensis.\n ${Logger.infoText(`You could visit ${git.secretsUri} to check that you can see repository settings, \n a page not found generally indicates you need to ask the repo owner for permission to add repository secrets, \n or ask the repo owner to add these secrets for you.`)}`\n : ''\n }`,\n ciDetails: (filename: string) =>\n `Add push-block job to CI file: ${Logger.highlightText(filename)}\\n`,\n ciMultipleChoices: () =>\n `Multiple GitHub workflow files found\\n${Logger.infoText(\n `Tell us which GitHub workflow builds a container image after each push:`\n )}`,\n ciMultipleBuildJobChoices: () =>\n `Multiple build jobs found in workflow\\n${Logger.infoText(\n `Choose the build job that produces a fresh container image to push to a block:`\n )}`,\n ciMultipleJobChoices: () =>\n `Other jobs found in workflow\\n${Logger.infoText(\n `Choose the job that produces a fresh container image we can push to a block:`\n )}`,\n ciMultipleAppImageVarChoices: () =>\n `Do one of these variables point to your tagged app image?\\n${Logger.infoText(\n `we have included a default choice - ensure your build image is tagged exactly the same as this`\n )}`,\n ciEnterOwnAppImagePrompt: (git: GitHelper) =>\n `Tell us the registry uri your app image is tagged and pushed with (\u23CE accept default) \\n${Logger.infoText(\n `Tip: ${\n git.type === 'github'\n ? `GitHub context variables available\\nhttps://docs.github.com/en/actions/learn-github-actions/variables#using-contexts-to-access-variable-values`\n : `GitLab CI/CD variables available\\nhttps://docs.gitlab.com/ee/ci/variables/`\n }`\n )}\\n`,\n confirm: () =>\n `Confirm these details are correct so we can make changes to your project`,\n createDevKey: (keyName: string, existing: boolean) =>\n `${\n !existing ? 'Created' : 'Checked permissions for'\n } development API key ${Logger.standardText(keyName)}`,\n createDeployKey: (keyName: string, existing: boolean) =>\n `${\n !existing ? 'Created' : 'Checked permissions for'\n } deployment API key ${Logger.standardText(keyName)}`,\n createKeyFail: (keyName: string, existing: boolean) =>\n `Failed to ${\n !existing ? 'create' : 'update'\n } API key ${Logger.highlightText(keyName)}`,\n writeEnvFile: () => `Written .env file to project home directory`,\n useEnvFileTip: () =>\n `You should alter existing project code that connects a Contensis client to use the variables from this file`,\n writeCiFile: (ciFilePath: string) =>\n `Updated CI file ${Logger.standardText(winSlash(ciFilePath))}`,\n ciFileNoChanges: (ciFilePath: string) =>\n `No updates needed for CI file ${Logger.standardText(\n winSlash(ciFilePath)\n )}`,\n ciBlockTip: (blockId: string, env: string, projectId: string) =>\n `A job is included to deploy your built container image to ${Logger.standardText(\n projectId\n )} at ${Logger.standardText(env)} in a block called ${Logger.standardText(\n blockId\n )}`,\n addGitSecretsIntro: () =>\n `We have created an API key that allows you to deploy your app image to a Contensis Block but we need you to add these details to your GitLab repository.`,\n addGitSecretsHelp: (git: GitHelper, id?: string, secret?: string) =>\n `Add secrets or variables in your repository's settings page\\n\\nGo to ${Logger.highlightText(\n git.secretsUri\n )}\\n\\n${\n git.type === 'github'\n ? `Add a \"New repository secret\"`\n : `Expand \"Variables\" and hit \"Add variable\"`\n }\\n\\n ${\n git.type === 'github' ? `Secret name:` : `Key:`\n } ${Logger.highlightText(`CONTENSIS_CLIENT_ID`)}\\n ${\n git.type === 'github' ? `Secret:` : `Value:`\n } ${Logger.standardText(\n id\n )}\\n\\n ${`Add one more secret/variable to the repository`}\\n\\n ${\n git.type === 'github' ? `Secret name:` : `Key:`\n } ${Logger.highlightText(`CONTENSIS_SHARED_SECRET`)}\\n ${\n git.type === 'github' ? `Secret:` : `Value:`\n } ${Logger.standardText(secret)}`,\n accessTokenFetch: () =>\n `Please wait, fetching Delivery API access token \u23F3`,\n accessTokenSuccess: (token: string) =>\n `Successfully fetched Delivery API token\\n ${Logger.infoText(token)}`,\n accessTokenFailed: () =>\n `Something went wrong! If the problem persists, please contact our support team \uD83D\uDEDF`,\n accessTokenPermission: () =>\n `We need permission to fetch your Delivery API token, please try again \u26A0\uFE0F`,\n clientDetailsLocation: () =>\n `Which option would you like to use for storing your client ID and secret`,\n clientDetailsInGit: (git: GitHelper) =>\n `${\n git.type === 'github' ? 'GitHub' : 'GitLab'\n } variables (recommended for public repositories)`,\n clientDetailsInEnv: () =>\n `Env variables (recommended for private repositories)`,\n success: () => `Contensis developer environment initialisation complete`,\n partialSuccess: () =>\n `Contensis developer environment initialisation completed with errors`,\n failed: () => `Contensis developer environment initialisation failed`,\n dryRun: () =>\n `Contensis developer environment initialisation dry run completed`,\n dryRunKeyMessage: (dryRun: boolean) =>\n dryRun ? '<< not created: dry-run >>' : undefined,\n noChanges: () =>\n `No changes were made to your project, run the command again without the ${Logger.highlightText(\n '--dry-run'\n )} flag to update your project with these changes`,\n startProjectTip: () =>\n `Start up your project in the normal way for development`,\n blockIdQuestion: () =>\n `Please enter your block id, this should be unquie and in kebab case e.g ${Logger.highlightText(\n 'my-awesome-website'\n )}`,\n },\n devrequests: {\n install: {\n notFound: (repo: string) =>\n `Could not find a release in ${repo} repo - please check github`,\n download: (repo: string, version: string) => `Found release ${version}`,\n downloading: (repo: string, version: string) =>\n `Downloading ${repo} ${version}`,\n downloadFail: (repo: string, version: string) =>\n `Problem downloading release ${version} from ${repo}`,\n downloaded: (repo: string, version: string) =>\n `Downloaded ${repo} ${version}`,\n applyUpdate: (version: string, existing: string) =>\n `Use updated version ${version} ${Logger.infoText(\n `(replaces ${existing})`\n )}?`,\n },\n launch: () => `Launching request handler for local development`,\n overrideBlock: () => `Which block will you be running?`,\n overrideUri: () => `How to access your development site`,\n spawn: () =>\n `If you see a firewall popup requesting network access, it is safe to approve`,\n exited: (code: number | null) =>\n `Request handler exited with code ${code}\\n`,\n errored: (error: Error) =>\n `Could not launch request handler due to error \\n${error}`,\n },\n};\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["import {\n BlockActionType,\n BlockRunningStatus,\n MigrateModelsResult,\n MigrateStatus,\n} from 'migratortron';\nimport pl from 'pluralize';\nimport { GitHelper } from '~/util/git';\nimport { Logger } from '~/util/logger';\nimport { winSlash } from '~/util/os';\n\nexport const LogMessages = {\n app: {\n contensis: () => 'Contensis',\n quit: () => `Goodbye \uD83D\uDC4B\\n`,\n startup: (version: string) =>\n `v${version} \u00A9 2001-${new Date().getFullYear()} Zengenti \uD83C\uDDEC\uD83C\uDDE7. \\n - Creators of Contensis and purveyors of other fine software\\n\\n\uD83D\uDC4B Welcome to the contensis-cli\\n`,\n help: () =>\n 'Press [CTRL]+[C] or type \"quit\" to return to your system shell\\nPress [TAB] for suggestions\\n',\n suggestions: () =>\n `\\n${Logger.errorText('>>')} Press [TAB] for suggestions\\n`,\n autocomplete: () => `\\n${Logger.errorText('>>')} Available commands:`,\n unknownError: () => `Something went wrong...`,\n fileOutput: (format = 'json', path?: string) =>\n `Output ${format} file: ${Logger.infoText(path)}\\n`,\n noFileOutput: () => `No output written\\n`,\n },\n command: {\n notKnown: (command: string) => `${command} is not known`,\n },\n envs: {\n found: (num: number) =>\n `Environments store found containing ${pl('environment', num, true)}`,\n notFound: (alias: string) =>\n `Environment ${Logger.highlightText(alias)} was not found in session cache`,\n removed: (alias: string) =>\n `Removed environment ${Logger.highlightText(alias)} from session cache`,\n tip: () =>\n `Connect to a Contensis cloud instance using \"contensis connect {cms alias}\"`,\n },\n connect: {\n command: {\n name: () => 'connect',\n example: () => `Example call:\\n > connect example-dev`,\n },\n args: {\n alias: {\n name: () => '<alias>',\n description: () => 'the Contensis Cloud alias to connect with',\n },\n },\n noEnv: () => `Cannot connect - no environment alias specified`,\n unreachable: (url: string, status: number) =>\n `Cannot reach ${url}${status ? ` - status ${status}` : ''}`,\n connected: (env: string) => `Current environment set to \"${env}\"`,\n help: () =>\n `Connect to a Contensis cloud instance using \"contensis connect {cms alias}\"`,\n projects: () => `Available projects:`,\n noProjects: () => `Cannot retrieve projects list`,\n tip: () =>\n `Introduce yourself with \"login {username}\" or \"login {clientId} -s {secret}\" or by passing credentials as options with your command`,\n },\n login: {\n command: {\n name: () => 'login',\n usage: () => `<user/clientId> [password] [-s <sharedSecret>]`,\n example: () =>\n `Example call:\\n > login myuserid\\n -- or --\\n > login {clientId} -s {sharedSecret}`,\n },\n args: {\n user: {\n name: () => '<user/clientId>',\n description: () => 'the username to login with',\n },\n password: {\n name: () => '[password]',\n description: () =>\n 'the password to use to login with (optional/insecure)',\n },\n secret: {\n name: () => '-s --sharedSecret <sharedSecret>',\n description: () =>\n 'the shared secret to use when logging in with a client id',\n },\n },\n passwordPrompt: (env?: string, userId?: string) =>\n userId\n ? `Enter password for ${userId}@${env}:`\n : `Please enter a password`,\n failed: (env: string, userId: string) =>\n `Unable to login to ${env} as ${userId}`,\n success: (env: string, userId: string) =>\n `User ${userId} connected to ${env} successfully\\n`,\n insecurePassword: () =>\n `Could not connect to local keystore - your password could be stored unencrypted!`,\n noEnv: () => `No environment set, use \"contensis connect {alias}\" first`,\n noUserId: () => `No user id specified`,\n },\n projects: {\n list: () => `Available projects:`,\n noList: () => `Cannot retrieve projects list`,\n set: (projectId: string) =>\n `Current project is set to ${Logger.highlightText(projectId)}`,\n failedSet: (projectId: string) =>\n `Project ${Logger.highlightText(projectId)} not found`,\n tip: () =>\n `You need to set your current working project with \"set project {projectId}\"`,\n created: (env: string, id: string) =>\n `[${env}] Created project ${Logger.highlightText(id)}`,\n failedCreate: (env: string, id: string) =>\n `[${env}] Unable to create project ${Logger.highlightText(id)}`,\n updated: (env: string, id: string) =>\n `[${env}] Updated project ${Logger.highlightText(id)}`,\n failedUpdate: (env: string, id: string) =>\n `[${env}] Unable to update project ${Logger.highlightText(id)}`,\n },\n migrate: {\n commitTip: () => `Add --commit flag to commit the previewed changes`,\n preview: (verb = 'IMPORT') => `\uD83D\uDD0D ${verb} PREVIEW \uD83D\uDD2D`,\n commit: (verb = 'IMPORT') => `COMMITTING ${verb} \u2728\u2604\uFE0F `,\n imported: (\n env: string,\n commit: boolean,\n entities: { [noun: string]: number }\n ) =>\n `${commit ? `Imported` : `Will import`} ${Object.entries(entities)\n .map(([noun, count]) => pl(noun, count, true))\n .join(' and ')} into ${env} environment`,\n\n models: {\n result: (\n status: keyof MigrateModelsResult['project']['contentTypes']\n ) => {\n switch (status) {\n case 'created':\n case 'updated':\n return Logger.successText;\n case 'errors':\n return Logger.errorText;\n default:\n return Logger.infoText;\n }\n },\n },\n status: (status: MigrateStatus) => {\n switch (status) {\n case 'no change':\n return Logger.successText;\n case 'create':\n case 'two-pass':\n case 'update':\n case 'delete':\n return Logger.warningText;\n case 'error':\n case 'not found':\n return Logger.errorText;\n default:\n return Logger.infoText;\n }\n },\n },\n models: {\n list: (projectId: string) =>\n `Content models in ${Logger.highlightText(projectId)}:`,\n noList: (projectId: string) =>\n `[${projectId}] Cannot retrieve content models`,\n get: (projectId: string, id: string) =>\n `[${projectId}] Content models ${Logger.infoText(`[ ${id} ]`)}`,\n failedGet: (projectId: string, id: string) =>\n `[${projectId}] Unable to get content models ${Logger.highlightText(id)}`,\n },\n nodes: {\n imported: (env: string, commit: boolean, count: number) =>\n LogMessages.migrate.imported(env, commit, { node: count }),\n failedImport: (env: string) => `[${env}] Unable to import nodes`,\n removed: (env: string, commit: boolean, root: string) =>\n `[${env}] ${commit ? `Deleted` : `Will delete`} nodes at ${root}`,\n failedRemove: (env: string) => `[${env}] Unable to delete nodes`,\n notFound: (env: string) => `[${env}] Nodes were not found `,\n commitTip: () => `Add --commit flag to commit the previewed changes`,\n failedGet: (projectId: string) =>\n `[${projectId}] Cannot retrieve nodes from Site view`,\n get: (projectId: string, root: string, depth: number) =>\n `[${projectId}] Site view nodes at: ${Logger.highlightText(root)}${\n depth ? ` to a depth of ${depth}` : ``\n }\\n`,\n noChange: (env: string) => `[${env}] No changes to be made`,\n },\n contenttypes: {\n list: (projectId: string) =>\n `Content types in ${Logger.highlightText(projectId)}:`,\n get: (projectId: string, id: string) =>\n `[${projectId}] Content type ${Logger.highlightText(id)}`,\n failedGet: (projectId: string, id: string) =>\n `[${projectId}] Unable to get content type ${Logger.highlightText(id)}`,\n created: (projectId: string, id: string, status?: string) =>\n `[${projectId}] Content type ${status}d ${Logger.highlightText(id)}`,\n removed: (env: string, id: string, commit: boolean) =>\n `[${env}] ${\n commit ? `Deleted` : `Will delete`\n } content type(s) ${Logger.highlightText(id)}`,\n failedRemove: (env: string, id: string) =>\n `[${env}] Unable to delete content type(s) ${Logger.highlightText(id)}`,\n },\n components: {\n list: (projectId: string) =>\n `Components in ${Logger.highlightText(projectId)}:`,\n get: (projectId: string, id: string) =>\n `[${projectId}] Component ${Logger.highlightText(id)}`,\n failedGet: (projectId: string, id: string) =>\n `[${projectId}] Unable to get component ${Logger.highlightText(id)}`,\n created: (projectId: string, id: string, status?: string) =>\n `[${projectId}] Component ${status}d ${Logger.highlightText(id)}`,\n removed: (env: string, id: string, commit: boolean) =>\n `[${env}] ${\n commit ? `Deleted` : `Will delete`\n } component(s) ${Logger.highlightText(id)}`,\n failedRemove: (env: string, id: string) =>\n `[${env}] Unable to delete component(s) ${Logger.highlightText(id)}`,\n },\n version: {\n set: (env: string, versionStatus: string) =>\n `[${env}] Content version status set to \"${versionStatus}\"`,\n invalid: (versionStatus: string) =>\n `Content version status \"${versionStatus}\" is not valid, allowed values are \"published\" or \"latest\".`,\n noEnv: () =>\n `No Contensis environment set, connect to your Contensis cloud instance using \"contensis connect {cms alias}\"`,\n },\n entries: {\n imported: (env: string, commit: boolean, entries: number, nodes = 0) =>\n LogMessages.migrate.imported(env, commit, {\n entry: entries,\n node: nodes,\n }),\n failedImport: (env: string) => `[${env}] Unable to import entries`,\n update: {\n preview: () => LogMessages.migrate.preview('UPDATE FIELD'),\n commit: () => LogMessages.migrate.preview('FIELD UPDATES'),\n success: (env: string, commit: boolean, entries: number, nodes = 0) =>\n `${commit ? `Updated` : `Will update`} ${pl('entry', entries, true)}${\n nodes > 0 ? ` and ${pl('node', nodes, true)}` : ''\n } in ${env} environment`,\n failed: (env: string) => `[${env}] Unable to update any entries`,\n },\n removed: (env: string, commit: boolean) =>\n `[${env}] ${commit ? `Deleted` : `Will delete`} entries`,\n failedRemove: (env: string) => `[${env}] Unable to delete entries`,\n notFound: (env: string) => `[${env}] Entries were not found`,\n noChange: (env: string) => `[${env}] No changes to be made`,\n },\n keys: {\n list: (env: string) => `[${env}] API keys:`,\n noList: (env: string) => `[${env}] Cannot retrieve API keys`,\n created: (env: string, name: string) =>\n `[${env}] Created API key ${Logger.highlightText(name)}`,\n tip: () =>\n `Assign your new key to a role with \"set role assignments\", or create a new role with \"create role\"`,\n failedCreate: (env: string, name: string) =>\n `[${env}] Unable to create API key ${Logger.highlightText(name)}`,\n failedUpdate: (env: string, name: string) =>\n `[${env}] Unable to update API key ${Logger.highlightText(name)}`,\n removed: (env: string, id: string) =>\n `[${env}] Deleted API key ${Logger.highlightText(id)}`,\n failedRemove: (env: string, id: string) =>\n `[${env}] Unable to delete API key ${Logger.highlightText(id)}`,\n },\n proxies: {\n list: (env: string, projectId: string | undefined) =>\n `[${env}] Retrieved proxies in project ${projectId}:`,\n noList: (env: string, projectId: string | undefined) =>\n `[${env}] Cannot retrieve proxies in project ${projectId}`,\n // noneExist: () => `Create a role with \"create renderer\"`,\n failedGet: (env: string, name: string, projectId: string) =>\n `[${env}] Unable to find proxy ${Logger.highlightText(\n name\n )} in project ${projectId}`,\n created: (env: string, name: string, projectId: string) =>\n `[${env}] Created proxy ${Logger.highlightText(\n name\n )} in project ${projectId}\\n`,\n failedCreate: (env: string, name: string, projectId: string) =>\n `[${env}] Unable to create proxy ${Logger.highlightText(\n name\n )} in project ${projectId}`,\n setPayload: () => `Updating proxy with details\\n`,\n set: () => `Succesfully updated proxy\\n`,\n failedSet: (env: string, name: string, projectId: string) =>\n `[${env}] Unable to update proxy ${Logger.highlightText(\n name\n )} in project ${projectId}`,\n removed: (env: string, id: string, projectId: string) =>\n `[${env}] Deleted proxy ${Logger.highlightText(\n id\n )} in project ${projectId}\\n`,\n failedRemove: (env: string, id: string, projectId: string) =>\n `[${env}] Unable to delete proxy ${Logger.highlightText(\n id\n )} in project ${projectId}`,\n },\n renderers: {\n list: (env: string, projectId: string | undefined) =>\n `[${env}] Retrieved renderers in project ${projectId}:`,\n noList: (env: string, projectId: string | undefined) =>\n `[${env}] Cannot retrieve renderers in project ${projectId}`,\n // noneExist: () => `Create a role with \"create renderer\"`,\n failedGet: (env: string, name: string, projectId: string) =>\n `[${env}] Unable to find renderer ${Logger.highlightText(\n name\n )} in project ${projectId}`,\n created: (env: string, name: string, projectId: string) =>\n `[${env}] Created renderer ${Logger.highlightText(\n name\n )} in project ${projectId}\\n`,\n failedCreate: (env: string, name: string, projectId: string) =>\n `[${env}] Unable to create renderer ${Logger.highlightText(\n name\n )} in project ${projectId}`,\n setPayload: () => `Updating renderer with details\\n`,\n set: () => `Succesfully updated renderer\\n`,\n failedSet: (env: string, name: string, projectId: string) =>\n `[${env}] Unable to update renderer ${Logger.highlightText(\n name\n )} in project ${projectId}`,\n removed: (env: string, id: string, projectId: string) =>\n `[${env}] Deleted renderer ${Logger.highlightText(\n id\n )} in project ${projectId}\\n`,\n failedRemove: (env: string, id: string, projectId: string) =>\n `[${env}] Unable to delete renderer ${Logger.highlightText(\n id\n )} in project ${projectId}`,\n },\n roles: {\n list: (env: string) => `[${env}] Retrieved roles`,\n noList: (env: string) => `[${env}] Cannot retrieve roles`,\n noneExist: () => `Create a role with \"create role\"`,\n failedGet: (env: string, name: string) =>\n `[${env}] Unable to find role ${Logger.highlightText(name)}`,\n created: (env: string, name: string) =>\n `[${env}] Created role ${Logger.highlightText(name)}\\n`,\n tip: () =>\n `Give access to your role with \"set role assignments\", allow your role to do things with \"set role permissions\"`,\n failedCreate: (env: string, name?: string) =>\n `[${env}] Unable to create role ${Logger.highlightText(name)}`,\n setPayload: () => `Updating role with details\\n`,\n set: () => `Succesfully updated role\\n`,\n failedSet: (env: string, name?: string) =>\n `[${env}] Unable to update role ${Logger.highlightText(name)}`,\n removed: (env: string, id: string) =>\n `[${env}] Deleted role ${Logger.highlightText(id)}\\n`,\n failedRemove: (env: string, id: string) =>\n `[${env}] Unable to delete role ${Logger.highlightText(id)}`,\n },\n taggroups: {\n list: (env: string, length: number) =>\n `[${env}] Retrieved ${pl('tag group', length, true)}`,\n noList: (env: string) => `[${env}] Cannot retrieve tag groups`,\n noneExist: () => `Create a tag group with \"create taggroup <name>\"`,\n imported: (env: string, commit: boolean, groups: number, tags: number) =>\n LogMessages.migrate.imported(env, commit, {\n 'tag group': groups,\n tag: tags,\n }),\n failedGet: (env: string, name: string) =>\n `[${env}] Unable to find a tag group ${Logger.highlightText(name)}`,\n created: (env: string, name: string) =>\n `[${env}] Created tag group ${Logger.highlightText(name)}\\n`,\n tip: () =>\n `Give access to your role with \"set role assignments\", allow your role to do things with \"set role permissions\"`,\n failedCreate: (env: string, name?: string) =>\n `[${env}] Unable to create ${name ? `tag group ${Logger.highlightText(name)}` : 'tag groups'}`,\n removed: (env: string, id: string, commit: boolean) =>\n `[${env}] ${\n commit ? `Deleted` : `Will delete`\n } tag group ${Logger.highlightText(id)}\\n`,\n failedRemove: (env: string, id: string) =>\n `[${env}] Unable to delete tag group ${Logger.highlightText(id)}`,\n },\n tags: {\n list: (env: string, length: number) =>\n `[${env}] Retrieved ${pl('tag', length, true)}`,\n noList: (env: string) => `[${env}] Cannot retrieve tags`,\n noneExist: () =>\n `Create a tag with \"create tag in <groupId> <tag label(s)...>\"`,\n imported: (env: string, commit: boolean, tags: number) =>\n LogMessages.migrate.imported(env, commit, { tag: tags }),\n failedGet: (env: string) => `[${env}] Unable to find tags`,\n created: (env: string, name: string) =>\n `[${env}] Created tag ${Logger.highlightText(name)}\\n`,\n failedCreate: (env: string, name?: string) =>\n `[${env}] Unable to create ${name ? `tag ${Logger.highlightText(name)}` : 'tags'}`,\n removed: (env: string, length: number, commit: boolean) =>\n `[${env}] ${\n !length\n ? 'No tags to delete'\n : `${commit ? `Deleted` : `Will delete`} ${pl('tag', length, true)}\\n`\n }`,\n failedRemove: (env: string, length: number) =>\n `[${env}] Unable to delete tags with ${pl('error', length)}`,\n noChange: (env: string) => `[${env}] No changes to be made`,\n },\n blocks: {\n runningStatus: (status: BlockRunningStatus | 'broken') => {\n switch (status) {\n case 'available':\n return Logger.successText(status);\n case 'pending':\n case 'starting':\n case 'stopped':\n return Logger.warningText(status);\n case 'degraded':\n case 'faulted':\n case 'broken':\n return Logger.errorText(status);\n default:\n return Logger.infoText(status);\n }\n },\n get: (\n id: string,\n branch: string,\n version: string,\n env: string,\n projectId?: string\n ) =>\n `[${env}] ${\n version && version !== 'latest'\n ? `Found v${version}`\n : 'Latest block versions'\n } for ${Logger.infoText(`${branch}/`)}${Logger.highlightText(\n id\n )} in project ${projectId}\\n`,\n noGet: (\n id: string,\n branch: string,\n version: string,\n env: string,\n projectId?: string\n ) =>\n `[${env}] Did not find ${\n version ? `v${version}` : 'any block versions'\n } for ${Logger.highlightText(id)} in branch ${Logger.infoText(\n branch\n )} in ${Logger.infoText(projectId)} project`,\n noGetTip: () =>\n `Check the available blocks and branches in this project by running \"list blocks\"`,\n list: (env: string, projectId?: string) =>\n `[${env}] Blocks in project ${projectId}\\n`,\n noList: (env: string, projectId?: string) =>\n `[${env}] Cannot retrieve blocks in project ${projectId}`,\n getLogs: (id: string, branch: string, env: string, projectId?: string) =>\n `[${env}] Requesting logs from block ${Logger.highlightText(\n id\n )} in branch ${branch} in project ${projectId}`,\n failedGetLogs: (id: string, env: string, projectId?: string) =>\n `[${env}] Unable to fetch block logs for ${Logger.highlightText(\n id\n )} in project ${projectId}`,\n tryPush: (id: string, branch: string, env: string, projectId?: string) =>\n `[${env}] Request to push block ${Logger.highlightText(\n id\n )} in branch ${branch} in project ${projectId}`,\n pushed: (id: string, branch: string, env: string, projectId?: string) =>\n `[${env}] Pushed block ${Logger.highlightText(\n id\n )} in branch ${branch} in project ${projectId}`,\n failedPush: (id: string, env: string, projectId?: string) =>\n `[${env}] Unable to push block ${Logger.highlightText(\n id\n )} in project ${projectId}`,\n failedParsingVersion: () =>\n `Did not find a \"version.versionNo\" in response`,\n actionComplete: (\n action: BlockActionType,\n id: string,\n env: string,\n projectId?: string\n ) =>\n `[${env}] Action ${Logger.highlightText(\n action\n )} on ${Logger.highlightText(\n id\n )} in project ${projectId} requested successfully`,\n actionFailed: (\n action: BlockActionType,\n id: string,\n env: string,\n projectId?: string\n ) =>\n `[${env}] Problem executing ${action} on block ${Logger.highlightText(\n id\n )} in project ${projectId}`,\n deleted: (id: string, env: string, projectId?: string) =>\n `[${env}] Deleted block ${Logger.highlightText(\n id\n )} in project ${projectId}`,\n failedDelete: (id: string, env: string, projectId?: string) =>\n `[${env}] Unable to delete block ${Logger.highlightText(\n id\n )} in project ${projectId}`,\n stopFollow: (id: string, env: string, projectId?: string) =>\n `[${env}]\\n\\n \uD83D\uDC4C stop fetching new ${Logger.highlightText(\n id\n )} logs in project ${projectId}`,\n timeoutFollow: (id: string, env: string, projectId?: string) =>\n `[${env}]\\n\\n \uD83E\uDD0F pausing fetching new ${Logger.highlightText(\n id\n )} logs in project ${projectId} due to too many requests`,\n },\n webhooks: {\n list: (env: string) => `[${env}] Webhook subscriptions:`,\n noList: (env: string) => `[${env}] Cannot retrieve webhook subscriptions`,\n noneExist: () => `No webhook subscriptions exist`,\n created: (env: string, name: string) =>\n `[${env}] Created Webhook subscription ${Logger.highlightText(name)}`,\n failedCreate: (env: string, name: string) =>\n `[${env}] Unable to create Webhook subscription ${Logger.highlightText(\n name\n )}`,\n deleted: (env: string, id: string) =>\n `[${env}] Deleted Webhook subscription ${Logger.highlightText(id)}`,\n failedDelete: (env: string, id: string) =>\n `[${env}] Unable to delete Webhook subscription ${Logger.highlightText(\n id\n )}`,\n },\n workflows: {\n list: (env: string) => `[${env}] Retrieved workflows`,\n noList: (env: string) => `[${env}] Cannot retrieve workflows`,\n noneExist: () => `No workflows found`,\n failedGet: (env: string, name: string) =>\n `[${env}] Unable to find workflow ${Logger.highlightText(name)}`,\n },\n devinit: {\n intro: () => `Contensis developer environment initialisation`,\n //`This will initialise your local working directory to develop with the current connected Contensis project`,\n projectDetails: (\n name: string,\n env: string,\n projectId: string,\n blockId: string,\n git: GitHelper\n ) =>\n `\n Project: ${Logger.standardText(name)}\n - Home: ${Logger.standardText(git.gitcwd())}\n - Repository: ${Logger.standardText(git.home)} \n - Block id: ${Logger.highlightText(blockId)}\n \n Connect to Contensis instance: ${Logger.standardText(env)}\n - Project id: ${Logger.standardText(projectId)}\n `,\n developmentKey: (name: string, existing: boolean) =>\n ` - ${\n !existing ? 'Create development API key' : 'Development API key found'\n }: ${Logger[!existing ? 'highlightText' : 'standardText'](name)}`,\n deploymentKey: (name: string, existing: boolean) =>\n ` - ${\n !existing ? 'Create deployment API key' : 'Deployment API key found'\n }: ${Logger[!existing ? 'highlightText' : 'standardText'](name)}`,\n ciIntro: (git: GitHelper, location: 'git' | 'env') =>\n `We will create API keys with permissions to use this project with Contensis, and add a job to your CI that will deploy a container build.\n ${\n location === 'git'\n ? `We will ask you to add secrets/variables to your git repository to give your workflow permission to push a Block to Contensis.\n ${Logger.infoText(`You could visit ${git.secretsUri} to check that you can see repository settings, \n a page not found generally indicates you need to ask the repo owner for permission to add repository secrets, \n or ask the repo owner to add these secrets for you.`)}`\n : ''\n }`,\n ciDetails: (filename: string) =>\n `Add push-block job to CI file: ${Logger.highlightText(filename)}\\n`,\n ciMultipleChoices: () =>\n `Multiple GitHub workflow files found\\n${Logger.infoText(\n `Tell us which GitHub workflow builds a container image after each push:`\n )}`,\n ciMultipleBuildJobChoices: () =>\n `Multiple build jobs found in workflow\\n${Logger.infoText(\n `Choose the build job that produces a fresh container image to push to a block:`\n )}`,\n ciMultipleJobChoices: () =>\n `Other jobs found in workflow\\n${Logger.infoText(\n `Choose the job that produces a fresh container image we can push to a block:`\n )}`,\n ciMultipleAppImageVarChoices: () =>\n `Do one of these variables point to your tagged app image?\\n${Logger.infoText(\n `we have included a default choice - ensure your build image is tagged exactly the same as this`\n )}`,\n ciEnterOwnAppImagePrompt: (git: GitHelper) =>\n `Tell us the registry uri your app image is tagged and pushed with (\u23CE accept default) \\n${Logger.infoText(\n `Tip: ${\n git.type === 'github'\n ? `GitHub context variables available\\nhttps://docs.github.com/en/actions/learn-github-actions/variables#using-contexts-to-access-variable-values`\n : `GitLab CI/CD variables available\\nhttps://docs.gitlab.com/ee/ci/variables/`\n }`\n )}\\n`,\n confirm: () =>\n `Confirm these details are correct so we can make changes to your project`,\n createDevKey: (keyName: string, existing: boolean) =>\n `${\n !existing ? 'Created' : 'Checked permissions for'\n } development API key ${Logger.standardText(keyName)}`,\n createDeployKey: (keyName: string, existing: boolean) =>\n `${\n !existing ? 'Created' : 'Checked permissions for'\n } deployment API key ${Logger.standardText(keyName)}`,\n createKeyFail: (keyName: string, existing: boolean) =>\n `Failed to ${\n !existing ? 'create' : 'update'\n } API key ${Logger.highlightText(keyName)}`,\n writeEnvFile: () => `Written .env file to project home directory`,\n useEnvFileTip: () =>\n `You should alter existing project code that connects a Contensis client to use the variables from this file`,\n writeCiFile: (ciFilePath: string) =>\n `Updated CI file ${Logger.standardText(winSlash(ciFilePath))}`,\n ciFileNoChanges: (ciFilePath: string) =>\n `No updates needed for CI file ${Logger.standardText(\n winSlash(ciFilePath)\n )}`,\n ciBlockTip: (blockId: string, env: string, projectId: string) =>\n `A job is included to deploy your built container image to ${Logger.standardText(\n projectId\n )} at ${Logger.standardText(env)} in a block called ${Logger.standardText(\n blockId\n )}`,\n addGitSecretsIntro: () =>\n `We have created an API key that allows you to deploy your app image to a Contensis Block but we need you to add these details to your GitLab repository.`,\n addGitSecretsHelp: (git: GitHelper, id?: string, secret?: string) =>\n `Add secrets or variables in your repository's settings page\\n\\nGo to ${Logger.highlightText(\n git.secretsUri\n )}\\n\\n${\n git.type === 'github'\n ? `Add a \"New repository secret\"`\n : `Expand \"Variables\" and hit \"Add variable\"`\n }\\n\\n ${\n git.type === 'github' ? `Secret name:` : `Key:`\n } ${Logger.highlightText(`CONTENSIS_CLIENT_ID`)}\\n ${\n git.type === 'github' ? `Secret:` : `Value:`\n } ${Logger.standardText(\n id\n )}\\n\\n ${`Add one more secret/variable to the repository`}\\n\\n ${\n git.type === 'github' ? `Secret name:` : `Key:`\n } ${Logger.highlightText(`CONTENSIS_SHARED_SECRET`)}\\n ${\n git.type === 'github' ? `Secret:` : `Value:`\n } ${Logger.standardText(secret)}`,\n accessTokenFetch: () =>\n `Please wait, fetching Delivery API access token \u23F3`,\n accessTokenSuccess: (token: string) =>\n `Successfully fetched Delivery API token\\n ${Logger.infoText(token)}`,\n accessTokenFailed: () =>\n `Something went wrong! If the problem persists, please contact our support team \uD83D\uDEDF`,\n accessTokenPermission: () =>\n `We need permission to fetch your Delivery API token, please try again \u26A0\uFE0F`,\n clientDetailsLocation: () =>\n `Which option would you like to use for storing your client ID and secret`,\n clientDetailsInGit: (git: GitHelper) =>\n `${\n git.type === 'github' ? 'GitHub' : 'GitLab'\n } variables (recommended for public repositories)`,\n clientDetailsInEnv: () =>\n `Env variables (recommended for private repositories)`,\n success: () => `Contensis developer environment initialisation complete`,\n partialSuccess: () =>\n `Contensis developer environment initialisation completed with errors`,\n failed: () => `Contensis developer environment initialisation failed`,\n dryRun: () =>\n `Contensis developer environment initialisation dry run completed`,\n dryRunKeyMessage: (dryRun: boolean) =>\n dryRun ? '<< not created: dry-run >>' : undefined,\n noChanges: () =>\n `No changes were made to your project, run the command again without the ${Logger.highlightText(\n '--dry-run'\n )} flag to update your project with these changes`,\n startProjectTip: () =>\n `Start up your project in the normal way for development`,\n blockIdQuestion: () =>\n `Please enter your block id, this should be unquie and in kebab case e.g ${Logger.highlightText(\n 'my-awesome-website'\n )}`,\n },\n devrequests: {\n install: {\n notFound: (repo: string) =>\n `Could not find a release in ${repo} repo - please check github`,\n download: (repo: string, version: string) => `Found release ${version}`,\n downloading: (repo: string, version: string) =>\n `Downloading ${repo} ${version}`,\n downloadFail: (repo: string, version: string) =>\n `Problem downloading release ${version} from ${repo}`,\n downloaded: (repo: string, version: string) =>\n `Downloaded ${repo} ${version}`,\n applyUpdate: (version: string, existing: string) =>\n `Use updated version ${version} ${Logger.infoText(\n `(replaces ${existing})`\n )}?`,\n },\n launch: () => `Launching request handler for local development`,\n overrideBlock: () => `Which block will you be running?`,\n overrideUri: () => `How to access your development site`,\n spawn: () =>\n `If you see a firewall popup requesting network access, it is safe to approve`,\n exited: (code: number | null) =>\n `Request handler exited with code ${code}\\n`,\n errored: (error: Error) =>\n `Could not launch request handler due to error \\n${error}`,\n },\n};\n"],
5
+ "mappings": "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",
6
6
  "names": ["pl"]
7
7
  }
@@ -121,7 +121,7 @@ class ContensisCli {
121
121
  );
122
122
  }
123
123
  this.format = outputOpts == null ? void 0 : outputOpts.format;
124
- this.output = (outputOpts == null ? void 0 : outputOpts.output) && import_path.default.join(process.cwd(), outputOpts.output);
124
+ this.output = (outputOpts == null ? void 0 : outputOpts.output) ? import_path.default.isAbsolute(outputOpts.output) ? outputOpts.output : import_path.default.join(process.cwd(), outputOpts.output) : void 0;
125
125
  const currentEnvironment = (outputOpts == null ? void 0 : outputOpts.alias) || this.currentEnv;
126
126
  const environments = this.cache.environments || {};
127
127
  this.currentEnv = currentEnvironment;
@@ -1058,7 +1058,7 @@ class ContensisCli {
1058
1058
  data,
1059
1059
  save
1060
1060
  }) => {
1061
- var _a, _b, _c, _d, _e;
1061
+ var _a, _b, _c, _d, _e, _f, _g, _h;
1062
1062
  const { currentEnv, currentProject, log, messages } = this;
1063
1063
  const mixedData = { tags: [], tagGroups: [] };
1064
1064
  if (data) {
@@ -1112,13 +1112,18 @@ class ContensisCli {
1112
1112
  log.help(messages.migrate.commitTip());
1113
1113
  }
1114
1114
  } else {
1115
- log.error(
1116
- messages.tags.failedCreate(
1117
- currentEnv,
1118
- (data == null ? void 0 : data.length) === 1 ? data == null ? void 0 : data[0].label["en-GB"] : void 0
1119
- ),
1120
- err
1121
- );
1115
+ const noChanges = ((_g = (_f = result == null ? void 0 : result.tagsToMigrate) == null ? void 0 : _f[currentProject]) == null ? void 0 : _g["no change"]) && result.tagsToMigrate[currentProject].totalCount === 0 && result.groupsToMigrate[currentProject].totalCount === 0;
1116
+ if (noChanges && !err && !((_h = result.errors) == null ? void 0 : _h.length)) {
1117
+ log.help(messages.tags.noChange(currentEnv));
1118
+ } else {
1119
+ log.error(
1120
+ messages.tags.failedCreate(
1121
+ currentEnv,
1122
+ (data == null ? void 0 : data.length) === 1 ? data == null ? void 0 : data[0].label["en-GB"] : void 0
1123
+ ),
1124
+ err
1125
+ );
1126
+ }
1122
1127
  }
1123
1128
  } else {
1124
1129
  log.warning(messages.models.noList(currentProject));
@@ -1288,6 +1293,7 @@ class ContensisCli {
1288
1293
  const models = await contensis.models.contentModels();
1289
1294
  const contentTypes = await contensis.models.contentTypes();
1290
1295
  const components = await contensis.models.components();
1296
+ const tagGroups = await contensis.models.tagGroups();
1291
1297
  const returnModels = (modelIds == null ? void 0 : modelIds.length) ? models == null ? void 0 : models.filter(
1292
1298
  (m) => modelIds.some((id) => id.toLowerCase() === m.id.toLowerCase())
1293
1299
  ) : void 0;
@@ -1310,12 +1316,23 @@ class ContensisCli {
1310
1316
  }).flat()
1311
1317
  )
1312
1318
  );
1319
+ const tagGroupIds = Array.from(
1320
+ new Set(
1321
+ (returnModels || models || []).map((m) => {
1322
+ var _a, _b;
1323
+ return ((_b = (_a = m.dependencies) == null ? void 0 : _a.tagGroups) == null ? void 0 : _b.map((g) => g[0])) || [];
1324
+ }).flat()
1325
+ )
1326
+ );
1313
1327
  exportResources.push(
1314
1328
  ...contentTypes.filter(
1315
1329
  (c) => contentTypeIds.map((i) => i.toLowerCase()).includes(c.id.toLowerCase())
1316
1330
  ),
1317
1331
  ...components.filter(
1318
1332
  (c) => componentIds.map((i) => i.toLowerCase()).includes(c.id.toLowerCase())
1333
+ ),
1334
+ ...tagGroups.filter(
1335
+ (g) => tagGroupIds.map((i) => i.toLowerCase()).includes(g.id.toLowerCase())
1319
1336
  )
1320
1337
  );
1321
1338
  }
@@ -1349,17 +1366,18 @@ class ContensisCli {
1349
1366
  await this.HandleFormattingAndOutput(
1350
1367
  opts.export ? exportResources : models,
1351
1368
  () => {
1352
- var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l;
1369
+ var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o;
1353
1370
  for (const model of models) {
1354
1371
  const components2 = ((_a = model.components) == null ? void 0 : _a.length) || 0;
1355
1372
  const contentTypes2 = ((_b = model.contentTypes) == null ? void 0 : _b.length) || 0;
1356
- const defaults = (((_c = model.defaults) == null ? void 0 : _c.length) || 0) + (((_d = model.nodes) == null ? void 0 : _d.length) || 0);
1357
- const dependencies = (((_f = (_e = model.dependencies) == null ? void 0 : _e.components) == null ? void 0 : _f.length) || 0) + (((_h = (_g = model.dependencies) == null ? void 0 : _g.contentTypes) == null ? void 0 : _h.length) || 0);
1358
- const dependencyOf = (((_j = (_i = model.dependencyOf) == null ? void 0 : _i.components) == null ? void 0 : _j.length) || 0) + (((_l = (_k = model.dependencyOf) == null ? void 0 : _k.contentTypes) == null ? void 0 : _l.length) || 0);
1359
- const hasAny = components2 + contentTypes2 + dependencies + dependencyOf;
1373
+ const tagGroups2 = ((_c = model.tagGroups) == null ? void 0 : _c.length) || 0;
1374
+ const defaults = (((_d = model.defaults) == null ? void 0 : _d.length) || 0) + (((_e = model.nodes) == null ? void 0 : _e.length) || 0);
1375
+ const dependencies = (((_g = (_f = model.dependencies) == null ? void 0 : _f.components) == null ? void 0 : _g.length) || 0) + (((_i = (_h = model.dependencies) == null ? void 0 : _h.contentTypes) == null ? void 0 : _i.length) || 0) + (((_k = (_j = model.dependencies) == null ? void 0 : _j.tagGroups) == null ? void 0 : _k.length) || 0);
1376
+ const dependencyOf = (((_m = (_l = model.dependencyOf) == null ? void 0 : _l.components) == null ? void 0 : _m.length) || 0) + (((_o = (_n = model.dependencyOf) == null ? void 0 : _n.contentTypes) == null ? void 0 : _o.length) || 0);
1377
+ const hasAny = components2 + contentTypes2 + tagGroups2 + dependencies + dependencyOf;
1360
1378
  log.raw(
1361
1379
  ` - ${log.highlightText(log.boldText(model.id))} ${hasAny ? log.infoText(
1362
- `{ ${components2 ? `components: ${components2}, ` : ""}${contentTypes2 ? `contentTypes: ${contentTypes2}, ` : ""}${defaults ? `defaults: ${defaults}, ` : ""}${dependencies ? `references: ${dependencies}, ` : ""}${dependencyOf ? `required by: ${dependencyOf}` : ""} }`
1380
+ `{ ${components2 ? `components: ${components2}, ` : ""}${contentTypes2 ? `contentTypes: ${contentTypes2}, ` : ""}${tagGroups2 ? `tagGroups: ${tagGroups2}, ` : ""}${defaults ? `defaults: ${defaults}, ` : ""}${dependencies ? `references: ${dependencies}, ` : ""}${dependencyOf ? `required by: ${dependencyOf}` : ""} }`
1363
1381
  ) : ""}`
1364
1382
  );
1365
1383
  }
@@ -1375,13 +1393,14 @@ class ContensisCli {
1375
1393
  fromFile
1376
1394
  }) => {
1377
1395
  const { currentProject, log, messages } = this;
1378
- const fileData = fromFile ? await (0, import_file_provider.readFileAsJSON)(fromFile) || [] : [];
1379
- if (typeof fileData === "string")
1380
- throw new Error(`Import file format must be of type JSON`);
1396
+ const mixedData = { models: [], tagGroups: [] };
1397
+ if (fromFile) {
1398
+ const fileData = fromFile ? await (0, import_file_provider.readFileAsJSON)(fromFile) || [] : [];
1399
+ (0, import_util.splitTagGroupsInModels)(fileData, mixedData.models, mixedData.tagGroups);
1400
+ }
1381
1401
  const contensis = await this.ConnectContensisImport({
1382
1402
  commit,
1383
- fromFile,
1384
- importDataType: "models"
1403
+ mixedData
1385
1404
  });
1386
1405
  if (contensis) {
1387
1406
  log.line();
@@ -1405,6 +1424,11 @@ Components:`));
1405
1424
  if (!result.components) log.info(`- None returned
1406
1425
  `);
1407
1426
  else (0, import_console.printModelMigrationAnalysis)(this, result.components);
1427
+ if (result.tagGroups && Object.keys(result.tagGroups).length) {
1428
+ log.raw(log.boldText(`
1429
+ Tag Groups:`));
1430
+ (0, import_console.printModelMigrationAnalysis)(this, result.tagGroups);
1431
+ }
1408
1432
  if (result.defaults && Object.keys(result.defaults).length) {
1409
1433
  log.raw(log.boldText(`
1410
1434
  Defaults:`));
@@ -1438,6 +1462,16 @@ Components:`));
1438
1462
  modelsResult[currentProject].components
1439
1463
  );
1440
1464
  }
1465
+ if (Object.values(modelsResult[currentProject].tagGroups || {}).some(
1466
+ (r) => r.length > 0
1467
+ )) {
1468
+ log.raw(log.boldText(`
1469
+ Tag Groups:`));
1470
+ (0, import_console.printModelMigrationResult)(
1471
+ this,
1472
+ modelsResult[currentProject].tagGroups
1473
+ );
1474
+ }
1441
1475
  if (Object.values(modelsResult[currentProject].defaults || {}).some(
1442
1476
  (r) => r.length > 0
1443
1477
  )) {
@@ -1798,7 +1832,7 @@ Components:`));
1798
1832
  saveEntries,
1799
1833
  data
1800
1834
  }) => {
1801
- var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k;
1835
+ var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n;
1802
1836
  const { currentEnv, currentProject, log, messages } = this;
1803
1837
  const contensis = await this.ConnectContensisImport({
1804
1838
  commit,
@@ -1856,9 +1890,16 @@ Components:`));
1856
1890
  log.help(messages.migrate.commitTip());
1857
1891
  }
1858
1892
  } else {
1859
- log.error(messages.entries.failedImport(currentEnv), err);
1860
- if (!((_k = (_j = result == null ? void 0 : result.entriesToMigrate) == null ? void 0 : _j[currentProject]) == null ? void 0 : _k.totalCount))
1861
- log.help(messages.entries.notFound(currentEnv));
1893
+ const noChanges = Object.values((_j = result == null ? void 0 : result.entriesToMigrate) == null ? void 0 : _j[currentProject]).every(
1894
+ (status) => typeof status === "number" || (status["no change"] || 0) > 0
1895
+ ) && result.entriesToMigrate[currentProject].totalCount === 0;
1896
+ if (noChanges && !err && !((_k = result == null ? void 0 : result.migrateResult) == null ? void 0 : _k.errors) && !((_l = result == null ? void 0 : result.nodesResult) == null ? void 0 : _l.errors)) {
1897
+ log.help(messages.entries.noChange(currentEnv));
1898
+ } else {
1899
+ log.error(messages.entries.failedImport(currentEnv), err);
1900
+ if (!((_n = (_m = result == null ? void 0 : result.entriesToMigrate) == null ? void 0 : _m[currentProject]) == null ? void 0 : _n.totalCount))
1901
+ log.help(messages.entries.notFound(currentEnv));
1902
+ }
1862
1903
  }
1863
1904
  } else {
1864
1905
  log.warning(messages.models.noList(currentProject));