The OpenVMS BACKUP utility provides protection against file
or volume corruption by creating functionally equivalent backup copies.
Files created by BACKUP are called save sets and are written in BACKUP format so that only BACKUP can interpret
the data in a save set.When you create save sets, you can also encrypt
them by using the  BACKUP /ENCRYPT command. 
|  | 
|  |  | 
|  | 
|  | NOTE: Standalone BACKUP, which is a version of the BACKUP utility
that runs without the support of the OpenVMS operating system, does
not support the /ENCRYPT qualifier. | 
|  | 
|  |  | 
|  | 
BACKUP /ENCRYPT requires a key. All the files in the save set
are encrypted  under the same key. When you use the /ENCRYPT qualifier
to specify a write  operation for an encrypted save set, the BACKUP
utility creates a key by  generating a 16-byte  random number from
the time of day and other transient data. To make this  random number
even more random, BACKUP encrypts this 16-byte value once using  itself
as a key with the DESCBC algorithm. The first eight bytes of the result
 are used as the encrypting key for the save set, and the second eight
bytes are  used as the initialization vector for the context area. 
One benefit of this procedure is that two save sets created
with the same command from the same set of files are not identical
in their encrypted form. 
You can override the system-generated encrypting key and initialization
vector by issuing either of the following commands:
- BACKUP  /ENCRYPT=(VALUE=key-value) 
For greater security, specify the /ENCRYPT qualifier
with no parameters. The  software prompts you for a key value. When
you enter it, the software does not  echo what you type and, for verification,
prompts you to retype the value. 
If you define a key with the ENCRYPT /CREATE_KEY command, specify
that key name on the BACKUP command line with the /ENCRYPT=(NAME=(key-name)) qualifier.
By default, BACKUP encrypts save set data using the DESCBC algorithm.
The key and algorithm you specify to override the defaults are used
to encrypt only  the data key and the initialization vector. 
BACKUP places the result of the encryption operation in the
save set as a BACKUP attribute subrecord of the BACKUP summary record.
At the time of a save set restore or listing operation, BACKUP uses
the system-generated key  or the key you supplied to decrypt the data
key and the initialization vector value. 
The BACKUP command qualifier /SAVE_SET is both an input save
set qualifier and an output save set qualifier, as follows:
- When you specify the /SAVE_SET and /ENCYRPT qualifiers
with an output save set specification, BACKUP writes file data (including
file names and attributes) in an encrypted form into the save set.  
- When you specify /SAVE_SET with an input save set
specification, BACKUP uses the decryption key specified to access
the file name, attributes, and data from the save set records. The
ENCRYPT option decrypts the data files after BACKUP reads the data
files from the save set medium and processes them according to the
remaining qualifiers of the BACKUP command.  
The following example creates an encrypted BACKUP file
of the default directory, as follows:
- ENCRYPT /CREATE_KEY defines a key, SANFRANCISCO, with
this value: A city set on a hill cannot be hid. 
- BACKUP /ENCRYPT saves all the files in the default
directory in a save set named 28JULSAVE.BCK and encrypts the save
set. - On device MKA600:, the data used to encrypt the file
names,  attributes, and all the other file data are encrypted with
the default  encryption algorithm DESCBC. The process uses the key
defined as SANFRANCISCO.  
| $ ENCRYPT /CREATE_KEY SANFRANCISCO "A city set on a hill cannot be hid" 
$ BACKUP /ENCRYPT=(NAME=SANFRANCISCO) * MKA600:28JULSAVE.BCK /SAVE_SET  | 
The following example creates a save set of the latest version
of all the files on a disk. The save set is encrypted using the DESCFB
algorithm and the key value Make peace.
| $ BACKUP /ENCRYPT=(VALUE="Make peace",ALGORITHM=DESCFB) *.* 28JULSAVE /SAVE_SET  | 
|  | 
| Restoring Files | 
|  | 
When you encrypt a save set, BACKUP does not store the information
within the save set. Consequently, to decrypt an encrypted save set,
specify /ENCRYPT with the RESTORE command so that BACKUP searches
for the data encryption control record. 
If you restore an unencrypted save set and mistakenly specify
/ENCRYPT,  BACKUP ignores the incorrect qualifier. If you try to restore
an encrypted saveset without the /ENCYRPT qualifier or with a key
name, you get the error  message:
| %BACKUP-F-ENCSAVSET, save set is encrypted, /ENCRYPT must be specified | 
The following commands restore file SALARY.DAT from a save set
created with a BACKUP /ENCRYPT command:
| $ ENCRYPT /CREATE_KEY CASTERBRIDGE "And all her shining keys"
$ BACKUP /ENCRYPT=(NAME=CASTERBRIDGE)
_$ From: MKA600:28JULSAVE.BCK /SELECT=SALARY.DAT
_$ To: SALARY28J.DAT | 
BACKUP tries to decrypt an encrypted save set by:
- Decrypting the encryption data that was saved in an
attribute subrecord.  
- Comparing a 32-bit checksum of the decrypted data
key with the stored value.  
- If there is a match, BACKUP assumes the data key is
valid and  restores the save set.  
- If BACKUP finds a mismatch, which is likely if the
data key or algorithm you specified in the BACKUP command is incorrect,
the utility displays:  
| %BACKUP-F-ENCKEYMAT, the supplied decryption key does not yield a readable save set | 
| Encrypting Distribution Files | 
|  | 
BACKUP /ENCRYPT can create a distribution disc that is useful
only to a customer who has the key used to encrypt the save sets in
the distribution kit.
In the following example, three keys are defined with ENCRYPT
/CREATE_KEY commands. With each of these keys, a software distribution
disc is created with each product encrypted into its respective save
set under a unique key. 
| $ ENCRYPT /CREATE_KEY SDXKEY "SDX V9.0 kit 99804034671838302" 
$ BACKUP /ENCRYPT=(NAME=SDXKEY) /REWIND - 
_From: MASTER:[SDXKIT]*.* MKA600:SDXKIT /SAVE_SET 
$ ENCRYPT /CREATE_KEY RQPKEY "RQP V4.5 kit FWTEBCJDITROEMMKAZXRYTC" 
$ BACKUP /ENCRYPT=(NAME=RQPKEY) - 
_From: MASTER:[RQPKIT]*.* MKA600:RQPKIT /SAVE_SET 
$ ENCRYPT /CREATE_KEY WOLKEY "WOL V2.0 kit 28374UEJDTLHGD84JF849SK95KD0" 
$ BACKUP /ENCRYPT=(NAME=WOLKEY) - 
_From: MASTER:[WOLKIT]*.* MKA600:WOLKIT /SAVE_SET  | 
The resulting save sets can be restored on a customer's
system only if the  customer has received the appropriate key by licensing
arrangement.
For example, the following commands restore save set WOLKIT:
| $ ENCRYPT /CREATE_KEY WOLKEY "WOL V2.0 kit 28374UEJDTLHGD84JF849SK95KD0" 
$ BACKUP /ENCRYPT=(NAME=WOLKEY) MKA600:WOLKIT /SAVE_SET SYSTEM:[RQPKIT]*.*  | 
In the following example, the save set SDXKIT is restored without
typing the  key name and key value on the command line. Instead, the
BACKUP  /ENCRYPT command prompts for this information, which is not
echoed on  your screen. 
| $ BACKUP /ENCRYPT /REWIND MKA600:SDXKIT /SAVE_SET SYSTEM:[SDXKIT]*.* 
Enter Key Value: (input not echoed) 
Verify: (input not echoed)  |