-
Notifications
You must be signed in to change notification settings - Fork 185
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
initial change to keyvault tests . (#282)
* initial. * Initial version * Initial version * Initial version * Removed unused code.
- Loading branch information
Showing
8 changed files
with
322 additions
and
44 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
# Using GO Keyvault SDK with Managed identities | ||
|
||
In order to run examples/go-keyvault-msi-example.go, follow these steps: | ||
- Create a keyvaul and a secret | ||
- Create a managed identity | ||
- Set the environment variables | ||
- go run examples/go-keyvault-msi-example.go | ||
|
||
## Create a vault and a secret | ||
- Logon to the azure portal in to your subscription and create an user assigned managed id. | ||
- Create a vault, a secret and set a value for that secret | ||
- Take a note of the keyvault name and set the **KVAULT_NAME** environment variable. | ||
- Take a note of the secret name and set the **KVAULT_SECRET_NAME** environment variable. | ||
|
||
## Create a managed identity | ||
- Logon to the azure portal in to your subscription and create an user assigned managed id. | ||
data:image/s3,"s3://crabby-images/7dbb5/7dbb586d02b3abcdaf253d9fd20cb634a15cf4c5" alt="create-user-assigned-id" | ||
- Assign a contributor role to the managed identity. | ||
data:image/s3,"s3://crabby-images/7a6f4/7a6f40f44a37cb89a1fd23ea89df559e9c7d81bc" alt="msid-role-assignemnt-contributor" | ||
- Assign managed id to VM. | ||
data:image/s3,"s3://crabby-images/6e692/6e69256cd446a789e531696033f5ff8e78fe7e95" alt="add-id-to-vm" | ||
- Copy client ID and assign is to the environment **AZURE_CLIENT_ID** variable. | ||
data:image/s3,"s3://crabby-images/e397c/e397c9563547869e2754c9975db285b7cf0fdd72" alt="msid-client-id" | ||
|
||
## Set the environment variables | ||
```code | ||
AZURE_TENANT_ID: Your Azure tenant ID | ||
AZURE_CLIENT_ID: Your Azure client ID. This will be an app ID from your AAD. | ||
KVAULT_NAME: The name of your vault (just the name, not the full URL/path) | ||
KVAULT_SECRET_NAME to the secret's name. | ||
**Important note:** Do NOT set AZURE_CLIENT_SECRET. This example uses Managed identities. | ||
``` | ||
|
||
## Run examples/go-keyvault-msi-example.go | ||
On your terminal where you have the environment variables set: | ||
|
||
```code | ||
$cd ~/go/src/azure-sdk-for-go-samples/keyvault/examples | ||
$go run go-keyvault-msi-example.go | ||
KVAULT_NAME: mekv01 | ||
Listing secret names in keyvault: | ||
string | ||
mesecret | ||
newsecret | ||
KVAULT_SECRET_NAME: mesecret | ||
KVAULT_SECRET Value: mesecretvalue | ||
Setting 'newsecret' to 'newvalue' | ||
added/updated: https://mekv01.vault.azure.net/secrets/newsecret/13cd55828aaf40e990b970c3c4cd07cf | ||
Listing secret names in keyvault: | ||
string | ||
mesecret | ||
newsecret | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,163 @@ | ||
package main | ||
|
||
// Copyright (c) Microsoft and contributors. All rights reserved. | ||
// | ||
// This source code is licensed under the MIT license found in the | ||
// LICENSE file in the root directory of this source tree. | ||
// | ||
// | ||
// You need to set four environment variables before using the app: | ||
// AZURE_TENANT_ID: Your Azure tenant ID | ||
// AZURE_CLIENT_ID: Your Azure client ID. This will be an app ID from your AAD. | ||
// KVAULT_NAME: The name of your vault (just the name, not the full URL/path) | ||
// | ||
// Optional command line argument: | ||
// If you have a secret already, set KVAULT_SECRET_NAME to the secret's name. | ||
// | ||
// NOTE: Do NOT set AZURE_CLIENT_SECRET. This example uses Managed identities. | ||
// The README.md provides more information. | ||
// | ||
// | ||
|
||
import ( | ||
"context" | ||
"fmt" | ||
"log" | ||
"net/http" | ||
"net/http/httputil" | ||
"os" | ||
"path" | ||
|
||
"github.com/Azure/azure-sdk-for-go/profiles/latest/keyvault/keyvault" | ||
kvauth "github.com/Azure/azure-sdk-for-go/services/keyvault/auth" | ||
"github.com/Azure/go-autorest/autorest" | ||
) | ||
|
||
var ( | ||
vaultName string | ||
secretName string | ||
) | ||
|
||
|
||
func listSecrets(basicClient keyvault.BaseClient) { | ||
secretList, err := basicClient.GetSecrets(context.Background(), "https://"+vaultName+".vault.azure.net", nil) | ||
if err != nil { | ||
fmt.Printf("unable to get list of secrets: %v\n", err) | ||
os.Exit(1) | ||
} | ||
|
||
// group by ContentType | ||
secWithType := make(map[string][]string) | ||
secWithoutType := make([]string, 1) | ||
for _, secret := range secretList.Values() { | ||
if secret.ContentType != nil { | ||
_, exists := secWithType[*secret.ContentType] | ||
if exists { | ||
secWithType[*secret.ContentType] = append(secWithType[*secret.ContentType], path.Base(*secret.ID)) | ||
} else { | ||
tempSlice := make([]string, 1) | ||
tempSlice[0] = path.Base(*secret.ID) | ||
secWithType[*secret.ContentType] = tempSlice | ||
} | ||
} else { | ||
secWithoutType = append(secWithoutType, path.Base(*secret.ID)) | ||
} | ||
} | ||
|
||
for k, v := range secWithType { | ||
fmt.Println(k) | ||
for _, sec := range v { | ||
fmt.Println(sec) | ||
} | ||
} | ||
for _, wov := range secWithoutType { | ||
fmt.Println(wov) | ||
} | ||
} | ||
|
||
func getSecret(basicClient keyvault.BaseClient, secname string) { | ||
secretResp, err := basicClient.GetSecret(context.Background(), "https://"+vaultName+".vault.azure.net", secname, "") | ||
if err != nil { | ||
fmt.Printf("unable to get value for secret: %v\n", err) | ||
os.Exit(1) | ||
} | ||
fmt.Println(*secretResp.Value) | ||
} | ||
|
||
func createUpdateSecret(basicClient keyvault.BaseClient, secname, secvalue string) { | ||
var secParams keyvault.SecretSetParameters | ||
secParams.Value = &secvalue | ||
newBundle, err := basicClient.SetSecret(context.Background(), "https://"+vaultName+".vault.azure.net", secname, secParams) | ||
if err != nil { | ||
fmt.Printf("unable to add/update secret: %v\n", err) | ||
os.Exit(1) | ||
} | ||
fmt.Println("added/updated: " + *newBundle.ID) | ||
} | ||
|
||
func deleteSecret(basicClient keyvault.BaseClient, secname string) { | ||
_, err := basicClient.DeleteSecret(context.Background(), "https://"+vaultName+".vault.azure.net", secname) | ||
if err != nil { | ||
fmt.Printf("error deleting secret: %v\n", err) | ||
os.Exit(1) | ||
} | ||
fmt.Println(secname + " deleted successfully") | ||
} | ||
|
||
func logRequest() autorest.PrepareDecorator { | ||
return func(p autorest.Preparer) autorest.Preparer { | ||
return autorest.PreparerFunc(func(r *http.Request) (*http.Request, error) { | ||
r, err := p.Prepare(r) | ||
if err != nil { | ||
log.Println(err) | ||
} | ||
dump, _ := httputil.DumpRequestOut(r, true) | ||
log.Println(string(dump)) | ||
return r, err | ||
}) | ||
} | ||
} | ||
|
||
func logResponse() autorest.RespondDecorator { | ||
return func(p autorest.Responder) autorest.Responder { | ||
return autorest.ResponderFunc(func(r *http.Response) error { | ||
err := p.Respond(r) | ||
if err != nil { | ||
log.Println(err) | ||
} | ||
dump, _ := httputil.DumpResponse(r, true) | ||
log.Println(string(dump)) | ||
return err | ||
}) | ||
} | ||
} | ||
|
||
func main() { | ||
vaultName = os.Getenv("KVAULT_NAME") | ||
fmt.Printf("KVAULT_NAME: %s\n", vaultName) | ||
|
||
authorizer, err := kvauth.NewAuthorizerFromEnvironment() | ||
if err != nil { | ||
fmt.Printf("unable to create vault authorizer: %v\n", err) | ||
os.Exit(1) | ||
} | ||
|
||
basicClient := keyvault.New() | ||
basicClient.Authorizer = authorizer | ||
|
||
fmt.Println("\nListing secret names in keyvault:") | ||
listSecrets(basicClient) | ||
|
||
if secretName = os.Getenv("KVAULT_SECRET_NAME"); secretName != "" { | ||
fmt.Printf("KVAULT_SECRET_NAME: %s\n", secretName) | ||
fmt.Print("KVAULT_SECRET Value: ") | ||
getSecret(basicClient, secretName) | ||
} else { | ||
fmt.Println("KVAULT_SECRET_NAME not set.\n") | ||
} | ||
|
||
fmt.Println("Setting 'newsecret' to 'newvalue'") | ||
createUpdateSecret(basicClient, "newsecret", "newvalue") | ||
fmt.Println("\nListing secret names in keyvault:") | ||
listSecrets(basicClient) | ||
} |
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.