schemaup
This commit is contained in:
@@ -21,7 +21,7 @@ __all__ = [
|
||||
"TopicFollower",
|
||||
"Notification",
|
||||
"Reaction",
|
||||
"UserRating"
|
||||
"UserRating",
|
||||
"ViewedEntry"
|
||||
]
|
||||
|
||||
|
@@ -11,23 +11,16 @@ class CollabAuthor(Base):
|
||||
|
||||
id = None # type: ignore
|
||||
collab = Column(ForeignKey("collab.id"), primary_key=True)
|
||||
author = Column(ForeignKey("user.slug"), primary_key=True)
|
||||
invitedBy = Column(ForeignKey("user.slug"))
|
||||
|
||||
|
||||
class CollabInvited(Base):
|
||||
__tablename__ = "collab_invited"
|
||||
|
||||
id = None # type: ignore
|
||||
collab = Column(ForeignKey("collab.id"), primary_key=True)
|
||||
author = Column(ForeignKey("user.slug"), primary_key=True)
|
||||
invitedBy = Column(ForeignKey("user.slug"))
|
||||
author = Column(ForeignKey("user.id"), primary_key=True)
|
||||
accepted = Column(Boolean, default=False)
|
||||
|
||||
|
||||
class Collab(Base):
|
||||
__tablename__ = "collab"
|
||||
|
||||
shout = Column(ForeignKey("shout.id"), primary_key=True)
|
||||
title = Column(String, nullable=True, comment="Title")
|
||||
body = Column(String, nullable=True, comment="Body")
|
||||
pic = Column(String, nullable=True, comment="Picture")
|
||||
authors = relationship(lambda: User, secondary=CollabAuthor.__tablename__)
|
||||
invites = relationship(lambda: User, secondary=CollabInvited.__tablename__)
|
||||
createdAt = Column(DateTime, default=datetime.now, comment="Created At")
|
||||
|
@@ -9,8 +9,8 @@ class ShoutCollection(Base):
|
||||
__tablename__ = "shout_collection"
|
||||
|
||||
id = None # type: ignore
|
||||
shout = Column(ForeignKey("shout.slug"), primary_key=True)
|
||||
collection = Column(ForeignKey("collection.slug"), primary_key=True)
|
||||
shout = Column(ForeignKey("shout.id"), primary_key=True)
|
||||
collectionId = Column(ForeignKey("collection.id"), primary_key=True)
|
||||
|
||||
|
||||
class Collection(Base):
|
||||
|
@@ -8,8 +8,8 @@ class CommunityFollower(Base):
|
||||
__tablename__ = "community_followers"
|
||||
|
||||
id = None # type: ignore
|
||||
follower = Column(ForeignKey("user.slug"), primary_key=True)
|
||||
community = Column(ForeignKey("community.slug"), primary_key=True)
|
||||
follower = Column(ForeignKey("user.id"), primary_key=True)
|
||||
communityId = Column(ForeignKey("community.id"), primary_key=True)
|
||||
joinedAt = Column(
|
||||
DateTime, nullable=False, default=datetime.now, comment="Created at"
|
||||
)
|
||||
|
22
orm/rbac.py
22
orm/rbac.py
@@ -122,7 +122,7 @@ class Operation(Base):
|
||||
|
||||
class Resource(Base):
|
||||
__tablename__ = "resource"
|
||||
resource_class = Column(
|
||||
resourceClass = Column(
|
||||
String, nullable=False, unique=True, comment="Resource class"
|
||||
)
|
||||
name = Column(String, nullable=False, unique=True, comment="Resource name")
|
||||
@@ -134,7 +134,7 @@ class Resource(Base):
|
||||
for res in ["shout", "topic", "reaction", "chat", "message", "invite", "community", "user"]:
|
||||
r = session.query(Resource).filter(Resource.name == res).first()
|
||||
if not r:
|
||||
r = Resource.create(name=res, resource_class=res)
|
||||
r = Resource.create(name=res, resourceClass=res)
|
||||
session.add(r)
|
||||
session.commit()
|
||||
|
||||
@@ -142,19 +142,19 @@ class Resource(Base):
|
||||
class Permission(Base):
|
||||
__tablename__ = "permission"
|
||||
__table_args__ = (
|
||||
UniqueConstraint("role_id", "operation_id", "resource_id"),
|
||||
UniqueConstraint("roleId", "operationId", "resourceId"),
|
||||
{"extend_existing": True},
|
||||
)
|
||||
|
||||
role_id = Column(
|
||||
roleId = Column(
|
||||
ForeignKey("role.id", ondelete="CASCADE"), nullable=False, comment="Role"
|
||||
)
|
||||
operation_id = Column(
|
||||
operationId = Column(
|
||||
ForeignKey("operation.id", ondelete="CASCADE"),
|
||||
nullable=False,
|
||||
comment="Operation",
|
||||
)
|
||||
resource_id = Column(
|
||||
resourceId = Column(
|
||||
ForeignKey("resource.id", ondelete="CASCADE"),
|
||||
nullable=False,
|
||||
comment="Resource",
|
||||
@@ -164,11 +164,11 @@ class Permission(Base):
|
||||
if __name__ == "__main__":
|
||||
Base.metadata.create_all(engine)
|
||||
ops = [
|
||||
Permission(role_id=1, operation_id=1, resource_id=1),
|
||||
Permission(role_id=1, operation_id=2, resource_id=1),
|
||||
Permission(role_id=1, operation_id=3, resource_id=1),
|
||||
Permission(role_id=1, operation_id=4, resource_id=1),
|
||||
Permission(role_id=2, operation_id=4, resource_id=1),
|
||||
Permission(roleId=1, operationId=1, resourceId=1),
|
||||
Permission(roleId=1, operationId=2, resourceId=1),
|
||||
Permission(roleId=1, operationId=3, resourceId=1),
|
||||
Permission(roleId=1, operationId=4, resourceId=1),
|
||||
Permission(roleId=2, operationId=4, resourceId=1),
|
||||
]
|
||||
global_session.add_all(ops)
|
||||
global_session.commit()
|
||||
|
@@ -28,12 +28,12 @@ class Reaction(Base):
|
||||
createdAt = Column(
|
||||
DateTime, nullable=False, default=datetime.now, comment="Created at"
|
||||
)
|
||||
createdBy = Column(ForeignKey("user.slug"), nullable=False, comment="Sender")
|
||||
createdBy = Column(ForeignKey("user.id"), nullable=False, index=True, comment="Sender")
|
||||
updatedAt = Column(DateTime, nullable=True, comment="Updated at")
|
||||
updatedBy = Column(ForeignKey("user.slug"), nullable=True, comment="Last Editor")
|
||||
updatedBy = Column(ForeignKey("user.id"), nullable=True, index=True, comment="Last Editor")
|
||||
deletedAt = Column(DateTime, nullable=True, comment="Deleted at")
|
||||
deletedBy = Column(ForeignKey("user.slug"), nullable=True, comment="Deleted by")
|
||||
shout = Column(ForeignKey("shout.slug"), nullable=False)
|
||||
deletedBy = Column(ForeignKey("user.id"), nullable=True, index=True, comment="Deleted by")
|
||||
shout = Column(ForeignKey("shout.id"), nullable=False, index=True)
|
||||
replyTo = Column(
|
||||
ForeignKey("reaction.id"), nullable=True, comment="Reply to reaction ID"
|
||||
)
|
||||
|
14
orm/shout.py
14
orm/shout.py
@@ -13,16 +13,16 @@ class ShoutTopic(Base):
|
||||
__tablename__ = "shout_topic"
|
||||
|
||||
id = None # type: ignore
|
||||
shout = Column(ForeignKey("shout.slug"), primary_key=True)
|
||||
topic = Column(ForeignKey("topic.slug"), primary_key=True)
|
||||
shout = Column(ForeignKey("shout.id"), primary_key=True, index=True)
|
||||
topic = Column(ForeignKey("topic.id"), primary_key=True, index=True)
|
||||
|
||||
|
||||
class ShoutReactionsFollower(Base):
|
||||
__tablename__ = "shout_reactions_followers"
|
||||
|
||||
id = None # type: ignore
|
||||
follower = Column(ForeignKey("user.slug"), primary_key=True)
|
||||
shout = Column(ForeignKey("shout.slug"), primary_key=True)
|
||||
follower = Column(ForeignKey("user.id"), primary_key=True, index=True)
|
||||
shout = Column(ForeignKey("shout.id"), primary_key=True, index=True)
|
||||
auto = Column(Boolean, nullable=False, default=False)
|
||||
createdAt = Column(
|
||||
DateTime, nullable=False, default=datetime.now, comment="Created at"
|
||||
@@ -34,8 +34,8 @@ class ShoutAuthor(Base):
|
||||
__tablename__ = "shout_author"
|
||||
|
||||
id = None # type: ignore
|
||||
shout = Column(ForeignKey("shout.slug"), primary_key=True)
|
||||
user = Column(ForeignKey("user.slug"), primary_key=True)
|
||||
shout = Column(ForeignKey("shout.id"), primary_key=True, index=True)
|
||||
user = Column(ForeignKey("user.id"), primary_key=True, index=True)
|
||||
caption = Column(String, nullable=True, default="")
|
||||
|
||||
|
||||
@@ -55,7 +55,7 @@ class Shout(Base):
|
||||
topics = relationship(lambda: Topic, secondary=ShoutTopic.__tablename__)
|
||||
reactions = relationship(lambda: Reaction)
|
||||
visibility = Column(String, nullable=True) # owner authors community public
|
||||
versionOf = Column(ForeignKey("shout.slug"), nullable=True)
|
||||
versionOf = Column(ForeignKey("shout.id"), nullable=True)
|
||||
oid = Column(String, nullable=True)
|
||||
media = Column(JSON, nullable=True)
|
||||
|
||||
|
@@ -9,8 +9,8 @@ class TopicFollower(Base):
|
||||
__tablename__ = "topic_followers"
|
||||
|
||||
id = None # type: ignore
|
||||
follower = Column(ForeignKey("user.slug"), primary_key=True)
|
||||
topic = Column(ForeignKey("topic.slug"), primary_key=True)
|
||||
follower = Column(ForeignKey("user.id"), primary_key=True, index=True)
|
||||
topic = Column(ForeignKey("topic.id"), primary_key=True, index=True)
|
||||
createdAt = Column(
|
||||
DateTime, nullable=False, default=datetime.now, comment="Created at"
|
||||
)
|
||||
|
25
orm/user.py
25
orm/user.py
@@ -6,13 +6,12 @@ from sqlalchemy.orm import relationship
|
||||
|
||||
from base.orm import Base, local_session
|
||||
from orm.rbac import Role
|
||||
from services.auth.roles import RoleStorage
|
||||
|
||||
|
||||
class UserNotifications(Base):
|
||||
__tablename__ = "user_notifications"
|
||||
# id auto
|
||||
user_id = Column(Integer, ForeignKey("user.id"))
|
||||
user = Column(Integer, ForeignKey("user.id"))
|
||||
kind = Column(String, ForeignKey("notification.kind"))
|
||||
values = Column(JSONType, nullable=True) # [ <var1>, .. ]
|
||||
|
||||
@@ -21,8 +20,8 @@ class UserRating(Base):
|
||||
__tablename__ = "user_rating"
|
||||
|
||||
id = None # type: ignore
|
||||
rater = Column(ForeignKey("user.slug"), primary_key=True)
|
||||
user = Column(ForeignKey("user.slug"), primary_key=True)
|
||||
raterId = Column(ForeignKey("user.id"), primary_key=True, index=True)
|
||||
user = Column(ForeignKey("user.id"), primary_key=True, index=True)
|
||||
value = Column(Integer)
|
||||
|
||||
@staticmethod
|
||||
@@ -34,16 +33,16 @@ class UserRole(Base):
|
||||
__tablename__ = "user_role"
|
||||
|
||||
id = None # type: ignore
|
||||
user_id = Column(ForeignKey("user.id"), primary_key=True)
|
||||
role_id = Column(ForeignKey("role.id"), primary_key=True)
|
||||
user = Column(ForeignKey("user.id"), primary_key=True, index=True)
|
||||
roleId = Column(ForeignKey("role.id"), primary_key=True, index=True)
|
||||
|
||||
|
||||
class AuthorFollower(Base):
|
||||
__tablename__ = "author_follower"
|
||||
|
||||
id = None # type: ignore
|
||||
follower = Column(ForeignKey("user.slug"), primary_key=True)
|
||||
author = Column(ForeignKey("user.slug"), primary_key=True)
|
||||
follower = Column(ForeignKey("user.id"), primary_key=True, index=True)
|
||||
author = Column(ForeignKey("user.id"), primary_key=True, index=True)
|
||||
createdAt = Column(
|
||||
DateTime, nullable=False, default=datetime.now, comment="Created at"
|
||||
)
|
||||
@@ -103,12 +102,12 @@ class User(Base):
|
||||
|
||||
async def get_permission(self):
|
||||
scope = {}
|
||||
for user_role in self.roles:
|
||||
role: Role = await RoleStorage.get_role(user_role.id) # type: ignore
|
||||
for role in self.roles:
|
||||
for p in role.permissions:
|
||||
if p.resource_id not in scope:
|
||||
scope[p.resource_id] = set()
|
||||
scope[p.resource_id].add(p.operation_id)
|
||||
if p.resourceId not in scope:
|
||||
scope[p.resourceId] = set()
|
||||
scope[p.resourceId].add(p.operationId)
|
||||
|
||||
return scope
|
||||
|
||||
|
||||
|
@@ -6,8 +6,8 @@ from base.orm import Base, local_session
|
||||
class ViewedEntry(Base):
|
||||
__tablename__ = "viewed"
|
||||
|
||||
viewer = Column(ForeignKey("user.slug"), default='anonymous')
|
||||
shout = Column(ForeignKey("shout.slug"), default="genesis-block")
|
||||
viewerId = Column(ForeignKey("user.id"), index=True, default=1)
|
||||
shout = Column(ForeignKey("shout.id"), index=True, default=1)
|
||||
amount = Column(Integer, default=1)
|
||||
createdAt = Column(
|
||||
DateTime, nullable=False, default=datetime.now, comment="Created at"
|
||||
|
Reference in New Issue
Block a user