Skip to content

cub tag create

cub tag create

Create a new tag or bulk create tags

Synopsis

Create a new tag or bulk create multiple tags by cloning existing ones.

SINGLE TAG CREATION:

Create a new tag to identify a set of revisions across units.

Examples:

  # Create a tag for a release
  cub tag create --space my-space release-v1.0

  # Create a tag with labels
  cub tag create --space my-space production-deploy --label version=1.0 --label environment=prod

  # Create a tag with a display name
  cub tag create --space my-space --json my-tag --from-stdin < tag.json

BULK TAG CREATION:

When no positional arguments are provided, bulk create mode is activated. This mode clones existing tags based on filters and creates multiple new tags with optional modifications.

Bulk Create Examples:

  # Clone all tags matching a pattern with name prefixes
  cub tag create --where "Slug LIKE 'release-%'" --name-prefix archive- --dest-space archive-space

  # Clone specific tags to multiple spaces
  cub tag create --tag release-v1.0 --dest-space dev-space,staging-space

  # Clone tags using a where expression for destination spaces
  cub tag create --where "Labels.version = '1.0'" --where-space "Labels.Environment IN ('dev', 'staging')"

  # Clone tags with modifications via JSON patch
  echo '{"Labels": {"archived": "true"}}' | cub tag create --where "CreatedAt < '2024-01-01'" --name-prefix old- --from-stdin
cub tag create [<slug>] [flags]

Options

      --allow-exists             Allow creation of resources that already exist
      --annotation strings       annotations in key=value format; can separate by commas and/or use multiple instances of the flag
      --delete-gate strings      delete gates in key[=true] format; can separate by commas and/or use multiple instances of the flag
      --dest-space strings       destination spaces for bulk create (can be repeated or comma-separated)
      --filename string          Read the ConfigHub entity JSON from file, URL (https://), or stdin (-); mutually exclusive with --from-stdin
      --filter string            Filter entity to apply to the list. Specify as 'space/filter' for cross-space filters or just 'filter' for current space. Supports both slugs and UUIDs. The filter will be combined with any --where clause using AND logic. Examples: "production-filters/security-check", "my-filter-uuid", "validation-rules"
      --filter-space string      filter entity containing WHERE expression to select destination spaces for bulk create (slug or UUID)
      --from-stdin               Read the ConfigHub entity JSON (e.g., retrieved with cub <entity> get --quiet --json) from stdin; merged with command arguments on create, and merged with command arguments and existing entity on update
  -h, --help                     help for create
      --jq string                jq expression, suppressing default output
      --json                     JSON output, suppressing default output
      --label strings            labels in key=value format; can separate by commas and/or use multiple instances of the flag
      --name-pattern string      a pattern string for name generation of clones, prefix 'template:' to use a Go template with .SourceEntitySlug to access the original Tag and .Labels to access variant labels, example: 'template:{{.SourceEntitySlug}}-{{.Labels.env}}'
      --name-prefix strings      name prefixes for bulk create (can be repeated or comma-separated)
      --quiet                    No default output.
      --tag strings              target specific tags by slug or UUID for bulk create (can be repeated or comma-separated)
      --variant-labels strings   labels for bulk create in the format of key1=value1|value2,key2=value1|value2|value3
      --verbose                  Detailed output, additive with default output
      --where string             Filter expression using SQL-inspired syntax. Supports conjunctions with AND. String operators: =, !=, <, >, <=, >=, LIKE, ILIKE, ~~, !~~, ~, ~*, !~, !~*. Pattern matching with LIKE/ILIKE uses % and _ wildcards. Regex operators (~, ~*, !~, !~*) support POSIX regular expressions. Examples: "Slug LIKE 'app-%'", "DisplayName ILIKE '%backend%'", "Slug ~ '^[a-z]+-[0-9]+$'"
      --where-space string       where expression to select destination spaces for bulk create
      --yaml                     YAML output, suppressing default output
      --yq string                yq expression, suppressing default output

Options inherited from parent commands

      --context string   The context to use for this command
      --debug            Debug output
      --space string     space ID to perform command on

SEE ALSO