2023-10-26 14:24:30 +02:00
|
|
|
import os
|
|
|
|
|
2023-10-26 14:14:40 +02:00
|
|
|
from flask import current_app
|
|
|
|
|
|
|
|
from ..db import get_db
|
|
|
|
|
|
|
|
|
|
|
|
class Attachment():
|
|
|
|
def __init__(self, uuid=None, data=None):
|
|
|
|
db = get_db()
|
|
|
|
if uuid is not None:
|
|
|
|
self.uuid = uuid
|
|
|
|
data = db.execute(
|
|
|
|
"""
|
|
|
|
SELECT * FROM attachments
|
|
|
|
WHERE uuid = ?
|
|
|
|
""",
|
|
|
|
(self.uuid,)
|
|
|
|
).fetchone()
|
|
|
|
if data is None:
|
|
|
|
raise LookupError
|
|
|
|
|
|
|
|
elif data is not None:
|
|
|
|
self.uuid = data["uuid"]
|
|
|
|
|
|
|
|
else:
|
|
|
|
raise LookupError
|
|
|
|
|
|
|
|
self.name = data["name"]
|
|
|
|
self.user_id = data["user_id"]
|
|
|
|
self.filetype = data["filetype"]
|
|
|
|
self.partition_uuid = data["partition_uuid"]
|
|
|
|
|
2023-10-26 14:24:30 +02:00
|
|
|
def delete(self):
|
|
|
|
db = get_db()
|
|
|
|
db.execute(
|
|
|
|
"""
|
|
|
|
DELETE FROM attachments
|
|
|
|
WHERE uuid = ?
|
|
|
|
""",
|
|
|
|
(self.uuid,)
|
|
|
|
)
|
|
|
|
db.commit()
|
|
|
|
|
|
|
|
os.remove(f"partitioncloud/attachments/{self.uuid}.{self.filetype}")
|
|
|
|
|
2023-10-26 14:14:40 +02:00
|
|
|
def __repr__(self):
|
|
|
|
return f"{self.name}.{self.filetype}"
|