Module tripleblind.team
Teams API
This module allows you to interact with the TripleBlind Router to obtain a list of teams available to the current user.
Classes
class Team
-
A Team object represents a group of users who can collaborate on projects.
Class variables
var all_user_rights
-
Rights which can be granted to a user.
Static methods
def add_member(user: str, team_id: int, rights: List[str] = None, session: Session | None = None) -> dict
-
Add a user to a team.
Rights which can be granted are: rights= [ "create_job" "delete_asset" "download_algorithm" "download_algorithm_output" "download_dataset" "download_dataset_output" "grant_permission_algorithm" "grant_permission_dataset" "invite_user" "manage_agreement" "manage_job" "manage_user" "publish_algorithm" "publish_dataset" "remove_user" "update_asset" ]
Args
user
:str
- The user ID or email to add to the team.
team_id
:int
- The team ID.
rights
:List[str]
, optional- The permissions to grant the user.
session
:Session
, optional- A connection session. If not specified the default session is used.
Returns
dict
- The updated team information.
def create(name: str, owner_email: str = None, session: Session | None = None) -> dict
-
Create a new team.
NOTE: This will only work for users which are an organization "owner".
Args
name
:str
- The name of the new team.
owner_email
:str
, optional- The email address of the team owner, defaults to the current user.
session
:Session
, optional- A connection session. If not specified the default session is used.
Returns
Team
- The newly created team.
def get_all(allow_cached: bool = True, session: Session | None = None) -> List[dict]
-
Retrieve a list of teams available to the current user.
Args
allow_cached
:bool
, optional- When True, allow usage of a previously cached list of teams. Set to False to force syncing with the server. Defaults to True.
session
:Session
, optional- A connection session. If not specified the default session is used.
Returns
List[dict]
- A list of Teams available to the current user, e.g.: [{'id': 1, 'name': 'IniTech'}, {'id': 11, 'name': 'Second Team'}]
def get_all_org(allow_cached: bool = True, session: Session | None = None) -> List[dict]
-
Retrieve a list of all teams for organization.
NOTE: This method is only available for users with the "owner" role.
Args
allow_cached
:bool
, optional- When True, allow usage of a previously cached list of teams. Set to False to force syncing with the server. Defaults to True.
session
:Session
, optional- A connection session. If not specified the default session is used.
Returns
List[dict]
- A list of Teams available to the current user, e.g.: [{'id': 1, 'name': 'IniTech'}, {'id': 11, 'name': 'Second Team'}]
def is_valid(team_id: int) -> bool
-
Check if the current user is a member of the given team ID.
Args
team_id
:int
- The team ID to check.
Returns
bool
- True if the team ID is valid, False otherwise.
def remove_member(user: str, team_id: int, session: Session | None = None) -> dict
-
Remove a user from a team.
NOTE: Unable to remove the owner of a team.
Args
user
:str
- The user ID or email to add to the team.
team_id
:int
- The team ID.
session
:Session
, optional- A connection session. If not specified the default session is used.
Returns
dict
- The updated team information.
def set_owner(team_id: int, owner_email: str, session: Session | None = None) -> dict
-
Set the owner of a team.
NOTE: This will only work for users who are organization owners or are currently the team owner.
Args
team_id
:int
- The team ID.
owner_email
:str
- The email address of the new owner.
session
:Session
, optional- A connection session. If not specified the default session is used.
Returns
dict
- The updated team information.