|
|
|
|
@ -258,20 +258,19 @@ class TenantService:
|
|
|
|
|
def switch_tenant(account: Account, tenant_id: int = None) -> None:
|
|
|
|
|
"""Switch the current workspace for the account"""
|
|
|
|
|
|
|
|
|
|
# Ensure tenant_id is provided
|
|
|
|
|
if tenant_id is None:
|
|
|
|
|
raise ValueError("Tenant ID must be provided.")
|
|
|
|
|
|
|
|
|
|
tenant_account_join = TenantAccountJoin.query.filter_by(account_id=account.id, tenant_id=tenant_id).first()
|
|
|
|
|
if not tenant_account_join:
|
|
|
|
|
raise AccountNotLinkTenantError("Tenant not found or account is not a member of the tenant.")
|
|
|
|
|
else:
|
|
|
|
|
with db.session.begin():
|
|
|
|
|
try:
|
|
|
|
|
TenantAccountJoin.query.filter_by(account_id=account.id).update({'current': False})
|
|
|
|
|
tenant_account_join.current = True
|
|
|
|
|
db.session.commit()
|
|
|
|
|
# Set the current tenant for the account
|
|
|
|
|
account.current_tenant_id = tenant_account_join.tenant_id
|
|
|
|
|
except exc.SQLAlchemyError:
|
|
|
|
|
db.session.rollback()
|
|
|
|
|
raise
|
|
|
|
|
TenantAccountJoin.query.filter(TenantAccountJoin.account_id == account.id, TenantAccountJoin.tenant_id != tenant_id).update({'current': False})
|
|
|
|
|
tenant_account_join.current = True
|
|
|
|
|
db.session.commit()
|
|
|
|
|
# Set the current tenant for the account
|
|
|
|
|
account.current_tenant_id = tenant_account_join.tenant_id
|
|
|
|
|
|
|
|
|
|
@staticmethod
|
|
|
|
|
def get_tenant_members(tenant: Tenant) -> List[Account]:
|
|
|
|
|
|