CyberArk Vault Integration

You can integrate Control-M with a CyberArk vault where you store and manage sensitive information (called secrets), such as passwords, access keys, or security keys. This integration enables Agents to retrieve secrets from your vault only when they connect to your plug-in application servers and execute jobs, so that sensitive information is not saved in Control-M components. Control-M communicates with the CyberArk vault via either of the following methods:

  • CyberArk SDK Agent: A local CyberArk Software Development Kit (SDK) credential provider (CP) that is installed on an Agent, as shown in the following diagram:

  • REST: A third-party CyberArk credential provider (CACP) that is stored in a third-party vault, as shown in the following diagram:

To set up a CyberArk vault integration, see Setting Up a CyberArk Vault Integration.

You can use secrets from your CyberArk vault in password-type fields in centralized connection profiles for the following:

During the creation or configuration of a centralized connection profile, the Use External Vault option enables you to locate and retrieve a secret for any password-type field in the connection profile parameters, as described in CyberArk Secret Parameters in Connection Profiles.

Setting Up a CyberArk Vault Integration

This procedure describes how to set up a CyberArk vault integration, which enables you to configure vault integration parameters and select the vault integrations that appear in Control-M SaaS.

Before You Begin

  • Verify that you have installed and configured one of the following CyberArk components:

    • SDK Communication: CyberArk Credential Provider (CP) version 12.1 or higher on the Agent host machine

    • REST Communication: CyberArk Central Credential Provider (CCP) version 12.1 or higher

  • For REST communication with CyberArk CCP through a proxy, ensure that proxy server settings are defined for the Agent, as described in Proxy Server Configuration, and that an agproxy.json file was generated by the Agent.

  • Use of more than one application (identified by AppID) per Agent is not recommended for security reasons.

Begin

  1. Open a command prompt window where your Agent is installed.

  2. Run the Vault Configuration (vault-cfg) utility and configure the integration of Control-M with the vault, as follows:

    For backward compatibility, you can use the Vault CLI (vault-cli) utility, which was provided in previous versions of Control-M, instead of the Vault Configuration (vault-cfg) utility.

    1. Navigate to the directory that contains the Vault Configuration utility:

      <AGENT_HOME>/ctm/cm/vault_cfg/

    2. Configure vault integration parameters by running one of the following commands:

      • Linux: ./vault-cfg.sh config update -p=<parameter> -v=<value>

      • Windows: vault-cfg.cmd config update -p=<parameter> -v=<value>

      Repeat this command for each parameter that you want to update. For descriptions of the CyberArk Vault integration parameters, see CyberArk Vault Integration Parameters for SDK Communication or CyberArk Vault Integration Parameters for REST Communication.

      • For certain parameters, you must recycle the Control-M plug-in (either Control-M MFT or Control-M Application Integrator) after changing the parameter value, as indicated in CyberArk Vault Integration Parameters for SDK Communication or CyberArk Vault Integration Parameters for REST Communication.

      • If you want to use your own server certificate, rather than trusting all server certificates, set the cyberark.rest.disable.trustall parameter to true (instead of the default false).

        After you create a keystore and import your server certificate in the next step, you must also configure the truststore.name, truststore.password, and truststore.type parameters.

      • If you want client certificate authentication when you use a REST connection, copy your private key into the same directory (<AGENT_HOME>/ctm/cm/vault_cfg/), and then configure the following parameters:

        • cyberark.<APPID>.client.certificate.password

        • cyberark.<APPID>.client.certificate.name

        • cyberark.<APPID>.client.certificate.type

      • After you configure the vault integration parameters, you can display the current parameter values by running one of the following commands:

        • Linux: ./vault-cfg.sh config display

        • Windows: vault-cfg.cmd config display

      • If you want to delete your settings and disable the vault integration, use one of the following commands:

        • Linux: ./vault-cfg.sh config delete

        • Windows: vault-cfg.cmd config delete

    3. If you want to use your own server certificate, create a keystore in this directory and import a server certificate for it, as follows:

      1. Generate a new keystore in PKCS#12 format using the following command:

        keytool -genkeypair -alias <keystoreAlias> -keyalg RSA -keysize 2048 -storetype PKCS12 -keystore /ctm/cm/vault_cfg/<your_keystore>.p12 -storepass <your_password>

      2. Import a server certificate using the following command:

        keytool -importcert -trustcacerts -alias <serverCertAlias> -file /home/path/<your_server_certificate>.cer -keystore /ctm/cm/vault_cfg/<your_keystore>.p12 -storepass <server_certificate_password>

      3. Import a root CA certificate using the following command:

        keytool -importcert -trustcacerts -alias <rootCAAlias> -file /home/path/<root_ca_certificate>.cer -keystore /ctm/cm/vault_cfg/<your_keystore>.p12 -storepass <root_ca_certificate_password>

    4. Test the connection to your vault by running one of the following commands:

      • Linux: ./vault-cfg.sh test -f=<secret_parameters_file>

      • Windows: vault-cfg.cmd test -f=<secret_parameters_file>

      Where <secret_parameters_file> is the path to a file that defines values for secret parameters in JSON format, as shown in the following example:

      Copy
      {
         "Type": "Secret:CyberArkVault:Basic",
         "AppID": "finance",
         "Safe": "financeDept",
         "Folder": "Root",
         "Account": "oracleSalaryService",
         "Reason": "I need it to export salaries for VP"
      }

      These parameters are described in CyberArk Secret Parameters in Connection Profiles. For a similar JSON format used by Control-M Automation API, see External Vault Secrets.

      For a list of possible return codes for the connection test, see CyberArk Vault Connection Return Codes.

  3. Select the vault integrations to appear in Control-M SaaS to use in centralized connection profiles, as described in Configuring System Settings.

    By default, all supported vault integrations are available when you want to retrieve secrets for password-type fields in connection profiles. Use this procedure to hide any integrations that are not relevant to you from appearing in the user interface.

    The selection of vault integrations does not affect the following:

    • Existing connection profile fields that are already configured to retrieve secrets from vault integrations that are no longer enabled.

    • JSON references to secrets used by Control-M Automation API. For more information, see Secrets in Code.

