mirror of https://gitlab.com/tildes/tildes.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
50 lines
1.3 KiB
50 lines
1.3 KiB
"""Add financials table
|
|
|
|
Revision ID: 879588c5729d
|
|
Revises: fa14e9f5ebe5
|
|
Create Date: 2019-11-05 19:50:13.973734
|
|
|
|
"""
|
|
|
|
from alembic import op
|
|
import sqlalchemy as sa
|
|
from sqlalchemy.dialects import postgresql
|
|
|
|
# revision identifiers, used by Alembic.
|
|
revision = "879588c5729d"
|
|
down_revision = "fa14e9f5ebe5"
|
|
branch_labels = None
|
|
depends_on = None
|
|
|
|
|
|
def upgrade():
|
|
op.create_table(
|
|
"financials",
|
|
sa.Column("entry_id", sa.Integer(), nullable=False),
|
|
sa.Column(
|
|
"entry_type",
|
|
postgresql.ENUM("EXPENSE", "GOAL", "INCOME", name="financialentrytype"),
|
|
nullable=False,
|
|
),
|
|
sa.Column("description", sa.Text(), nullable=True),
|
|
sa.Column("amount", sa.Numeric(scale=2), nullable=False),
|
|
sa.Column("date_range", postgresql.DATERANGE(), nullable=False),
|
|
sa.Column(
|
|
"is_approximate", sa.Boolean(), server_default="false", nullable=False
|
|
),
|
|
sa.PrimaryKeyConstraint("entry_id", name=op.f("pk_financials")),
|
|
)
|
|
op.create_index(
|
|
"ix_financials_date_range_gist",
|
|
"financials",
|
|
["date_range"],
|
|
unique=False,
|
|
postgresql_using="gist",
|
|
)
|
|
|
|
|
|
def downgrade():
|
|
op.drop_index("ix_financials_date_range_gist", table_name="financials")
|
|
op.drop_table("financials")
|
|
|
|
op.execute("DROP TYPE financialentrytype")
|