aboutsummaryrefslogtreecommitdiff
path: root/alembic.ini
diff options
context:
space:
mode:
authorTolmachev Igor <me@igorek.dev>2026-03-22 19:56:47 +0300
committerTolmachev Igor <me@igorek.dev>2026-03-22 20:19:27 +0300
commit536d022e8a55f6e53f01dfb7e0fae2ef24385aad (patch)
tree721d7195db7fc12c725b27301f77e345df64d1b4 /alembic.ini
downloadvpn_manager_bot-536d022e8a55f6e53f01dfb7e0fae2ef24385aad.tar.gz
vpn_manager_bot-536d022e8a55f6e53f01dfb7e0fae2ef24385aad.zip
Init project
Diffstat (limited to 'alembic.ini')
-rw-r--r--alembic.ini149
1 files changed, 149 insertions, 0 deletions
diff --git a/alembic.ini b/alembic.ini
new file mode 100644
index 0000000..c32232a
--- /dev/null
+++ b/alembic.ini
@@ -0,0 +1,149 @@
1# A generic, single database configuration.
2
3[alembic]
4# path to migration scripts.
5# this is typically a path given in POSIX (e.g. forward slashes)
6# format, relative to the token %(here)s which refers to the location of this
7# ini file
8script_location = %(here)s/alembic
9
10# template used to generate migration file names; The default value is %%(rev)s_%%(slug)s
11# Uncomment the line below if you want the files to be prepended with date and time
12# see https://alembic.sqlalchemy.org/en/latest/tutorial.html#editing-the-ini-file
13# for all available tokens
14# file_template = %%(year)d_%%(month).2d_%%(day).2d_%%(hour).2d%%(minute).2d-%%(rev)s_%%(slug)s
15# Or organize into date-based subdirectories (requires recursive_version_locations = true)
16# file_template = %%(year)d/%%(month).2d/%%(day).2d_%%(hour).2d%%(minute).2d_%%(second).2d_%%(rev)s_%%(slug)s
17
18# sys.path path, will be prepended to sys.path if present.
19# defaults to the current working directory. for multiple paths, the path separator
20# is defined by "path_separator" below.
21prepend_sys_path = .
22
23# timezone to use when rendering the date within the migration file
24# as well as the filename.
25# If specified, requires the tzdata library which can be installed by adding
26# `alembic[tz]` to the pip requirements.
27# string value is passed to ZoneInfo()
28# leave blank for localtime
29# timezone =
30
31# max length of characters to apply to the "slug" field
32# truncate_slug_length = 40
33
34# set to 'true' to run the environment during
35# the 'revision' command, regardless of autogenerate
36# revision_environment = false
37
38# set to 'true' to allow .pyc and .pyo files without
39# a source .py file to be detected as revisions in the
40# versions/ directory
41# sourceless = false
42
43# version location specification; This defaults
44# to <script_location>/versions. When using multiple version
45# directories, initial revisions must be specified with --version-path.
46# The path separator used here should be the separator specified by "path_separator"
47# below.
48# version_locations = %(here)s/bar:%(here)s/bat:%(here)s/alembic/versions
49
50# path_separator; This indicates what character is used to split lists of file
51# paths, including version_locations and prepend_sys_path within configparser
52# files such as alembic.ini.
53# The default rendered in new alembic.ini files is "os", which uses os.pathsep
54# to provide os-dependent path splitting.
55#
56# Note that in order to support legacy alembic.ini files, this default does NOT
57# take place if path_separator is not present in alembic.ini. If this
58# option is omitted entirely, fallback logic is as follows:
59#
60# 1. Parsing of the version_locations option falls back to using the legacy
61# "version_path_separator" key, which if absent then falls back to the legacy
62# behavior of splitting on spaces and/or commas.
63# 2. Parsing of the prepend_sys_path option falls back to the legacy
64# behavior of splitting on spaces, commas, or colons.
65#
66# Valid values for path_separator are:
67#
68# path_separator = :
69# path_separator = ;
70# path_separator = space
71# path_separator = newline
72#
73# Use os.pathsep. Default configuration used for new projects.
74path_separator = os
75
76
77# set to 'true' to search source files recursively
78# in each "version_locations" directory
79# new in Alembic version 1.10
80# recursive_version_locations = false
81
82# the output encoding used when revision files
83# are written from script.py.mako
84# output_encoding = utf-8
85
86# database URL. This is consumed by the user-maintained env.py script only.
87# other means of configuring database URLs may be customized within the env.py
88# file.
89sqlalchemy.url = sqlite+aiosqlite:///storage/database.db
90
91
92[post_write_hooks]
93# post_write_hooks defines scripts or Python functions that are run
94# on newly generated revision scripts. See the documentation for further
95# detail and examples
96
97# format using "black" - use the console_scripts runner, against the "black" entrypoint
98# hooks = black
99# black.type = console_scripts
100# black.entrypoint = black
101# black.options = -l 79 REVISION_SCRIPT_FILENAME
102
103# lint with attempts to fix using "ruff" - use the module runner, against the "ruff" module
104# hooks = ruff
105# ruff.type = module
106# ruff.module = ruff
107# ruff.options = check --fix REVISION_SCRIPT_FILENAME
108
109# Alternatively, use the exec runner to execute a binary found on your PATH
110# hooks = ruff
111# ruff.type = exec
112# ruff.executable = ruff
113# ruff.options = check --fix REVISION_SCRIPT_FILENAME
114
115# Logging configuration. This is also consumed by the user-maintained
116# env.py script only.
117[loggers]
118keys = root,sqlalchemy,alembic
119
120[handlers]
121keys = console
122
123[formatters]
124keys = generic
125
126[logger_root]
127level = WARNING
128handlers = console
129qualname =
130
131[logger_sqlalchemy]
132level = WARNING
133handlers =
134qualname = sqlalchemy.engine
135
136[logger_alembic]
137level = INFO
138handlers =
139qualname = alembic
140
141[handler_console]
142class = StreamHandler
143args = (sys.stderr,)
144level = NOTSET
145formatter = generic
146
147[formatter_generic]
148format = %(levelname)-5.5s [%(name)s] %(message)s
149datefmt = %H:%M:%S