Add FileService

Signed-off-by: Tiago Garcia <tiago.rgarcia@ua.pt>
This commit is contained in:
Tiago Garcia 2024-11-12 12:27:04 +00:00
parent 5d826f409b
commit 0b0b42dac7
Signed by: TiagoRG
GPG Key ID: DFCD48E3F420DB42
6 changed files with 144 additions and 4 deletions

View File

@ -9,8 +9,8 @@ class File(Base):
__tablename__ = 'files' __tablename__ = 'files'
id: Mapped[int] = mapped_column(Integer, primary_key=True, index=True) id: Mapped[int] = mapped_column(Integer, primary_key=True, index=True)
file_handle: Mapped[str] = mapped_column(String, nullable=False) file_handle: Mapped[str] = mapped_column(String, unique=True, nullable=False)
document_handle: Mapped[str] = mapped_column(String, nullable=False) document_handle: Mapped[str] = mapped_column(String, unique=True, nullable=True)
name: Mapped[str] = mapped_column(String, nullable=False) name: Mapped[str] = mapped_column(String, nullable=False)
created_at: Mapped[int] = mapped_column(Integer, nullable=False) created_at: Mapped[int] = mapped_column(Integer, nullable=False)
org_id: Mapped[int] = mapped_column(Integer, ForeignKey('organizations.id'), nullable=False) org_id: Mapped[int] = mapped_column(Integer, ForeignKey('organizations.id'), nullable=False)

View File

View File

@ -1,2 +1,3 @@
from .orgs import OrganizationService from .orgs import OrganizationService
from .users import UserService from .users import UserService
from .files import FileService

View File

@ -0,0 +1,56 @@
import os
from datetime import datetime
from typing import List, Type
from sqlalchemy.orm import Session
from models import File, Organization, User
class FileService:
def __init__(self, db: Session):
self.db = db
self.repos = os.path.join(os.path.dirname(os.path.dirname(os.path.abspath(__file__))), "repository")
def create_dummy_file(self, org: Organization, user: User) -> File:
file = File(
file_handle = "dummy_file",
document_handle = "org/dummy_file.txt",
name = "dummy_file",
created_at = int(datetime.now().timestamp()),
org_id = 1,
creator_id = 1,
org = org,
creator = user
)
file_path = os.path.join(self.repos, file.document_handle)
with open(file_path, "w") as f:
f.write("Dummy file content")
self.db.add(file)
self.db.commit()
self.db.refresh(file)
return file
def get_file(self, file_id: int) -> File | None:
return self.db.query(File).filter(File.id == file_id).first()
def get_file_by_document_handle(self, document_handle: str) -> File | None:
return self.db.query(File).filter(File.document_handle == document_handle).first()
def get_file_by_file_handle(self, file_handle: str) -> File | None:
return self.db.query(File).filter(File.file_handle == file_handle).first()
def list_files(self) -> list[Type[File]]:
return self.db.query(File).all()
def list_files_in_org(self, org: Organization) -> list[Type[File]]:
return self.db.query(File).filter(File.org_id == org.id).all()
def delete_file(self, file: File) -> File:
file_path = os.path.join(self.repos, file.document_handle)
os.remove(file_path)
file.document_handle = None
self.db.commit()
self.db.refresh(file)
return file

View File

@ -1,3 +1,5 @@
import os.path
from sqlalchemy.orm import Session from sqlalchemy.orm import Session
from models import Organization from models import Organization
@ -12,6 +14,11 @@ class OrganizationService:
if not user: if not user:
user = UserService(self.db).create_user(username, full_name, email, public_key) user = UserService(self.db).create_user(username, full_name, email, public_key)
project_root = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
repos = os.path.join(project_root, "repository")
if not os.path.exists(os.path.join(repos, name)):
os.mkdir(os.path.join(repos, name))
organization = Organization( organization = Organization(
name=name, name=name,
owner_id=user.id, owner_id=user.id,

View File

@ -1,14 +1,16 @@
import os
from pprint import PrettyPrinter from pprint import PrettyPrinter
import database.setup_db import database.setup_db
from database import SessionLocal from database import SessionLocal
from services import OrganizationService, UserService from services import OrganizationService, UserService, FileService
database.setup_db.setup_db() database.setup_db.setup_db()
db = SessionLocal() db = SessionLocal()
org_service = OrganizationService(db) org_service = OrganizationService(db)
user_service = UserService(db) user_service = UserService(db)
file_service = FileService(db)
def test_create_organization(): def test_create_organization():
org = org_service.create_organization( org = org_service.create_organization(
@ -133,4 +135,78 @@ def test_get_user():
db.delete(org) db.delete(org)
db.delete(user) db.delete(user)
db.commit()
def test_create_dummy_file():
org = org_service.create_organization(
name="org",
username="testuser",
full_name="Test User",
email="test@mail.com",
public_key="abc123"
)
file = file_service.create_dummy_file(org, org.owner)
assert file.file_handle == "dummy_file"
assert file.document_handle == "org/dummy_file.txt"
assert file.name == "dummy_file"
project_root = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
repos = os.path.join(project_root, "repository")
with open(os.path.join(repos, file.document_handle), "r") as f:
assert f.read() == "Dummy file content"
os.remove(os.path.join(repos, file.document_handle))
db.delete(file)
db.delete(org.owner)
db.delete(org)
db.commit()
def test_get_file():
org = org_service.create_organization(
name="org",
username="testuser",
full_name="Test User",
email="test@mail.com",
public_key="abc123"
)
file = file_service.create_dummy_file(org, org.owner)
file2 = file_service.get_file_by_file_handle("dummy_file")
assert file2.file_handle == "dummy_file"
assert file2.document_handle == "org/dummy_file.txt"
assert file2.name == "dummy_file"
project_root = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
repos = os.path.join(project_root, "repository")
os.remove(os.path.join(repos, file.document_handle))
db.delete(file)
db.delete(org.owner)
db.delete(org)
db.commit()
def test_delete_file():
org = org_service.create_organization(
name="org",
username="testuser",
full_name="Test User",
email="test@mail.com",
public_key="abc123"
)
file = file_service.create_dummy_file(org, org.owner)
file2 = file_service.delete_file(file)
assert file2.file_handle == "dummy_file"
assert file2.document_handle is None
assert os.path.exists(os.path.join(os.path.dirname(os.path.dirname(os.path.abspath(__file__))), "repository", "org", "dummy_file.txt")) == False
db.delete(file)
db.delete(org.owner)
db.delete(org)
db.commit() db.commit()