- Add Catalog Concept to Document Domain

- Create Catalog views
- Modify document stack creation
This commit is contained in:
Josako
2024-10-14 13:56:23 +02:00
parent 0f4558d775
commit 270479c77d
10 changed files with 339 additions and 102 deletions

View File

@@ -26,55 +26,55 @@ def upgrade():
op.add_column('document_version', sa.Column('object_name', sa.String(length=200), nullable=True))
op.add_column('document_version', sa.Column('file_size', sa.Float(), nullable=True))
# ### Upgrade values for bucket_name, object_name and file_size to reflect minio reality ###
from common.models.document import DocumentVersion
from common.extensions import minio_client
from minio.error import S3Error
# Create a connection
connection = op.get_bind()
session = Session(bind=connection)
# Get the current schema name (which should be the tenant ID)
current_schema = connection.execute(text("SELECT current_schema()")).scalar()
tenant_id = int(current_schema)
doc_versions = session.query(DocumentVersion).all()
for doc_version in doc_versions:
try:
object_name = minio_client.generate_object_name(doc_version.doc_id,
doc_version.language,
doc_version.id,
doc_version.file_name)
bucket_name = minio_client.generate_bucket_name(tenant_id)
doc_version.object_name = object_name
doc_version.bucket_name = bucket_name
try:
stat = minio_client.client.stat_object(
bucket_name=bucket_name,
object_name=object_name
)
doc_version.file_size = stat.size / 1048576
current_app.logger.info(f"Processed Upgrade for DocumentVersion {doc_version.id} for Tenant {tenant_id}")
except S3Error as e:
if e.code == "NoSuchKey":
current_app.logger.warning(
f"Object {doc_version.object_name} not found in bucket {doc_version.bucket_name}. Skipping.")
continue # Move to the next item
else:
raise e # Handle other types of S3 errors
except Exception as e:
session.rollback()
current_app.logger.error(f"Couldn't process upgrade for DocumentVersion {doc_version.id} for "
f"Tenant {tenant_id}. Error: {str(e)}")
try:
session.commit()
current_app.logger.info(f"Successfully updated file sizes for tenant schema {current_schema}")
except Exception as e:
session.rollback()
current_app.logger.error(f"Error committing changes for tenant schema {current_schema}: {str(e)}")
# # ### Upgrade values for bucket_name, object_name and file_size to reflect minio reality ###
# from common.models.document import DocumentVersion
# from common.extensions import minio_client
# from minio.error import S3Error
#
# # Create a connection
# connection = op.get_bind()
# session = Session(bind=connection)
#
# # Get the current schema name (which should be the tenant ID)
# current_schema = connection.execute(text("SELECT current_schema()")).scalar()
# tenant_id = int(current_schema)
#
# doc_versions = session.query(DocumentVersion).all()
# for doc_version in doc_versions:
# try:
# object_name = minio_client.generate_object_name(doc_version.doc_id,
# doc_version.language,
# doc_version.id,
# doc_version.file_name)
# bucket_name = minio_client.generate_bucket_name(tenant_id)
# doc_version.object_name = object_name
# doc_version.bucket_name = bucket_name
#
# try:
# stat = minio_client.client.stat_object(
# bucket_name=bucket_name,
# object_name=object_name
# )
# doc_version.file_size = stat.size / 1048576
# current_app.logger.info(f"Processed Upgrade for DocumentVersion {doc_version.id} for Tenant {tenant_id}")
# except S3Error as e:
# if e.code == "NoSuchKey":
# current_app.logger.warning(
# f"Object {doc_version.object_name} not found in bucket {doc_version.bucket_name}. Skipping.")
# continue # Move to the next item
# else:
# raise e # Handle other types of S3 errors
# except Exception as e:
# session.rollback()
# current_app.logger.error(f"Couldn't process upgrade for DocumentVersion {doc_version.id} for "
# f"Tenant {tenant_id}. Error: {str(e)}")
#
# try:
# session.commit()
# current_app.logger.info(f"Successfully updated file sizes for tenant schema {current_schema}")
# except Exception as e:
# session.rollback()
# current_app.logger.error(f"Error committing changes for tenant schema {current_schema}: {str(e)}")
# ### commands auto generated by Alembic - Remove old fields ###
# op.drop_column('document_version', 'file_location')