2024-11-15 01:18:23 +00:00
|
|
|
from flask_sqlalchemy import SQLAlchemy
|
2024-11-13 02:49:43 +00:00
|
|
|
from database import db_connection
|
2024-11-12 01:33:31 +00:00
|
|
|
|
2024-11-13 02:49:43 +00:00
|
|
|
|
|
|
|
class User(db_connection.Model):
|
2024-11-12 01:33:31 +00:00
|
|
|
__tablename__ = 'users'
|
|
|
|
|
2024-11-13 02:49:43 +00:00
|
|
|
id = db_connection.Column(db_connection.Integer, primary_key=True, index=True)
|
|
|
|
username = db_connection.Column(db_connection.String, unique=True, index=True, nullable=False)
|
|
|
|
full_name = db_connection.Column(db_connection.String, nullable=False)
|
|
|
|
email = db_connection.Column(db_connection.String, unique=True, index=True, nullable=False)
|
2024-11-15 01:18:23 +00:00
|
|
|
public_keys = db_connection.Column(db_connection.JSON, nullable=False, default=dict)
|
2024-11-16 22:59:54 +00:00
|
|
|
orgs = db_connection.Column(db_connection.JSON, nullable=False, default=dict)
|
|
|
|
|
2024-11-13 02:49:43 +00:00
|
|
|
def to_dict(self):
|
|
|
|
return {
|
|
|
|
"id": self.id,
|
|
|
|
"username": self.username,
|
|
|
|
"full_name": self.full_name,
|
|
|
|
"email": self.email,
|
2024-11-16 22:59:54 +00:00
|
|
|
"orgs": [{"id": org_id, "name": org_data["name"], "status": org_data["status"]} for org_id, org_data in self.orgs.items()],
|
2024-11-13 02:49:43 +00:00
|
|
|
}
|