41 lines
1.0 KiB
Python
41 lines
1.0 KiB
Python
from sqlalchemy import Column, ForeignKey, String
|
|
from sqlalchemy.orm import relationship
|
|
|
|
from atst.models import Base
|
|
from atst.models.types import Id
|
|
from atst.models import mixins
|
|
|
|
|
|
class Environment(Base, mixins.TimestampsMixin, mixins.AuditableMixin):
|
|
__tablename__ = "environments"
|
|
|
|
id = Id()
|
|
name = Column(String, nullable=False)
|
|
|
|
project_id = Column(ForeignKey("projects.id"), nullable=False)
|
|
project = relationship("Project")
|
|
|
|
@property
|
|
def users(self):
|
|
return [r.user for r in self.roles]
|
|
|
|
@property
|
|
def num_users(self):
|
|
return len(self.users)
|
|
|
|
@property
|
|
def displayname(self):
|
|
return self.name
|
|
|
|
def auditable_workspace_id(self):
|
|
return self.project.workspace_id
|
|
|
|
def __repr__(self):
|
|
return "<Environment(name='{}', num_users='{}', project='{}', workspace='{}', id='{}')>".format(
|
|
self.name,
|
|
self.num_users,
|
|
self.project.name,
|
|
self.project.workspace.name,
|
|
self.id,
|
|
)
|