54b69f0d68
- Move alembic/ directory to nextcloud_mcp_server/alembic/ subpackage - Update migrations.py to use package location instead of alembic.ini - Update env.py to set script_location dynamically - Update alembic.ini for development CLI usage - Fix Dockerfile typo: .vnev -> .venv This fixes FileNotFoundError when running in Docker with non-editable install. The alembic package is now installed with the main package, making it work in both development and production environments. Resolves: Docker startup error 'alembic.ini not found at /app/.venv/lib/python3.12/site-packages/alembic.ini' 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
91 lines
2.2 KiB
INI
91 lines
2.2 KiB
INI
# Alembic configuration file for nextcloud-mcp-server
|
|
|
|
[alembic]
|
|
# Path to migration scripts
|
|
script_location = nextcloud_mcp_server/alembic
|
|
|
|
# Template used to generate migration file names
|
|
# Default: %%(rev)s_%%(slug)s
|
|
file_template = %%(year)d%%(month).2d%%(day).2d_%%(hour).2d%%(minute).2d_%%(rev)s_%%(slug)s
|
|
|
|
# Timezone for migration timestamps
|
|
# Default: utc
|
|
timezone = utc
|
|
|
|
# Max length of characters to apply to the "slug" field
|
|
# Default: 40
|
|
# truncate_slug_length = 40
|
|
|
|
# Set to 'true' to run the environment during the 'revision' command
|
|
# Default: false
|
|
# revision_environment = false
|
|
|
|
# Set to 'true' to allow .pyc and .pyo files without a source .py file
|
|
# Default: false
|
|
# sourceless = false
|
|
|
|
# Version location specification
|
|
# Supports single or multiple directories
|
|
version_locations = nextcloud_mcp_server/alembic/versions
|
|
|
|
# Path separator for version locations (required to suppress deprecation warning)
|
|
# Use os (for cross-platform compatibility)
|
|
path_separator = os
|
|
|
|
# Set to 'true' to search source files recursively in each "version_locations" directory
|
|
# Default: false
|
|
# recursive_version_locations = false
|
|
|
|
# Output encoding used when revision files are written
|
|
# Default: utf-8
|
|
# output_encoding = utf-8
|
|
|
|
# Database URL - can be overridden by:
|
|
# 1. Passing -x database_url=... to alembic commands
|
|
# 2. Setting in environment via get_database_url() in env.py
|
|
# Default: sqlite:///app/data/tokens.db
|
|
sqlalchemy.url = sqlite+aiosqlite:////app/data/tokens.db
|
|
|
|
[post_write_hooks]
|
|
# Post-write hooks allow you to run scripts after generating migration files
|
|
# Example: format migrations with ruff
|
|
# hooks = ruff
|
|
# ruff.type = exec
|
|
# ruff.executable = ruff
|
|
# ruff.options = format REVISION_SCRIPT_FILENAME
|
|
|
|
# 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
|