Run targets
Run command against the given set of deployment targets.
Usage
tkm targets run [group-path...] \
  --map <command> \
  [--reduce <command>] \
  [--map-role-name <role-name>] \
  [--map-args <args>] \
  [--disable-map-role] \
  [--reduce-role-arn <role-arn>] \
  [--target <target>]... \
  [--exclude-target <target>]... \
  [--label <label>]... \
  [--exclude-label <label>]... \
  [--capture-after <line>] \
  [--capture-before <line>] \
  [--capture-last-line] \
  [--output <format>] \
  [--concurrent-targets <count>] \
  [--reset-cache]
Positional arguments
- group-path- 
- Provide one or more deployment group paths to run command only against the targets that belong to the deployment groups located under the given deployment group paths in the deployment groups hierarchy.
- Optional.
 
Options
In addition to the common options, this command has the following options.
- --map <command>- 
- Command to run against each target.
- To invoke a JavaScript function from a file, give the path to the file prefixed with js:
- The JavaScript file must have a default export that exports a mapper function of type MapFunction.
- For each target, Takomo invokes the mapper function and collects the returned values.
- After all targets are processed, Takomo invokes the reduce command with the returned values.
 
- Invoking a TypeScript function from a file works the same, but you need to give the path to the file with ts:prefix
 
- --reduce <command>- 
- Command to invoke with results from the map command.
- To invoke a JavaScript function from a file, give path to the file prefixed with js:
- The JavaScript file must have a default export that exports a reducer function of type ReduceFunction:
 
- Invoking a TypeScript function from a file works the same, but you need to give the path to the file with ts:prefix
 
- --map-role-name <role-name>- 
- Name of IAM role Takomo should assume from each account when invoking the map command.
 
- --map-args <args>- 
- Additional arguments passed to the map command
- To read the argument value from a file, prefix the argument with file:
- If the file's extension is .json, its contents are parsed as JSON and stored to an object.
- If the file's extension is .yaml or .yml, its contents are parsed as YAML and stored to an object.
- Otherwise, the file's contents are passed as is.
 
 
- --disable-map-role- 
- By default, Takomo assumes an IAM role from each account. Use this option to disable this functionality.
 
- --reduce-role-arn <role arn>- 
- ARN of IAM role Takomo should assume when running the reduce command.
 
- --label <label>- 
- Choose deployment targets by label. You can use this option multiple times to specify more labels.
 
- --exclude-label <label>- 
- Exclude deployment targets by label. You can use this option multiple times to specify more labels.
 
- --target <target>- 
- Deployment targets to include in the run. You can use this option multiple times to specify more targets. You can use % character as a wildcard at the beginning and/or end of the target name to more than one target.
 
- --exclude-target <target>- 
- Exclude deployment targets. You can use this option multiple times to specify more targets. You can use % character as a wildcard at the beginning and/or end of the target name to more than one target.
 
- --capture-after <line>- 
- Capture all output from the map command after this line.
 
- --capture-before <line>- 
- Capture all output from the map command before this line.
 
- --capture-last-line- 
- Capture only the last line from the map command.
 
- --output <format>- 
- Print the result from the reduce command using this format
- Supported values: text, json, yaml
 
- --concurrent-targets <number>- 
- Number of deployment targets to run concurrently. Defaults to 1.
 
- --reset-cache- 
- Reset cached files under .takomo-cache dir
 
IAM permissions
# Minimum permissions. Additional permissions are needed to actually 
# modify resources defined in the CloudFormation templates.
Statement: 
  
  # IAM permissions needed only if targets are located in more
  # than one AWS account. Specify resource to restrict access 
  # to specific roles.  
  - Sid: IAM
    Effect: Allow
    Action:
      - sts:AssumeRole
    Resource: "*"
Examples
Run aws s3 ls command against all targets. Assume role MyRunnerRole from each target account.
tkm targets run --map "aws s3 ls" --map-role-name MyRunnerRole
Invoke a JavaScript function defined in a file found from path /Documents/my-mapper.js:
tkm targets run --map js:/Documents/my-mapper.js --map-role-name MyRunnerRole
Invoke a JavaScript function defined in a file found from path /Documents/my-mapper.js then invoke another JavaScript function from a file /Documents/reducer.js with the list of results collected from the map function.
tkm targets run \
  --map js:/Documents/my-mapper.js \
  --reduce js:/Documents/reducer.js \
  --map-role-name MyRunnerRole
Example of a mapper function written with JavaScript. Note that this function requires that you have declared @aws-sdk/client-sts in your package.json dependencies.
import { STS } from "@aws-sdk/client-sts"
export default async ({ credentials }) => {
  const { Account } = await new STS({
    credentials,
    region: "us-east-1",
  }).getCallerIdentity({})
  return Account
}
Example of a mapper function written with TypeScript:
import { MapFunction } from "takomo"
export interface MyTarget {
  accountId: string
  message: string
}
const map: MapFunction<MyTarget> = async ({ target }) => {
  return {
    accountId: target.accountId!,
    message: target.vars.message,
  }
}
export default map
Example of a reducer function written with JavaScript.
export default ({ targets }) => targets.sort().join(",")
Example of a reducer function written with TypeScript.
import { ReduceFunction } from "takomo"
export interface MyTarget {
  accountId: string
  message: string
}
const reduce: ReduceFunction<MyTarget, string> = async ({ targets }) => {
  return targets.map((t) => t.accountId + "=" + t.message).join("")
}
export default reduce