2017-04-23 22:06:55 -05:00
|
|
|
##########################################################################
|
|
|
|
#
|
|
|
|
# pgAdmin 4 - PostgreSQL Tools
|
|
|
|
#
|
2024-01-01 02:43:48 -06:00
|
|
|
# Copyright (C) 2013 - 2024, The pgAdmin Development Team
|
2017-04-23 22:06:55 -05:00
|
|
|
# This software is released under the PostgreSQL Licence
|
|
|
|
#
|
|
|
|
##########################################################################
|
|
|
|
|
|
|
|
"""Update DB to version 14
|
|
|
|
|
|
|
|
Revision ID: 09d53fca90c7
|
|
|
|
Revises: fdc58d9bd449
|
|
|
|
Create Date: 2017-03-13 12:27:30.543908
|
|
|
|
|
|
|
|
"""
|
|
|
|
import base64
|
2017-09-28 04:16:49 -05:00
|
|
|
import os
|
2017-04-23 22:06:55 -05:00
|
|
|
import config
|
2022-10-20 05:48:41 -05:00
|
|
|
import sqlalchemy as sa
|
|
|
|
from alembic import op
|
2017-09-28 04:16:49 -05:00
|
|
|
from pgadmin.model import db, Server
|
2022-10-20 05:48:41 -05:00
|
|
|
from pgadmin.setup import get_version_for_migration
|
2017-04-23 22:06:55 -05:00
|
|
|
|
|
|
|
# revision identifiers, used by Alembic.
|
|
|
|
|
|
|
|
revision = '09d53fca90c7'
|
|
|
|
down_revision = 'fdc58d9bd449'
|
|
|
|
branch_labels = None
|
|
|
|
depends_on = None
|
|
|
|
|
|
|
|
|
|
|
|
def upgrade():
|
2022-10-20 05:48:41 -05:00
|
|
|
version = get_version_for_migration(op)
|
2017-04-23 22:06:55 -05:00
|
|
|
# Changes introduced in schema version 2
|
|
|
|
if version < 2:
|
|
|
|
# Create the 'server' table
|
|
|
|
db.metadata.create_all(db.engine, tables=[Server.__table__])
|
|
|
|
if version < 3:
|
2022-10-20 05:48:41 -05:00
|
|
|
op.add_column('server', sa.Column('comment', sa.String(length=1024)))
|
2017-04-23 22:06:55 -05:00
|
|
|
if version < 4:
|
2022-11-16 02:31:55 -06:00
|
|
|
op.add_column('server', sa.Column('password', sa.String()))
|
2017-04-23 22:06:55 -05:00
|
|
|
if version < 5:
|
2022-10-20 05:48:41 -05:00
|
|
|
op.add_column('server', sa.Column('role', sa.String(length=64)))
|
2017-04-23 22:06:55 -05:00
|
|
|
if version < 6:
|
2022-10-20 05:48:41 -05:00
|
|
|
with op.batch_alter_table("server") as batch_op:
|
|
|
|
batch_op.create_check_constraint(
|
|
|
|
"ck_port_range",
|
|
|
|
"port >= 1024 AND port <= 65535"
|
|
|
|
)
|
|
|
|
|
|
|
|
batch_op.create_check_constraint(
|
|
|
|
"ck_ssl_mode",
|
|
|
|
"ssl_mode IN ('allow', 'prefer', 'require', 'disable', \
|
|
|
|
'verify-ca', 'verify-full')"
|
|
|
|
)
|
2017-04-23 22:06:55 -05:00
|
|
|
if version < 8:
|
2022-10-20 05:48:41 -05:00
|
|
|
op.create_table(
|
|
|
|
'module_preference',
|
|
|
|
sa.Column('id', sa.Integer(), nullable=False, autoincrement=True),
|
|
|
|
sa.Column('name', sa.String(length=256), nullable=False),
|
|
|
|
sa.PrimaryKeyConstraint('id'))
|
|
|
|
|
|
|
|
op.create_table(
|
|
|
|
'preference_category',
|
|
|
|
sa.Column('id', sa.Integer(), nullable=False, autoincrement=True),
|
|
|
|
sa.Column('mid', sa.Integer(),),
|
|
|
|
sa.Column('name', sa.String(length=256), nullable=False),
|
|
|
|
sa.ForeignKeyConstraint(['mid'], ['module_preference.id'], ),
|
|
|
|
sa.PrimaryKeyConstraint('id'))
|
|
|
|
|
|
|
|
op.create_table(
|
|
|
|
'preferences',
|
|
|
|
sa.Column('id', sa.Integer(), nullable=False, autoincrement=True),
|
|
|
|
sa.Column('cid', sa.Integer(), nullable=False),
|
|
|
|
sa.Column('name', sa.String(length=256), nullable=False),
|
|
|
|
sa.ForeignKeyConstraint(['cid'], ['preference_category.id'], ),
|
|
|
|
sa.PrimaryKeyConstraint('id'))
|
|
|
|
|
|
|
|
op.create_table(
|
|
|
|
'user_preferences',
|
|
|
|
sa.Column('pid', sa.Integer(), nullable=False),
|
|
|
|
sa.Column('uid', sa.Integer(), nullable=False),
|
|
|
|
sa.Column('value', sa.String(length=1024), nullable=False),
|
2022-11-16 02:31:55 -06:00
|
|
|
sa.ForeignKeyConstraint(['pid'], ['preferences.id'],
|
|
|
|
ondelete='CASCADE'),
|
|
|
|
sa.ForeignKeyConstraint(['uid'], ['user.id'], ondelete='CASCADE'),
|
2022-10-20 05:48:41 -05:00
|
|
|
sa.PrimaryKeyConstraint('pid', 'uid'))
|
2017-04-23 22:06:55 -05:00
|
|
|
|
|
|
|
if version < 9:
|
2022-10-20 05:48:41 -05:00
|
|
|
op.create_table(
|
|
|
|
'debugger_function_arguments',
|
|
|
|
sa.Column('server_id', sa.Integer(), nullable=False),
|
|
|
|
sa.Column('database_id', sa.Integer(), nullable=False),
|
|
|
|
sa.Column('schema_id', sa.Integer(), nullable=False),
|
|
|
|
sa.Column('function_id', sa.Integer(), nullable=False),
|
|
|
|
sa.Column('arg_id', sa.Integer(), nullable=False),
|
|
|
|
sa.Column('is_null', sa.Integer(), nullable=False),
|
|
|
|
sa.Column('is_expression', sa.Integer(), nullable=False),
|
|
|
|
sa.Column('use_default', sa.Integer()),
|
|
|
|
sa.Column('value', sa.String(), nullable=False),
|
|
|
|
sa.CheckConstraint('is_null >= 0 AND is_null <= 1'),
|
|
|
|
sa.CheckConstraint('is_expression >= 0 AND is_expression <= 1'),
|
|
|
|
sa.CheckConstraint('use_default >= 0 AND use_default <= 1'),
|
|
|
|
sa.PrimaryKeyConstraint('server_id', 'database_id', 'schema_id',
|
|
|
|
'function_id', 'arg_id'))
|
2017-04-23 22:06:55 -05:00
|
|
|
if version < 10:
|
2022-10-20 05:48:41 -05:00
|
|
|
op.create_table(
|
|
|
|
'process',
|
|
|
|
sa.Column('user_id', sa.Integer(), nullable=False),
|
|
|
|
sa.Column('pid', sa.String(), nullable=False),
|
|
|
|
sa.Column('desc', sa.String(), nullable=False),
|
|
|
|
sa.Column('command', sa.String(), nullable=False),
|
|
|
|
sa.Column('arguments', sa.String()),
|
|
|
|
sa.Column('start_time', sa.String()),
|
|
|
|
sa.Column('end_time', sa.String()),
|
|
|
|
sa.Column('logdir', sa.String()),
|
|
|
|
sa.Column('exit_code', sa.Integer()),
|
|
|
|
sa.Column('acknowledge', sa.String()),
|
2022-11-16 02:31:55 -06:00
|
|
|
sa.ForeignKeyConstraint(['user_id'], ['user.id'],
|
|
|
|
ondelete='CASCADE'),
|
2022-10-20 05:48:41 -05:00
|
|
|
sa.PrimaryKeyConstraint('pid'))
|
2017-04-23 22:06:55 -05:00
|
|
|
|
|
|
|
if version < 11:
|
2022-10-20 05:48:41 -05:00
|
|
|
# get metadata from current connection
|
Update SQLAlchemy, Flask, Flask-SQLAlchemy, and other packages to current versions. #5901
- Update Flask, Flask-SQLAlchemy, Flask-Babel, Flask-Security-Too, Flask-SocketIO, pytz, psutil, SQLAlchemy, bcrypt, cryptography, eventlet, Authlib, requests python packages
- Remove pinned dnspython, Werkzeug packages from requirements.txt
2023-03-15 01:27:16 -05:00
|
|
|
meta = sa.MetaData()
|
2022-10-20 05:48:41 -05:00
|
|
|
# define table representation
|
Update SQLAlchemy, Flask, Flask-SQLAlchemy, and other packages to current versions. #5901
- Update Flask, Flask-SQLAlchemy, Flask-Babel, Flask-Security-Too, Flask-SocketIO, pytz, psutil, SQLAlchemy, bcrypt, cryptography, eventlet, Authlib, requests python packages
- Remove pinned dnspython, Werkzeug packages from requirements.txt
2023-03-15 01:27:16 -05:00
|
|
|
meta.reflect(op.get_bind(), only=('role',))
|
2022-10-20 05:48:41 -05:00
|
|
|
role_table = sa.Table('role', meta)
|
|
|
|
|
|
|
|
op.execute(
|
|
|
|
role_table.update().where(role_table.c.name == 'Administrators')
|
|
|
|
.values(name='Administrator',
|
|
|
|
description='pgAdmin Administrator Role'))
|
|
|
|
|
|
|
|
op.bulk_insert(role_table,
|
|
|
|
[{'name': 'User', 'description': 'pgAdmin User Role'}])
|
2017-04-23 22:06:55 -05:00
|
|
|
|
|
|
|
if version < 13:
|
2022-10-20 05:48:41 -05:00
|
|
|
op.add_column('server', sa.Column('discovery_id', sa.String()))
|
2017-04-23 22:06:55 -05:00
|
|
|
|
|
|
|
if version < 14:
|
2022-10-20 05:48:41 -05:00
|
|
|
keys_table = op.create_table(
|
|
|
|
'keys',
|
|
|
|
sa.Column('name', sa.String(), nullable=False),
|
|
|
|
sa.Column('value', sa.String(), nullable=False),
|
|
|
|
sa.PrimaryKeyConstraint('name'))
|
2017-04-23 22:06:55 -05:00
|
|
|
|
2022-10-20 05:48:41 -05:00
|
|
|
secret_key = base64.urlsafe_b64encode(os.urandom(32)).decode()
|
2021-11-24 05:52:57 -06:00
|
|
|
if hasattr(config, 'SECRET_KEY'):
|
2022-10-20 05:48:41 -05:00
|
|
|
secret_key = config.SECRET_KEY
|
|
|
|
|
|
|
|
# If SECURITY_PASSWORD_SALT is not in the config, but we're upgrading,
|
|
|
|
# then it must (unless the user edited the main config - which they
|
|
|
|
# shouldn't have done) have been at it's default value, so we'll use
|
|
|
|
# that. Otherwise, use whatever we can find in the config.
|
|
|
|
security_password_salt = 'SuperSecret3'
|
2017-04-23 22:06:55 -05:00
|
|
|
if hasattr(config, 'SECURITY_PASSWORD_SALT'):
|
2022-10-20 05:48:41 -05:00
|
|
|
security_password_salt = config.SECURITY_PASSWORD_SALT
|
|
|
|
|
|
|
|
op.bulk_insert(keys_table,
|
|
|
|
[{'name': 'CSRF_SESSION_KEY', 'value':
|
|
|
|
base64.urlsafe_b64encode(os.urandom(32)).decode()},
|
|
|
|
{'name': 'SECRET_KEY', 'value': secret_key},
|
|
|
|
{'name': 'SECURITY_PASSWORD_SALT',
|
|
|
|
'value': security_password_salt}])
|
|
|
|
|
|
|
|
# get metadata from current connection
|
Update SQLAlchemy, Flask, Flask-SQLAlchemy, and other packages to current versions. #5901
- Update Flask, Flask-SQLAlchemy, Flask-Babel, Flask-Security-Too, Flask-SocketIO, pytz, psutil, SQLAlchemy, bcrypt, cryptography, eventlet, Authlib, requests python packages
- Remove pinned dnspython, Werkzeug packages from requirements.txt
2023-03-15 01:27:16 -05:00
|
|
|
meta = sa.MetaData()
|
2022-10-20 05:48:41 -05:00
|
|
|
# define table representation
|
Update SQLAlchemy, Flask, Flask-SQLAlchemy, and other packages to current versions. #5901
- Update Flask, Flask-SQLAlchemy, Flask-Babel, Flask-Security-Too, Flask-SocketIO, pytz, psutil, SQLAlchemy, bcrypt, cryptography, eventlet, Authlib, requests python packages
- Remove pinned dnspython, Werkzeug packages from requirements.txt
2023-03-15 01:27:16 -05:00
|
|
|
meta.reflect(op.get_bind(), only=('version',))
|
2022-10-20 05:48:41 -05:00
|
|
|
version_table = sa.Table('version', meta)
|
|
|
|
|
|
|
|
op.execute(
|
|
|
|
version_table.update().where(version_table.c.name == 'ConfigDB')
|
|
|
|
.values(value=config.SETTINGS_SCHEMA_VERSION))
|
2017-04-23 22:06:55 -05:00
|
|
|
# ### end Alembic commands ###
|
|
|
|
|
|
|
|
|
|
|
|
def downgrade():
|
2020-07-24 01:16:30 -05:00
|
|
|
# pgAdmin only upgrades, downgrade not implemented.
|
|
|
|
pass
|