Version: v3.4.x LTS
zwe init certificate
zwe init certificate
zwe > init > certificate
zwe init certificate [parameter [parameter]...]
Description
This command will generate certificate used by Zowe services.
If you specify --update-config with this command, these configurations could
be written back to your Zowe YAML configuration file:
zowe.certificatebased on yourzowe.setup.certificateconfiguration.zowe.setup.security.productbased on the detected External Security Manager
These Zowe YAML configurations showing with sample values are used:
zowe:
setup:
jcl:
header: "123456"
dataset:
prefix: IBMUSER.ZWE
jcllib: IBMUSER.ZWE.CUST.JCLLIB
security:
product: RACF
groups:
admin: ZWEADMIN
users:
zowe: ZWESVUSR
certificate:
type: PKCS12
dname:
caCommonName:
commonName:
orgUnit:
org:
locality:
state:
country:
validity: 3650
pkcs12:
directory: /global/zowe/keystore
lock: true
name: localhost
password: password
caAlias: local_ca
caPassword: local_ca_password
import:
keystore:
password:
alias:
keyring:
owner:
name: ZoweKeyring
label: localhost
caLabel: localca
import:
dsName:
password:
connect:
user:
label:
zOSMF:
ca:
user: IZUSVR
san:
- zos.example.com
- internal-lpar1.zos.example.com
- internal-lpar2.zos.example.com
- internal-lpar3.zos.example.com
importCertificateAuthorities:
-
externalDomains:
- zos.example.com
verifyCertificates: STRICT
zOSMF:
host: zosmf.example.com
port: 443
zowe.setup.jcl.headeris optional additional JCL fields used for submitting JCLs.zowe.setup.certificate.typeis the type of certificate. Valid values are "PKCS12" (USS keystore) or "JCEKS", "JCECCAKS", "JCERACFKS", "JCECCARACFKS", and "JCEHYBRIDRACFKS (z/OS keyring).zowe.setup.certificate.dnameis the distinguished name of the certificate. You can definecaCommonName,commonName,orgUnit,org,locality,state, and / orcountry. These configurations are optional.zowe.setup.certificate.validityis the validity days of the certificate. This is optional.zowe.setup.certificate.sanis theSubject Alternative Name(s) of the certificate if they are different fromzowe.externalDomains. Please note, forJCEKS,JCECCAKS,JCERACFKS,JCECCARACFKS, andJCEHYBRIDRACFKStype, with limitation of RACDCERT command, this should contain exact one hostname (domain) and one IP address.zowe.setup.certificate.importCertificateAuthoritiesis the list of certificate authorities will be imported to Zowe PKCS12 keystore or keyring. Please note, for keyring type, only maximum 2 CAs are supported. If you are usingPKCS12certificate, this should be USS files in PEM format. If you are usingJCEKS,JCECCAKS,JCERACFKS,JCECCARACFKS, orJCEHYBRIDRACFKScertificate, this should be certificate labels on the z/OS system.zOSMF.hostandzOSMF.portis the z/OSMF service information. This is required if you are using z/OSMF as authentication service.zowe.verifyCertificatesindicates how Zowe should validate the certificate of services registered under Zowe APIML. Valid values are "STRICT", "NONSTRICT" or "DISABLED". If this is "STRICT", this command will try to validate the z/OSMF service certificate if z/OSMF is defined.
For PKCS12 certificate users,
zowe.setup.certificate.pkcs12.directoryis the directory where you plan to store the PKCS12 keystore and truststore. This is required ifzowe.setup.certificate.typeisPKCS12.zowe.setup.certificate.pkcs12.lockis a boolean configuration to tell if we should lock the PKCS12 keystore directory only for Zowe runtime user and group. Default value is true.zowe.setup.security.groups.adminandzowe.setup.security.users.zowewill be the default owner of keystore directory.- You can also define
name,password,caAliasandcaPasswordunderzowe.setup.certificate.pkcs12to customized keystore and truststore. These configurations are optional, but it is recommended to update them from default values. - Define
zowe.setup.certificate.pkcs12.import.keystoreif you already acquired certificate from other CA, stored them in PKCS12 format, and want to import into Zowe PKCS12 keystore. zowe.setup.certificate.pkcs12.import.passwordis the password for keystore defined inzowe.setup.certificate.pkcs12.import.keystore.zowe.setup.certificate.pkcs12.import.aliasis the original certificate alias defined inzowe.setup.certificate.pkcs12.import.keystore. After imported, the certificate will be saved as alias specified inzowe.setup.certificate.pkcs12.name.
For keyring certificate users,
zowe.setup.certificate.keyring.owneris the keyring owner. It's optional and default value iszowe.setup.security.users.zowe. If it's also not defined, the default value isZWESVUSR.zowe.setup.certificate.keyring.nameis the keyring name will be created on z/OS. This is required ifzowe.setup.certificate.typeis one ofJCEKS,JCECCAKS,JCERACFKS,JCECCARACFKS, orJCEHYBRIDRACFKS.- If you want to let Zowe to generate new certificate,
- You can also customize
labelandcaLabelunderzowe.setup.certificate.keyringif you want to generate new certificate. Default value oflabelislocalhostand default value ofcaLabelislocalca.
- You can also customize
- If you want to import certificate stored in MVS data set into Zowe keyring,
zowe.setup.certificate.keyring.connect.dsNameis required in this case. It tells Zowe the data set where the certificate is stored.zowe.setup.certificate.keyring.connect.passwordis the password when importing the certificate.- The certificate will be imported with label defined in
zowe.setup.certificate.keyring.label.
- If you want to connect existing certificate into Zowe keyring,
zowe.setup.certificate.keyring.connect.useris required and tells Zowe the owner of existing certificate. This field can have value ofSITE.zowe.setup.certificate.keyring.connect.labelis also required and tells Zowe the label of existing certificate.
- If
zowe.verifyCertificatesis notDISABLED, and z/OSMF host (zOSMF.host) is provided, Zowe will try to trust z/OSMF certificate.- If you are using
RACForTSSsecurity manager, Zowe will try to automatically detect the z/OSMF CA based on certificate owner specified byzowe.setup.certificate.keyring.zOSMF.user. Default value of this field isIZUSVR. If the automatic detection failed, you will need to definezowe.setup.certificate.keyring.zOSMF.caindicates what is the label of z/OSMF root certificate authority. - If you are using
ACF2security manager,zowe.setup.certificate.keyring.zOSMF.cais required to indicate what is the label of z/OSMF root certificate authority.
- If you are using
Examples
zwe init certificate -v -c /path/to/zowe.yaml
Parameters
| Full name | Alias | Type | Required | Help message |
|---|---|---|---|---|
| --allow-overwrite,--allow-overwritten | boolean | no | Allow overwritten existing MVS data set. | |
| --update-config | boolean | no | Whether to update YAML configuration file with initialization result. | |
| --ignore-security-failures | boolean | no | Whether to ignore security setup job failures. | |
| --security-dry-run,--dry-run | boolean | no | Generates and prints JCL but does not execute. |
Inherited from parent command
| Full name | Alias | Type | Required | Help message |
|---|---|---|---|---|
| --allow-overwrite,--allow-overwritten | boolean | no | Allow overwritten existing MVS data set. | |
| --skip-security-setup | boolean | no | Whether to skip security related setup. | |
| --security-dry-run,--dry-run | boolean | no | Generates JCL or displays actions to be taken on the system without modifying the system. | |
| --ignore-security-failures | boolean | no | Whether to ignore security setup job failures. | |
| --update-config | boolean | no | Whether to update YAML configuration file with initialization result. | |
| --jcl | boolean | no | Generates and submits JCL to drive the init command, rather than using USS utilities. | |
| --help | -h | boolean | no | Display this help. |
| --debug,--verbose | -v | boolean | no | Enable verbose mode. |
| --trace | -vv | boolean | no | Enable trace level debug mode. |
| --silent | -s | boolean | no | Do not display messages to standard output. |
| --log-dir,--log | -l | string | no | Write logs to this directory. |
| --config | -c | string | no | Path to Zowe configuration zowe.yaml file. |
| --configmgr | boolean | no | Deprecated. This behavior is always enabled. |
Errors
| Error code | Exit code | Error message |
|---|---|---|
| ZWEL0164E | 164 | Value of %s (%s) defined in Zowe YAML configuration file is invalid. Valid values are %s. |
| ZWEL0174E | 174 | Failed to generate certificate in Zowe keyring "%s/%s". |
| ZWEL0319E | 319 | zowe.setup.dataset.jcllib does not exist, cannot run. Run 'zwe init', 'zwe init generate', or submit JCL zowe.setup.dataset.prefix.SZWESAMP(ZWEGENER) before running this command. |
| ZWEL0201E | 201 | File %s does not exist. |
| ZWEL0326E | 326 | An error occurred while processing Zowe YAML config %s: |
Inherited from parent command
| Error code | Exit code | Error message |
|---|---|---|
| 100 | If the user pass --help or -h parameter, the zwe command always exits with 100 code. | |
| ZWEL0064E | 64 | failed to run command os.pipe - Cannot start component %s |
| ZWEL0101E | 101 | ZWE_zowe_runtimeDirectory is not defined. |
| ZWEL0102E | 102 | Invalid parameter %s. %s |
| ZWEL0103E | 103 | Invalid type of parameter %s. |
| ZWEL0104E | 104 | Invalid command %s. |
| ZWEL0105E | 105 | The Zowe YAML config file is associated to Zowe runtime "%s", which is not same as where zwe command is located. |
| ZWEL0106E | 106 | %s parameter is required. |
| ZWEL0107E | 107 | No handler defined for command %s. |
| ZWEL0108E | 108 | Zowe YAML config file is required. |
| ZWEL0109E | 109 | The Zowe YAML config file specified does not exist. |
| ZWEL0110E | 110 | Doesn't have write permission on %s directory. |
| ZWEL0111E | 111 | Command aborts with error. |
| ZWEL0112E | 112 | Zowe runtime environment must be prepared first with "zwe internal start prepare" command. |
| ZWEL0114E | 114 | Reached max retries on allocating random number. |
| ZWEL0115E | 115 | This command was submitted with FILE() or PARMLIB() syntax, which is only supported when JCL is also enabled. |
| ZWEL0116E | 116 | Could not delete existing dataset: %s |
| ZWEL0120E | 120 | This command must run on a z/OS system. |
| ZWEL0121E | 121 | Cannot find node. Please define NODE_HOME environment variable. |
| ZWEL0122E | 122 | Cannot find java. Please define JAVA_HOME environment variable. |
| ZWEL0123E | 123 | This function is only available in Zowe Containerization deployment. |
| ZWEL0131E | 131 | Cannot find key %s defined in file %s. |
| ZWEL0132E | 132 | No manifest file found in component %s. |
| ZWEL0133E | 133 | Data set %s already exists. |
| ZWEL0134E | 134 | Failed to find SMS status of data set %s. |
| ZWEL0135E | 135 | Failed to find volume of data set %s. |
| ZWEL0136E | 136 | Failed to APF authorize data set %s. |
| ZWEL0137E | 137 | z/OSMF root certificate authority is not provided (or cannot be detected) with trusting z/OSMF option enabled. |
| ZWEL0138E | 138 | Failed to update key %s of file %s. |
| ZWEL0139E | 139 | Failed to create directory %s. |
| ZWEL0140E | 140 | Failed to translate Zowe configuration (%s). |
| ZWEL0142E | 142 | Failed to refresh APIML static registrations. |
| ZWEL0144E | 144 | Cannot generate JCL with a header line greater than 80 characters. Line in error: %s. Please adjust this line in 'zowe.setup.jcl.header'. |
| ZWEL0151E | 151 | Failed to create temporary file %s. Please check permission or volume free space. |
| ZWEL0157E | 157 | %s (%s) is not defined in Zowe YAML configuration file. |
| ZWEL0158W | Failed to find job %s result. | |
| ZWEL0159E | 159 | Failed to modify %s. |
| ZWEL0160W | Failed to run JCL %s. | |
| ZWEL0160E | 160 | Failed to write to %s. Please check if target data set is opened by others. |
| ZWEL0161E | 161 | Failed to run JCL %s. |
| ZWEL0162E | 162 | Failed to find job %s result. |
| ZWEL0163E | 163 | Job %s ends with code %s. |
| ZWEL0164W | Job %s(%s) ends with code %s (%s). | |
| ZWEL0172E | Component %s has %s defined but the file is missing. | |
| ZWEL0173E | 173 | Please enter an IP address in either the subject alternative name (zowe.setup.certificate.san) or external domain (zowe.externalDomains) in the Zowe YAML configuration file. |
| ZWEL0200E | Failed to copy USS file %s to MVS data set %s. | |
| ZWEL0201E | File %s does not exist. | |
| ZWEL0202E | Unable to find samplib key for %s. | |
| ZWEL0203E | Env value in key-value pair %s has not been defined. | |
| ZWEL0300W | %s already exists. This %s will be overwritten. | |
| ZWEL0301W | %s already exists and will not be overwritten. For upgrades, you must use --allow-overwrite. | |
| ZWEL0316E | 316 | Invalid PARMLIB format %s. |
| ZWEL0322E | 322 | %s is not a valid directory. |
| ZWEL0326E | 326 | An error occurred while processing Zowe YAML config %s: |