IBM Cloud Schematics CLI
Run these commands to work with IBM Cloud Schematics workspaces, actions, provisioned resources and configure Schematics.
Schematics CLI commands are region specific. They operate only in the region/location that the IBM Cloud CLI is configured to work in. Ensure the CLI location
and the url
endpoint are pointing to the region where you
want to create or update your workspaces and actions. For more information about location and endpoint, see Where is my information stored?.
To run Schematics commands, use ibmcloud schematics
or ibmcloud sch
.
Prerequisites
- Set up your CLI.
- Install Schematics plug-in.
Be sure to keep your CLI up-to-date so that you can use the current released commands and their options. For more information about the current command-line version releases, see Command-line version history.
Actions commands
Review the commands to create, update, list, delete, and work with your Schematics actions.
ibmcloud schematics action create
Create an action to run an Ansible playbook on a single target host or a group of target hosts. You use Ansible playbooks to perform cloud operations or install software on cloud resources. To try out this capability or to get started, use one of the IBM-provided Ansible playbooks. You can create an action by using a payload file or the command's interactive mode.
Ensure the location
and the url
endpoint are pointing to the same region when you create or update the workspaces and actions. For more information about location and endpoint, see Where is my information stored?.
Syntax
ibmcloud schematics action create --name ACTION_NAME [--description DESCRIPTION] --location GEOGRAPHY --resource-group RESOURCE_GROUP [--template GIT_TEMPLATE_REPO] [--playbook-name PLAYBOOK_NAME] [--credential CREDENTIAL_FILE] [--credential-json CREDENTIAL_JSON_FILE] [--bastion BASTION_HOST_IP_ADDRESS] [--bastion-credential-json BASTION_CREDENTIAL_JSON_FILE] [--inventory INVENTORY_ID] [—-inventory-connection-type INVENTORY_CONNECTION_TYPE] [--input INPUT_VARIABLES_LIST] [--input-file INPUT_VARIABLES_FILE_PATH] [--env ENV_VARIABLES_LIST] [--env-file ENV_VARIABLES_FILE_PATH] [--github-token GITHUB_ACCESS_TOKEN] [--output OUTPUT] [--file FILE_NAME ] [--no-prompt]
Command options
Flag | Required / Optional | Description |
---|---|---|
--name or -n |
Required | A unique name for the action. |
--description or -d |
Optional | The short description for an action. |
--location or -l |
Required | The geography or location where you want to create the action, such as us-south , us-east , eu-de , or eu-gb . The geography or location determines where your action runs and where your
action data is stored. For more information, see Where is my information stored?. Make sure that you can store data in this location as you cannot change the location
after the action is created. |
--resource-group or -r |
Required | The name of the resource group where you want to create the action. |
--template or -tr |
Optional | The URL to the Git repository where your Ansible playbook is stored. |
--playbook-name or --pn |
Optional | The name of the Ansible playbook. |
--credentials or -C |
Optional | The file path to the private SSH key that you want to use to access your target host, such as ~/.ssh/id_rsa . The SSH key should contain at the end of the key details in case of command-line or API calls. |
--credential-json or --cj |
Optional | Provide path of JSON file that contains credential JSON payload to access the target host. |
--bastion or -b |
Optional | The IP address of the bastion host. |
--bastion-credential-json or --bj |
Optional | Provide path of JSON file that contains bastion credential JSON payload to access the bastion host. |
--inventory or -y |
Optional | The ID of the resource inventory that you want to use in your action. To list existing inventories, run ibmcloud schematics inventory list . |
--inventory-connection-type or --it |
Optional | Type of inventory connection. Supported values are ssh , or winrm . Currently, WinRM supports only Windows system with the public IPs and do not support Bastion host. |
--input or --in |
Optional | The input variables for your action. Input variables must be entered as key-value pairs, such as --input mykey=myvalue . To specify multiple input variables, use multiple --input flags in your command. You can
also store your input variables in a file and reference this file by using the --input-file command option. |
--input-file or --if |
Optional | The path to a file where you specified all your input variables. Input variables must be specified as key-value pairs in JSON format. |
--env or -e |
Optional | The environment variables for an action. Environment variables must be entered as key-value pairs, such as --env mykey=myvalue . To provide multiple environment variables, use multiple --env flags in your command. |
--env-file or -E |
Optional | The path to a file where you specified all environment variables for an action. Environment variables must be specified as key-value pairs in JSON format. |
--github-token or -g |
Optional | The personal access token in GitHub that you want to use to connect to a private GitHub repository. If you want to clone from the Git repository see the allowed and blocked file extensions for cloning. |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
--file or -f |
Optional | The path to the JSON payload file containing the definition of the action that you want to create. For more information, see Using a payload file. |
--no-prompt |
Optional | Set this flag to run the command without an interactive mode. |
Example
ibmcloud schematics action create --name start-vsi --location us-south --resource-group default --template https://github.com/Cloud-Schematics/ansible-is-instance-actions --playbook-name stop-vsi-playbook.yml --input instance_ip=172.4.5.0
Using a payload file
Create a JSON file that includes the details for the action that you want to create, such as the ID, name, and description. Then, use the --file
command option to create your action from your payload file.
You need to replace the <...>
placeholders with the actual values. For example, "<ACTION_NAME>"
as "testaction"
.
Syntax
{
"name": "<ACTION_NAME>",
"description": "<DESCRIPTION>",
"location": "<LOCATION>",
"resource_group": "<RESOURCE_GROUP>",
"bastion_connection_type": "ssh",
"inventory_connection_type": "winrm",
"source": {
"source_type" : "git",
"git" : {
"git_repo_url": "<YOUR_REPOSITORY>"
}
},
"command_parameter": "<PLAYBOOK_NAME>",
"bastion": {},
"bastion_credentials": {
"metadata": {}
},
"tags": [
"<ACTION_TAGS>"
],
"source_readme_url": "stringtype",
"source_type": "GitHub"
}
ibmcloud schematics action create --file <FILE_NAME>
Example
ibmcloud schematics action create --file sample.json
Using the interactive mode
Instead of entering the command options or using a payload file, you can use the command's interactive mode to create an action. By default, the action is created with minimal user input. To add more information to your action, you can update the action later.
- Initiate the interactive mode by running the command without command options.
ibmcloud schematics action create
- Enter a name for your action and press the return key.
- Enter the resource group where you want to create the action and press the return key.
- Enter the location where you want to create the action, such as
us-south
,us-east
,eu-de
, oreu-gb
. Then, press the return key. The location determines where your action runs and where your action data is stored. For more information, see Where is my information stored?. Make sure that you can store data in this location as you cannot change the location after the action is created. - Enter the URL to the GitHub repository where your Ansible playbook is stored. Then, press the return key.
- If applicable, enter the personal access token that you want to use to access your GitHub repository. Then, press the return key. If you want to clone from the Git repository see the allowed and blocked file extensions for cloning.
- Enter the name of the Ansible playbook that you want to run and press the return key.
- Review the details of the action that was created for you.
ibmcloud schematics action update
Update the information of an existing action the using the action_id
. Ensure the CLI location
and the url
endpoint are pointing to the region where you want to create or update your workspaces and actions.
For more information about location and endpoint, see Where is my information stored?.
Syntax
ibmcloud schematics action update --id ACTION_ID --name ACTION_NAME [--description DESCRIPTION] --location GEOGRAPHY --resource-group RESOURCE_GROUP [--template GIT_TEMPLATE_REPO] [--playbook-name PLAYBOOK_NAME] [--github-token GITHUB_ACCESS_TOKEN] [--credential CREDENTIAL_FILE] [--credential-json CREDENTIAL_JSON_FILE] [--bastion BASTION_HOST_IP_ADDRESS] [--bastion-credential-json BASTION_CREDENTIAL_JSON_FILE] [--inventory INVENTORY_ID] [--inventory-connection-type INVENTORY_CONNECTION_TYPE] [--input INPUT_VARIABLES_LIST] [--input-file INPUT_VARIABLES_FILE_PATH] [--env ENV_VARIABLES_LIST] [--env-file ENV_VARIABLES_FILE_PATH] [--file FILE_NAME] [--no-prompt] [--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The ID of an action that you want to update. |
--name or -n |
Optional | A new unique name for your action. |
--description or -d |
Optional | The short description for an action. |
--location or -l |
Required | Geographic locations supported by IBM Cloud Schematics service such as us-south , us-east , eu-de , eu-gb . |
--resource-group or -r |
Required | Resource-group name for an action. |
--template or -tr |
Optional | The URL to the Git repository where your Ansible playbook is stored. |
--playbook-name or --pn |
Optional | Name of the playbook. |
--github-token or -g |
Optional | The personal access token in GitHub that you want to use to connect to a private GitHub repository. If you want to clone from the Git repository see the allowed and blocked file extensions for cloning. |
--credentials or -C |
Optional | The file path to the private SSH key that you want to use access your target host, such as ~/.ssh/id_rsa . The SSH key should contain at the end of the key details in case of command-line or API calls. |
--credential-json or --cj |
Optional | Provide path of JSON file that contains credential JSON payload to access the target host. |
--bastion or -b |
Optional | The IP address of the bastion host. |
--bastion-credential-json or --bj |
Optional | Provide path of JSON file that contains bastion credential JSON payload to access the bastion host. |
--inventory or -y |
Optional | The ID of the resource inventory that you want to use in your action. To list existing inventories, run ibmcloud schematics inventory list . |
--inventory-connection-type or --it |
Optional | Type of inventory connection. Supported values are ssh , or winrm . Currently, WinRM supports only Windows system with the public IPs and do not support Bastion host. |
--input or --in |
Optional | The input variables for your action. Input variables must be entered as key-value pairs, such as --input mykey=myvalue . To specify multiple input variables, use multiple --input flags in your command. You can
also store your input variables in a file and reference this file in the --input-file command option. |
--input-file or --if |
Optional | The path to a file where you specified all your input variables. Input variables must be specified as key-value pairs in JSON format. |
--env or -e |
Optional | The environment variables for an action. Environment variables must be entered as key-value pairs, such as --env mykey=myvalue . To provide multiple environment variables, use multiple --env flags in your command. |
--env-file or -E |
Optional | The path to a file where you specified all environment variables for an action. Environment variables must be specified as key-value pairs in JSON format. |
--file or -f |
Optional | Path to the JSON payload file containing the definition of the action to update. For more information, see Using the payload file. Note that parameters, such as the location or resource group cannot be updated after the action is created. |
--no-prompt |
Optional | Set this flag to run the command without user prompts. |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
Example
ibmcloud schematics action update --id us-south.workspace.101010101 --description "This is my description"
ibmcloud schematics action get
Retrieve the detailed information of an existing Schematics Action using an action_id
.
Syntax
ibmcloud schematics action get --id ACTION_ID [--profile PROFILE] [--output OUTPUT] [--no-prompt]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The ID of an action that you want to retrieve. |
--profile or -p |
Optional | The depth of information that you want to retrieve. Supported values are detailed and summary . The default value is summary . |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
--no-prompt |
Optional | Set this flag to run the command without the interactive mode. |
Example
ibmcloud schematics action get --id us-south.workspace.101010101 -p summary
ibmcloud schematics action list
Retrieve a list of all actions defined in the current IBM Cloud region for your account.
Syntax
ibmcloud schematics action list [--limit LIMIT] [--offset OFFSET] [--profile PROFILE] [--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--limit or -l |
Optional | The maximum number of actions that you want to list. The number must be a positive integer between 1 and 200. The default value is -1 . |
--offset or -m |
Optional | The position of the action in the list of actions from where you want to start listing your actions. For example, if you have three actions in your account and region, the command returns these actions as a list with three elements. To retrieve all actions, you must enter position number 0. To retrieve actions number 2 and 3 and leave out action number 1 in this list, you must enter position number 1. Position number 1 represents the second position in the list of actions. Negative numbers are not supported and are ignored. |
--profile or -p |
Optional | The depth of information that is returned. Supported values are ids , and summary . The default value is summary . |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
Example
ibmcloud schematics action list --profile ids
ibmcloud schematics action delete
Delete a Schematics action.
Syntax
ibmcloud schematics action delete --id ACTION_ID [--force][--no-prompt]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The ID of an action that you want to delete. |
--force or -f |
Optional | Force the deletion without user confirmation. |
--no-prompt |
Optional | Set this flag to run the command without user prompts. |
Example
ibmcloud schematics action delete --id us-south.workspace.101010101
ibmcloud schematics action upload
You can upload a tape archive file (.tar
) from your local file system to an IBM Cloud Schematics action. Enter the full file path on your local machine where your .tar
file is stored. Create the .tar
file of your template repo by using the TAR
command given tar -cvf mytestactionupload.tar $TEMPLATE_REPO_FOLDER
command.
Syntax
ibmcloud schematics action upload --id ACTION_ID --file FILE_NAME [--no-prompt] [--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | ID of an action that you want to upload. |
--file or -f |
Required | Path of the TAR file to upload for an action. |
--no-prompt |
Optional | Set this flag to stop interactive command-line session. |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
Example
ibmcloud schematics action upload --id us.ACTION.testphase1.2eddf83a --file <FILE_PATH>/mytestactionupload.tar
Actions Job commands
Review the commands to create, update, list, and delete Schematics jobs when working with Schematics actions.
ibmcloud schematics job run
Create a job in IBM Cloud Schematics to execute the Ansible playbook specified by your Schematics action. You can create a job by using a payload file or the command's interactive mode.
Syntax
ibmcloud schematics job run --command-object COMMAND_OBJECT_TYPE --command-object-id COMMAND_OBJECT_ID --command-name COMMAND_NAME [--playbook-name PLAYBOOK_NAME] [--command-options COMMAND_OPTIONS] [--input INPUT_VARIABLES_LIST] [--input-file INPUT_VARIABLES_FILE_PATH] [--env ENV_VARIABLES_LIST] [--env-file ENV_VARIABLES_FILE_PATH] [--output OUTPUT] [--file FILE_NAME ] [--no-prompt]
Command options
Flag | Required / Optional | Description |
---|---|---|
--command-object or -c |
Required | The name of the Schematics automation resource. Currently, only action is supported. |
--command-object-id or -cid |
Required | The ID of the Schematics actions where you want to run the job. |
--command-name, or -n |
Required | The command that you want to run for your action. Supported values are ansible_playbook_check , and ansible_playbook_run . |
--playbook-name or -pn |
Optional | The name of the Ansible playbook that you want to run. |
--command-options or -co |
Optional | The command-line options for the command. |
--input or --in |
Optional | The input variables for an action. This flag can be set multiple times, and must be in a format --inputs test=testvalue . |
--input-file or --if |
Optional | Input variables for an action. Provide the JSON file path that contains input variables. |
--env or -e |
Optional | The environment variables for an action. This flag can be set multiple times, and must be in a format --env-variables test=testvalue . |
--env-file or -E |
Optional | The environment variables for an action. Provide JSON file path that contains environment variables. |
--result-format or -f |
Optional | The result response output in JSON format. |
--file or -f |
Optional | Path to the JSON file containing the definition of the new job. |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
If the action contains the playbook name, you need to add the playbook name, so that the action playbook name takes the precedence. If you need to override the playbook name through the job, then, you have to create an action with the new playbook name.
Using the payload file
You can provide a payload file to specify certain parameters for the job run
command. Then, you pass the file name to the command by using the --file
command option.
You need to replace the <...>
placeholders with the actual values. For example, "<COMMAND_OBJECT>"
as "action".
Syntax
{
"command_object": "<COMMAND_OBJECT>",
"command_object_id": "<COMMAND_OBJECT_ID>",
"command_name": "<COMMAND_NAME>",
"command_parameter": "<PLAYBOOK_NAME>"
}
Example
{
"command_object": "action",
"command_object_id": "us-east.ACTION.Example-11110000011",
"command_name": "ansible_playbook_check",
"command_parameter": "site.yml"
}
ibmcloud schematics job run --file sample.json
Using the interactive mode
Instead of entering your job details by using command options or a payload file, you can use the interactive mode for the command. This mode prompts you to enter the required values to create a job in Schematics.
- Enter the command to create the job without any command options.
ibmcloud schematics job run
- When prompted to
Enter command-object>
, enteraction
and press the return key. - When prompted to
Enter command-object-id>
, enter the action ID details and press the return key. - When prompted to
Enter command-name>
, enteransible_playbook_run
oransible_playbook_check
, and press the return key. - Review the CLI output for the job that was created for you.
ibmcloud schematics job update
Create a job by copying the settings of an existing job, and run the job in IBM Cloud Schematics.
Syntax
ibmcloud schematics job update --id JOB_ID [--output OUTPUT] [--no-prompt]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id |
Required | The ID of an existing job that you want to copy and run again. |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
--no-prompt |
Optional | Set this flag to create the job without an interactive command-line session. |
Example
ibmcloud schematics job update --id us-east.JOB.yourjob_ID_1231
ibmcloud schematics job get
Retrieve the details of an actions job using a job ID.
Syntax
ibmcloud schematics job get --id JOB_ID [--profile PROFILE] [--output OUTPUT] [--no-prompt]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The ID of the job ID that you want to retrieve. |
--profile or -p |
Optional | The depth of information that you want to retrieve. Supported values are detailed and summary . The default value is summary . |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
--no-prompt |
Optional | Set this flag to retrieve job details without an interactive command-line session. |
Example
ibmcloud schematics job get --id us-east.JOB.yourjob_ID_1231 --profile detailed
ibmcloud schematics job list
Retrieve a list of all Schematics jobs that ran for a Schematics Action. The command displays a list of jobs with the status as in_progress
, success
, or failed
.
Syntax
ibmcloud schematics job list --resource-type RESOURCE_TYPE --id RESOURCE_ID [--limit LIMIT] [--offset OFFSET] [--profile PROFILE] [--output OUTPUT] [--all] [--no-prompt]
Command options
Flag | Required / Optional | Description |
---|---|---|
--resource-type or -rt |
Required | The name of the Schematics resource. Only action is supported. |
--id or -i |
Required | The ID of the Schematics actions for which you want to list jobs. |
--limit or -l |
Optional | The maximum number of workspaces that you want to list. The number must be a positive integer between 1 and 200. The default value is -1 . |
--offset or -m |
Optional | The position of the job in the list of jobs from where you want to start listing your jobs. For example, if you have three jobs in your account, the command returns these jobs as a list with three elements. To retrieve all jobs, you must enter position number 0. To retrieve job number 2 and 3 and leave out job number 1 in this list, you must enter position number 1. Position number 1 represents the second position in the list of jobs. Negative numbers are not supported and are ignored. |
--profile or -p |
Optional | The depth of information that is returned. Supported values are ids or summary . The default value is summary . |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
--all or -A |
Optional | Lists all the jobs including the Schematics internal jobs. |
--no-prompt |
Optional | Set this flag to create the job without an interactive command-line session. |
Example
ibmcloud schematics job list --resource-type action --id us-south.ACTION.interactive.aaa1a111 --profile ids --output json
ibmcloud schematics job logs
Retrieve the logs for a Schematics action job. For more information about viewing job logs, see Reviewing the Schematics job details.
Syntax
ibmcloud schematics job logs --id JOB_ID [log-prefix] [log-header] [--no-prompt]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The ID of the job for which you want to retrieve detailed logs. |
--log-prefix or --lp |
Optional | Adds the prefix of command executed in the job logs. |
--log-header or --lh |
Optional | Used to convert command headers in the job logs in the Schematics format. |
--no-prompt |
Optional | Set this flag to run the command without an interactive command-line session. |
Example
ibmcloud schematics job logs --id us-east.JOB.yourjob_ID_1231
ibmcloud schematics job delete
Delete a job for a Schematics action.
You cannot delete or stop a running job. To remove a job, you must wait for the job to complete.
Syntax
ibmcloud schematics job delete --id JOB_ID [--force] [--no-prompt]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The ID of the job that you want to delete. |
--force or -f |
Optional | To force the deletion without user confirmation. |
--no-prompt |
Optional | Set this flag to run the command without an interactive command-line session. |
Example
ibmcloud schematics job delete --id us-east.JOB.yourjob_ID_1231
Agents commands
ibmcloud schematics agent create
Create an agent registration in the currently selected Schematics region. Agents help you run your Terraform or Ansible jobs on your infrastructure. For more information about the steps to use the create command, see deploying agents.
Syntax
ibmcloud schematics agent create --name AGENT_NAME --location LOCATION --agent-location AGENT_LOCATION --cluster-id CLUSTER_ID --cluster-resource-group CLUSTER_RESOURCE_GROUP --cos-instance-name COS_INSTANCE_NAME --cos-bucket COS_BUCKET --cos-location COS_LOCATION --resource-group RESOURCE_GROUP [--version VERSION] [--infra-type INFRA_TYPE] [--description DESCRIPTION] [--tags TAGS] [--metadata AGENT_METADATA] [--validate] [--deploy] [--file FILE] [--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--name or -n |
Required | The unique name of an agent. Must be descriptive of the agent role, location and usage. |
--location or -l |
Required | The Schematics location where the agent are defined, us-south , us-east , eu-de , eu-gb . Jobs are picked up from this location for execution. |
--agent-location or --al |
Required | A descriptive user defined label to identify where the agent is deployed in the user environment. This could be a Cloud region or a user data center. For example, London MZR . |
--cluster-id or -c |
Required | The ID of the Kubernetes cluster for deploying an Agent. |
--cluster-resource-group or --cg |
Required | The name of the clusters' resource group. |
--cos-instance-name or --on |
Required | The name of the COS instance. |
--cos-bucket or -b |
Required | The ID or the name of the COS bucket. |
--cos-location or --ol |
Required | The COS bucket location. Supported format are eu-gb , us-south , so on. |
--resource-group or -g |
Required | Resource group name or ID the agent are associated with. |
--version or -v |
Required | A user defined label specifying the version of the agent. Example v1.0.0 |
--infra-type or -i |
Required | Specify the type of the target agent infrastructure. Supported values are ibm-kubernetes , ibm-openshift , or ibm-satellite . |
--description or -d |
Optional | A description that identifies the agent usage, and the network zones and resources the agent is able to access. |
--tags or -t |
Optional | Agent tags. You can repeat the flag multiple times. Tags allow for faster and easier search for agent related resources. |
--metadata or --md |
Optional | Metadata of the agent. You can use the flag multiple times. For example, git:private-git.github.com or git:gitlab.com . If not set, defaults to git:github.com . |
--validate |
Optional | Run validate, after creating the agent. |
--deploy |
Optional | Run deploy without validating, after creating the agent. |
--file or f |
Optional | Path to a JSON file containing the definition of an agent. |
--output or -o |
Optional | Specify output format, only JSON is supported. |
Example
ibmcloud schematics agent create --name agenttestcli10jan --location us-east --agent-location us-east --version 1.0.0-prega --infra-type ibm_kubernetes --cluster-id clbjrdml00cgremot1k0 --cluster-resource-group Default --cos-instance-name agent-test-cos-standard --cos-bucket agent-test-bucket --cos-location us-east --resource-group Default --description "This agent is created to test for the prod release and COS"
ibmcloud schematics agent delete
Uninstall an agent. For more information about the steps to use the delete command, see deleting an agent.
Syntax
ibmcloud schematics agent delete --id AGENT_ID [--force]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id |
Required | The ID of an agent. |
--force or -f |
Optional | The force action without confirmation. Set the --force parameter to true to delete all the agent flows to keep destroy parallel to workspace destroy flow. By default, this parameter is set to false. |
Example
ibmcloud schematics agent delete --id <AGENT_ID>
ibmcloud schematics agent deploy
Deploy or upgrade an agent to force deploy. For more information about the steps to use deploy command, see deploying agent.
Syntax
ibmcloud schematics agent deploy --id AGENT_ID [--force-redploy] [--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id |
Required | The ID of an agent. |
--force-redeploy or -fd |
Optional | Force redeploys an Agent. |
--output or -o |
Optional | Specify output format, only JSON is supported. |
Example
ibmcloud schematics agent deploy --id <AGENT_ID>
ibmcloud schematics agent destroy
Destroy an agent destroys the IBM Cloud resources associated with the Schematics agent deployment.
Syntax
ibmcloud schematics agent destroy --id AGENT_ID [--force]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id |
Required | The ID of an agent. |
--force or -f |
Optional | The force action without confirmation. |
Example
ibmcloud schematics agent destroy --id <AGENT_ID>
ibmcloud schematics agent get
Retrieves the details of an agent. For more information about the steps to use get command, see displaying an agent.
Syntax
ibmcloud schematics agent get --id AGENT_ID [--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id |
Required | The ID of an agent. |
--output or -o |
Optional | Specify output format, only JSON is supported. |
Example
ibmcloud schematics agent get --id <AGENT_ID>
ibmcloud schematics agent health
Performs the post deployment validation of an agent. For more information about the steps to use the agent health command, see Monitoring agent health.
Syntax
ibmcloud schematics agent health --id AGENT_ID [--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id |
Required | The ID of an agent. |
--output or -o |
Optional | Specify output format, only JSON is supported. |
Example
ibmcloud schematics agent health --id <AGENT_ID>
ibmcloud schematics agent list
Lists the agents defined in the current Schematics region. For more information about the steps to use list command, see displaying an agent.
Syntax
ibmcloud schematics agent list [--location LOCATION] [--limit LIMIT] [--offset OFFSET] [--output OUTPUT_FORMAT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--location or -l |
Optional | Geographic locations supported by IBM Cloud Schematics service such as us-south , us-east , eu-de , eu-gb . |
--limit or -lm |
Optional | Maximum number of agents to list. Ignored if a negative number is set. Maximum limit is 200, (default is -1). |
--offset or -m |
Optional | Offset in list. Ignored if a negative number is set (default: -1). |
--output or -o |
Optional | Specify output format, only JSON is supported. |
Example
ibmcloud schematics agent list --location us-south
ibmcloud schematics agent update
Update an agent configuration. Updating an agent does not re-validate or re-deploy your agent. For more information about the steps to use the agent update command, see deploying agent.
Syntax
ibmcloud schematics agent update --id AGENT_ID [--description DESCRIPTION] [--tags TAGS] [--version VERSION] [--metadata AGENT_METADATA] [--file FILE] [--output OUTPUT] [--no-prompt]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id |
Required | The ID of an agent. |
--tags or -t |
Optional | Agent tags. This flag can be used multiple times, and search the agent related resources faster. |
--description or -d |
Optional | Short description of an agent. |
--version value or -v |
Optional | Specify the version of an agent. Defaults to available latest version. |
--metadata |
Optional | Metadata of the agent. You can use the flag multiple times. For example, git:private-git.github.com or git:gitlab.com . If not set, defaults to git:github.com . |
--file or -f |
Optional | Path to the JSON file that contains the definition of the agent. |
--output or -o |
Optional | Specify output format, only JSON is supported. |
--no-prompt |
Optional | Set this flag to update an inventory without an interactive command-line session. |
Example
ibmcloud schematics agent update --id <AGENT_ID>
ibmcloud schematics agent validate
Checks the prerequisites scan that analyses an agent and cluster configuration before deploying. For more information about the steps to use validate command, see deploying agent.
Syntax
ibmcloud schematics agent validate --id AGENT_ID [--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id |
Required | The ID of the agent. |
--output or -o |
Optional | Specify output format, only JSON is supported. |
Example
ibmcloud schematics agent validate --id AGENT_ID
Agents policy commands
Schematics (assignment) policies tell Schematics which agent it should use to execute workspace and action jobs in a specific network zone. Each agent have at least one policy associated with it to identify the jobs to run in the agents' location. See assignment policies.
ibmcloud schematics policy create
Create a policy by using Schematics to select one or more Schematics objects, such as a workspace or action, to be executed on the target agent.
Syntax
ibmcloud schematics policy create --name POLICY_NAME --kind POLICY_KIND --location LOCATION --resource-group RESOURCE_GROUP --target-file TARGET_FILE [--description DESCRIPTION] [--tags TAGS] [--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--name or -n |
Required | The unique name of the policy. |
--kind or -K |
Required | Policy kind for managing and deriving policy decision. Supported is agent_assignment_policy . |
--location or -l |
Optional | Geographic location of Schematics service where the agent is defined. For example, us-south , us-east , eu-de , eu-gb . Jobs are picked up from this location for processing. |
--resource-group or -r |
Required | Resource group name or ID for the policy. |
--target-file or tf |
Optional | Path to the JSON file containing the definition of the policy. |
--description or -d |
Optional | The description of the Schematics policy. |
--tags or -t |
Optional | Tags can be used multiple times to search for and locate agent policies faster. |
--output or -o |
Optional | Specify output format, only JSON is supported. |
Using the payload file
You can provide a payload file to specify certain parameters for the policy create
command. Then, you pass the file name to the command by using the --target-file
command option.
You need to replace the <...>
placeholders with the actual values. For example, "<SELECTOR_KIND>"
as "ids"
.
Syntax
{
"target": {
"selector_kind": "<SELECTOR_KIND>",
"selector_ids": [
"<SELECTOR_ID>"
]
},
"parameter": {
"agent_assignment_policy_parameter": {
"selector_kind": "<SELECTOR_KIND>",
"selector_scope": [{
"kind": "<WORKSPACE>",
"tags": [
"dev:<ENVIRONMENT>",
"demo"
],
"resource_groups": [
"<RESOURCE_GROUP>"
],
"locations": [
"<LOCATION>"
]
}]
}
}
}
Example
{
"target": {
"selector_kind": "ids",
"selector_ids": [
"demo-agent-one"
]
},
"parameter": {
"agent_assignment_policy_parameter": {
"selector_kind": "scoped",
"selector_scope": [{
"kind": "workspace",
"tags": [
"dev:test",
"demo"
],
"resource_groups": [
"Default"
],
"locations": [
"us-south"
]
}]
}
}
}
Example
ibmcloud schematics policy create --name policy-101 --kind agent_assignment_policy --location us-south --resource-group Default --target-file ./<PATH>/target.json
ibmcloud schematics policy delete
Delete a Schematics policy.
Syntax
ibmcloud schematics policy delete --id POLICY_ID [--force]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The ID of the policy. |
--force or -f |
Optional | The force action without confirmation. |
Example
ibmcloud schematics policy delete --id policy-101.soP.282e
ibmcloud schematics policy get
Retrieve the details of an existing Schematics policy using policy ID.
Syntax
ibmcloud schematics policy get --id POLICY_ID [--profile PROFILE] [--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | ID of the policy. |
--profile or -p |
Optional | Level of details to return. Valid values are summary , detailed , or ids . Defaults to summary . |
--output or -o |
Optional | Specify output format, only JSON is supported. |
Example
ibmcloud schematics policy get --id policy-101.soP.282e
ibmcloud schematics policy list
Retrieve a list of all policies in the IBM Cloud region for your account.
Syntax
ibmcloud schematics policy list [--profile PROFILE] [--limit LIMIT] [--offset OFFSET] [--output OUTPUT]
Flag | Required / Optional | Description |
---|---|---|
--profile or -r |
Optional | The level of details to return. Valid values are summary , detailed and ids . Defaults to summary . |
--limit or -l |
Optional | Maximum number of policies to list. Ignored if a negative number is set. The number must be a positive integer between 1 and 200. The default value is -1 . |
--offset or -m |
Optional | Offset in list. Ignored if a negative number is set. The default value is -1 . |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
Example
ibmcloud schematics policy list --profile ids092030
ibmcloud schematics policy update
Update an existing policy using policy ID.
Syntax
ibmcloud schematics policy update --id POLICY_ID [--kind POLICY_KIND] [--description DESCRIPTION] [--resource-group RESOURCE_GROUP] [--tags TAGS] [--file FILE] [--output OUTPUT]
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | ID of the policy. |
--kind or -k |
Optional | Policy kind for managing and deriving policy decision. Supported is agent_assignment_policy . |
--description or -d |
Optional | The description of Schematics customization policy. |
--resource-group or -r |
Optional | Resource group name or ID for the policy. |
--tags or -t |
Optional | Policy tags. This flag can be used multiple times to search for and locate agent policies faster. |
--file or -f |
Optional | Path to the JSON file containing the definition of the policy. |
--output or -o |
Optional | Specify output format, only JSON is supported. |
Example
ibmcloud schematics policy update --id <AGENT_ID> --description PolicyDescriptionUpdated
Configure BYOK or KYOK commands
You can use your encryption keys from the IBM Cloud key management services (KMS), IBM Key Protect(BYOK), and Hyper Protect Crypto Services (KYOK) to encrypt and secure your data stored in Schematics. For more information about how to protect sensitive data in Schematics, see protecting your sensitive data in Schematics.
Prerequisites
The key management system lists the instance that are created from your specific location and region. Following prerequisites are followed to perform the KMS activity.
- You should have your
KYOK
, orBYOK
. To create the IBM Key Protect keys, see create BYOK. To create an IBM Cloud Hyper Protect Crypto Services keys, see create KYOK. - You need to add root key to Schematics services.
- You need to configure service to service authorization to integrate
BYOK
, andKYOK
in Schematics service.
KMS setting is a one time settings. You need to open a support ticket to update KMS settings.
ibmcloud schematics kms instance ls
Lists all the KMS instances of your IBM Cloud account to find your Key Protector Hyper Protect Crypto Services by using your location where keys are created and encrypted scheme such as KYOK
, or BYOK
.
Syntax
ibmcloud schematics kms instances ls --location LOCATION_NAME --scheme ENCRYPTION_SCHEME [--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--location or -l |
Required | Set the Schematics location name. Supported values are US , or EU . |
--scheme or -s |
Required | Specify the encryption scheme. Supported values are KYOK , or BYOK . |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
Example
ibmcloud schematics kms instances ls -l US -s byok
ibmcloud schematics kms enable
Enable KMS to encrypt your data in the specific location. For more information about enabling customer-managed keys for Schematics, see enabling keys.
Update the KMS settings for your location, by using your private endpoint, CRN
, primary CRK
, and secondary CRK
. Note that you can update the KMS settings only once. For example, if you use an API endpoint
for a geography, such as North America
, only that are created in us-south
or us-east
are retrieved.
Syntax
ibmcloud schematics kms enable --location LOCATION_NAME --scheme ENCRYPTION_SCHEME --group RESOURCE_GROUP --primary_name PRIMARY_KMS_NAME --primary_crn PRIMARY_KEY_CRN --primary_endpoint PRIMARY_KMSPRIVATEENDPOINT [--secondary_name SECONDARY_KMS_NAME][--secondary_crn SECONDARY_KEY_CRN] [--secondary_endpoint SECONDARY_KMSPRIVATEENDPOINT] [--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--location or -l |
Required | Set the Schematics location name. Supported values are US , or EU . |
--scheme or -s |
Required | Specify the encryption scheme. Supported values are KYOK , or BYOK . |
--group or -g |
Required | Specify the resource group name. Default value is Default . |
--primary_name or --pn |
Required | Specify the primary KMS name. |
--primary_crn or --pc |
Required | Specify the primary key CRN name. |
--primary_endpoint or --pe |
Required | Specify the primary KMS private endpoint. |
--secondary_name or --sn |
Optional | Specify the secondary KMS name. |
--secondary_crn or --sc |
Optional | Specify the secondary key CRN. |
--secondary_endpoint or --se |
Optional | Specify the secondary KMS private endpoint. |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
Example
ibmcloud schematics kms enable -l US -s byok -g Default -pn Key-Protect-south -pc crn:v1:bluemix:public:kms:us-south:lalalalal -pe https://private.us-south.kms.cloud.ibm.com
ibmcloud schematics kms info
Retrieve the KMS on the API endpoint that you have your KYOK
, or BYOK
. For example, if you use an API endpoint for a geography, such as North America
, only that are created in us-south
or
us-east
are retrieved. Note that you need to enable kms instances
in your account to run info
command-line.
Syntax
ibmcloud schematics kms info --location LOCATION_NAME [--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--location or -l |
Required | Set the Schematics location name. Supported values are US , or EU . |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
Example
ibmcloud schematics kms info -l US
General commands
Use these general commands to find help and version information for the IBM Cloud Schematics command-line plug-in.
ibmcloud schematics help
View the supported IBM Cloud Schematics command-line commands.
Syntax
ibmcloud schematics help [command]
Command options
Flag | Required / Optional | Description |
---|---|---|
--help or -h |
Required | Lists the supported commands. |
command |
Optional | Specify the name of the command to fetch the command details. |
Example
ibmcloud schematics help
ibmcloud schematics version
List the versions of all supported open source projects in Schematics, such as the IBM Cloud Provider Plug-in for Terraform, Ansible, Helm, and Kubernetes that are used to run Schematics actions on IBM Cloud resources.
Syntax
ibmcloud schematics version [--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--output or -o |
Optional | Returns the CLI output in JSON format. Currently only JSON file format is supported. |
Example
ibmcloud schematics version --output json > "<filename.json>"
Inventory commands
Review the commands to create, update, list, delete and work with your IBM Cloud Schematics inventories used with Schematics actions.
ibmcloud schematics inventory create
Create a resource inventory in IBM Cloud Schematics that you can use with a Schematics action. A resource inventory includes all the target hosts where you want to run an Ansible playbook. You can create an inventory by using a payload file or the interactive mode.
Syntax
ibmcloud schematics inventory create --name INVENTORY_NAME [--description DESCRIPTION] [--location GEOGRAPHY] [--resource-group RESOURCE_GROUP] [--inventories-ini INVENTORY_INI_FILE] [--resource-query RESOURCE_QUERY_ID] [--file FILE_NAME ] [--output OUTPUT] [--no-prompt]
You need to pass either --inventories-ini
file path or --resource-query
ID for the inventory to use the target host details.
Command options
Flag | Required / Optional | Description |
---|---|---|
--name or -n |
Required | The unique name of a resource inventory. |
--description or -d |
Optional | The short description of an inventory. |
--location or -l |
Optional | The location where you want to store your resource inventory, such as us-south , us-east , eu-de , or eu-gb . For more information about data storage in Schematics, see Where is my data stored?. |
resource-group or -r |
Optional | The name of the resource group where you want to create the action. |
--inventories-ini or -y |
Optional | The file path to the resource inventory file where you specified all target hosts. The resource inventory file must be provided in INI format. For more information about how to create a static resource inventory file, see
Creating static inventory files. |
--resource-query |
Optional | Enter the ID of a resource query that you created. A resource query helps to dynamically build your resource inventory by using the IBM Cloud resources that you created with a Schematics workspace. To create a resource query, see the
ibmcloud schematics resource-query create command. To enter multiple resource query IDs, use --resource-query id1 --resource-query id2 . |
--file or -f |
Optional | The path to the JSON file where you specified the resource inventory that you want to create. |
--output or -o |
Optional | Specify the output format. Only JSON format is supported. |
--no-prompt |
Optional | Set this flag to create an inventory without an interactive command-line session. |
Using the payload file
You can provide a payload file to specify certain parameters for the inventory create
command. Then, you pass the file name to the command by using the --file
command option.
You need to replace the <...>
placeholders with the actual values. For example, "<INVENTORY_NAME>"
as "myinventory"
.
Syntax
{
"name": "<INVENTORY_NAME>",
"description": "<DESCRIPTION",
"location": "<GEOGRAPHY>",
"resource_group": "<RESOURCE_GROUP>",
"resource_queries": [
"<RESOURCE_QUERY_ID>"
]
}
Example
{
"name": "myinventory",
"description": "This is the resource inventory for production",
"location": "us-east",
"resource_group": "default",
"resource_queries": [
"default.RESOURCEQUERY.string.df3d8a47"
]
}
ibmcloud schematics inventory create --file inventory.json
Using the interactive mode
Instead of entering your inventory details by using the command options or a payload file, you can also use the interactive mode for the command. This mode prompts you to enter the required values to create an inventory in Schematics.
- Enter the command to create the inventory without any command options.
ibmcloud schematics inventory create
- Enter a name for your inventory and press the return key.
- Enter the resource group where you want to create the inventory and press the return key.
- Enter the location where you want to create the inventory, such as
us-south
, us-east, eu-de, or eu-gb. Then, press the return key. - Review the details of the inventory that was created.
ibmcloud schematics inventory delete
Delete the resource inventory definition using the inventory ID.
Syntax
ibmcloud schematics inventory delete --id ACTION_ID [--force][--no-prompt]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The ID of an inventory that you want to delete. |
--force or -f |
Optional | Force the deletion without user confirmation. |
--no-prompt |
Optional | Set this flag to run the command without user prompts. |
Example
ibmcloud schematics inventory delete --id us-east.INVENTORY.inventoryid12342
ibmcloud schematics inventory get
Retrieve detailed information of an existing IBM Cloud Schematics inventory using the inventory ID.
Syntax
ibmcloud schematics inventory get --id ID [--profile PROFILE] [--output OUTPUT] [--no-prompt]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The ID of the resource inventory for which you want to list detailed information. |
--profile or -p |
Optional | The depth of information that you want to retrieve. Supported values are detailed and summary . The default value is summary . |
--output or -o |
Optional | Specify the output format. Only JSON format is supported. |
--no-prompt |
Optional | Set this flag to retrieve details of an inventory without an interactive command-line session. |
Example
ibmcloud schematics inventory get --id us-east.INVENTORY.inventoryid12342 --output json
ibmcloud schematics inventory list
Retrieve a list of all Schematics inventories in the current region for your account.
Syntax
ibmcloud schematics inventory list [--limit LIMIT] [--offset OFFSET] [--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--limit or -l |
Optional | The maximum number of inventories that you want to list. The number must be a positive integer between 1 and 200. The default value is -1 . |
--offset or -m |
Optional | The position of the inventory in the list of inventories. For example, if you have three inventories in your account, the command returns these inventories as a list with three elements. To see a specific inventory in this list, you
must enter the position number that the inventory has in the list. To list the first inventory in the list, enter 0 . To list the second inventory, enter 1 and so forth. Negative numbers are not supported and
are ignored. The default value is -1 . |
--output or -o |
Optional | Specify the output format. Only JSON format is supported. |
Example
ibmcloud schematics inventory list --output json
ibmcloud schematics inventory update
Update an existing resource inventory.
Syntax
ibmcloud schematics inventory update --id ID --name INVENTORY_NAME [--description DESCRIPTION] [--location GEOGRAPHY] [--resource-group RESOURCE_GROUP] [--inventories-ini INVENTORY_INI_FILE] [--resource-query RESOURCE_QUERY_ID] [--file FILE_NAME ] [--output OUTPUT] [--no-prompt]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | Enter the ID of a resource inventory that you want to update. |
--name or -n |
Required | The unique name of an inventory. |
--description or -d |
Optional | The short description of an inventory. |
--location or -l |
Optional | The geographic locations supported by IBM Cloud Schematics service, such as us-south , us-east , eu-de , or eu-gb . |
resource-group or -r |
Optional | The resource group name for an action. |
--inventories-ini or -y |
Optional | File path of INI format file that contains the host details. |
--resource-query |
Optional | Pass resource query ID. To pass multiple IDs use --resource-query id1 --resource-query id2 . |
--file or -f |
Optional | Path to the JSON file containing the definition of an inventory. |
--output or -o |
Optional | Specify the output format. Only JSON format is supported. |
--no-prompt |
Optional | Set this flag to update an inventory without an interactive command-line session. |
Example
ibmcloud schematics inventory update --id us-east.INVENTORY.inventory12312 --name inventoryname600 --description "Short description" --location us-east --resource-group Default --resource-query default.RESOURCEQUERY.string.12121 --output OUTPUT
Inventory resource query commands
Dynamically build actions resource inventories using resource queries. Resource queries enable you to gather target host information from Schematics workspaces. For more information about resource queries and conditions, see Creating resource inventories for Schematics actions.
ibmcloud schematics resource query create
Create a resource query in IBM Cloud Schematics that you can use to build your resource inventory. You can create a resource query by using a payload file or the command's interactive mode. You can create resource conditions by using resource queries.
Syntax
ibmcloud schematics resource-query create --name RESOURCE_QUERY_NAME [--type RESOURCE_QUERY_TYPE] [--query-file QUERY_FILE_PATH] [--file FILE_NAME ] [--output OUTPUT] [--no-prompt]
Command options
Flag | Required / Optional | Description |
---|---|---|
--name or -n |
Required | The unique name for a resource query. |
--type or -t |
Optional | The type of resource that you want to retrieve. Supported values are vsi . |
--query-file or -f |
Optional | The path to the JSON file where you specified the details of your resource query. To find a list of supported queries, see Supported resource queries. |
--file or -f |
Optional | The path to the JSON file that specifies the details of the resource query that you want to create. |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
--no-prompt |
Optional | Set this flag to create the resource query without an interactive command-line session. |
Using the payload file
You can provide a payload file to specify certain parameters for the resource_query create
command. Then, you pass the file name to the command by using the --file
command option. For a list of supported resource
queries, see Supported resource queries.
You need to replace the <...>
placeholders with the actual values. For example, "<WORKSPACE_ID"
as us-east.workspace.ID1231
.
Syntax
[{
"query_type": "workspaces",
"query_condition": [
{
"name": "workspace-id",
"value": "<WORKSPACE_ID>",
"description": "string"
},
{
"name": "resource-name",
"value": "<RESOURCE_NAME>",
"description": "string"
}
]
}]
Example
[{
"query_type": "workspaces",
"query_condition": [
{
"name": "workspace-id",
"value": "us-east.workspace.ID1231",
"description": "string"
},
{
"name": "resource-name",
"value": "tf00vpc-pubpriv-frontend-vsi",
"description": "string"
}
]
}]
ibmcloud schematics resource-query create --name myquery --type vsi --query-file queries.json
Using the interactive mode
Instead of entering your resource query details by using the command options or a payload file, you can use the interactive mode for the command. This mode prompts you to enter the required values to create a resource query in Schematics. You can create resource conditions by using resource queries.
- Enter the command to create the resource query without any command options.
ibmcloud schematics resource-query create
- Enter a name for your resource query and press the return key.
- Enter the path to your payload file. For a sample payload file, see Using the payload file. Then, press the return key.
- Review the details of the resource query that was created for you.
ibmcloud schematics resource query delete
Delete the resource resource query definition by using the resource query ID from the IBM Cloud Schematics service. Note you can delete the location and region, resource group from where your inventory was created. Also, make sure your IP addresses are in the allowlist.
Syntax
ibmcloud schematics resource-query delete --id ID [--force] [--no-prompt]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The ID of a resource query that you want to delete. |
--force or -f |
Optional | Force the deletion without user confirmation. |
--no-prompt |
Optional | Set this flag to run the command without user prompts. |
Example
ibmcloud schematics resource-query delete --id us-east.INVENTORY.inventoryid12342
ibmcloud schematics resource query get
Retrieve the information of an existing IBM Cloud Schematics resource query by using a resource query ID.
Syntax
ibmcloud schematics resource-query get --id ID [--profile PROFILE] [--output OUTPUT] [--no-prompt]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The ID of the resource query that you want to retrieve. |
--profile or -p |
Optional | The depth of information that you want to retrieve. Supported values are detailed and summary . The default value is summary . |
--output or -o |
Optional | Specify the output format. Only JSON format is supported. |
--no-prompt |
Optional | Set this flag to retrieve a resource query without an interactive command-line session. |
Example
ibmcloud schematics resource-query get --id us-east.INVENTORY.inventoryid12342
ibmcloud schematics resource query list
Retrieve a list of all Schematics resource queries in the current region for your account.
Syntax
ibmcloud schematics resource-query list [--limit LIMIT] [--offset OFFSET] [--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--limit or -l |
Optional | The maximum number of resource queries that you want to list. The number must be a positive integer between 1 and 200. The default value is -1 . |
--offset or -m |
Optional | The position of the resource query in the list of resource queries. For example, if you have three resource queries in your account, the command returns these resource queries as a list with three elements. To see a specific resource
query in this list, you must enter the position number that the resource query has in the list. To list the first resource query in the list, enter 0 . To list the second resource query, enter 1 and so forth.
Negative numbers are not supported and are ignored. The default value is -1 . |
--output or -o |
Optional | Specify the output format. Only JSON format is supported. |
Example
ibmcloud schematics resource-query list --output listoutput.json
ibmcloud schematics resource query update
Update or replace a resource query creates a copy of an resource query and relaunches an existing resource query by updating the information of an existing IBM Cloud Schematics resource query.
Syntax
ibmcloud schematics resource-query update --id ID --name RESOURCE_QUERY_NAME [--type RESOURCE_QUERY_TYPE] [--query-file QUERY_FILE_PATH] [--file FILE_NAME ] [--output OUTPUT] [--no-prompt]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The resource query ID. |
--name or -n |
Required | The unique name for a resource query. |
--type or -t |
Optional | The type of the resource query. such as vsi |
--query-file or -f |
Optional | The path to the JSON file containing queries. |
--file or -f |
Optional | Path to the JSON file containing the definition of an inventory. |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
--no-prompt |
Optional | Set this flag to create the resource query without an interactive command-line session. |
Example
ibmcloud schematics resource-query update --id us-east.INVENTORY.inventory12312 --name inventoryname600 --description "Short description" --location us-east --resource-group Default --resource-query default.RESOURCEQUERY.string.12121
Workspace commands
Review the commands that you can use to create and work with your IBM Cloud Schematics workspace.
ibmcloud schematics workspace action
Retrieve all activities (jobs) for a workspace, including the user ID of the person who initiated the action, the status, and a timestamp.
When you create a Terraform execution plan, or apply your Terraform template with Schematics, a Schematics actions is automatically created and assigned an action ID. You can use the action ID to retrieve the logs of this action by using the
ibmcloud schematics logs
command.
Syntax
ibmcloud schematics workspace action --id WORKSPACE_ID [--act-id ACTION_ID] [--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The unique identifier of the workspace for which you want to retrieve workspace activities. To find the ID of your workspace, run ibmcloud schematics workspace list command. |
--act-id or -a |
Optional | Enter the ID of a action that you want to retrieve. |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
Example
ibmcloud schematics workspace action --id myworkspace-a1aa1a1a-a11a-11
ibmcloud schematics workspace delete
Delete a workspace from the current region for your account. The deletion of your workspace does not remove any IBM Cloud resources that you provisioned with this workspace. You can access and work with your resources from the IBM Cloud dashboard directly, but you cannot use IBM Cloud Schematics to manage your resources after you delete the workspace.
Decide if you want to delete the workspace, any associated resources, or both. This action cannot be undone. If you remove the workspace and keep the resources, you need to manage the resources with the resource list or CLI.
Action | Delete workspace | Delete all associated resources |
---|---|---|
Delete workspace | True | False |
Delete only resources | False | True |
Delete workspace and the resources provisioned by workspace | True | True |
Resources destroyed using command-line or resource list, and want to delete workspace | True | False |
Syntax
ibmcloud schematics workspace delete --id WORKSPACE_ID [--force]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The unique identifier of the workspace that you want to remove. To find the ID of your workspace, run ibmcloud schematics workspace list command. |
--force or -f |
Optional | Force the deletion of your workspace without command-line prompts. |
Example
ibmcloud schematics workspace delete --id myworkspace-a1aa1a1a-a11a-11
ibmcloud schematics workspace get
Retrieve the details of an existing workspace, including the values of all input variables.
Syntax
ibmcloud schematics workspace get --id WORKSPACE_ID [--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The unique identifier of the workspace, for which you want to retrieve the details. To find the Resource ID of a workspace, run ibmcloud schematics workspace list command to view the of list service instances.
From your resource group get an Resource ID for the --id flag. |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
Example
ibmcloud schematics workspace get --id myworkspace-a1aa1a1a-a11a-11
ibmcloud schematics workspace import
You can import an existing resource with an valid resource address into your workspace state file. You need to ensure that the resource is only imported once and to a single workspace. Otherwise, you may see unwanted behavior if the resource
is defined in multiple workspaces. Review the Terraform documentation for details on how to use the import
command.
Syntax
ibmcloud schematics workspace import --id WORKSPACE_ID --options OPTIONS --address ADDRESS --resourceID RESOURCE_ID
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The unique identifier of the workspace for which you want to import an instance or resource. To find the ID of your workspace, run ibmcloud schematics workspace list command. |
--options or -o |
Required | The command-line flags. For example -var-file xxxxx/tf . |
--address or -adr |
Required | Provide the address of the resource name you want to import. |
--resourceID or -rid |
Required | Provide the resource ID that you need to import in the file. |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
Use the option -options -var-file=schematics.tfvars
to tell Schematics to import the resource with the saved workspace variables.
Example
ibmcloud schematics workspace import --id WID --address ibm_iam_access_group.accgrp --resourceID AccessGroupId-xxxxxx-xxxx-xxx-xxx-xxxx -o -var-file=schematics.tfvars
ibmcloud schematics workspace list
List the workspaces for the current region of your IBM Cloud account and shows the details for your workspace. List workspace checks for the deprecation in a loop by invoking versions
API every time for all the workspace through
file cache.
Syntax
ibmcloud schematics workspace list [--limit LIMIT] [--offset OFFSET] [--output] [--region]
Command options
Flag | Required / Optional | Description |
---|---|---|
--limit or -l |
Optional | The maximum number of workspaces that you want to list. The number must be a positive integer starting from 1, maximum is 200. The default value is -1 . |
--offset or -m |
Optional | The position of the workspace in the list of workspaces. For example, if you have three workspaces in your account, the command returns these workspaces as a list with three elements. To see a specific workspace in this list, you must
enter the position number that the workspace has in the list. To list the first workspace in the list, enter 0 . To list the second workspace, enter 1 and so forth. Negative numbers are not supported and are
ignored. The default value is -1 . |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
--region or -r |
Optional | Specify the region, such as eu , us , eu-gb , eu-de , us-south , or us-east . |
Example
ibmcloud schematics workspace list --limit 10 --offset 20
ibmcloud schematics workspace new
Create a Schematics workspace that points to your Terraform template in GitHub or GitLab. If you want to provide your Terraform template by uploading a tape archive file (.tar
), you can create the workspace without a connection
to a GitHub repository and then use the ibmcloud schematics workspace upload
command to provide the template.
Schematics does not support passing .tar
file to create a workspace.
IBM Cloud Schematics supports 50 API requests per minute, per host, and per customer. The location can be us-east
, us-south
, eu-gb
, or eu-de
region. You need to wait before calling the command
again.
To create a workspace, you can specify your workspace settings in a JSON file. Make sure that the JSON file follows the structure as outlined in this command. Also ensure the location
and the url
endpoint are pointing
to the same region when you create or update workspaces and actions. For more information about location and endpoint, see Where is my information stored?.
IBM Cloud Schematics deprecates older version of Terraform. For more information, see Deprecating older version of Terraform process in IBM Cloud Schematics.
IBM Cloud Schematics deprecates creation of workspace using the IBM Cloud Provider Plug-in for Terraform v1.2, v1.3 template from 2nd week of April 2024.
Syntax
ibmcloud schematics workspace new --file FILE_NAME --state STATE_FILE_PATH [--agent-id AGENT_ID] [--github-token GITHUB_TOKEN] [--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--file or -f |
Optional | The relative path to a JSON file on your local machine that is used to configure your workspace. For more information about the sample JSON file with the details, see JSON file create template. |
--state |
Optional | The relative path to an existing Terraform state file on your local machine. To create the Terraform state file: 1. Show the content of an existing Terraform state file by using the ibmcloud schematics state pull command.2. Copy the content of the state file from your command-line output in to a file on your local machine that is named terraform.tfstate . 3. Use the relative path to the file in the --state command parameter. Note The Schematics workspace supports the terraform.tfstate file of less than 2 MB. |
--github-token or -g |
Optional | Enter the functional personal access tokens for HTTPS Git operations. For example, --github-token ${FUNCTIONAL_GIT_KEY} . |
--agent-id or --aid |
Optional | The ID of an Agent where your workspace is created. The agent help you to run your workspace jobs on your infrastructure. For more information, see Schematics Agent. |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
The Schematics ibmcloud terraform
command usage displays warning and deprecation message as Alias 'terraform' are deprecated. Use 'schematics' or 'sch' in your commands.
Create file template in JSON format
Schematics supports to download the Terraform modules template from the private repository. For more information, see Supporting to download modules from private remote host.
You can create the JSON file as shared in the example.json
file for workspace creation and pass the file path along with the file name in --file
flag. The description of all the parameters of example.json
as described in the table.
You need to replace the <...>
placeholders with the actual values. For example, "<workspace_name>"
as "testworkspace"
.
Example
{
"name": "<workspace_name>",
"type": [
"<terraform_version>"
],
"location": "<location>",
"description": "<workspace_description>",
"tags": [],
"template_repo": {
"url": "<github_source_repo_url>"
},
"template_data": [
{
"folder": ".",
"type": "<terraform_version>",
"env_values":[
{
"env_key1": "dummy_text"
},
{
"env_key2": "dummy_text"
}
],
"variablestore": [
{
"name": "<variable_name_x>",
"value": "<variable_value_x>",
"type": "string",
"secure": true,
"description":"<description>"
},
{
"name": "<variable_name_x>",
"value": "<variable_value_x>",
"type": "bool",
"secure": false,
"description":"<description>"
},
{
"name": "<variable_name_x>",
"value": "<variable_value_x>",
"type": "list(string);",
"secure": false,
"description":"<description>"
},
{
"name": "<variable_name_x>",
"value": "<variable_value_x>",
"type": "map(number)",
"secure": false,
"description":"<description>"
},
{
"name": "<variable_name_x>",
"value": "<variable_value_x>",
"type": "tuple([string, list(string), number, bool])",
"secure": false,
"description":"<description>"
},
{
"name": "<variable_name_x>",
"value": "<variable_value_x>",
"type": "any",
"secure": false,
"description":"<description>"
}
]
}
],
}
Example JSON for uploading in a .tar
file
{
"name": "<workspace_name>",
"type": [
"<terraform_version>"
],
"location": "<location>",
"description": "<workspace_description>",
"tags": [],
"template_repo": {
"url": "<github_source_repo_url>"
},
"template_data": [
{
"folder": ".",
"type": "<terraform_version>",
"env_values":[
{
"env_key1": "dummy_text"
},
{
"env_key2": "dummy_text"
}
],
"variablestore": [
{
"name": "<variable_name_x>",
"value": "<variable_value_x>",
"type": "string",
"secure": true,
"description":"<description>"
},
{
"name": "<variable_name_x>",
"value": "<variable_value_x>",
"type": "bool",
"secure": false,
"description":"<description>"
},
{
"name": "<variable_name_x>",
"value": "<variable_value_x>",
"type": "list(string)",
"secure": false,
"description":"<description>"
},
{
"name": "<variable_name_x>",
"value": "<variable_value_x>",
"type": "map(number)",
"secure": false,
"description":"<description>"
},
{
"name": "<variable_name_x>",
"value": "<variable_value_x>",
"type": "tuple([string, list(string), number, bool])",
"secure": false,
"description":"<description>"
},
{
"name": "<variable_name_x>",
"value": "<variable_value_x>",
"type": "any",
"secure": false,
"description":"<description>"
}
]
}
]
}
Parameter | Required / Optional | Description |
---|---|---|
workspace_name |
Optional | Enter a name for your workspace. The maximum length of character limit is set to less than 1 MB. For more information, see Designing your workspace structure. |
terraform_version |
Optional | The Terraform version that you want to use to run your Terraform code. Enter terraform_v1.5 to use Terraform version 1.5,terraform_v1.4 to use Terraform version 1.4, and similarly, terraform_v1.4 .
For example, when you specify terraform_v1.5 means users can have template that are of Terraform v1.5.0 , v1.5.1 , or v1.5.7 , so on. Make sure that your Terraform config files are
compatible with the Terraform version that you specify. This is a required variable. If the Terraform version is not specified, By default, Schematics selects the version from your template. Schematics supports Terraform_v1.x and also plans to make releases available after 30 to 45 days of HashiCorp Configuration Language (HCL) release. |
location |
Optional | Enter the location where you want to create your workspace. The location determines where your Schematics actions run and where your workspace data is stored. If you do not enter a location, Schematics determines the location based
on the IBM Cloud region that you targeted. To view the region that you targeted, run ibmcloud target --output json and look at the region field. To target a different region, run ibmcloud target -r <region> .
If you enter a location, make sure that the location matches the IBM Cloud region that you targeted. |
description |
Optional | Enter a description for your workspace. |
template_repo.url |
Optional | Enter the URL to the GitHub or GitLab repository where your Terraform configuration files are stored. |
template_repo.branch |
Optional | Enter the GitHub or GitLab branch where your Terraform configuration files are stored. Now, in template_repo , you can also update URL with more parameters as shown in the block. |
template_repo.datafolder |
Optional | Enter the name of the folder in the Git repository, that contains the template. |
template_repo.release |
Optional | Enter the GitHub or GitLab release that points to your Terraform configuration files. |
github_source_repo_url |
Optional | Enter the link to your GitHub repository. The link can point to the master branch, a different branch, or a subdirectory. If you choose to create your workspace without a GitHub repository, your workspace is created with
a draft state. To connect your workspace to a GitHub repository later, you must use the ibmcloud schematics workspace update command. If you plan to provide your Terraform template by uploading a tape
archive file (.tar ), leave the URL empty, and use the ibmcloud schematics workspace upload command after you created
the workspace. If you want to clone from the Git repository see the allowed and blocked file extensions for cloning. |
env_values |
Optional | A list of environment variables that you want to apply during the execution of a bash script or Terraform action. This field must be provided as a list of key-value pairs. Each entry is a map with one entry where key = variable name and value = value . You can define environment variables for IBM Cloud catalog offerings that are provisioned by using a bash script files. |
variable_name |
Optional | Enter the name for the input variable that you declared in your Terraform configuration files. |
variable_type |
Optional | Terraform v0.12 supports string , list , map , bool , number and complex data types such as list(type) , map(type) , object({attribute name=type,..}) ,
set(type) , tuple([type]) . |
variable_value |
Optional | Enter the value as a string for the primitive types such as bool , number , string , and HCL format for the complex variables, as you provide in a .tfvars file. You need
to enter escaped string of HCL format for the value, as shown in the example. For more information about how to declare variables in a Terraform configuration file and provide value to schematics, see Using input variables to customize resources.
For example |
secure |
Optional | Set the secure parameter to true. By default, this parameter is set to false. |
val1 |
Optional | In the payload you can provide an environment variable that can execute in your workspace during plan, apply or destroy stage. Also values are encrypted and stored in COS. |
IBM Cloud Schematics supports setting up environment variable such as TF_PARALLELISM
, TF_LOG
. For more information about the list of environment variable and its usage, see List of environment variables.
Example
ibmcloud schematics workspace new --file example.json
ibmcloud schematics refresh
Perform an IBM Cloud refresh action against your workspace. A refresh action validates the IBM Cloud resources in your account against the state that is stored in the Terraform state file of your workspace. If differences are found, the Terraform state file is updated accordingly.
Syntax
ibmcloud schematics refresh --id WORKSPACE_ID [--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The unique identifier of the workspace that you want to refresh and run an action against. To find the ID of a workspace, run ibmcloud schematics workspace list command. |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
Example
ibmcloud schematics refresh --id myworkspace-a1aa1a1a-a11a-11
ibmcloud schematics state list
List the Name
, Type
, URL
, and Taint Status
of the IBM Cloud resources that are documented in your Terraform state file (terraform.tfstate
).
Taint Status
returns tainted for (true) or blank for (false).
Syntax
ibmcloud schematics state list --id WORKSPACE_ID [--output json]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The unique identifier of the workspace for which you want to list the IBM Cloud resources that are documented in the Terraform state file. To find the ID of a workspace, run ibmcloud schematics workspace list command. |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
Example
ibmcloud schematics state list --id myworkspace-a1aa1a1a-a11a-11
ibmcloud schematics workspace taint
Manually marks an instance or resources as tainted, by forcing the resources to be re-created on the next apply. Taint modifies the state file, but not the infrastructure in your workspace. When you perform next plan the changes displays as re-created, and in the next apply the change is implemented.
You must execute ibmcloud schematics state list
command to view the tainted status of your resources. Taint Status
returns tainted for (true) or blank for (false).
Syntax
ibmcloud schematics workspace taint --id WORKSPACE_ID [--options OPTIONS] --address PARAMETER
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The unique identifier of the workspace for which you want to re-create the instance or resource. To find the ID of your workspace, run ibmcloud schematics workspace list command. |
--options or -o |
Optional | Enter the option flag that you want to show. |
--address or -adr |
Required | Enter the address of the resource to mark as taint. |
Example
ibmcloud schematics workspace taint --id myworkspace-lalalalalalala-11 --address null_resource.sleep
ibmcloud schematics workspace untaint
Manually marks an instance or resources as untaint
, by forcing the resources to be restored on the next apply. When you perform next plan the changes shows as restored and in the next apply the change is implemented.
You can execute ibmcloud schematics state list
command to view the tainted status of your resources. Taint Status
returns tainted for (true) or blank for (false).
Syntax
ibmcloud schematics workspace untaint --id WORKSPACE_ID [--options OPTIONS] [--address PARAMETER]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The unique identifier of the workspace for which you want to re-create the instance or resource. To find the ID of your workspace, run ibmcloud schematics workspace list command. |
--options or -o |
Optional | Enter the option flag that you want to show. |
--address or -adr |
Optional | Enter the address of the resource to mark as untaint . |
{: caption="Schematics workspace untaint flags" caption-side="top"} |
Example
ibmcloud schematics workspace untaint --id myworkspace-asdff1a1a-42145-11 --address null_resource.sleep
ibmcloud schematics workspace update
IBM Cloud Schematics deprecates older version of Terraform. For more information, see Deprecating older version of Terraform process in IBM Cloud Schematics.
Update the details for an existing workspace, such as the workspace name, variables, or source control URL. To provision or modify IBM Cloud, see the ibmcloud schematics plan
command.
IBM Cloud Schematics supports 50 API requests per minute, per host, and per customer. The region can be us-east
, us-south
, eu-gb
, or eu-de
region. You need to wait before calling the command
again. Ensure the location
and the url
endpoint are pointing to the same region when you create or update workspaces and actions. For more information about location and endpoint, see Where is my information stored?.
If you provided your Terraform template by uploading a tape archive file (.tar
) and you want to update your template, you must use the ibmcloud schematics workspace upload
command.
Syntax
ibmcloud schematics workspace update --id WORKSPACE_ID [--file FILE_NAME] [--github-token GITHUB_TOKEN] [--pull-latest] [--output OUTPUT]
Pull-latest
flag is not supported for workspaces created by using templates from IBM Cloud catalogs.
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The unique identifier of the workspace for which you want to update the instance or resource. To find the ID of your workspace, run ibmcloud schematics workspace list command. |
--file or -f |
Optional | The relative path to a JSON file on your local machine that includes the updated parameters for your workspace. For more information about the sample JSON file with the details, see JSON file update template. |
--github-token or -g |
Optional | Enter the GitHub token value to access private Git repository. |
--pull-latest or --pl |
Optional | Pull the latest changes from your GitHub repository into workspace. If this flag is set --file flag is ignored. |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
Update file template in JSON format
You can create the JSON as shared in the example.json
file for workspace update and pass the file path along with the file name in --file
flag. The description of all the parameters of example.json is described
in the table.
You need to replace the <...>
placeholders with the actual values. For example, "<workspace_name>"
as "testworkspace"
.
example.json:
{
"name": "<workspace_name>",
"type": "<terraform_version>",
"description": "<workspace_description>",
"tags": [],
"resource_group": "<resource_group>",
"workspace_status": {
"frozen": "<true_or_false>"
},
"template_repo": {
"url": "<source_repo_url>"
},
"template_data": [
{
"folder": ".",
"type": "<terraform_version>",
"env_values":[
{
"env_key1": "dummy_text"
},
{
"env_key2": "dummy_text"
}
],
"variablestore": [
{
"name": "<variable_name1>",
"value": "<variable_value1>",
"type": "<variable_type1>",
"secure": true,
"use_default": true },
{
"name": "<variable_name2>",
"value": "<variable_value2>",
"type": "<variable_type2>",
"secure": false,
"use_default": true
}
]
}
],
}
Parameter | Required / Optional | Description |
---|---|---|
name |
Optional | Enter a name for your workspace. For more information, see Designing your workspace structure. If you update the name of the workspace, the ID of the workspace does not change. |
type |
Optional | The Terraform version that you want to use to run your Terraform code. Enter terraform_v1.5 to use Terraform version 1.5, terraform_v1.4 to use Terraform version 1.4. For example, when you specify terraform_v1.5 means users can have template that are of Terraform v1.5.0 , v1.5.1 , or v1.5.7 , so on. Make sure that your Terraform config files are compatible with the Terraform version that you specify. This
is a required variable. If the Terraform version is not specified, By default, Schematics selects the version from your template. |
description |
Optional | Enter tags that you want to associate with your workspace. Tags can help you find your workspace faster. |
resource_group |
Optional | Enter the resource group where you want to provision your workspace. |
workspace_status |
Optional | Freeze or unfreeze a workspace. If a workspace is frozen, changes to the workspace are disabled. |
template_repo.url |
Optional | Enter the URL to the GitHub or GitLab repository where your Terraform configuration files are stored. |
template_repo.branch |
Optional | Enter the GitHub or GitLab branch where your Terraform configuration files are stored. Now, in template repository, you can also update URL with more parameters as shown in the block. |
template_repo.datafolder |
Optional | Enter the name of the folder in the Git repository, that contains the template. |
template_repo.release |
Optional | Enter the GitHub or GitLab release that points to your Terraform configuration files. |
github_source_repo_url |
Optional | Enter the link to your GitHub repository. The link can point to the master branch, a different branch, or a subdirectory. |
template_data.folder |
Optional | Enter the name for the input variable that you declared in your Terraform configuration files. |
template_data.type |
Optional | Enter the name for the input variable type that you declared in your Terraform configuration files. |
template_data[0].env_values[i].va11 |
Optional | A list of environment variables that you want to apply during the execution of a bash script or Terraform job. This field must be provided as a list of key-value pairs, for example, TF_LOG=debug . Each entry is a map with
one entry where key is the environment variable name and value is value. |
template_data[0].env_values[i].val2 |
Optional | A list of environment variables that you want to apply during the execution of a bash script or Terraform job. This field must be provided as a list of key-value pairs, for example, TF_LOG=debug . Each entry is a map with
one entry where key is the environment variable name and value is value. |
template_data[0].env_values_metadata |
Optional | Environment variables metadata. |
template_data[0].variablestore[i].name |
Optional | Enter the name for the input variable that you declared in your Terraform configuration files. |
template_data[0].variablestore[ii].type |
Required | Terraform v0.12 supports string , list , map , bool , number and complex data types such as list(type) , map(type) , object({attribute name=type,..}) ,
set(type) , tuple([type]) . |
template_data[0].variablestore[iii].value |
Optional | Enter the value as a string for the primitive types such as bool , number , string , and HCL format for the complex variables, as you provide in a .tfvars file. You can
override the default values of .tfvars by setting use_default parameter as true . You need to enter escaped string of HCL format for the value, as shown in the example. For more
information about how to declare variables in a Terraform configuration file and provide value to schematics, see Using input variables to customize resources and variable store example |
template_data[0].variablestore[iv].secure |
Optional | Set the secure parameter to true. By default, this parameter is set to false. |
template_data[0].variablestore[v].use_default |
Optional | Set the use_default parameter to true to override the default .tfvars parameter. By default, this parameter is set to false. |
github_source_repo_url |
Optional | Enter the link to your GitHub repository. The link can point to the master branch, a different branch, or a subdirectory. |
Example for variable store
"variablestore": [
{
"value": "[\n {\n internal = 800\n external = 83009\n protocol = \"tcp\"\n }\n ]",
"description": "",
"name": "docker_ports",
"type": "list(object({\n internal = number\n external = number\n protocol = string\n }))",
"use_default":true
},
Example
ibmcloud schematics workspace update --id myworkspace-a1aa1a1a-a11a-11 --file myfile.json
ibmcloud schematics workspace upload
Provide your Terraform template by uploading a tape archive file (.tar
) to your Schematics workspace. The .tar
supports the Cloud Shell commands.
Before you begin, make sure that you created your workspace without a link to a GitHub or GitLab repository.
Syntax
ibmcloud schematics workspace upload --id WORKSPACE_ID --file FILE_NAME --template TEMPLATE_ID [--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The unique identifier of the workspace where you want to upload your tape archive file (.tar ). To find the ID of your workspace, run ibmcloud schematics workspace list command. |
--file or -f |
Required | Enter the full file path on your local machine where your .tar file is stored. |
--template or -tid |
Required | The unique identifier of the Terraform template for which you want to show the content of the Terraform state file. To find the ID of the template, run ibmcloud schematics workspace get --id <workspace_ID> and find
the template ID in the Template Variables for: field of your command-line output. |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
Example
ibmcloud schematics workspace upload --id myworkspace-a1aa1a1a-a11a-11 --file /Users/myuser/Documents/mytar/vpc.tar --template 25111111-0000-4c
Create the TAR
file of your template repo by using the TAR
command given tar -cvf vpc.tar $TEMPLATE_REPO_FOLDER
Example of the variable value
"variablestore": [
{
"value": "[\n {\n internal = 800\n external = 83009\n protocol = \"tcp\"\n }\n ]",
"description": "",
"name": "docker_ports",
"type": "list(object({\n internal = number\n external = number\n protocol = string\n }))"
},
]
Workspace job commands
Run Schematics operations, to create, update, and delete IBM Cloud resources. Using familiar Terraform semantics, plan, apply and destroy Terraform workspaces to manage the lifecycle of cloud resources.
ibmcloud schematics apply
When you apply a workspace Terraform template, your resources are provisioned, modified, or removed from IBM Cloud. Temporary files created during the apply operation can be persisted for future operations.
Your workspace must be in an Inactive, Active, Failed, or Stopped state to perform a Schematics apply operation. For more information about workspace states, see workspace state diagram.
While your Terraform jobs are running, the workspace is locked and changes cannot be made to your workspace until execution is complete.
Syntax
ibmcloud schematics apply --id WORKSPACE_ID [--target RESOURCE1] [--target RESOURCE2] [--var-file PATH_TO_VARIABLES_FILE] [--force] [--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The unique identifier of the workspace that points to the Terraform template in your source control repository that you want to apply in IBM Cloud. To find the ID of your workspace, run ibmcloud schematics workspace list command. |
--target or -t |
Optional | Target the creation of a specific resource of your Terraform configuration file by entering the Terraform resource address, such as ibm_is_instance.vm1 . All other resources that are defined in your configuration file is
not created or updated. To target the creation of multiple resources, use the following syntax: --target <resource1> --target <resource2> . If the targeted resource specifies the count attribute
and no index is specified in the resource address, such as ibm_is_instance.vm1[1] , all instances that share the same resource name are targeted for creation. |
--var-file or --vf |
Optional | The file path to the terraform.tfvars file that you created on your local machine. Use this file to store sensitive information, such as the IBM Cloud API key or credentials to connect to IBM Cloud classic infrastructure
in the format <key>=<value> . Variables must be defined in single line format for example, as availability_zone_names = ["us-east-1a","us-west-1c"] . All key value pairs that
are defined in this file are automatically loaded into Terraform when you initialize the Terraform CLI. To specify multiple tfvars files, specify --var-file TFVARS_FILE_PATH1 --var-file TFVARS_FILE_PATH2 . |
--force or -f |
Optional | Force the execution of this command without user prompts. |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
Example
ibmcloud schematics apply --id myworkspace-a1aa1a1a-a11a-11 --target ibm_is_instance.vm1 --var-file ./terraform.tfvars
ibmcloud schematics destroy
Remove IBM Cloud resources that you provisioned using your Schematics workspace, even if these resources are active.
Use this command with caution. After you run the command, you cannot reverse the removal of your IBM Cloud resources. If you have written data to provisioned storage or databases, ensure that you create a backup to persist your data
Your workspace must be in an Active, Failed, or Stopped state to perform a Schematics destroy action.
Syntax
ibmcloud schematics destroy --id WORKSPACE_ID [--target RESOURCE1] [--target RESOURCE2] [--force] [--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The unique identifier of the workspace that points to the Terraform template in your source repository that specifies the IBM Cloud resources that you want to remove. To find the ID of a workspace, run ibmcloud schematics workspace list command. |
--target or -t |
Optional | Target the deletion of a specific resource by entering the Terraform resource address, such as ibm_is_instance.vm1 . All other resources in your workspace remain unchanged. To target the deletion of multiple resources, use
the following syntax: --target <resource1> --target <resource2> . If the targeted resource specifies the count attribute and no index is specified in the resource address, such as ibm_is_instance.vm1[1] ,
all instances that share the same resource name are targeted for deletion. Also, if the targeted resource can only be deleted if dependent resources are deleted, such as a VPC can only be deleted if the attached subnet is deleted,
then all dependent resources are targeted for deletion as well. |
--force or -f |
Optional | Force the execution of this command without user prompts. |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
Example
ibmcloud schematics destroy --id myworkspace-a1aa1a1a-a11a-11 --target ibm_is_vpc.myvpc
ibmcloud schematics logs
Retrieve the Terraform log files for Schematics workspace or a specific workspace action ID. Use the log files to troubleshoot Terraform template issues or issues that occur during the resource provisioning, modification, or deletion process.
Syntax
ibmcloud schematics logs --id WORKSPACE_ID [--act-id ACTION_ID]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The unique identifier of the workspace for which you want to retrieve Terraform log files. To find the ID of a workspace, run ibmcloud schematics workspace list command. |
--act-id or -1 |
Optional | The ID of an action for which you want to retrieve Terraform logs. To find a list of action IDs, run ibmcloud schematics workspace action --id WORKSPACE_ID command. |
Example
ibmcloud schematics logs --id myworkspace-a1aa1a1a-a11a-11 --act-id 9876543121abc1234cdst
ibmcloud schematics output
Retrieve the Terraform output values for the workspace. You can define output values in your Terraform template to include data that you want to make accessible to other workspaces.
Syntax
ibmcloud schematics output --id WORKSPACE_ID[--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The unique identifier of the workspace for which you want to list Terraform output values. To find the ID of your workspace, run ibmcloud schematics workspace list command. |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
Example
ibmcloud schematics output --id myworkspace3_2-31cf7130-d0c4-4d
ibmcloud schematics plan
Scan the Terraform template in your source repository and compare this template against the IBM Cloud resources that are already deployed. The command-line output shows the IBM Cloud resources that must be added, modified, persisted, or removed to achieve the state that is described in your configuration file.
Your workspace must be in an Inactive, Active, Failed, or Stopped state to perform a Schematics plan action.
During the creation of the Terraform execution plan, you cannot make any changes to your workspace.
Syntax
ibmcloud schematics plan --id WORKSPACE_ID [--var-file PATH_TO_VARIABLES_FILE] [--output OUTPUT]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The unique identifier of the workspace that points to the Terraform template in your source repository that you want to scan. To find the ID of a workspace, run ibmcloud schematics workspace list command. |
--var-file or --vf |
Optional | The file path to the terraform.tfvars file that you created on your local machine. Use this file to store sensitive information, such as the IBM Cloud API key or credentials to connect to IBM Cloud classic infrastructure
in the format <key>=<value> . Variables must be defined in single line format for example, as availability_zone_names = ["us-east-1a","us-west-1c"] . All key value pairs that
are defined in this file are automatically loaded into Terraform when you initialize the Terraform CLI. To specify multiple tfvars files, specify --var-file TFVARS_FILE_PATH1 --var-file TFVARS_FILE_PATH2 . |
--output or -o |
Optional | Returns the command-line output in JSON format. Currently only JSON file format is supported. |
Example
ibmcloud schematics plan --id myworkspace-a1aa1a1a-a11a-11
Workspace stop commands
After invoking a workspace job, like a plan
, an apply
, or a destroy
, you may want to stop the running job, or to stop the provisioning of resources. When stopping, or canceling a long running job, it is
advisable to first check the job logs to determine whether the job is actually stuck and needs stopping, or if it is performing long running operations that are taking time to complete.
Schematics provides a number of options to allows users to (gracefully) stop
, force-stop
, or terminate
the running job in order of immediacy and impact of the stop operation.
Review the commands to (gracefully) stop
, force-stop
or terminate
jobs.
ibmcloud schematics workspace job stop
Stops a running workspace job by sending an interrupt signal to Terraform to terminate execution.
Syntax
ibmcloud schematics workspace job stop --id WORKSPACE_ID --job-id JOB_ID [--stop] [--force-stop] [--terminate]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The workspace ID to update. |
--job-id or --jid |
Required | The job ID of the job. |
--stop, |
Optional | Removes the job from the pending queue. |
--force-stop or --fs |
Optional | Sends a kill signal to the Terraform execution in the engine, also attempts to immediately stop the execution. |
--terminate or -t |
Optional | Abruptly kills the engine, marks the job as stopped, and unlocks your workspace. Data is not saved using this flag. |
Example
ibmcloud schematics workspace job stop --id <WORKSPACE_ID> --stop --job-id <JOB_ID>
ibmcloud schematics workspace job stop --id <WORKSPACE_ID> --force-stop --job-id <JOB_ID>
ibmcloud schematics workspace job stop --id <WORKSPACE_ID> --terminate --job-id <JOB_ID>
Workspace state file commands
Review the commands that you can use to work with the Terraform state file (terraform.tfstate
) for a workspace.
You can import an existing Terraform state file during the creation of your workspace. For more information, see the ibmcloud workspace new
command.
ibmcloud schematics state pull
Show the content of the Terraform state file (terraform.tfstate
) for a specific Terraform template of your workspace.
Syntax
ibmcloud schematics state pull --id WORKSPACE_ID --template TEMPLATE_ID
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The unique ID of the workspace where you want to run the commands. |
--template or --tid |
Required | The unique identifier of the Terraform template for which you want to show the content of the Terraform state file. To find the ID of the template, run ibmcloud schematics workspace get --id <workspace_ID> and find
the template ID in the Template Variables for: field of your command-line output. |
Example
ibmcloud schematics state pull --id myworkspace-a1aa1a1a-a11a-11 --template a1aa11a1-11a1-11
ibmcloud schematics workspace state show
Provides the readable output from a state or plan of a workspace as Terraform sees it. You can use to ensure the current state and planned operations status. You need to use the workspace ID to retrieve the logs by using the ibmcloud schematics logs
command.
Syntax
ibmcloud schematics workspace state show --id WORKSPACE_ID --address ADDRESS [--options OPTIONS]
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The unique ID of the workspace to update. |
--address or -adr |
Required | Enter the address that points to a single resource in the state to show. |
--options or -o |
Optional | Enter the command-line flags. |
Example
ibmcloud schematics workspace show --id myworkspace-a1aa1a1a-a11a-11 --address null_resource.sleep
ibmcloud schematics workspace state mv
If you move the state for a resource within the state file. The workspace continues to function, but the next plan or apply operation will not find the resource or instance in the state file. If no changes are made to the template, you can see recreation of the resource on the next operation by Terraform.
ibmcloud schematics workspace state mv --id WORKSPACE_ID --source SOURCE --destination DESTINATION
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The unique ID of the workspace for which you want to move an instance or resource. To find the ID of your workspace, run ibmcloud schematics workspace list command. |
--source or -s |
Required | Enter the source address of an item to move. |
--destination or -d |
Required | Provide the destination address of an item. |
Example
ibmcloud schematics workspace state mv --id myworkspace-a1aa1a1a-a11a-11 -s testsourceresource -d null_resource.sleep
ibmcloud schematics workspace state rm
If you remove the state for a resource or instance within the state file. The workspace continues to function, but the next plan or apply operation will not find the resource or instance in the state file. If no changes are made to the template, you can see recreation of the resource on the next operation by Terraform.
ibmcloud schematics workspace state rm --id WORKSPACE_ID [--options OPTIONS] --address PARAMETER
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The unique identifier of the workspace for which you want to remove the instance or resource. To find the ID of your workspace, run ibmcloud schematics workspace list command. |
--options or -o |
Optional | Enter the option flag that you want to remove. |
--address or -adr |
Required | Enter the address of the resource to mark as taint. |
Example
ibmcloud schematics workspace state rm --id myworkspace-a1aa1a1a-a11a-11 --address null_resource.sleep --destination null_resource.slept
Workspace Terraform commands
You can run Terraform commands to manipulate IBM Cloud resources and modify Schematics state.
Workspace Terraform commands are not supported in the UI.
The table provides the summary of supported Terraform workspace commands.
Command | Description |
---|---|
show |
Inspects Terraform state or plan. |
output |
Reads an output from a Terraform state file. |
import |
Imports an existing infrastructure into Terraform. |
taint |
Mark a resource for recreation. |
untaint |
Do not mark a resource as tainted. |
state |
An advanced state management command to write sub commands to remove or move rm && mv . |
Terraform commands
Terraform commands are executed using a JSON file to specify inputs.
Syntax
ibmcloud schematics workspace commands --id WORKSPACE_ID --file FILE_NAME
Command options
Flag | Required / Optional | Description |
---|---|---|
--id or -i |
Required | The unique ID of the workspace where you want to run the commands. To find the ID of your workspace, run ibmcloud schematics workspace list command. |
--file or --f |
Required | Path to the JSON file containing the list of Terraform commands. |
Sample payload of Test.JSON
file
{
"commands": [
{
"command": "state show",
"command_params": "data.template_file.test",
"command_name": "Test1",
"command_desc": "Showing state",
"command_onerror": "continue"
},
{
"command": "taint",
"command_params": "null_resource.sleep",
"command_name": "Test2",
"command_desc": "Marking taint",
"command_onerror": "continue"
},
{
"command": "untaint",
"command_params": "null_resource.sleep",
"command_name": "Test3",
"command_desc": "Marking untaint",
"command_onerror": "continue"
},
{
"command": "state list ",
"command_params": "",
"command_name": "Test4",
"command_desc": "Checking state list",
"command_onerror": "continue"
},
{
"command": "state rm ",
"command_params": "data.template_file.test",
"command_name": "Test5",
"command_desc": "Removing state",
"command_onerror": "continue"
}
],
"operation_name": "workspace Command",
"description": "Executing command"
}
The table provides the list of key parameters of the JSON file for the Commands
API, for the command-line and the API.
Key | Required / Optional | Description |
---|---|---|
command |
Required | Provide the command. Supported commands are show ,taint , untaint , state , import , output . |
command_params |
Required | The address parameters for the command name for CLI , such as resource name, absolute path of the file name. For API, you have to send option flag and address parameter in command_params . |
command_name |
Required | The name for the command block. |
command_desc |
Optional | The text to describe the command block. |
command_onError |
Optional | Instruction to continue or break in case of error in the command. |
command_dependsOn |
Optional | Dependency on the previous commands. |
command_status |
Not required | Displays the command executed status, either success or failure |
Example
ibmcloud schematics workspace commands --id cli-sleepy-0bedc51f-c344-50 --file /<FILE_PATH>/Test.JSON