plugins
The cfy plugins command is used to manage plugins stored on a Cloudify manager.
You can use the command to upload, download, delete and list plugins and also to get information on a specific plugin.
A Cloudify plugin is an archive created by wagon.
Each plugin has a plugin.yaml file that map node lifecycle operations to appropriate plugin functions.
See plugins for more information.
Optional flags
These commands support the common CLI flags.
Commands
upload
Usage
cfy plugins upload [OPTIONS] PLUGIN_PATH
Upload a plugin to Cloudify Manager.
PLUGIN_PATH is the path to the wagon archive to upload.
Wagon (via the --format flag) enables you to create archives in both tar.gz and zip formats. Cloudify only supports wagon in the tar.gz format.
Required flags
- -y, --yaml-path TEXT- The path to the yaml file for the plugin
Optional flags
- -t, --tenant-name TEXT- The name of the tenant of the plugin. If unspecified, the current tenant is used.
- -l, --visibility TEXT- Defines who can see the resource, can be set to one of [‘private’, ‘tenant’, ‘global’] [default: tenant].
- -i, --icon-path TEXT- The path to the plugin’s icon file (must be a valid PNG image).
- --title TEXT- The plugin’s title, used e.g. in UI topology view.
All the mentioned paths (PLUGIN_PATH, --yaml-path's value and --icon-path's value) may be not only local filesystem paths, but also valid URLs (either http:// or https://).
Example
$ cfy plugins upload -y plugin.yaml -i https://cloudify.co/wp-content/uploads/2019/08/aws-1.png cloudify_aws_plugin-1.4.4-py27-none-linux_x86_64-centos-Core.wgn
...
Validating plugin cloudify_aws_plugin-1.4.4-py27-none-linux_x86_64-centos-Core.wgn...
Plugin validated successfully
Uploading plugin cloudify_aws_plugin-1.4.4-py27-none-linux_x86_64-centos-Core.wgn...
 cloudify_aws_plug... |################################################| 100.0%
Plugin uploaded. The plugin's id is e90b1a09-6b56-4a92-b9cd-5fc4ef32ab74
...download
Usage
cfy plugins download [OPTIONS] PLUGIN_ID
Download a plugin from Cloudify Manager.
PLUGIN_ID is the ID of the plugin to download.
Optional flags
- -o, --output-path TEXT- The local path for the download.
- -t, --tenant-name TEXT- The name of the tenant of the plugin. If unspecified, the current tenant is used.
Example
$ cfy plugins download e90b1a09-6b56-4a92-b9cd-5fc4ef32ab74
...
Downloading plugin e90b1a09-6b56-4a92-b9cd-5fc4ef32ab74...
 e90b1a09-6b56-4a9... |################################################| 100.0%
Plugin downloaded as e90b1a09-6b56-4a92-b9cd-5fc4ef32ab74.tar.gz
...delete
Usage
cfy plugins delete [OPTIONS] PLUGIN_ID
Delete a plugin from Cloudify Manager.
PLUGIN_ID is the ID of the plugin to be deleted.
Optional flags
- -f, --force- Delete the plugin, even if there are deployments that are currently using it.
- -t, --tenant-name TEXT- The name of the tenant of the plugin. If unspecified, the current tenant is used.
Example
$ cfy plugins delete e90b1a09-6b56-4a92-b9cd-5fc4ef32ab74
...
Deleting plugin e90b1a09-6b56-4a92-b9cd-5fc4ef32ab74...
Plugin deleted
...list
Usage
cfy plugins list [OPTIONS]
List all available plugins on Cloudify Manager. You can use this command to retrieve the IDs of the plugins you want to download or delete.
Optional flags
- --sort-by TEXT- Key for sorting the list.
- --descending- Sort list in descending order. [default: False]
- -t, --tenant-name TEXT- The name of the tenant from which to list the plugins. If unspecified, the current tenant is used. This argument cannot be used simultaneously with the- all-tenantsargument.
- -a, --all-tenants- Include resources from all tenants associated with the user. This argument cannot be used simultaneously with the- tenant-nameargument.
- --search TEXTSearch plugins by package-name. The returned list will include only plugins that contain the given search pattern.
- --get-dataWhen set to True, displays the full list of connected resources (users/tenants/user-groups), for each listed resource. When set to False displays the total number of connected resources. (default:False)
- -o, --pagination-offset INTEGERThe number of resources to skip; –pagination-offset=1 skips the first resource [default: 0]
- -s, --pagination-size INTEGERThe max number of results to retrieve per page [default: 1000]
Example
$ cfy plugins list
...
Listing all plugins...
Plugins:
+--------------------------------------+---------------------+-----------------+--------------+--------------------+----------------------+--------------------------+------------+----------------+------------+
|                  id                  |     package_name    | package_version | distribution | supported_platform | distribution_release |       uploaded_at        | visibility |  tenant_name   | created_by |
+--------------------------------------+---------------------+-----------------+--------------+--------------------+----------------------+--------------------------+------------+----------------+------------+
| e90b1a09-6b56-4a92-b9cd-5fc4ef32ab74 | cloudify-aws-plugin |      1.4.4      |    centos    |    linux_x86_64    |         core         | 2017-04-04 07:02:54.526  |   tenant   | default_tenant |   admin    |
+--------------------------------------+---------------------+-----------------+--------------+--------------------+----------------------+--------------------------+------------+----------------+------------+
...get
Usage
cfy plugins get [OPTIONS] PLUGIN_ID
Retrieve information for a specific plugin.
PLUGIN_ID is the ID of the plugin for which to retrieve information.
Optional flags
- -t, --tenant-name TEXT- The name of the tenant of the plugin. If unspecified, the current tenant is used.
- --get-data- When set to True, displays the full list of connected resources (users/tenants/user-groups), for each listed resource. When set to False displays the total number of connected resources. (default:False)
Example
$ cfy plugins get e90b1a09-6b56-4a92-b9cd-5fc4ef32ab74
...
Retrieving plugin e90b1a09-6b56-4a92-b9cd-5fc4ef32ab74...
Plugin:
+--------------------------------------+---------------------+-----------------+--------------+--------------------+----------------------+--------------------------+------------+----------------+------------+
|                  id                  |     package_name    | package_version | distribution | supported_platform | distribution_release |       uploaded_at        | visibility |  tenant_name   | created_by |
+--------------------------------------+---------------------+-----------------+--------------+--------------------+----------------------+--------------------------+------------+----------------+------------+
| e90b1a09-6b56-4a92-b9cd-5fc4ef32ab74 | cloudify-aws-plugin |      1.4.4      |    centos    |    linux_x86_64    |         core         | 2017-04-04 07:02:54.526  |   tenant   | default_tenant |   admin    |
+--------------------------------------+---------------------+-----------------+--------------+--------------------+----------------------+--------------------------+------------+----------------+------------+
...validate
Usage
cfy plugins validate [OPTIONS] PLUGIN_PATH
Validate a plugin.
This validates that the plugin’s archive is not corrupted. A valid plugin is a wagon (http://github.com/cloudify-cosomo/wagon) in the tar.gz format.
PLUGIN_PATH is the path to wagon archive to validate.
Example
$ cfy plugins validate cloudify_aws_plugin-1.4.4-py27-none-linux_x86_64-centos-Core.wgn
...
Validating plugin cloudify_aws_plugin-1.4.4-py27-none-linux_x86_64-centos-Core.wgn...
Plugin validated successfully
...set-visibility
Usage
cfy plugins set-visibility [OPTIONS] PLUGIN_ID
Set the plugin’s visibility
PLUGIN_ID - The id of the plugin to update.
Required flags
- -l, --visibility TEXT- Defines who can see the resource, can be set to one of [‘tenant’, ‘global’].
Example
$ cfy plugins set-visibility e90b1a09-6b56-4a92-b9cd-5fc4ef32ab74 -l global
...
Plugin `e90b1a09-6b56-4a92-b9cd-5fc4ef32ab74` was set to global
...set-owner
Usage
cfy plugins set-owner [OPTIONS] PLUGIN_ID
Change ownership of a plugin.
PLUGIN_ID - The id of the plugin to update.
Optional flags
- -s, --username USERNAME- The name of the user who will be the new owner of the resource. [required]
Example
$ cfy plugins set-owner e90b1a09-6b56-4a92-b9cd-5fc4ef32ab74 -s admin
...
Plugin `e90b1a09-6b56-4a92-b9cd-5fc4ef32ab74` is now owned by user `admin`.
...blueprint-labels
blueprint-labels list
cfy plugins blueprint-labels list [OPTIONS] PLUGIN_ID
List blueprint labels for specific plugin.
PLUGIN_ID is the id of the plugin.
blueprint-labels add
cfy plugins blueprint-labels add [OPTIONS] LABELS_LIST PLUGIN_ID
Add blueprint labels for specific plugin.
PLUGIN_ID is the id of the plugin.
LABELS_LIST is a list in <label1>:<value1>,<label2>:<value2> format of labels.  Any backslash,
comma and colon in <value> must be escaped with \.
blueprint-labels delete
cfy plugins blueprint-labels delete [OPTIONS] LABEL PLUGIN_ID
Delete blueprint labels from specific plugin.
PLUGIN_ID is the id of the plugin.
LABEL can either be a list of labels in <label1>:<value1>,<label2>:<value2> format, or just a
<label1> string.  In case the former is used, only specified values are going to be removed from
list of plugin’s labels.  If <value> is not specified, then whole <label> is deleted.  Any
backslash, comma and colon in <value> must be escaped with \.
deployment-labels
deployment-labels list
cfy plugins deployment-labels list [OPTIONS] PLUGIN_ID
List deployment labels for specific plugin.
PLUGIN_ID is the id of the plugin.
deployment-labels add
cfy plugins deployment-labels add [OPTIONS] LABELS_LIST PLUGIN_ID
Add deployment labels for specific plugin.
PLUGIN_ID is the id of the plugin.
LABELS_LIST is a list in <label1>:<value1>,<label2>:<value2> format of labels.  Any backslash,
comma and colon in <value> must be escaped with \.
deployment-labels delete
cfy plugins deployment-labels delete [OPTIONS] LABEL PLUGIN_ID
Delete deployment labels from specific plugin.
PLUGIN_ID is the id of the plugin.
LABEL can either be a list of labels in <label1>:<value1>,<label2>:<value2> format, or just a
<label1> string.  In case the former is used, only specified values are going to be removed from
list of plugin’s labels.  If <value> is not specified, then whole <label> is deleted.  Any
backslash, comma and colon in <value> must be escaped with \.
resource-tags
resource-tags list
cfy plugins resource-tags list [OPTIONS] PLUGIN_ID
List resource tags for specific plugin.
PLUGIN_ID is the id of the plugin.
resource-tags add
cfy plugins resource-tags add [OPTIONS] KEY_VALUES PLUGIN_ID
Add resource tags for specific plugin.
PLUGIN_ID is the id of the plugin.
KEY_VALUES is a list in <key1>:<value1>,<key2>:<value2> format of resource tags.  Any backslash,
comma and colon in <value> must be escaped with \.
resource-tags delete
cfy plugins resource-tags delete [OPTIONS] KEY PLUGIN_ID
Delete resource tags from specific plugin.
PLUGIN_ID is the id of the plugin.
KEY a string which identifies a resource tag to remove for the list associated with the  plugin.
bundle-upload
Usage
cfy plugins bundle-upload [OPTIONS]
Upload a bundle of plugins to Cloudify Manager.
Optional flags
- -p, --path TEXT- Path to a plugins bundle file or URL. If unspecified, a default URL is used.
Example
$ cfy plugins bundle-upload -p /dir/cloudify-plugins-bundle.tgz
...update
Usage
cfy plugins update [OPTIONS] (BLUEPRINT_ID|--all)
Update the plugins of all the deployments of the single blueprint in case BLUEPRINT_ID was
provided, or all blueprints of the current tenant in case --all flag was used instead.
BLUEPRINT_ID the blueprint’s ID to perform the plugins update with, mutually exclusive with
--all flag.
Optional flags
- --all-blueprints- Update the plugins used in all blueprints accessible to the current tenant or tenant selected by- --tenant-name, or all tenants in case the- --all-tenantsflag was used.
- -a, --all-tenants- Include blueprints from all tenants associated with the user. You cannot use this argument with- --tenant-name.
- --except-blueprint TEXT- List of blueprint IDs to be excluded from all blueprints update (can be passed multiple times or take comma separated values).
- --plugin-name TEXT- Update only the specific plugin in all selected deployments (can be passed multiple times or take comma separated values).
- --to-latest TEXT- List of plugin names to be upgraded to the latest version (can be passed multiple times or take comma separated values).
- --all-to-latest- Update all (selected) plugins to the latest version of a plugin.
- --to-minor TEXT- List of plugin names to be upgraded to the latest minor version (can be passed multiple times or take comma separated values).
- --all-to-minor- Update all (selected) plugins to the latest minor version.
- --auto-correct-types- If set, before creating a plan for a new deployment, an attempt will be made to cast old inputs’ values to the valid types declared in blueprint.
- --reevaluate-active-statuses- After a failed plugins update the update metadata may get invalid. Reevaluate will correct the metadata based on the last known execution. The statuses of previous active update operations will be reevaluated based on relevant executions’ statuses.- terminatedexecutions will be mapped to- successfulupdates, while- failedand any- *cancel*statuses will be mapped to- failed. This flag is also passed down to the deployment update flows and has a similar effect on those.
- --manager TEXT- Connect to a specific manager by IP or host
- -q, --quiet- Show only critical logs
- --format [plain|json]
- -v, --verbose- Show verbose output. You can supply this up to three times (i.e. -vvv)
- --json
- -t, --tenant-name TEXT- The name of the tenant of the plugin. If not specified, the current tenant will be used
- --include-logs / --no-logs- Include logs in returned events [default: True]
- --json-output- Output events in a consumable JSON format
- -f, --force- Use the- --forceoption to allow an update to a deployment used as a component in another deployment. This flag applies to both direct deployment update and cascading update to components.
Example
$ cfy plugin update openstack_blueprint
...
Updating the plugins of the deployments of the blueprint openstack_blueprint
2019-06-16 15:59:50.843  CFY <None> Starting 'update_plugin' workflow execution
2019-06-16 15:59:50.845  CFY <None> Executing deployment update for deployment openstack_blueprint_deployment...
2019-06-16 15:59:55.880  CFY <None> update_plugin workflow execution succeeded
...get-update
Usage
cfy plugins get-update [OPTIONS] PLUGINS_UPDATE_ID
Retrieve information for a specific plugins update
PLUGINS_UPDATE_ID is the id of the plugins update to get information on.
Optional flags
- -q, --quiet- Show only critical logs
- --format [plain|json]
- -v, --verbose- Show verbose output. You can supply this up to three times (i.e. -vvv)
- --json
- -t, --tenant-name TEXT- The name of the tenant of the plugins update. If not specified, the current tenant will be used
Example
$ cfy plugin get-update 'bffee604-7133-43b0-9f5f-7a893bffd238'
...history
Usage
cfy plugins history [OPTIONS]
Show blueprint history by listing plugins updates
If --blueprint-id is provided, list plugins updates for that blueprint. Otherwise, list plugins updates for all blueprints.
Optional flags
- -b, --blueprint-id TEXT- The unique identifier for the blueprint
- --sort-by TEXT- Key for sorting the list
- --descending- Sort list in descending order [default: False]
- -t, --tenant-name TEXT- The name of the tenant to list plugins updates from. If not specified, the current tenant will be used. You cannot use this argument with arguments: [all_tenants]
- -a, --all-tenants- Include resources from all tenants associated with the user. You cannot use this argument with arguments: [tenant_name]
- --search TEXT- Search resources by name/id. The returned list will include only resources that contain the given search pattern
- -o, --pagination-offset INTEGER- The number of resources to skip; –pagination-offset=1 skips the first resource [default: 0]
- -s, --pagination-size INTEGER- The max number of results to retrieve per page [default: 1000]
- -q, --quiet- Show only critical logs
- --format [plain|json]
- -v, --verbose- Show verbose output. You can supply this up to three times (i.e. -vvv)
- --json
Example
$ cfy plugins history --blueprint-id 'fdse5u0d-6281-43h0-924f-7z693bflw945'
...