CyberArk Vault Integration Parameters for SDK Communication

The following table lists the CyberArk Vault integration parameters that you can configure using the Vault CLI utility when you use SDK communication to connect with CyberArk CP. For each parameter, the table indicates whether you need to recycle the component (Control-M MFT or Application Integrator) after changing the parameter value.

You must type all parameter names in lowercase.

Parameter

Description

Recycle Required?

provider.name

Determines the vault provider and enables vault integration.

For integration with a CyberArk vault, set the value to cyberark

Mandatory. No default.

Yes

communication.type

Defines the type of communication with CyberArk.

Values:

  • SDK: Connection to CyberArk Credential Provider

  • REST: Connection to CyberArk Central Credential Provider

Default: SDK

Yes, when changed to SDK

cyberark.connection.port

Defines the CyberArk Credential Provider connection port.

Default: 18923

No

cyberark.connection.timeout

Determines the number of seconds to wait before the CyberArk Credential Provider connection times out.

Default: 30

No

cyberark.sdk.path

Defines the path to the directory that contains the CyberArk Credential Provider Java SDK, javapasswordsdk.jar (in Linux) or JavaPasswordSDK.jar (in Windows).

Supported CyberArk Credential Provider versions are 12.1 or higher.

Default:

  • Linux: /opt/CARKaim/sdk

  • Windows: <CP_installation_path>\CyberArk\ApplicationPasswordSdk

Yes

cyberark.retry.count

Determines the number of times to retry retrieving the up-to-date password from CyberArk when the account is in Password‑Change‑In‑Process state.

The retry interval is 1500 milliseconds.

If the change does not complete within the configured number of retries, retrieval fails so that the job will not use an outdated password.

Default: 3

Yes

CyberArk Vault Integration Parameters for REST Communication

The following table lists the CyberArk Vault integration parameters that you can configure using the Vault Configuration utility when you use REST communication to connect with CyberArk CCP. For each parameter, the table indicates whether you need to recycle the component (Control-M MFT or Application Integrator) after changing the parameter value.

You must type all parameter names in lowercase.

Parameter

Description

Recycle Required?

provider.name

Determines the vault provider and enables vault integration.

For integration with a CyberArk vault, set the value to cyberark

Mandatory. No default.

Yes

communication.type

Defines the type of communication with CyberArk.

Values:

  • SDK: Connection to CyberArk Credential Provider

  • REST: Connection to CyberArk Central Credential Provider

Default: SDK

Only when changed to SDK

cyberark.<APPID>.endpoint

Defines the CyberArk Vault REST Server endpoint for the specific AppID for a connection to CyberArk Central Credential Provider.

Mandatory. No default.

No

cyberark.<APPID>.client.certificate.password

Defines the client certificate password for the specific AppID, used together with the client certificate.

The password is encrypted.

No

cyberark.<APPID>.client.certificate.name

