Recommended releases

Download Released

Key provides the ability to manage keys, which can be employed by other
modules. It gives site administrators the ability to define how and
where keys are stored, which allows the option of a high level of
security and allows sites to meet regulatory or compliance
requirements.

Examples of the types of keys that could be managed with Key are:

  • A password or API key for connecting to an external service, such as
    PayPal, MailChimp, Authorize.net, UPS, an SMTP mail server, or Amazon
    Web Services
  • A key used for encrypting data

Requirements

Key requires the Plugin Manager
module.

Installation

Install Key using a standard method for installing a contributed Backdrop
module.

Configuration

Key provides an administration page where users with the "administer
keys" permission can add, edit, and delete keys.

Key type

A key type can be selected for a key in order to indicate the purpose
of the key. The following key types are included with Key:

  • Authentication: A generic key type to use for a password or API
    key that does not belong to any other defined key type. This is the
    default.
  • Encryption: Can be used for encrypting and decrypting data. This
    key type has a field for selecting a key size, which is used to
    validate the size of the key value.

Key types are Plugin Manager plugins, so new types can be defined easily.

Key provider

A key provider is the means by which the key value is stored and/or
provided when needed. The following key providers are included with
Key:

  • Configuration: Stores the key in Backdrop configuration settings.
    The key value can be set, edited, and viewed through the administrative
    interface, making it useful during site development. However, for
    better security on production websites, keys should not be stored in
    configuration. Keys using the Configuration provider are not obscured
    when editing, making it even more important that this provider not be
    used in a production environment.
  • File: Stores the key in a file, which can be anywhere in the file
    system, as long as it's readable by the user that runs the web server.
    Storing the key in a file outside of the web root is generally more
    secure than storing it in the database.

Both the Configuration and File provider plugins support storing the
key with Base64 encoding.

Key providers are Plugin Manager plugins, so new providers can be defined
easily.

Key input

When adding or editing a key, if the selected key provider accepts a
key value, a key input is automatically selected, as defined by the key
type, in order to submit a key value. The following key inputs are
included with Key:

  • None: This input is used by default when the selected key
    provider does not accept a key value. The File key provider uses this
    input.
  • Text Field: This input provides a basic text field for submitting
    a key value. The Configuration key provider uses this input.
  • Textarea Field: This input is the same as the text field input,
    except it uses a textarea HTML element, so it's useful for longer keys,
    such as SSH keys.

The Text Field and Textarea Field input plugins support the submission
of keys that are Base64-encoded.

Key inputs are Plugin Manager plugins, so new inputs can be defined easily.

Generating a Random Encryption Key

Encryption keys have options for key size. The default key size
is 256 bits, with 8 bits per byte. For example, a string like
12345678901234567890123456789012 has 32 characters/bytes or 256 bits. There is
also an option for specifying if the key was Base64-encoded. Base64 is used here
to encode arbitrary bytes which are known to be safe to send without getting
corrupted.

One way to generate a random encryption key in a Unix environment is to
enter the following command (changing the path and file name to suit your
needs):

dd if=/dev/urandom bs=32 count=1 > /path/to/secret.key

This will create a binary file with a random 256-bit key. For a 128-bit key,
change the 32 to 16 in the command. For simplification, consider the "bs" (byte)
to equal a character.

To use base64 encoding when generating the key, use:

dd if=/dev/urandom bs=32 count=1 | base64 -i - > path/to/secret.key

Alternatively, you could also create your own 32 character string and search
online for a site that can base64 encode it. Then save it to text file that is
outside the web root and enter the path to the key in the key settings.

Integrating Modules

The following modules have not been ported to Backdrop at this time, but allow
keys to be stored on a designated external key management server:

For Developers

Creating a key will have no effect unless another module makes use of
it. That integration would typically present itself to the end user in
the form of a field that lists available keys and allows the user to
choose one. This could appear, for instance, on the integrating
module's configuration page.

Modules can add a key field to a form using the key_select API element,
which behaves like a select element, but is populated with available
keys as options.

$form['secret_key'] = array(
  '#type' => 'key_select',
  '#title' => t('Secret key'),
);

There are a couple of additional properties that can be used:

  • #key_filters An array of filters to apply to the list of keys.
    Currently, filtering is quite basic, though it will be improved. You can
    filter on key type and/or key provider. Examples:

    • #key_filters = ['type' => 'mailchimp'] This would only display
      MailChimp keys.
    • #key_filters = ['provider' => 'file'] This would only display keys
      that use the File key provider.
    • #key_filters = ['type' => 'mailchimp', 'provider' => 'file']
      This would only display MailChimp keys that use the File key provider.
  • #key_description This is a boolean value that determines if information
    about keys is added to the element's description. It is TRUE by default
    and it prepends the description with the following text (with a link to
    the add key form), which can be disabled by setting #key_description to 
    FALSE:

    Choose an available key. If the desired key is not listed, create a new
    key.

Modules can retrieve configuration for all keys, configuration for a specific
key or the value of a specific key:

Get all key configurations

key_get_keys()

Get a specific key configuration

key_get_key($key_id)

Get a specific key value

key_get_key_value($key_id)

License

This project is GPL v2 software. See the LICENSE.txt file in this directory for
complete text.

Maintainers

Credits

Ported to Backdrop by Herb v/d Dool and
Justin Keiser.

Drupal version currently maintained by: