API reference#
safir Package#
Safir is the Rubin Observatory’s library for building FastAPI services for the Rubin Science Platform.
Variables#
The version string of Safir (PEP 440 / SemVer compatible). |
|
The decomposed version, split across " |
safir.arq Module#
An arq client with a mock for testing.
Classes#
|
A base class for errors related to arq jobs. |
|
The job was not successfully queued. |
|
A job cannot be found. |
|
The job's result is unavailable. |
|
Mode configuration for the Arq queue. |
|
Information about a queued job. |
|
The full result of a job, as well as its metadata. |
|
An common interface for working with an arq queue that can be implemented either with a real Redis backend, or an in-memory repository for testing. |
|
A distributed queue, based on arq and Redis. |
|
A mocked queue for testing API services. |
Class Inheritance Diagram#
data:image/s3,"s3://crabby-images/3074a/3074adde908d0bb2e794fdcea5bf30668444288c" alt="Inheritance diagram of safir.arq.ArqJobError, safir.arq.JobNotQueued, safir.arq.JobNotFound, safir.arq.JobResultUnavailable, safir.arq.ArqMode, safir.arq.JobMetadata, safir.arq.JobResult, safir.arq.ArqQueue, safir.arq.RedisArqQueue, safir.arq.MockArqQueue"
safir.asyncio Module#
Utility functions for asyncio code.
Functions#
Run the decorated function with |
safir.database Module#
Utility functions for database management.
Functions#
|
Create a new async database session. |
|
Create a new async database engine. |
|
Create a new sync database session. |
Add the UTC time zone to a naive datetime from the database. |
|
Strip time zone for storing a datetime in the database. |
|
|
Create and initialize a new database. |
Classes#
Database initialization failed. |
Class Inheritance Diagram#
data:image/s3,"s3://crabby-images/dee20/dee20ce7fbe7e823e4110053f808a315c86880f1" alt="Inheritance diagram of safir.database.DatabaseInitializationError"
safir.dependencies.arq Module#
A FastAPI dependency that supplies a Redis connection for arq.
Classes#
A FastAPI dependency that maintains a Redis client for enqueing tasks to the worker pool. |
Variables#
Singleton instance of |
Class Inheritance Diagram#
data:image/s3,"s3://crabby-images/7d365/7d3650c785d9ee977093ef95bf8824677149f34f" alt="Inheritance diagram of safir.dependencies.arq.ArqDependency"
safir.dependencies.db_session Module#
Manage an async database session.
Classes#
Manages an async per-request SQLAlchemy session. |
Variables#
The dependency that will return the async session proxy. |
Class Inheritance Diagram#
data:image/s3,"s3://crabby-images/f9a94/f9a943a77323a94e6067aa8c45ef181886e832ee" alt="Inheritance diagram of safir.dependencies.db_session.DatabaseSessionDependency"
safir.dependencies.gafaelfawr Module#
Gafaelfawr authentication dependencies.
Functions#
|
Retrieve authentication information from HTTP headers. |
|
Logger bound to the authenticated user. |
safir.dependencies.http_client Module#
HTTP client dependency for FastAPI.
Classes#
Provides an |
Variables#
Default timeout (in seconds) for outbound HTTP requests. |
|
The dependency that will return the HTTP client. |
Class Inheritance Diagram#
data:image/s3,"s3://crabby-images/88015/8801538fbec668ef5bab39ef402b84d3ec0dac8a" alt="Inheritance diagram of safir.dependencies.http_client.HTTPClientDependency"
safir.dependencies.logger Module#
Logger dependency for FastAPI.
Provides a structlog
logger as a FastAPI dependency. The logger will
incorporate information from the request in its bound context.
Classes#
Provides a structlog logger configured with request information. |
Variables#
The dependency that will return the logger for the current request. |
Class Inheritance Diagram#
data:image/s3,"s3://crabby-images/fe65b/fe65bfc991e3082e3330d069b31d1265e3fa8b84" alt="Inheritance diagram of safir.dependencies.logger.LoggerDependency"
safir.gcs Module#
Utilities for interacting with Google Cloud Storage.
Classes#
|
Generate signed URLs for Google Cloud Storage blobs. |
Class Inheritance Diagram#
data:image/s3,"s3://crabby-images/44b9e/44b9ea5d499f8348476c71b27542bc728f13d76d" alt="Inheritance diagram of safir.gcs.SignedURLService"
safir.kubernetes Module#
Utilities for configuring a Kubernetes client.
Functions#
Load the Kubernetes configuration. |
Variables#
safir.logging Module#
Utilities for configuring structlog-based logging.
Functions#
|
Add the log level to the event dict as |
|
Configure logging and structlog. |
|
Set up logging. |
Classes#
|
Python logging level. |
|
Logging profile for the application. |
Variables#
Name of the configured global logger. |
Class Inheritance Diagram#
data:image/s3,"s3://crabby-images/dc7ce/dc7ce67bd8d5f79b5ca118430dedd33363f923be" alt="Inheritance diagram of safir.logging.LogLevel, safir.logging.Profile"
safir.metadata Module#
Standardized metadata for Roundtable HTTP services.
Functions#
|
Retrieve metadata for the application. |
|
Get a specific URL from a package's |
Classes#
|
Metadata about a package. |
Class Inheritance Diagram#
data:image/s3,"s3://crabby-images/605ad/605ada78bc0a8f608001646a2369ad7543a01ff3" alt="Inheritance diagram of safir.metadata.Metadata"
safir.models Module#
Standard models for FastAPI applications.
Examples
To reference the ErrorModel
model when returning an error message, use code
similar to this:
@router.get(
"/route/{foo}",
...,
responses={404: {"description": "Not found", "model": ErrorModel}},
)
async def route(foo: str) -> None:
...
raise HTTPException(
status_code=status.HTTP_404_NOT_FOUND,
detail=[
{"loc": ["path", "foo"], "msg": msg, "type": "invalid_foo"},
],
)
Notes
FastAPI does not appear to export its error response model in a usable form, so define a copy of it so that we can reference it in API definitions to generate good documentation.
Classes#
|
The detail of the error message. |
|
A structured API error message. |
Class Inheritance Diagram#
data:image/s3,"s3://crabby-images/e6e40/e6e403e6b282c115439f660143df0b8422a4170b" alt="Inheritance diagram of safir.models.ErrorDetail, safir.models.ErrorModel"
safir.middleware.ivoa Module#
Middleware for IVOA services.
Classes#
|
Make query parameter keys all lowercase. |
Class Inheritance Diagram#
data:image/s3,"s3://crabby-images/3abbb/3abbb04d91a7db3d76386ba8c2ed6fa3455068d0" alt="Inheritance diagram of safir.middleware.ivoa.CaseInsensitiveQueryMiddleware"
safir.middleware.x_forwarded Module#
Update the request based on X-Forwarded-For
headers.
Classes#
|
Middleware to update the request based on |
Class Inheritance Diagram#
data:image/s3,"s3://crabby-images/a1956/a195628baaaf82f4a94146a323009b09952bca19" alt="Inheritance diagram of safir.middleware.x_forwarded.XForwardedMiddleware"
safir.pydantic Module#
Utility functions for Pydantic models.
Functions#
Pydantic validator for datetime fields. |
|
|
Convert a string to camel case. |
|
Generate a validator imposing a one and only one constraint. |
Classes#
|
|
Class Inheritance Diagram#
data:image/s3,"s3://crabby-images/bef3f/bef3f3e1b7f790cf0d069d1ee1659365c2856e73" alt="Inheritance diagram of safir.pydantic.CamelCaseModel"
safir.testing.gcs Module#
Mock Google Cloud Storage API for testing.
Functions#
|
Replace the Google Cloud Storage API with a mock class. |
Classes#
|
Mock version of |
|
Mock version of |
|
Mock version of |
Class Inheritance Diagram#
data:image/s3,"s3://crabby-images/42adb/42adb2014905f7796eaec8f836cf9d5e929e3467" alt="Inheritance diagram of safir.testing.gcs.MockBlob, safir.testing.gcs.MockBucket, safir.testing.gcs.MockStorageClient"
safir.testing.kubernetes Module#
Mock Kubernetes API for testing.
Functions#
Replace the Kubernetes API with a mock class. |
Classes#
Mock Kubernetes API for testing. |
Class Inheritance Diagram#
data:image/s3,"s3://crabby-images/40700/407007aadfc29a70f48fb12bab2a4a7d57096f14" alt="Inheritance diagram of safir.testing.kubernetes.MockKubernetesApi"