Defines the client certificate name for the specific AppID.

No

cyberark.<APPID>.client.certificate.type

Defines the client certificate type for the specific AppID.

Values:

  • JKS

  • PKCS12

Default: PKCS12

No

truststore.name

Defines the truststore name.

No

truststore.password

Defines the truststore password.

The password is encrypted.

No

truststore.type

Defines the truststore type.

Values:

  • JKS

  • PKCS12

Default: PKCS12

No

cyberark.<APPID>.os.user.authentication

Determines whether OS user authentication is used for the specific AppID.

Values:

  • true

  • false

Default: false

No

cyberark.rest.connection.timeout

Determines the number of seconds to wait before the CyberArk Central Credential Provider connection times out.

Default: 5

No

cyberark.rest.disable.trustall

Determines whether to disable trust of all server certificates.

Values:

  • true

  • false

Default: false

No

cyberark.rest.retry.count

Determines the number of times to retry retrieving the up-to-date password from CyberArk when the account is in Password‑Change‑In‑Process state.

If the change does not complete within the configured number of retries, retrieval fails so that the job will not use an outdated password.

Default: 3

Yes

cyberark.rest.retry.interval.millis

Determines the retry interval, that is, the number of seconds between attempts to retrieve an up-to-date password from CyberArk when the account is in Password‑Change‑In‑Process state.

Default: 1000

Yes

CyberArk Secret Parameters in Connection Profiles

The following tables describe the parameters that are used to locate and retrieve passwords or secrets from a CyberArk vault. These parameters appear when you select the Use External Vault option for any password-type field in the connection profile parameters. For the retrieval of the secret, you can choose between retrieval based on default CyberArk parameters or retrieval based on a query to CyberArk.

The following table describes parameters that are available for retrieval of a secret based on default CyberArk parameters.

Parameter

Description

Vault Integration

Determines one of the following vault types and/or methods to locate and retrieve the secret:

  • CyberArk Vault: Defines default CyberArk parameters.

  • CyberArk Vault - Query Based: Enables you to include additional CyberArk parameters.

AppID

Defines the unique ID of the application that issues the password request.

Maximum length: 128

Safe

Defines the name of the CyberArk Safe where the password is stored.

Maximum length: 28

Folder

(Optional) Defines the name of the folder where the password is stored.

Maximum length: 160

Default: Root

Account

Defines the name of the account (that is, the object name) to retrieve.

Maximum length: 165

Reason

(Optional) Defines the reason for the request.

Maximum length: 344

The following table describes parameters that are available for retrieval of a secret based on a query to CyberArk.

Parameter

Description

Vault Integration

Determines one of the following vault types and/or methods to locate and retrieve the secret:

  • CyberArk Vault: Defines default CyberArk parameters.

  • CyberArk Vault - Query Based: Enables you to include additional CyberArk parameters.

AppID

Defines the unique ID of the application that issues the password request.

Maximum Length: 128

Query

Defines a query for the location and retrieval of the secret. This query enables you to include additional CyberArk properties.

Maximum Length: 2,048 characters

The query has the following format:

Copy
property1=value1;property2=value2;property3=value3

Safe=financeDep;title=Sr;Department=IT

  • The query must uniquely define a single secret.

  • For more information about properties that you can include in the query, see CyberArk Documentation.

  • Properties and values are subject to CyberArk restrictions.

  • The query format is Exact. Regular expressions are not supported.

Reason

(Optional) Defines the reason for the request.

Maximum length: 344

CyberArk Vault Connection Return Codes

The following table lists return codes from connections to the CyberArk vault by either the Vault CLI utility connection test or during a job execution when Control-M attempts to locate and retrieve a secret.

Return Code

Description

0

Success (Ended OK)

1

General error

2

Incorrect use of shell builtins (for example, incorrect number of arguments)

11

Unexpected parameter

12

Mandatory parameter is missing

13

Type of vault integration is missing

20

Unsupported vault provider

21

Vault integration is not enabled on this component; the provider.name parameter is not set

30

Wrong SDK path

31

Failed to get the vault secret.

This return code might be accompanied by errors returned from the vault provider. For a list of errors from CyberArk, see the list of Application Provider Messages in CyberArk Documentation.

32

Wrong configuration parameter

41

Regular password, not Vault Secret Locator

51

Missing file permissions

61

Keystore is missing or missing keystore permissions

62

Failed to instantiate keystore

63

Failed to load keystore

64

Wrong keystore password

71

Wrong certificate passphrase

72

SSL issue

90

General error