- semi-random data for applications and environments - added users to applications and environments - updated CSPRole enum with current CSP roles
64 lines
1.9 KiB
Python
64 lines
1.9 KiB
Python
from enum import Enum
|
|
from sqlalchemy import Index, ForeignKey, Column, String
|
|
from sqlalchemy.dialects.postgresql import UUID
|
|
from sqlalchemy.orm import relationship
|
|
|
|
from atst.models import Base, types, mixins
|
|
|
|
|
|
class CSPRole(Enum):
|
|
BASIC_ACCESS = "Basic Access"
|
|
NETWORK_ADMIN = "Network Admin"
|
|
BUSINESS_READ = "Business Read-only"
|
|
TECHNICAL_READ = "Technical Read-only"
|
|
|
|
|
|
class EnvironmentRole(Base, mixins.TimestampsMixin, mixins.AuditableMixin):
|
|
__tablename__ = "environment_roles"
|
|
|
|
id = types.Id()
|
|
environment_id = Column(
|
|
UUID(as_uuid=True), ForeignKey("environments.id"), nullable=False
|
|
)
|
|
environment = relationship("Environment", backref="roles")
|
|
|
|
role = Column(String())
|
|
|
|
user_id = Column(UUID(as_uuid=True), ForeignKey("users.id"), nullable=False)
|
|
user = relationship("User", backref="environment_roles")
|
|
|
|
def __repr__(self):
|
|
return "<EnvironmentRole(role='{}', user='{}', environment='{}', id='{}')>".format(
|
|
self.role, self.user.full_name, self.environment.name, self.id
|
|
)
|
|
|
|
@property
|
|
def history(self):
|
|
return self.get_changes()
|
|
|
|
@property
|
|
def displayname(self):
|
|
return self.role
|
|
|
|
@property
|
|
def event_details(self):
|
|
return {
|
|
"updated_user_name": self.user.displayname,
|
|
"updated_user_id": str(self.user_id),
|
|
"role": self.role,
|
|
"environment": self.environment.displayname,
|
|
"environment_id": str(self.environment_id),
|
|
"application": self.environment.application.name,
|
|
"application_id": str(self.environment.application_id),
|
|
"portfolio": self.environment.application.portfolio.name,
|
|
"portfolio_id": str(self.environment.application.portfolio.id),
|
|
}
|
|
|
|
|
|
Index(
|
|
"environments_role_user_environment",
|
|
EnvironmentRole.user_id,
|
|
EnvironmentRole.environment_id,
|
|
unique=True,
|
|
)
|