Deploying Python Flask app with API keys
May 13, 2024
3 min read
0
4
0
Exposing API keys when deploying on the cloud can lead to various security risks and consequences:
Unauthorized Access to sensitive data, systems, or functionalities.
Exposed API keys can be used maliciously to extract or modify sensitive data, leading to data breaches.
Exposed API keys can be used to incur financial charges or perform actions that result in financial loss.
Security incidents resulting from exposed API keys can damage an organization’s reputation and erode trust with customers or users.
Organizations may face legal and compliance issues, violations of contractual obligations.
Google cloud services offers a service ‘Google Cloud Secret Manager’ to manage secrets in your applications. This offers several advantages:
Security: Secret Manager provides a secure and centralized way to store sensitive information such as API keys, database credentials, and other secrets.
Storing secrets separately from your application’s source code reduces the risk of accidental exposure.
Secret Manager provides a user-friendly interface for managing secrets, including versioning and rotation.
Secret Manager seamlessly integrates with other Google Cloud services, allows you to securely access secrets from your applications running on these platforms without having to manage credentials or configuration files manually.
Overall, using Secret Manager helps enhance the security posture of your applications by reducing the risk of unauthorized access to sensitive information and simplifying the management of secrets throughout their lifecycle.
To integrate Google Cloud Secret Manager with a Python application running on Google Cloud Run, you can follow these steps:
Create a new Google project
New Project — Google Cloud console. The project name/ ID is the globally unique identifier for your project that cannot be changed
Start console https://console.cloud.google.com/
Activate Cloud Shell
Create directory for your source code.
Click on Open Editor
Drag and drop your source code from the parent directory, along with requirements.txt
In console.google.com, Dashboard, type in search “Secret manager”
Enable the API for your project
Create secret keys for all your APIs and enter the values or upload json files.
Grant Permissions: Ensure that the service account used by your Cloud Run service has the appropriate permissions to access the secret. You can do this by granting the roles/secretmanager.secretAccessor role to the service account.
Go to the IAM page in the Google Cloud console.
Go to IAM
Click the Project selector list at the top of the page.
In the Select from dialog that appears, select the organization for which you want to enable Secret Manager.
On the IAM page, next to your username, click Edit.
In the Edit permissions panel that appears, add the necessary roles.
Click Add another role. Select a role to add, such as Secret Manager Secret Accessor.
To add more roles, repeat the previous step. Click Save.
Access Secrets in your Python Code:
Add google-cloud-secret-manager to requirements.txt
In your python code: Add imports
from google.cloud import secretmanager
Sample code using the keys
def get_secret(secret_name):
# Create the Secret Manager client
client = secretmanager.SecretManagerServiceClient()
# Build the secret name
secret_path = f”projects/{your-project-id}/secrets/{your-secret-id}/versions/latest”
# Access the secret
response = client.access_secret_version(name=secret_path)
# Return the secret value
return response.payload.data.decode(“UTF-8”)
secret_value = get_secret(“your-secret-id”)
-Replace “your-project-id” and “your-secret-id” with your actual project ID and secret ID.
-Deploy Your Cloud Run Service: Deploy your Python application to Google Cloud Run making sure to grant the Cloud Run service account the necessary permissions to access Secret Manager.