FirestoreStorage#
- class gafaelfawr.storage.firestore.FirestoreStorage(client, logger)#
- Bases: - object- Google Firestore storage layer. - Gafaelfawr supports assigning UIDs and GIDs from Google Firestore rather than getting them from LDAP or upstream authentication tokens. This module provides the read/write layer and transaction management for that storage. It’s used from inside a per-process cache. - This class authenticates to Google on creation, so it should not be created fresh for every request. - Parameters:
- client ( - AsyncClient) – Firestore client to use.
- logger ( - BoundLogger) – Logger for debug messages and errors.
 
 - Methods Summary - get_gid(group)- Get the GID for a group. - get_uid(username, *[, bot])- Get the UID for a user. - Initialize a Firestore document store for UID/GID assignment. - Methods Documentation - async get_gid(group)#
- Get the GID for a group. - Retrieve the assigned GID for a group, or assign a new GID to that group if the group hasn’t been seen before. - Parameters:
- group ( - str) – Name of the group.
- Returns:
- GID of the group. 
- Return type:
- Raises:
- FirestoreAPIError – Raised if some error occurs talking to Firestore. 
- FirestoreNotInitializedError – Raised if Firestore has not been initialized. 
- NoAvailableGidError – Raised if no more GIDs are available in that range. 
 
 
 - async get_uid(username, *, bot=False)#
- Get the UID for a user. - Retrieve the assigned UID for a user, or assign a new UID to that user if the user hasn’t been seen before. - Parameters:
- Returns:
- UID of the user. 
- Return type:
- Raises:
- FirestoreAPIError – Raised if some error occurs talking to Firestore. 
- FirestoreNotInitializedError – Raised if Firestore has not been initialized. 
- NoAvailableUidError – Raised if no more UIDs are available in that range. 
 
 
 - async initialize()#
- Initialize a Firestore document store for UID/GID assignment. - This is safe to call on an already-initialized document store and will silently do nothing. - Raises:
- FirestoreError – Raised if some error occurs talking to Firestore. 
- Return type: