Merge branch 'main' of gitlab.prodcontest.com:team-39/backend

* 'main' of gitlab.prodcontest.com:team-39/backend:
  fix(): update migrations
This commit is contained in:
ITQ
2025-11-22 18:26:35 +03:00
9 changed files with 175 additions and 383 deletions
@@ -1,67 +0,0 @@
"""add resume
Revision ID: 0d2e7755303c
Revises: 9140c6824ab8
Create Date: 2025-11-22 00:08:04.421819
"""
from typing import Sequence, Union
from alembic import op
import sqlalchemy as sa
# revision identifiers, used by Alembic.
revision: str = '0d2e7755303c'
down_revision: Union[str, Sequence[str], None] = '9140c6824ab8'
branch_labels: Union[str, Sequence[str], None] = None
depends_on: Union[str, Sequence[str], None] = None
def upgrade() -> None:
"""Upgrade schema."""
# ### commands auto generated by Alembic - please adjust! ###
op.create_table('resume',
sa.Column('id', sa.UUID(), nullable=False),
sa.Column('deleted_at', sa.DateTime(timezone=True), nullable=True),
sa.Column('created_at', sa.DateTime(timezone=True), nullable=False),
sa.Column('user_id', sa.UUID(), nullable=False),
sa.Column('position', sa.String(), nullable=False),
sa.Column('about_me', sa.String(), nullable=False),
sa.Column('key_skills', sa.String(), nullable=False),
sa.Column('experience_type', sa.String(), nullable=False),
sa.Column('down_resume_id', sa.UUID(), nullable=True, default=None),
sa.ForeignKeyConstraint(['down_resume_id'], ['resume.id'], ondelete='CASCADE'),
sa.ForeignKeyConstraint(['user_id'], ['users.id'], ondelete='CASCADE'),
sa.PrimaryKeyConstraint('id')
)
op.create_table('resume_embedding',
sa.Column('id', sa.UUID(), nullable=False),
sa.Column('deleted_at', sa.DateTime(timezone=True), nullable=True),
sa.Column('created_at', sa.DateTime(timezone=True), nullable=False),
sa.Column('resume_id', sa.UUID(), nullable=False),
sa.Column('vector', sa.ARRAY(sa.Numeric()), nullable=False),
sa.ForeignKeyConstraint(['resume_id'], ['resume.id'], ondelete='CASCADE'),
sa.PrimaryKeyConstraint('id')
)
op.create_table('resume_prediction',
sa.Column('id', sa.UUID(), nullable=False),
sa.Column('deleted_at', sa.DateTime(timezone=True), nullable=True),
sa.Column('created_at', sa.DateTime(timezone=True), nullable=False),
sa.Column('resume_id', sa.UUID(), nullable=False),
sa.Column('from_salary', sa.Numeric(), nullable=False),
sa.Column('to_salary', sa.Numeric(), nullable=False),
sa.Column('recommended_skills', sa.ARRAY(sa.Numeric()), nullable=False),
sa.ForeignKeyConstraint(['resume_id'], ['resume.id'], ondelete='CASCADE'),
sa.PrimaryKeyConstraint('id')
)
# ### end Alembic commands ###
def downgrade() -> None:
"""Downgrade schema."""
# ### commands auto generated by Alembic - please adjust! ###
op.drop_table('resume_prediction')
op.drop_table('resume_embedding')
op.drop_table('resume')
# ### end Alembic commands ###
@@ -1,34 +0,0 @@
"""
Revision ID: 2b2091969d4c
Revises: 2ebcb2592cab
Create Date: 2025-11-22 11:24:36.215215
"""
from typing import Sequence, Union
from alembic import op
import sqlalchemy as sa
# revision identifiers, used by Alembic.
revision: str = '2b2091969d4c'
down_revision: Union[str, Sequence[str], None] = '2ebcb2592cab'
branch_labels: Union[str, Sequence[str], None] = None
depends_on: Union[str, Sequence[str], None] = None
def upgrade() -> None:
"""Upgrade schema."""
# ### commands auto generated by Alembic - please adjust! ###
op.add_column('resume', sa.Column('up_resume_id', sa.UUID(), nullable=True))
op.create_foreign_key(None, 'resume', 'resume', ['up_resume_id'], ['id'], ondelete='CASCADE')
# ### end Alembic commands ###
def downgrade() -> None:
"""Downgrade schema."""
# ### commands auto generated by Alembic - please adjust! ###
op.drop_constraint(None, 'resume', type_='foreignkey')
op.drop_column('resume', 'up_resume_id')
# ### end Alembic commands ###
@@ -1,37 +0,0 @@
"""add key skills
Revision ID: 2ebcb2592cab
Revises: 5b7a1ca1f06b
Create Date: 2025-11-22 03:59:55.147083
"""
from typing import Sequence, Union
from alembic import op
import sqlalchemy as sa
# revision identifiers, used by Alembic.
revision: str = '2ebcb2592cab'
down_revision: Union[str, Sequence[str], None] = '5b7a1ca1f06b'
branch_labels: Union[str, Sequence[str], None] = None
depends_on: Union[str, Sequence[str], None] = None
def upgrade() -> None:
"""Upgrade schema."""
# ### commands auto generated by Alembic - please adjust! ###
op.create_table('key_skills',
sa.Column('id', sa.Integer(), autoincrement=True, nullable=False),
sa.Column('name', sa.String(), nullable=False),
sa.PrimaryKeyConstraint('id'),
sa.UniqueConstraint('name')
)
# ### end Alembic commands ###
def downgrade() -> None:
"""Downgrade schema."""
# ### commands auto generated by Alembic - please adjust! ###
op.drop_table('key_skills')
# ### end Alembic commands ###
@@ -1,47 +0,0 @@
"""fix resume types
Revision ID: 5b7a1ca1f06b
Revises: 0d2e7755303c
Create Date: 2025-11-22 01:12:18.097168
"""
from typing import Sequence, Union
from alembic import op
import sqlalchemy as sa
from sqlalchemy.dialects import postgresql
from pgvector.sqlalchemy import Vector
# revision identifiers, used by Alembic.
revision: str = '5b7a1ca1f06b'
down_revision: Union[str, Sequence[str], None] = '0d2e7755303c'
branch_labels: Union[str, Sequence[str], None] = None
depends_on: Union[str, Sequence[str], None] = None
def upgrade() -> None:
"""Upgrade schema."""
# ### commands auto generated by Alembic - please adjust! ###
op.alter_column('resume_embedding', 'vector',
existing_type=postgresql.ARRAY(sa.NUMERIC()),
type_=Vector(),
existing_nullable=False)
op.alter_column('resume_prediction', 'recommended_skills',
existing_type=postgresql.ARRAY(sa.NUMERIC()),
type_=sa.ARRAY(sa.String(), as_tuple=True),
existing_nullable=False)
# ### end Alembic commands ###
def downgrade() -> None:
"""Downgrade schema."""
# ### commands auto generated by Alembic - please adjust! ###
op.alter_column('resume_prediction', 'recommended_skills',
existing_type=sa.ARRAY(sa.String(), as_tuple=True),
type_=postgresql.ARRAY(sa.NUMERIC()),
existing_nullable=False)
op.alter_column('resume_embedding', 'vector',
existing_type=pgvector.sqlalchemy.vector.VECTOR(),
type_=postgresql.ARRAY(sa.NUMERIC()),
existing_nullable=False)
# ### end Alembic commands ###
@@ -0,0 +1,175 @@
"""empty message
Revision ID: 892aba57b356
Revises:
Create Date: 2025-11-22 18:19:36.694430
"""
from typing import Sequence, Union
from alembic import op
import sqlalchemy as sa
import pgvector.sqlalchemy
from sqlalchemy import Text
from sqlalchemy.dialects.postgresql import JSONB, UUID
import template_project.adapters.data_gateways.tables
from template_project.adapters.data_gateways.tables import StringArrayType
# revision identifiers, used by Alembic.
revision: str = '892aba57b356'
down_revision: Union[str, Sequence[str], None] = None
branch_labels: Union[str, Sequence[str], None] = None
depends_on: Union[str, Sequence[str], None] = None
def upgrade() -> None:
"""Upgrade schema."""
# ### commands auto generated by Alembic - please adjust! ###
op.create_table('key_skills',
sa.Column('id', sa.Integer(), autoincrement=True, nullable=False),
sa.Column('name', sa.String(), nullable=False),
sa.PrimaryKeyConstraint('id'),
sa.UniqueConstraint('name')
)
op.create_table('users',
sa.Column('id', sa.UUID(), nullable=False),
sa.Column('deleted_at', sa.DateTime(timezone=True), nullable=True),
sa.Column('created_at', sa.DateTime(timezone=True), nullable=False),
sa.PrimaryKeyConstraint('id')
)
op.create_table('access_token',
sa.Column('id', sa.UUID(), nullable=False),
sa.Column('user_id', sa.UUID(), nullable=False),
sa.Column('revoked', sa.Boolean(), nullable=False),
sa.Column('expires_in', sa.DateTime(timezone=True), nullable=False),
sa.Column('deleted_at', sa.DateTime(timezone=True), nullable=True),
sa.Column('created_at', sa.DateTime(timezone=True), nullable=False),
sa.ForeignKeyConstraint(['user_id'], ['users.id'], ondelete='CASCADE'),
sa.PrimaryKeyConstraint('id')
)
op.create_table('auth_identities',
sa.Column('id', sa.UUID(), nullable=False),
sa.Column('user_id', sa.UUID(), nullable=False),
sa.Column('method', sa.Enum('EMAIL', 'YANDEX', name='auth_method'), nullable=False),
sa.Column('identifier', sa.String(), nullable=False),
sa.Column('secret_key', sa.String(), nullable=True),
sa.Column('created_at', sa.DateTime(timezone=True), nullable=False),
sa.ForeignKeyConstraint(['user_id'], ['users.id'], ondelete='CASCADE'),
sa.PrimaryKeyConstraint('id'),
sa.UniqueConstraint('method', 'identifier', name='uq_auth_method_identifier')
)
op.create_table('notification_devices',
sa.Column('id', sa.UUID(), nullable=False),
sa.Column('user_id', sa.UUID(), nullable=False),
sa.Column('device_id', sa.String(), nullable=False),
sa.Column('deleted_at', sa.DateTime(timezone=True), nullable=True),
sa.Column('created_at', sa.DateTime(timezone=True), nullable=False),
sa.ForeignKeyConstraint(['user_id'], ['users.id'], ondelete='CASCADE'),
sa.PrimaryKeyConstraint('id'),
sa.UniqueConstraint('user_id', 'device_id', name='uq_user_device')
)
op.create_table('profiles',
sa.Column('id', sa.UUID(), nullable=False),
sa.Column('user_id', sa.UUID(), nullable=False),
sa.Column('email', sa.String(), nullable=True),
sa.Column('display_name', sa.String(), nullable=True),
sa.Column('first_name', sa.String(), nullable=True),
sa.Column('last_name', sa.String(), nullable=True),
sa.Column('avatar_url', sa.String(), nullable=True),
sa.Column('phone', sa.String(), nullable=True),
sa.Column('deleted_at', sa.DateTime(timezone=True), nullable=True),
sa.Column('created_at', sa.DateTime(timezone=True), nullable=False),
sa.ForeignKeyConstraint(['user_id'], ['users.id'], ondelete='CASCADE'),
sa.PrimaryKeyConstraint('id'),
sa.UniqueConstraint('user_id')
)
op.create_table('resume',
sa.Column('id', sa.UUID(), nullable=False),
sa.Column('deleted_at', sa.DateTime(timezone=True), nullable=True),
sa.Column('created_at', sa.DateTime(timezone=True), nullable=False),
sa.Column('user_id', sa.UUID(), nullable=False),
sa.Column('position', sa.String(), nullable=False),
sa.Column('location', sa.String(), nullable=False),
sa.Column('about_me', sa.String(), nullable=False),
sa.Column('key_skills', StringArrayType(astext_type=Text()), server_default=sa.text("'[]'::jsonb"), nullable=False),
sa.Column('experience_type', sa.String(), nullable=False),
sa.Column('down_resume_id', sa.UUID(), nullable=True),
sa.Column('up_resume_id', sa.UUID(), nullable=True),
sa.ForeignKeyConstraint(['down_resume_id'], ['resume.id'], ondelete='CASCADE'),
sa.ForeignKeyConstraint(['up_resume_id'], ['resume.id'], ondelete='CASCADE'),
sa.ForeignKeyConstraint(['user_id'], ['users.id'], ondelete='CASCADE'),
sa.PrimaryKeyConstraint('id')
)
op.create_table('resume_education',
sa.Column('id', sa.UUID(), nullable=False),
sa.Column('deleted_at', sa.DateTime(timezone=True), nullable=True),
sa.Column('created_at', sa.DateTime(timezone=True), nullable=False),
sa.Column('resume_id', sa.UUID(), nullable=False),
sa.Column('place', sa.String(), nullable=False),
sa.Column('grade', sa.Enum('BASIC_GENERAL_EDUCATION', 'SECONDARY_GENERAL_EDUCATION', 'SECONDARY_PROFESSIONAL_EDUCATION', 'BACHELOR', 'SPECIALIST', 'MASTER', 'POSTGRADUATE_STUDIES', 'OTHER', name='education_grade'), nullable=False),
sa.Column('specialization', sa.String(), nullable=False),
sa.Column('description', sa.String(), nullable=True),
sa.ForeignKeyConstraint(['resume_id'], ['resume.id'], ondelete='CASCADE'),
sa.PrimaryKeyConstraint('id')
)
op.create_table('resume_embedding',
sa.Column('id', sa.UUID(), nullable=False),
sa.Column('deleted_at', sa.DateTime(timezone=True), nullable=True),
sa.Column('created_at', sa.DateTime(timezone=True), nullable=False),
sa.Column('resume_id', sa.UUID(), nullable=False),
sa.Column('vector', pgvector.sqlalchemy.vector.VECTOR(), nullable=False),
sa.ForeignKeyConstraint(['resume_id'], ['resume.id'], ondelete='CASCADE'),
sa.PrimaryKeyConstraint('id')
)
op.create_table('resume_experience',
sa.Column('id', sa.UUID(), nullable=False),
sa.Column('deleted_at', sa.DateTime(timezone=True), nullable=True),
sa.Column('created_at', sa.DateTime(timezone=True), nullable=False),
sa.Column('resume_id', sa.UUID(), nullable=False),
sa.Column('place', sa.String(), nullable=False),
sa.Column('description', sa.String(), nullable=False),
sa.Column('months_duration', sa.Integer(), nullable=False),
sa.ForeignKeyConstraint(['resume_id'], ['resume.id'], ondelete='CASCADE'),
sa.PrimaryKeyConstraint('id')
)
op.create_table('resume_prediction',
sa.Column('id', sa.UUID(), nullable=False),
sa.Column('deleted_at', sa.DateTime(timezone=True), nullable=True),
sa.Column('created_at', sa.DateTime(timezone=True), nullable=False),
sa.Column('resume_id', sa.UUID(), nullable=False),
sa.Column('from_salary', sa.Numeric(), nullable=False),
sa.Column('to_salary', sa.Numeric(), nullable=False),
sa.Column('recommended_skills', template_project.adapters.data_gateways.tables.StringArrayType(astext_type=Text()), server_default=sa.text("'[]'::jsonb"), nullable=False),
sa.ForeignKeyConstraint(['resume_id'], ['resume.id'], ondelete='CASCADE'),
sa.PrimaryKeyConstraint('id')
)
op.create_table('resume_project',
sa.Column('id', sa.UUID(), nullable=False),
sa.Column('deleted_at', sa.DateTime(timezone=True), nullable=True),
sa.Column('created_at', sa.DateTime(timezone=True), nullable=False),
sa.Column('resume_id', sa.UUID(), nullable=False),
sa.Column('name', sa.String(), nullable=False),
sa.Column('description', sa.String(), nullable=False),
sa.ForeignKeyConstraint(['resume_id'], ['resume.id'], ondelete='CASCADE'),
sa.PrimaryKeyConstraint('id')
)
# ### end Alembic commands ###
def downgrade() -> None:
"""Downgrade schema."""
# ### commands auto generated by Alembic - please adjust! ###
op.drop_table('resume_project')
op.drop_table('resume_prediction')
op.drop_table('resume_experience')
op.drop_table('resume_embedding')
op.drop_table('resume_education')
op.drop_table('resume')
op.drop_table('profiles')
op.drop_table('notification_devices')
op.drop_table('auth_identities')
op.drop_table('access_token')
op.drop_table('users')
op.drop_table('key_skills')
# ### end Alembic commands ###
@@ -1,41 +0,0 @@
"""empty message
Revision ID: 9140c6824ab8
Revises: b5fa4f3e95c5
Create Date: 2025-11-20 20:57:31.722554
"""
from typing import Sequence, Union
from alembic import op
import sqlalchemy as sa
# revision identifiers, used by Alembic.
revision: str = '9140c6824ab8'
down_revision: Union[str, Sequence[str], None] = 'b5fa4f3e95c5'
branch_labels: Union[str, Sequence[str], None] = None
depends_on: Union[str, Sequence[str], None] = None
def upgrade() -> None:
"""Upgrade schema."""
# ### commands auto generated by Alembic - please adjust! ###
op.create_table('notification_devices',
sa.Column('id', sa.UUID(), nullable=False),
sa.Column('user_id', sa.UUID(), nullable=False),
sa.Column('device_id', sa.String(), nullable=False),
sa.Column('deleted_at', sa.DateTime(timezone=True), nullable=True),
sa.Column('created_at', sa.DateTime(timezone=True), nullable=False),
sa.ForeignKeyConstraint(['user_id'], ['users.id'], ondelete='CASCADE'),
sa.PrimaryKeyConstraint('id'),
sa.UniqueConstraint('user_id', 'device_id', name='uq_user_device')
)
# ### end Alembic commands ###
def downgrade() -> None:
"""Downgrade schema."""
# ### commands auto generated by Alembic - please adjust! ###
op.drop_table('notification_devices')
# ### end Alembic commands ###
@@ -1,51 +0,0 @@
"""empty message
Revision ID: ad80834713c3
Revises:
Create Date: 2025-11-12 00:03:31.080899
"""
from typing import Sequence, Union
from alembic import op
import sqlalchemy as sa
# revision identifiers, used by Alembic.
revision: str = 'ad80834713c3'
down_revision: Union[str, Sequence[str], None] = None
branch_labels: Union[str, Sequence[str], None] = None
depends_on: Union[str, Sequence[str], None] = None
def upgrade() -> None:
"""Upgrade schema."""
# ### commands auto generated by Alembic - please adjust! ###
op.create_table('users',
sa.Column('id', sa.UUID(), nullable=False),
sa.Column('email', sa.String(), nullable=False),
sa.Column('hashed_password', sa.String(), nullable=False),
sa.Column('deleted_at', sa.DateTime(timezone=True), nullable=True),
sa.Column('created_at', sa.DateTime(timezone=True), nullable=False),
sa.PrimaryKeyConstraint('id'),
sa.UniqueConstraint('email')
)
op.create_table('access_token',
sa.Column('id', sa.UUID(), nullable=False),
sa.Column('user_id', sa.UUID(), nullable=False),
sa.Column('revoked', sa.Boolean(), nullable=False),
sa.Column('expires_in', sa.DateTime(timezone=True), nullable=False),
sa.Column('deleted_at', sa.DateTime(timezone=True), nullable=True),
sa.Column('created_at', sa.DateTime(timezone=True), nullable=False),
sa.ForeignKeyConstraint(['user_id'], ['users.id'], ondelete='CASCADE'),
sa.PrimaryKeyConstraint('id')
)
# ### end Alembic commands ###
def downgrade() -> None:
"""Downgrade schema."""
# ### commands auto generated by Alembic - please adjust! ###
op.drop_table('access_token')
op.drop_table('users')
# ### end Alembic commands ###
@@ -1,52 +0,0 @@
"""empty message
Revision ID: b5fa4f3e95c5
Revises: f29dccaa6356
Create Date: 2025-11-20 01:13:13.877236
"""
from typing import Sequence, Union
from alembic import op
import sqlalchemy as sa
# revision identifiers, used by Alembic.
revision: str = 'b5fa4f3e95c5'
down_revision: Union[str, Sequence[str], None] = 'f29dccaa6356'
branch_labels: Union[str, Sequence[str], None] = None
depends_on: Union[str, Sequence[str], None] = None
def upgrade() -> None:
"""Upgrade schema."""
# ### commands auto generated by Alembic - please adjust! ###
op.create_table('profiles',
sa.Column('id', sa.UUID(), nullable=False),
sa.Column('user_id', sa.UUID(), nullable=False),
sa.Column('email', sa.String(), nullable=True),
sa.Column('display_name', sa.String(), nullable=True),
sa.Column('first_name', sa.String(), nullable=True),
sa.Column('last_name', sa.String(), nullable=True),
sa.Column('avatar_url', sa.String(), nullable=True),
sa.Column('phone', sa.String(), nullable=True),
sa.Column('deleted_at', sa.DateTime(timezone=True), nullable=True),
sa.Column('created_at', sa.DateTime(timezone=True), nullable=False),
sa.ForeignKeyConstraint(['user_id'], ['users.id'], ondelete='CASCADE'),
sa.PrimaryKeyConstraint('id'),
sa.UniqueConstraint('user_id')
)
op.drop_constraint(op.f('users_email_key'), 'users', type_='unique')
op.drop_column('users', 'hashed_password')
op.drop_column('users', 'email')
# ### end Alembic commands ###
def downgrade() -> None:
"""Downgrade schema."""
# ### commands auto generated by Alembic - please adjust! ###
op.add_column('users', sa.Column('email', sa.VARCHAR(), autoincrement=False, nullable=True))
op.add_column('users', sa.Column('hashed_password', sa.VARCHAR(), autoincrement=False, nullable=True))
op.create_unique_constraint(op.f('users_email_key'), 'users', ['email'], postgresql_nulls_not_distinct=False)
op.drop_table('profiles')
# ### end Alembic commands ###
@@ -1,54 +0,0 @@
"""empty message
Revision ID: f29dccaa6356
Revises: ad80834713c3
Create Date: 2025-11-18 00:14:48.550720
"""
from typing import Sequence, Union
from alembic import op
import sqlalchemy as sa
# revision identifiers, used by Alembic.
revision: str = 'f29dccaa6356'
down_revision: Union[str, Sequence[str], None] = 'ad80834713c3'
branch_labels: Union[str, Sequence[str], None] = None
depends_on: Union[str, Sequence[str], None] = None
def upgrade() -> None:
"""Upgrade schema."""
# ### commands auto generated by Alembic - please adjust! ###
op.create_table('auth_identities',
sa.Column('id', sa.UUID(), nullable=False),
sa.Column('user_id', sa.UUID(), nullable=False),
sa.Column('method', sa.Enum('EMAIL', 'YANDEX', name='auth_method'), nullable=False),
sa.Column('identifier', sa.String(), nullable=False),
sa.Column('secret_key', sa.String(), nullable=True),
sa.Column('created_at', sa.DateTime(timezone=True), nullable=False),
sa.ForeignKeyConstraint(['user_id'], ['users.id'], ondelete='CASCADE'),
sa.PrimaryKeyConstraint('id'),
sa.UniqueConstraint('method', 'identifier', name='uq_auth_method_identifier')
)
op.alter_column('users', 'email',
existing_type=sa.VARCHAR(),
nullable=True)
op.alter_column('users', 'hashed_password',
existing_type=sa.VARCHAR(),
nullable=True)
# ### end Alembic commands ###
def downgrade() -> None:
"""Downgrade schema."""
# ### commands auto generated by Alembic - please adjust! ###
op.alter_column('users', 'hashed_password',
existing_type=sa.VARCHAR(),
nullable=False)
op.alter_column('users', 'email',
existing_type=sa.VARCHAR(),
nullable=False)
op.drop_table('auth_identities')
# ### end Alembic commands ###