This example demonstrates how to use the Infisical Go SDK in a simple Go application. The application retrieves a secret named API_KEY from the dev environment of the YOUR_PROJECT_ID project.
We do not recommend hardcoding your Machine Identity Tokens. Setting it as an environment variable would be best.
The SDK supports a variety of authentication methods. The most common authentication method is Universal Auth, which uses a client ID and client secret to authenticate.
Please note that this authentication method will only work if you’re running your application on Google Cloud Platform.
Please read more about this authentication method.
Using environment variables
Call .Auth().GcpIdTokenAuthLogin() with empty arguments to use the following environment variables:
INFISICAL_GCP_AUTH_IDENTITY_ID - Your Infisical Machine Identity ID.
Please note that this authentication method will only work if you’re running your application on AWS.
Please read more about this authentication method.
Using environment variables
Call .Auth().AwsIamAuthLogin() with empty arguments to use the following environment variables:
INFISICAL_AWS_IAM_AUTH_IDENTITY_ID - Your Infisical Machine Identity ID.
Please note that this authentication method will only work if you’re running your application on Azure.
Please read more about this authentication method.
Using environment variables
Call .Auth().AzureAuthLogin() with empty arguments to use the following environment variables:
INFISICAL_AZURE_AUTH_IDENTITY_ID - Your Infisical Machine Identity ID.
Please note that this authentication method will only work if you’re running your application on Kubernetes.
Please read more about this authentication method.
Using environment variables
Call .Auth().KubernetesAuthLogin() with empty arguments to use the following environment variables:
INFISICAL_KUBERNETES_IDENTITY_ID - Your Infisical Machine Identity ID.
INFISICAL_KUBERNETES_SERVICE_ACCOUNT_TOKEN_PATH_ENV_NAME - The environment variable name that contains the path to the service account token. This is optional and will default to /var/run/secrets/kubernetes.io/serviceaccount/token.
Using the SDK directly
// Service account token path will default to /var/run/secrets/kubernetes.io/serviceaccount/token if empty value is passed_, err = client.Auth().KubernetesAuthLogin("MACHINE_IDENTITY_ID","SERVICE_ACCOUNT_TOKEN_PATH")if err !=nil{ fmt.Println(err) os.Exit(1)}
secret, err := client.Secrets().Create(infisical.CreateSecretOptions{ ProjectID:"PROJECT_ID", Environment:"dev", SecretKey:"NEW_SECRET_KEY", SecretValue:"NEW_SECRET_VALUE", SecretComment:"This is a new secret",})