Authentication
External APIs typically require the caller to present a set of authentication credentials. In the case of cloud infrastructure providers (Google Cloud Platform and Amazon Web Services in particular) Stormware uses locally available credentials that are generated and also used by cloud CLI tools.
Note
You must install the google extra when using the Google Cloud Platform authentication
mechanism.
Note
You must install the amazon extra when using the Amazon Web Services authentication
mechanism.
Google Cloud Platform
The default authentication mechanism (implemented in GCPAuth) first
looks for a set of credentials in the
$XDG_CONFIG_HOME/gcloud/credentials/{configuration}.json file, where configuration defaults
to the organization_id, which is derived from the provided organization value by replacing
dots with dashes. If the credentials file does not exist, we use the application default
credentials.
Note
We recommend using the gcpl script for creating a credentials file.
A default organization and project can be set under the tool.stormware section
of a project’s pyproject.toml file as follows:
[tool.stormware]
organization = 'example.com'
project = 'my-project'
If the project is not provided, the project.name value is used from the pyproject.toml file
instead.
Amazon Web Services
The authentication logic is implemented in AWSAuth – we look for
the credentials of the organization_id named profile, which is derived the same way as it is
for the Google Cloud Platform authentication. If the credentials cannot be found for the named
profile then the boto3 credential location mechanism is used.
Note
We recommend using the awsl script for generating named profile credentials.
Secret Store
The credentials for most connectors are retrieved from a secret store, which has the following abstract interface:
- class stormware.secrets.SecretStore
Stormware comes with two built-in secret store implementations for Google Cloud Platform and Amazon Web Services, and further secret stores can be easily added by simply inheriting and implementing the
SecretStore interface.
Note
When no secret store is explicitly provided the connectors default to using the Google Cloud
Secret Manager store when the google extra is installed and the AWS Secrets Manager store
when the amazon extra is installed. If both extras are installed, the Google Cloud Secret
Manager store takes precedence.
For further information regarding connector authentication please consult the documentation of the specific connector that you intend to use.
Authentication Managers
- class stormware.google.auth.GCPAuth(*, organization: str | None = None, project: str | None = None, service_account_email: str | None = None, oauth_flow: bool | None = None, oauth_scopes: Iterable[str] | None = None, oauth_user_email: str | None = None, oauth_force_reauth: bool = False, oauth_credentials_key: str | None = None, oauth_client_secrets_key: str | None = None)
Google Cloud Platform authentication manager.
- Parameters:
organization – The organization name to use.
project – The project name to use.
service_account_email – The service account to impersonate. Defaults to the
service_account_emailvalue inpyproject.tomlunder thetool.stormware.googlesection.oauth_flow – Whether to use only the OAuth 2.0 flow (
True), disallow the OAuth 2.0 flow (False), or use the OAuth 2.0 flow only when the OAuth user email is specified (None).oauth_user_email – The email address of the user that should complete the OAuth 2.0 flow.
oauth_scopes – The OAuth 2.0 scopes to request. Defaults to using the registered scopes, or, if no scopes are registered, then the
oauth_scopesvalue set inpyproject.tomlunder thetool.stormware.googlesection, or, if no such value is set, then to all connector scopes.oauth_force_reauth – Whether to force the user to re-authenticate in the OAuth 2.0 flow.
oauth_credentials_key – The Secret Manager key to use for caching the obtained OAuth 2.0 credentials. Defaults to the
oauth_credentials_keyvalue set inpyproject.tomlunder thetool.stormware.googlesection, orstormware-google-oauth-credentialsif not set. If the secret does not exist, the credentials will be cached using local storage under$XDG_CONFIG_HOME/stormware/{project}/google/{oauth_credentials_key}.json, whereprojectis theproject.namevalue in thepyproject.tomlfile.oauth_client_secrets_key – The Secret Manager key for the OAuth 2.0 client ID and client secrets. Defaults to the
oauth_client_secrets_keyvalue set inpyproject.tomlunder thetool.stormware.googlesection, orstormware-google-oauth-client-secretsif not set.
- project(project: str | None = None) str
Return the project name.
Defaults to the
projectvalue set inpyproject.tomlunder thetool.stormwaresection or thenamevalue set under theprojectsection.
- project_id(organization: str | None = None, project: str | None = None) str
Return the project ID.
The project ID is constructed as
{project}-{organization_id}.
- credentials_path(organization: str | None = None) Path | None
Return the path to the credentials or
Noneif it does not exist.Constructed as
$XDG_CONFIG_HOME/gcloud/credentials/{organization_id}.json.
- credentials(*, organization: str | None = None, project: str | None = None, scopes: Iterable[str] | None = None) Credentials
Return the organization credentials, application default credentials or user credentials.
For the OAuth 2.0 flow the client ID and client secret are loaded from Secret Manager as a string-encoded JSON object with the
client_idandclient_secretkeys. The client ID and client secret can be obtained by creating a new OAuth 2.0 desktop client in Google Cloud console (under https://console.cloud.google.com/apis/credentials).- Parameters:
organization – The organization name to use.
project – The project name to use.
scopes – The requested credential scopes.
- class stormware.amazon.auth.AWSAuth(*args: Any, credentials: Path = PosixPath('~/.aws/credentials'), **kwargs: Any)
Amazon Web Services authentication manager.
- profile(organization: str | None = None) str | None
Return the profile name (same as the organization ID) or
Noneif it does not exist.
- organization(organization: str | None = None) str
Return the organization name.
Defaults to the
organizationvalue set inpyproject.tomlunder thetool.stormwaresection.