Python API

Crypto

class RPA.Crypto.Crypto(encryption_type: str | EncryptionType | None = None)

Library for common encryption and hashing operations.

Library uses by default the Fernet format for encryption. More specifically, it uses AES in CBC mode with a 128-bit key for encryption and HMAC with SHA256 for authentication.

Alternative encryption format for the library is AES256.

To use the encryption features, generate a key with the command line utility rpa-crypto or with the keyword Generate Key. Store the key in a secure place, such as Robocorp Vault, and load it within the execution before calling encryption/decryption keywords.

Example usage with Robocorp Vault

Create an encryption key with the CLI utility:

> rpa-crypto key
rGx1edA07yz7uD08ChiPSunn8vaauRxw0pAbsal9zjM=

Store the key in Robocorp Vault, in this case with the name EncryptionKey.

Load the key from the vault before encryption operations:

Use encryption key from vault    EncryptionKey
${encrypted}=   Encrypt file    orders.xlsx
Add work item file    ${encrypted}    name=Orders

In another task, this same key can be used to decrypt the file:

Use encryption key from vault    EncryptionKey
${encrypted}=    Get work item file    Orders
${orders}=   Decrypt file    ${encrypted}
ROBOT_LIBRARY_DOC_FORMAT = 'REST'
ROBOT_LIBRARY_SCOPE = 'GLOBAL'
decrypt_file(path: str, output: str | None = None, encryption_type: str | EncryptionType | None = None) str

Decrypt a file.

Parameters:
  • path – Path to encrypted input file

  • output – Path to decrypted output file

Returns:

Path to the decrypted file

If no output path is given, it will generate one from the input path. The resulting output path is returned.

Example:

Use encryption key    ${key}
${path}=    Decrypt file    orders.xlsx.enc
Log    Path to decrypted file is: ${path}
decrypt_string(data: bytes | str, encoding: str = 'utf-8', encryption_type: str | EncryptionType | None = None) str | bytes

Decrypt a string.

Parameters:
  • data – Encrypted data as base64 string

  • encoding – Original encoding of string

Returns:

Decrypted string or raw bytes, if None given as encoding

Returns the decrypted string that is parsed with the given encoding, or if the encoding is None the raw bytes are returned.

Example:

Use encryption key    ${key}
${text}=    Decrypt string    ${token}
Log    Secret string is: ${text}
encrypt_file(path: str, output: str | None = None, encryption_type: str | EncryptionType | None = None) str

Encrypt a file.

Parameters:
  • path – Path to source input file

  • output – Path to encrypted output file

Returns:

Path to the encrypted file

If no output path is given, it will generate one from the input path. The resulting output path is returned.

Example:

Use encryption key    ${key}
${path}=    Encrypt file    orders.xlsx
Log    Path to encrypted file is: ${path}
encrypt_string(text: bytes | str, encoding: str = 'utf-8', encryption_type: str | EncryptionType | None = None) bytes

Encrypt a string.

Parameters:
  • text – Source text to encrypt

  • encoding – Used text encoding

Returns:

Token of the encrypted string in bytes

Example:

Use encryption key    ${key}
${token}=    Encrypt string    This is a secret, don't share it
generate_key(encryption_type: str | EncryptionType | None = None) str

Generate a Fernet encryption key as base64 string.

Returns:

Generated key as a string

This key can be used for encryption/decryption operations with this library.

NOTE: Store the generated key in a secure place! If the key is lost, the encrypted data can not be recovered. If anyone else gains access to it, they can decrypt your data.

hash_file(path: str, method: Hash = Hash.SHA1) str

Calculate a hash from a file, in base64 format.

Parameters:
  • path – Path to file

  • method – The used hashing method

Returns:

Hash digest of the file

Example:

${digest}=    Hash file    orders.xlsx    method=MD5
Should not be equal    ${digest}    uSlyRHlbu8NzY29YMZhDUpdErP4=
hash_string(text: str, method: Hash = Hash.SHA1, encoding='utf-8') str

Calculate a hash from a string, in base64 format.

Parameters:
  • text – String to hash

  • method – Used hashing method

  • encoding – Used text encoding

Returns:

Hash digest of the string

Example:

${digest}=    Hash string    A value that will be hashed
Should be equal    ${digest}    uSlyRHlbu8NzY29YMZhDUpdErP4=
use_encryption_key(key: bytes | str, encryption_type: str | EncryptionType | None = None) None

Set key for all following encryption/decryption operations.

Parameters:

key – Encryption key as base64 string

Assumes the given key has been generated previously using either the keyword Generate Key or with the matching command line utility.

Example:

${key}=    Read file    encryption.key
Use encryption key      ${key}
use_encryption_key_from_vault(name: str, key: str | None = None, encryption_type: str | EncryptionType | None = None) None

Load an encryption key from Robocorp Vault.

Parameters:
  • name – Name of secret in Vault

  • key – Name of encryption key in secret

If the secret only has one value, the key argument is optional.

Example:

# Secret with one value
Use encryption key from vault    Encryption
# Secret with multiple values
Use encryption key from vault    name=Encryption    key=CryptoKey