Brandon Cornejo
5 years ago
11 changed files with 383 additions and 235 deletions
-
14Makefile
-
4acks/commands.py
-
39acks/npc/commands.py
-
12acks/npc/default_classes.csv
-
54acks/npc/models.py
-
275acks/npc/npc_party.py
-
85alembic.ini
-
1alembic/README
-
86alembic/env.py
-
24alembic/script.py.mako
-
24alembic/versions/7287451b8bce_create_characterclass_table.py
@ -1,12 +0,0 @@ |
|||||
name,bucket,prime_requisite,hit_die_size,maximum_level,armour_modifier,melee_light,melee_medium,melee_heavy,ranged_light,ranged_heavy |
|
||||
Elven Nightblade,Demi-Human,D+I,6,11,-4,1,2,0,0,0 |
|
||||
Elven Spellsword,Demi-Human,S+I,6,10,-4,0,1,0,0,0 |
|
||||
Explorer,Campaign,S+D,6,14,-3,1,1,0,0,1 |
|
||||
Bladedancer,Campaign,W+D,6,14,-2,0,1,0,0,0 |
|
||||
Cleric,Core,WIS,6,14,0,1,3,1,1,3 |
|
||||
Fighter,Core,STR,8,14,1,1,4,1,1,1 |
|
||||
Thief,Core,DEX,4,14,-6,1,1,0,1,0 |
|
||||
Mage,Core,INT,4,14,-8,1,0,0,0,0 |
|
||||
Assassin,Campaign,S+D,6,14,-6,1,2,0,1,0 |
|
||||
Bard,Campaign,D+H,6,14,-3,1,2,0,1,0 |
|
||||
Dwarven Vaultguard,Demi-Human,STR,8,13,-1,0,3,1,1,1 |
|
@ -0,0 +1,85 @@ |
|||||
|
# A generic, single database configuration. |
||||
|
|
||||
|
[alembic] |
||||
|
# path to migration scripts |
||||
|
script_location = alembic |
||||
|
|
||||
|
# template used to generate migration files |
||||
|
# file_template = %%(rev)s_%%(slug)s |
||||
|
|
||||
|
# timezone to use when rendering the date |
||||
|
# within the migration file as well as the filename. |
||||
|
# string value is passed to dateutil.tz.gettz() |
||||
|
# leave blank for localtime |
||||
|
# timezone = |
||||
|
|
||||
|
# max length of characters to apply to the |
||||
|
# "slug" field |
||||
|
# truncate_slug_length = 40 |
||||
|
|
||||
|
# set to 'true' to run the environment during |
||||
|
# the 'revision' command, regardless of autogenerate |
||||
|
# revision_environment = false |
||||
|
|
||||
|
# set to 'true' to allow .pyc and .pyo files without |
||||
|
# a source .py file to be detected as revisions in the |
||||
|
# versions/ directory |
||||
|
# sourceless = false |
||||
|
|
||||
|
# version location specification; this defaults |
||||
|
# to alembic/versions. When using multiple version |
||||
|
# directories, initial revisions must be specified with --version-path |
||||
|
# version_locations = %(here)s/bar %(here)s/bat alembic/versions |
||||
|
|
||||
|
# the output encoding used when revision files |
||||
|
# are written from script.py.mako |
||||
|
# output_encoding = utf-8 |
||||
|
|
||||
|
sqlalchemy.url = driver://user:pass@localhost/dbname |
||||
|
|
||||
|
|
||||
|
[post_write_hooks] |
||||
|
# post_write_hooks defines scripts or Python functions that are run |
||||
|
# on newly generated revision scripts. See the documentation for further |
||||
|
# detail and examples |
||||
|
|
||||
|
# format using "black" - use the console_scripts runner, against the "black" entrypoint |
||||
|
# hooks=black |
||||
|
# black.type=console_scripts |
||||
|
# black.entrypoint=black |
||||
|
# black.options=-l 79 |
||||
|
|
||||
|
# Logging configuration |
||||
|
[loggers] |
||||
|
keys = root,sqlalchemy,alembic |
||||
|
|
||||
|
[handlers] |
||||
|
keys = console |
||||
|
|
||||
|
[formatters] |
||||
|
keys = generic |
||||
|
|
||||
|
[logger_root] |
||||
|
level = WARN |
||||
|
handlers = console |
||||
|
qualname = |
||||
|
|
||||
|
[logger_sqlalchemy] |
||||
|
level = WARN |
||||
|
handlers = |
||||
|
qualname = sqlalchemy.engine |
||||
|
|
||||
|
[logger_alembic] |
||||
|
level = INFO |
||||
|
handlers = |
||||
|
qualname = alembic |
||||
|
|
||||
|
[handler_console] |
||||
|
class = StreamHandler |
||||
|
args = (sys.stderr,) |
||||
|
level = NOTSET |
||||
|
formatter = generic |
||||
|
|
||||
|
[formatter_generic] |
||||
|
format = %(levelname)-5.5s [%(name)s] %(message)s |
||||
|
datefmt = %H:%M:%S |
@ -0,0 +1 @@ |
|||||
|
Generic single-database configuration. |
@ -0,0 +1,86 @@ |
|||||
|
from logging.config import fileConfig |
||||
|
|
||||
|
from sqlalchemy import engine_from_config |
||||
|
from sqlalchemy import pool |
||||
|
|
||||
|
from alembic import context |
||||
|
|
||||
|
|
||||
|
from acks import app |
||||
|
from acks.models import db |
||||
|
|
||||
|
# this is the Alembic Config object, which provides |
||||
|
# access to the values within the .ini file in use. |
||||
|
config = context.config |
||||
|
|
||||
|
# set the sqlalchemy url to the one defined for flask-sqlalchemy |
||||
|
config.set_main_option('sqlalchemy.url', app.config['SQLALCHEMY_DATABASE_URI']) |
||||
|
|
||||
|
# Interpret the config file for Python logging. |
||||
|
# This line sets up loggers basically. |
||||
|
fileConfig(config.config_file_name) |
||||
|
|
||||
|
# add your model's MetaData object here |
||||
|
# for 'autogenerate' support |
||||
|
# from myapp import mymodel |
||||
|
# target_metadata = mymodel.Base.metadata |
||||
|
from acks.models import BaseModel |
||||
|
target_metadata = BaseModel.metadata |
||||
|
|
||||
|
# other values from the config, defined by the needs of env.py, |
||||
|
# can be acquired: |
||||
|
# my_important_option = config.get_main_option("my_important_option") |
||||
|
# ... etc. |
||||
|
|
||||
|
|
||||
|
def run_migrations_offline(): |
||||
|
"""Run migrations in 'offline' mode. |
||||
|
|
||||
|
This configures the context with just a URL |
||||
|
and not an Engine, though an Engine is acceptable |
||||
|
here as well. By skipping the Engine creation |
||||
|
we don't even need a DBAPI to be available. |
||||
|
|
||||
|
Calls to context.execute() here emit the given string to the |
||||
|
script output. |
||||
|
|
||||
|
""" |
||||
|
url = config.get_main_option("sqlalchemy.url") |
||||
|
context.configure( |
||||
|
url=url, |
||||
|
target_metadata=target_metadata, |
||||
|
literal_binds=True, |
||||
|
dialect_opts={"paramstyle": "named"}, |
||||
|
) |
||||
|
|
||||
|
with context.begin_transaction(): |
||||
|
context.run_migrations() |
||||
|
|
||||
|
|
||||
|
def run_migrations_online(): |
||||
|
"""Run migrations in 'online' mode. |
||||
|
|
||||
|
In this scenario we need to create an Engine |
||||
|
and associate a connection with the context. |
||||
|
|
||||
|
""" |
||||
|
|
||||
|
connectable = engine_from_config( |
||||
|
config.get_section(config.config_ini_section), |
||||
|
prefix="sqlalchemy.", |
||||
|
poolclass=pool.NullPool, |
||||
|
) |
||||
|
|
||||
|
with connectable.connect() as connection: |
||||
|
context.configure( |
||||
|
connection=connection, target_metadata=target_metadata |
||||
|
) |
||||
|
|
||||
|
with context.begin_transaction(): |
||||
|
context.run_migrations() |
||||
|
|
||||
|
|
||||
|
if context.is_offline_mode(): |
||||
|
run_migrations_offline() |
||||
|
else: |
||||
|
run_migrations_online() |
@ -0,0 +1,24 @@ |
|||||
|
"""${message} |
||||
|
|
||||
|
Revision ID: ${up_revision} |
||||
|
Revises: ${down_revision | comma,n} |
||||
|
Create Date: ${create_date} |
||||
|
|
||||
|
""" |
||||
|
from alembic import op |
||||
|
import sqlalchemy as sa |
||||
|
${imports if imports else ""} |
||||
|
|
||||
|
# revision identifiers, used by Alembic. |
||||
|
revision = ${repr(up_revision)} |
||||
|
down_revision = ${repr(down_revision)} |
||||
|
branch_labels = ${repr(branch_labels)} |
||||
|
depends_on = ${repr(depends_on)} |
||||
|
|
||||
|
|
||||
|
def upgrade(): |
||||
|
${upgrades if upgrades else "pass"} |
||||
|
|
||||
|
|
||||
|
def downgrade(): |
||||
|
${downgrades if downgrades else "pass"} |
@ -0,0 +1,24 @@ |
|||||
|
"""create CharacterClass table |
||||
|
|
||||
|
Revision ID: 7287451b8bce |
||||
|
Revises: |
||||
|
Create Date: 2019-12-02 23:01:13.613091 |
||||
|
|
||||
|
""" |
||||
|
from alembic import op |
||||
|
import sqlalchemy as sa |
||||
|
|
||||
|
|
||||
|
# revision identifiers, used by Alembic. |
||||
|
revision = '7287451b8bce' |
||||
|
down_revision = None |
||||
|
branch_labels = None |
||||
|
depends_on = None |
||||
|
|
||||
|
|
||||
|
def upgrade(): |
||||
|
pass |
||||
|
|
||||
|
|
||||
|
def downgrade(): |
||||
|
pass |
Write
Preview
Loading…
Cancel
Save
Reference in new issue