from flask import Flaskfrom infisical_client import ClientSettings, InfisicalClient, GetSecretOptionsapp = Flask(__name__)client = InfisicalClient(ClientSettings( client_id="MACHINE_IDENTITY_CLIENT_ID", client_secret="MACHINE_IDENTITY_CLIENT_SECRET",))@app.route("/")defhello_world():# access value name = client.getSecret(options=GetSecretOptions( environment="dev", project_id="PROJECT_ID", secret_name="NAME"))returnf"Hello! My name is: {name.secret_value}"
This example demonstrates how to use the Infisical Python SDK with a Flask application. The application retrieves a secret named “NAME” and responds to requests with a greeting that includes the secret value.
We do not recommend hardcoding your Machine Identity Tokens. Setting it as an environment variable would be best.
To reduce the number of API requests, the SDK temporarily stores secrets it retrieves. By default, a secret remains cached for 5 minutes after it’s first fetched. Each time it’s fetched again, this 5-minute timer resets. You can adjust this caching duration by setting the “cache_ttl” option when creating the client.
secret = client.getSecret(options=GetSecretOptions( environment="dev", project_id="PROJECT_ID", secret_name="API_KEY"))value = secret.secret_value # get its value
By default, getSecret() fetches and returns a shared secret. If not found, it returns a personal secret.
tag (string): A base64-encoded, 128-bit authentication tag.
iv (string): A base64-encoded, 96-bit initialization vector.
ciphertext (string): A base64-encoded, encrypted ciphertext.