При звонке на new pulumi.Config('someName')
хотелось бы получить массив секретов, которые находятся под someName:aValue
.
Я пытался вызвать что-то вроде const cfg = new pulumi.Config('someName')
, но после этого все методы этого класса требуют ключ (например, aValue), но это бесполезно, когда нужны все секреты под логическим именем.
пулуми.*.yaml
someName:someValue1:
secure: someSecureValue
someName:someValue2:
secure: someOtherSecureValue
какой-то файл.ts
const cfg = new pulumi.Config('someName')
С приведенным выше кодом я ищу список всех секретов под someName
.
Из документы:
Configuration values are always stored as strings, but can be parsed as richly typed values.
For richer structured data, the config.getObject method can be used to parse JSON values.
Для секретных значений есть функции getSecretObject()
и requireSecretObject()
. Для вашего примера вы бы сделали что-то вроде
pulumi config set --secret someName '{"someValue1": "someSecureValue", "someValue2": "someOtherSecureValue" }'
а затем прочитайте его с
const config = new pulumi.Config();
const someName = config.requireSecretObject("someName");
const someValue1 = someName.someValue1;
Очевидно, вы также можете использовать несколько секретов как отдельные ключи в файле конфигурации и извлекать их один за другим с помощью отдельных вызовов requireSecretObject
.
Массив будет настроен как
pulumi config set --secret someName '["someSecureValue", "someOtherSecureValue"]'
@shon Отредактировал его, чтобы использовать объект вместо массива
Спасибо за обновление, после того, как вы предоставили ссылку на документ, она указала мне правильное направление, и теперь, когда вы обновили ответ, я буду голосовать за этот. Спасибо.
В вашем примере показано someName с массивом секретов, но мне нужно несколько
someName:someValue1
иsomeName:someValue2
каждый со значением для сопоставления. Не уверен, что ваш пример иллюстрирует это, иначе я его упускаю.