Ability to map specific values from multi-value keys to config overrides

Created on 12 May 2018, over 6 years ago
Updated 5 September 2023, over 1 year ago

I'd like a way to map elements of a multi-value key to a config override.

A use case is AWS key pairs - most modules have the key id and secret as two separate configs. On the config override form, if the selected key entity is a multi-value type, there should be a new textfield to specify the key within the json object to use.

If the json looked like this:

{
  "access_key":"AKIAJWVN5Z4FOFT7NLNA",
  "secret_key":"R4nm063hgMVo4BTT5xOs5nHLeLXA6lar7ZJ3Nt0i"
}

You would specify "access_key" in the new textfield in this example, and "secret_key" in another config override mapping the aws secret.

Feature request
Status

Needs review

Version

1.0

Component

Code

Created by

🇦🇺Australia nicksanta

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Comments & Activities

Not all content is available!

It's likely this issue predates Contrib.social: some issue and comment data are missing.

  • First commit to issue fork.
  • Open in Jenkins → Open on Drupal.org →
    Core: 9.5.x + Environment: PHP 8.0 & MySQL 5.7
    last update over 1 year ago
    8 pass
  • @lind101 opened merge request.
  • Status changed to Needs review over 1 year ago
  • 🇬🇧United Kingdom lind101

    Ran into a similar issue when storing user login credentials. I used a `user_password` KeyType to store the key data and needed to override a `credentials => ['username' => '', 'password' => '']` config structure with the key.

    Decided to go a slightly different route in MR15 than that suggested approach, and just allow whole sections of config to be overriden by a key if needed rather than picking out individual values.

  • 🇬🇧United Kingdom lind101

    MR15 will be a breaking change for anyone using a serialized mutivalue key in it's entirety as a config override (Not sure if this would actually work in reality, but it can currently be configure that way).

    Unfortuantly there is no easy way to address this. I did explore adding a new field to the KeyConfigOverride and only unseriaziling if it was set, but by the time the override value is actually set in KeyConfigOverride::loadOverrides we have lost context of which KeyConfigOverride entity supplied to override, meaing we can't use any of it's properties to influence the setting of the value.

    Incidently this also means that the suggested approach of mapping to a specific field on a multivalue key will also not work.

    The only way that I can see around this is to change the KeyConfigOverride::getMapping method to store the KeyConfigOverride id rather than the Key ID and then retrieve the key id (and any associated config we need) in KeyConfigOverride::loadOverrides. But that would probably result in all existing KeyConfigOverride breaking, very much a bigger change.

Production build 0.71.5 2024