42 lines
1.6 KiB
Python
42 lines
1.6 KiB
Python
from sqlalchemy import Column, BigInteger, Integer, String, ForeignKey, DateTime, JSON, Boolean
|
|
from sqlalchemy.orm import relationship
|
|
|
|
from .base import AlchemyBase
|
|
from hashlib import sha256
|
|
from base58 import b58encode, b58decode
|
|
from app.core.content.content_id import ContentId
|
|
|
|
|
|
class StoredContent(AlchemyBase):
|
|
__tablename__ = 'node_storage'
|
|
|
|
id = Column(Integer, autoincrement=True, primary_key=True)
|
|
hash = Column(String(64), nullable=False, unique=True) # base58
|
|
onchain_index = Column(BigInteger, nullable=True, default=None)
|
|
|
|
filename = Column(String(1024), nullable=False)
|
|
meta = Column(JSON, nullable=False, default={})
|
|
|
|
user_id = Column(Integer, ForeignKey('users.id'), nullable=False)
|
|
|
|
storj_cid = Column(String(1024), nullable=False, unique=True)
|
|
ipfs_cid = Column(String(1024), nullable=False, unique=True)
|
|
telegram_cid = Column(String(1024), nullable=False, unique=True)
|
|
|
|
created = Column(DateTime, nullable=False, default=0)
|
|
disabled = Column(DateTime, nullable=False, default=0)
|
|
disabled_by = Column(Integer, ForeignKey('users.id'), nullable=True, default=None)
|
|
|
|
key_id = Column(Integer, ForeignKey('known_keys.id'), nullable=True, default=None)
|
|
|
|
user = relationship('User', uselist=False, foreign_keys=[user_id])
|
|
key = relationship('KnownKey', uselist=False, foreign_keys=[key_id])
|
|
|
|
@property
|
|
def cid(self) -> ContentId:
|
|
return ContentId(
|
|
content_hash=b58decode(self.hash),
|
|
onchain_index=self.onchain_index,
|
|
accept_type=self.meta.get('content_type', 'image/jpeg')
|
|
)
|