A developer guide for querying organization information via the Python SDK.
Client
Get the current organization
organization = client.get_organization()
Methods
Get IAM integrations
# get the default IAM integration
default_iam_integration = organization.get_default_iam_integration()
# get all of the IAM integrations (returns a list of IAMIntegration objects)
iam_integrations = organization.get_iam_integrations()
for integration in iam_integrations:
print(integration)
Create a project tag
organization.create_resource_tag(
{
"text": "new-tag-name",
"color": "ffffff"
}
)
Get the project tags
# get the project tags (returns a list of ResourceTag objects)
tags = organization.get_resource_tags()
for tag in tags:
print(tag)
Invite users
Depending on the level of access required, you can:
- Invite users to a workspace without assigning them to any projects.
- Invite users to a workspace and assign them to specific projects.
# get and view the available roles
roles = client.get_roles()
print("Roles: ", roles)
# create an invitation for an organization-wide role (in this case, a labeler)
organization.invite_user(
email="<email_address>",
role=roles["LABELER"]
)
# get and view the available roles
roles = client.get_roles()
print("Roles: ", roles)
# get a project
project = client.get_project("<project_id>")
# create a ProjectRole object for a project-based role, in this case a labeler
project_role = lb.ProjectRole(project=project, role=roles["LABELER"])
# create an invitation for the project-based role
org.invite_user(
email="<email_address>",
# for a project-based role, the org-wide role must be NONE
role=roles["NONE"],
project_roles=[project_role]
)
# Mass invite users to project
emails = []
for email in emails:
invite = organization.invite_user(emails,
roles["NONE"],
project_roles=[project_role])
View the invite limit
# already accounts for users currently in the organization, thus:
# used = users + invites_sent
# remaining = limit - used
organization.invite_limit()
Remove a user
# the argument must be a User object
organization.remove_user(user)
Attributes
Get the basics
# name (str)
organization.name
# created_at (datetime)
organization.created_at
# updated_at (datetime)
organization.updated_at
Get the users
# get the users (relationship to User objects)
users = organization.users()
# inspect one user
next(users)
# inspect all users
for user in users:
print(user)
# for ease of use, you can convert the paginated collection to a list
list(users)
Get the projects
# get the projects (relationship to Project objects)
projects = organization.projects()
# inspect one project
next(projects)
# inspect all projects
for project in projects:
print(project)
# for ease of use, you can convert the paginated collection to a list
list(projects)
Get the webhooks
# get the webhooks (relationship to Webhook objects)
webhooks = organization.webhooks()
# inspect one webhook
next(webhooks)
# inspect all webhooks
for webhook in webhooks:
print(webhook)
# for ease of use, you can convert the paginated collection to a list
list(webhooks)