/
AzureKeyVaultHelper.cs
47 lines (39 loc) · 1.41 KB
/
AzureKeyVaultHelper.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
using Azure.Identity;
using Azure.Security.KeyVault.Secrets;
using LightKeysTransfer.Abstract;
using LightKeysTransfer.Common;
using LightKeysTransfer.Entities;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace LightKeysTransfer.Implementation
{
internal class AzureKeyVaultHelper : IKeyTransferHelper
{
public string MainText => "Set or update secrets in Azure Key Vault";
public KeyTransferResult Perform()
{
try
{
Console.WriteLine("Enter name of the vault:");
var vault = Console.ReadLine();
var kvUri = $"https://{vault}.vault.azure.net";
Console.WriteLine("Enter key:");
var key = Console.ReadLine();
Console.WriteLine("Enter Secret:");
var secret = CryptHelper.GetSensitiveText();
var client = new SecretClient(new Uri(kvUri), new DefaultAzureCredential());
client.SetSecret(new KeyVaultSecret(key, secret));
Console.WriteLine($"The secret has been written for the key: {key} in vault: {vault}.");
}
catch (Exception e)
{
Console.WriteLine(e.Message);
return KeyTransferResult.Errored;
}
return KeyTransferResult.Success;
}
}
}