Compare commits
	
		
			9 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 0b01fa38d8 | ||
|  | 801dde15be | ||
|  | 75480e2041 | ||
|  | 45129cef9f | ||
|  | 3a0dd2355d | ||
|  | 0e71bc16ae | ||
|  | c39462820c | ||
|  | f15cbaf9e0 | ||
|  | 15131469df | 
| @@ -2,6 +2,14 @@ | |||||||
|  |  | ||||||
| ## 0.6 | ## 0.6 | ||||||
|  |  | ||||||
|  | ### 0.6.3 | ||||||
|  |  | ||||||
|  | - Improve `inspectdb` and support `postgres` & `sqlite`. | ||||||
|  |  | ||||||
|  | ### 0.6.2 | ||||||
|  |  | ||||||
|  | - Support migration for specified index. (#203) | ||||||
|  |  | ||||||
| ### 0.6.1 | ### 0.6.1 | ||||||
|  |  | ||||||
| - Fix `pyproject.toml` not existing error. (#217) | - Fix `pyproject.toml` not existing error. (#217) | ||||||
|   | |||||||
							
								
								
									
										9
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										9
									
								
								Makefile
									
									
									
									
									
								
							| @@ -15,13 +15,12 @@ deps: | |||||||
| 	@poetry install -E asyncpg -E asyncmy | 	@poetry install -E asyncpg -E asyncmy | ||||||
|  |  | ||||||
| style: deps | style: deps | ||||||
| 	isort -src $(checkfiles) | 	@isort -src $(checkfiles) | ||||||
| 	black $(black_opts) $(checkfiles) | 	@black $(black_opts) $(checkfiles) | ||||||
|  |  | ||||||
| check: deps | check: deps | ||||||
| 	black --check $(black_opts) $(checkfiles) || (echo "Please run 'make style' to auto-fix style issues" && false) | 	@black --check $(black_opts) $(checkfiles) || (echo "Please run 'make style' to auto-fix style issues" && false) | ||||||
| 	flake8 $(checkfiles) | 	@pflake8 $(checkfiles) | ||||||
| 	bandit -x tests -r $(checkfiles) |  | ||||||
|  |  | ||||||
| test: deps | test: deps | ||||||
| 	$(py_warn) TEST_DB=sqlite://:memory: py.test | 	$(py_warn) TEST_DB=sqlite://:memory: py.test | ||||||
|   | |||||||
							
								
								
									
										43
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										43
									
								
								README.md
									
									
									
									
									
								
							| @@ -7,7 +7,7 @@ | |||||||
|  |  | ||||||
| ## Introduction | ## Introduction | ||||||
|  |  | ||||||
| Aerich is a database migrations tool for Tortoise-ORM, which is like alembic for SQLAlchemy, or like Django ORM with | Aerich is a database migrations tool for TortoiseORM, which is like alembic for SQLAlchemy, or like Django ORM with | ||||||
| it\'s own migration solution. | it\'s own migration solution. | ||||||
|  |  | ||||||
| ## Install | ## Install | ||||||
| @@ -165,7 +165,7 @@ Now your db is rolled back to the specified version. | |||||||
|  |  | ||||||
| ### Inspect db tables to TortoiseORM model | ### Inspect db tables to TortoiseORM model | ||||||
|  |  | ||||||
| Currently `inspectdb` only supports MySQL. | Currently `inspectdb` support MySQL & Postgres & SQLite. | ||||||
|  |  | ||||||
| ```shell | ```shell | ||||||
| Usage: aerich inspectdb [OPTIONS] | Usage: aerich inspectdb [OPTIONS] | ||||||
| @@ -189,7 +189,44 @@ Inspect a specified table in the default app and redirect to `models.py`: | |||||||
| aerich inspectdb -t user > models.py | aerich inspectdb -t user > models.py | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| Note that this command is limited and cannot infer some fields, such as `IntEnumField`, `ForeignKeyField`, and others. | For example, you table is: | ||||||
|  |  | ||||||
|  | ```sql | ||||||
|  | CREATE TABLE `test` | ||||||
|  | ( | ||||||
|  |     `id`       int            NOT NULL AUTO_INCREMENT, | ||||||
|  |     `decimal`  decimal(10, 2) NOT NULL, | ||||||
|  |     `date`     date                                    DEFAULT NULL, | ||||||
|  |     `datetime` datetime       NOT NULL                 DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, | ||||||
|  |     `time`     time                                    DEFAULT NULL, | ||||||
|  |     `float`    float                                   DEFAULT NULL, | ||||||
|  |     `string`   varchar(200) COLLATE utf8mb4_general_ci DEFAULT NULL, | ||||||
|  |     `tinyint`  tinyint                                 DEFAULT NULL, | ||||||
|  |     PRIMARY KEY (`id`), | ||||||
|  |     KEY `asyncmy_string_index` (`string`) | ||||||
|  | ) ENGINE = InnoDB | ||||||
|  |   DEFAULT CHARSET = utf8mb4 | ||||||
|  |   COLLATE = utf8mb4_general_ci | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | Now run `aerich inspectdb -t test` to see the generated model: | ||||||
|  |  | ||||||
|  | ```python | ||||||
|  | from tortoise import Model, fields | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class Test(Model): | ||||||
|  |     date = fields.DateField(null=True, ) | ||||||
|  |     datetime = fields.DatetimeField(auto_now=True, ) | ||||||
|  |     decimal = fields.DecimalField(max_digits=10, decimal_places=2, ) | ||||||
|  |     float = fields.FloatField(null=True, ) | ||||||
|  |     id = fields.IntField(pk=True, ) | ||||||
|  |     string = fields.CharField(max_length=200, null=True, ) | ||||||
|  |     time = fields.TimeField(null=True, ) | ||||||
|  |     tinyint = fields.BooleanField(null=True, ) | ||||||
|  | ``` | ||||||
|  |  | ||||||
|  | Note that this command is limited and can't infer some fields, such as `IntEnumField`, `ForeignKeyField`, and others. | ||||||
|  |  | ||||||
| ### Multiple databases | ### Multiple databases | ||||||
|  |  | ||||||
|   | |||||||
| @@ -8,7 +8,9 @@ from tortoise.transactions import in_transaction | |||||||
| from tortoise.utils import get_schema_sql | from tortoise.utils import get_schema_sql | ||||||
|  |  | ||||||
| from aerich.exceptions import DowngradeError | from aerich.exceptions import DowngradeError | ||||||
| from aerich.inspectdb import InspectDb | from aerich.inspect.mysql import InspectMySQL | ||||||
|  | from aerich.inspect.postgres import InspectPostgres | ||||||
|  | from aerich.inspect.sqlite import InspectSQLite | ||||||
| from aerich.migrate import Migrate | from aerich.migrate import Migrate | ||||||
| from aerich.models import Aerich | from aerich.models import Aerich | ||||||
| from aerich.utils import ( | from aerich.utils import ( | ||||||
| @@ -106,10 +108,19 @@ class Command: | |||||||
|             ret.append(version) |             ret.append(version) | ||||||
|         return ret |         return ret | ||||||
|  |  | ||||||
|     async def inspectdb(self, tables: List[str]): |     async def inspectdb(self, tables: List[str] = None) -> str: | ||||||
|         connection = get_app_connection(self.tortoise_config, self.app) |         connection = get_app_connection(self.tortoise_config, self.app) | ||||||
|         inspect = InspectDb(connection, tables) |         dialect = connection.schema_generator.DIALECT | ||||||
|         await inspect.inspect() |         if dialect == "mysql": | ||||||
|  |             cls = InspectMySQL | ||||||
|  |         elif dialect == "postgres": | ||||||
|  |             cls = InspectPostgres | ||||||
|  |         elif dialect == "sqlite": | ||||||
|  |             cls = InspectSQLite | ||||||
|  |         else: | ||||||
|  |             raise NotImplementedError(f"{dialect} is not supported") | ||||||
|  |         inspect = cls(connection, tables) | ||||||
|  |         return await inspect.inspect() | ||||||
|  |  | ||||||
|     async def migrate(self, name: str = "update"): |     async def migrate(self, name: str = "update"): | ||||||
|         return await Migrate.migrate(name) |         return await Migrate.migrate(name) | ||||||
|   | |||||||
| @@ -10,12 +10,11 @@ from click import Context, UsageError | |||||||
| from tomlkit.exceptions import NonExistentKey | from tomlkit.exceptions import NonExistentKey | ||||||
| from tortoise import Tortoise | from tortoise import Tortoise | ||||||
|  |  | ||||||
|  | from aerich import Command | ||||||
|  | from aerich.enums import Color | ||||||
| from aerich.exceptions import DowngradeError | from aerich.exceptions import DowngradeError | ||||||
| from aerich.utils import add_src_path, get_tortoise_config | from aerich.utils import add_src_path, get_tortoise_config | ||||||
|  | from aerich.version import __version__ | ||||||
| from . import Command |  | ||||||
| from .enums import Color |  | ||||||
| from .version import __version__ |  | ||||||
|  |  | ||||||
| CONFIG_DEFAULT_VALUES = { | CONFIG_DEFAULT_VALUES = { | ||||||
|     "src_folder": ".", |     "src_folder": ".", | ||||||
| @@ -31,7 +30,7 @@ def coro(f): | |||||||
|         try: |         try: | ||||||
|             loop.run_until_complete(f(*args, **kwargs)) |             loop.run_until_complete(f(*args, **kwargs)) | ||||||
|         finally: |         finally: | ||||||
|             if f.__name__ != "cli": |             if Tortoise._inited: | ||||||
|                 loop.run_until_complete(Tortoise.close_connections()) |                 loop.run_until_complete(Tortoise.close_connections()) | ||||||
|  |  | ||||||
|     return wrapper |     return wrapper | ||||||
| @@ -250,7 +249,8 @@ async def init_db(ctx: Context, safe): | |||||||
| @coro | @coro | ||||||
| async def inspectdb(ctx: Context, table: List[str]): | async def inspectdb(ctx: Context, table: List[str]): | ||||||
|     command = ctx.obj["command"] |     command = ctx.obj["command"] | ||||||
|     await command.inspectdb(table) |     ret = await command.inspectdb(table) | ||||||
|  |     click.secho(ret) | ||||||
|  |  | ||||||
|  |  | ||||||
| def main(): | def main(): | ||||||
|   | |||||||
							
								
								
									
										31
									
								
								aerich/coder.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								aerich/coder.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | |||||||
|  | import base64 | ||||||
|  | import json | ||||||
|  | import pickle  # nosec: B301,B403 | ||||||
|  |  | ||||||
|  | from tortoise.indexes import Index | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class JsonEncoder(json.JSONEncoder): | ||||||
|  |     def default(self, obj): | ||||||
|  |         if isinstance(obj, Index): | ||||||
|  |             return { | ||||||
|  |                 "type": "index", | ||||||
|  |                 "val": base64.b64encode(pickle.dumps(obj)).decode(),  # nosec: B301 | ||||||
|  |             } | ||||||
|  |         else: | ||||||
|  |             return super().default(obj) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def object_hook(obj): | ||||||
|  |     _type = obj.get("type") | ||||||
|  |     if not _type: | ||||||
|  |         return obj | ||||||
|  |     return pickle.loads(base64.b64decode(obj["val"]))  # nosec: B301 | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def encoder(obj: dict): | ||||||
|  |     return json.dumps(obj, cls=JsonEncoder) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def decoder(obj: str): | ||||||
|  |     return json.loads(obj, object_hook=object_hook) | ||||||
| @@ -78,15 +78,11 @@ class BaseDDL: | |||||||
|         auto_now_add = field_describe.get("auto_now_add", False) |         auto_now_add = field_describe.get("auto_now_add", False) | ||||||
|         auto_now = field_describe.get("auto_now", False) |         auto_now = field_describe.get("auto_now", False) | ||||||
|         if default is not None or auto_now_add: |         if default is not None or auto_now_add: | ||||||
|             if ( |             if field_describe.get("field_type") in [ | ||||||
|                 field_describe.get("field_type") |  | ||||||
|                 in [ |  | ||||||
|                 "UUIDField", |                 "UUIDField", | ||||||
|                 "TextField", |                 "TextField", | ||||||
|                 "JSONField", |                 "JSONField", | ||||||
|                 ] |             ] or is_default_function(default): | ||||||
|                 or is_default_function(default) |  | ||||||
|             ): |  | ||||||
|                 default = "" |                 default = "" | ||||||
|             else: |             else: | ||||||
|                 try: |                 try: | ||||||
| @@ -195,6 +191,12 @@ class BaseDDL: | |||||||
|             table_name=model._meta.db_table, |             table_name=model._meta.db_table, | ||||||
|         ) |         ) | ||||||
|  |  | ||||||
|  |     def drop_index_by_name(self, model: "Type[Model]", index_name: str): | ||||||
|  |         return self._DROP_INDEX_TEMPLATE.format( | ||||||
|  |             index_name=index_name, | ||||||
|  |             table_name=model._meta.db_table, | ||||||
|  |         ) | ||||||
|  |  | ||||||
|     def add_fk(self, model: "Type[Model]", field_describe: dict, reference_table_describe: dict): |     def add_fk(self, model: "Type[Model]", field_describe: dict, reference_table_describe: dict): | ||||||
|         db_table = model._meta.db_table |         db_table = model._meta.db_table | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										163
									
								
								aerich/inspect/__init__.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										163
									
								
								aerich/inspect/__init__.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,163 @@ | |||||||
|  | from typing import Any, List, Optional | ||||||
|  |  | ||||||
|  | from pydantic import BaseModel | ||||||
|  | from tortoise import BaseDBAsyncClient | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class Column(BaseModel): | ||||||
|  |     name: str | ||||||
|  |     data_type: str | ||||||
|  |     null: bool | ||||||
|  |     default: Any | ||||||
|  |     comment: Optional[str] | ||||||
|  |     pk: bool | ||||||
|  |     unique: bool | ||||||
|  |     index: bool | ||||||
|  |     length: Optional[int] | ||||||
|  |     extra: Optional[str] | ||||||
|  |     decimal_places: Optional[int] | ||||||
|  |     max_digits: Optional[int] | ||||||
|  |  | ||||||
|  |     def translate(self) -> dict: | ||||||
|  |         comment = default = length = index = null = pk = "" | ||||||
|  |         if self.pk: | ||||||
|  |             pk = "pk=True, " | ||||||
|  |         else: | ||||||
|  |             if self.unique: | ||||||
|  |                 index = "unique=True, " | ||||||
|  |             else: | ||||||
|  |                 if self.index: | ||||||
|  |                     index = "index=True, " | ||||||
|  |         if self.data_type in ["varchar", "VARCHAR"]: | ||||||
|  |             length = f"max_length={self.length}, " | ||||||
|  |         if self.data_type == "decimal": | ||||||
|  |             length = f"max_digits={self.max_digits}, decimal_places={self.decimal_places}, " | ||||||
|  |         if self.null: | ||||||
|  |             null = "null=True, " | ||||||
|  |         if self.default is not None: | ||||||
|  |             if self.data_type in ["tinyint", "INT"]: | ||||||
|  |                 default = f"default={'True' if self.default == '1' else 'False'}, " | ||||||
|  |             elif self.data_type == "bool": | ||||||
|  |                 default = f"default={'True' if self.default == 'true' else 'False'}, " | ||||||
|  |             elif self.data_type in ["datetime", "timestamptz", "TIMESTAMP"]: | ||||||
|  |                 if "CURRENT_TIMESTAMP" == self.default: | ||||||
|  |                     if "DEFAULT_GENERATED on update CURRENT_TIMESTAMP" == self.extra: | ||||||
|  |                         default = "auto_now=True, " | ||||||
|  |                     else: | ||||||
|  |                         default = "auto_now_add=True, " | ||||||
|  |             else: | ||||||
|  |                 if "::" in self.default: | ||||||
|  |                     default = f"default={self.default.split('::')[0]}, " | ||||||
|  |                 elif self.default.endswith("()"): | ||||||
|  |                     default = "" | ||||||
|  |                 else: | ||||||
|  |                     default = f"default={self.default}, " | ||||||
|  |  | ||||||
|  |         if self.comment: | ||||||
|  |             comment = f"description='{self.comment}', " | ||||||
|  |         return { | ||||||
|  |             "name": self.name, | ||||||
|  |             "pk": pk, | ||||||
|  |             "index": index, | ||||||
|  |             "null": null, | ||||||
|  |             "default": default, | ||||||
|  |             "length": length, | ||||||
|  |             "comment": comment, | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class Inspect: | ||||||
|  |     _table_template = "class {table}(Model):\n" | ||||||
|  |  | ||||||
|  |     def __init__(self, conn: BaseDBAsyncClient, tables: Optional[List[str]] = None): | ||||||
|  |         self.conn = conn | ||||||
|  |         try: | ||||||
|  |             self.database = conn.database | ||||||
|  |         except AttributeError: | ||||||
|  |             pass | ||||||
|  |         self.tables = tables | ||||||
|  |  | ||||||
|  |     @property | ||||||
|  |     def field_map(self) -> dict: | ||||||
|  |         raise NotImplementedError | ||||||
|  |  | ||||||
|  |     async def inspect(self) -> str: | ||||||
|  |         if not self.tables: | ||||||
|  |             self.tables = await self.get_all_tables() | ||||||
|  |         result = "from tortoise import Model, fields\n\n\n" | ||||||
|  |         tables = [] | ||||||
|  |         for table in self.tables: | ||||||
|  |             columns = await self.get_columns(table) | ||||||
|  |             fields = [] | ||||||
|  |             model = self._table_template.format(table=table.title().replace("_", "")) | ||||||
|  |             for column in columns: | ||||||
|  |                 field = self.field_map[column.data_type](**column.translate()) | ||||||
|  |                 fields.append("    " + field) | ||||||
|  |             tables.append(model + "\n".join(fields)) | ||||||
|  |         return result + "\n\n\n".join(tables) | ||||||
|  |  | ||||||
|  |     async def get_columns(self, table: str) -> List[Column]: | ||||||
|  |         raise NotImplementedError | ||||||
|  |  | ||||||
|  |     async def get_all_tables(self) -> List[str]: | ||||||
|  |         raise NotImplementedError | ||||||
|  |  | ||||||
|  |     @classmethod | ||||||
|  |     def decimal_field(cls, **kwargs) -> str: | ||||||
|  |         return "{name} = fields.DecimalField({pk}{index}{length}{null}{default}{comment})".format( | ||||||
|  |             **kwargs | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  |     @classmethod | ||||||
|  |     def time_field(cls, **kwargs) -> str: | ||||||
|  |         return "{name} = fields.TimeField({null}{default}{comment})".format(**kwargs) | ||||||
|  |  | ||||||
|  |     @classmethod | ||||||
|  |     def date_field(cls, **kwargs) -> str: | ||||||
|  |         return "{name} = fields.DateField({null}{default}{comment})".format(**kwargs) | ||||||
|  |  | ||||||
|  |     @classmethod | ||||||
|  |     def float_field(cls, **kwargs) -> str: | ||||||
|  |         return "{name} = fields.FloatField({null}{default}{comment})".format(**kwargs) | ||||||
|  |  | ||||||
|  |     @classmethod | ||||||
|  |     def datetime_field(cls, **kwargs) -> str: | ||||||
|  |         return "{name} = fields.DatetimeField({null}{default}{comment})".format(**kwargs) | ||||||
|  |  | ||||||
|  |     @classmethod | ||||||
|  |     def text_field(cls, **kwargs) -> str: | ||||||
|  |         return "{name} = fields.TextField({null}{default}{comment})".format(**kwargs) | ||||||
|  |  | ||||||
|  |     @classmethod | ||||||
|  |     def char_field(cls, **kwargs) -> str: | ||||||
|  |         return "{name} = fields.CharField({pk}{index}{length}{null}{default}{comment})".format( | ||||||
|  |             **kwargs | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  |     @classmethod | ||||||
|  |     def int_field(cls, **kwargs) -> str: | ||||||
|  |         return "{name} = fields.IntField({pk}{index}{comment})".format(**kwargs) | ||||||
|  |  | ||||||
|  |     @classmethod | ||||||
|  |     def smallint_field(cls, **kwargs) -> str: | ||||||
|  |         return "{name} = fields.SmallIntField({pk}{index}{comment})".format(**kwargs) | ||||||
|  |  | ||||||
|  |     @classmethod | ||||||
|  |     def bigint_field(cls, **kwargs) -> str: | ||||||
|  |         return "{name} = fields.BigIntField({pk}{index}{default}{comment})".format(**kwargs) | ||||||
|  |  | ||||||
|  |     @classmethod | ||||||
|  |     def bool_field(cls, **kwargs) -> str: | ||||||
|  |         return "{name} = fields.BooleanField({null}{default}{comment})".format(**kwargs) | ||||||
|  |  | ||||||
|  |     @classmethod | ||||||
|  |     def uuid_field(cls, **kwargs) -> str: | ||||||
|  |         return "{name} = fields.UUIDField({pk}{index}{default}{comment})".format(**kwargs) | ||||||
|  |  | ||||||
|  |     @classmethod | ||||||
|  |     def json_field(cls, **kwargs) -> str: | ||||||
|  |         return "{name} = fields.JSONField({null}{default}{comment})".format(**kwargs) | ||||||
|  |  | ||||||
|  |     @classmethod | ||||||
|  |     def binary_field(cls, **kwargs) -> str: | ||||||
|  |         return "{name} = fields.BinaryField({null}{default}{comment})".format(**kwargs) | ||||||
							
								
								
									
										69
									
								
								aerich/inspect/mysql.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								aerich/inspect/mysql.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,69 @@ | |||||||
|  | from typing import List | ||||||
|  |  | ||||||
|  | from aerich.inspect import Column, Inspect | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class InspectMySQL(Inspect): | ||||||
|  |     @property | ||||||
|  |     def field_map(self) -> dict: | ||||||
|  |         return { | ||||||
|  |             "int": self.int_field, | ||||||
|  |             "smallint": self.smallint_field, | ||||||
|  |             "tinyint": self.bool_field, | ||||||
|  |             "bigint": self.bigint_field, | ||||||
|  |             "varchar": self.char_field, | ||||||
|  |             "longtext": self.text_field, | ||||||
|  |             "text": self.text_field, | ||||||
|  |             "datetime": self.datetime_field, | ||||||
|  |             "float": self.float_field, | ||||||
|  |             "date": self.date_field, | ||||||
|  |             "time": self.time_field, | ||||||
|  |             "decimal": self.decimal_field, | ||||||
|  |             "json": self.json_field, | ||||||
|  |             "longblob": self.binary_field, | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |     async def get_all_tables(self) -> List[str]: | ||||||
|  |         sql = "select TABLE_NAME from information_schema.TABLES where TABLE_SCHEMA=%s" | ||||||
|  |         ret = await self.conn.execute_query_dict(sql, [self.database]) | ||||||
|  |         return list(map(lambda x: x["TABLE_NAME"], ret)) | ||||||
|  |  | ||||||
|  |     async def get_columns(self, table: str) -> List[Column]: | ||||||
|  |         columns = [] | ||||||
|  |         sql = """select c.*, s.NON_UNIQUE, s.INDEX_NAME | ||||||
|  | from information_schema.COLUMNS c | ||||||
|  |          left join information_schema.STATISTICS s on c.TABLE_NAME = s.TABLE_NAME | ||||||
|  |     and c.TABLE_SCHEMA = s.TABLE_SCHEMA | ||||||
|  |     and c.COLUMN_NAME = s.COLUMN_NAME | ||||||
|  | where c.TABLE_SCHEMA = %s | ||||||
|  |   and c.TABLE_NAME = %s""" | ||||||
|  |         ret = await self.conn.execute_query_dict(sql, [self.database, table]) | ||||||
|  |         for row in ret: | ||||||
|  |             non_unique = row["NON_UNIQUE"] | ||||||
|  |             if non_unique is None: | ||||||
|  |                 unique = False | ||||||
|  |             else: | ||||||
|  |                 unique = not non_unique | ||||||
|  |             index_name = row["INDEX_NAME"] | ||||||
|  |             if index_name is None: | ||||||
|  |                 index = False | ||||||
|  |             else: | ||||||
|  |                 index = row["INDEX_NAME"] != "PRIMARY" | ||||||
|  |             columns.append( | ||||||
|  |                 Column( | ||||||
|  |                     name=row["COLUMN_NAME"], | ||||||
|  |                     data_type=row["DATA_TYPE"], | ||||||
|  |                     null=row["IS_NULLABLE"] == "YES", | ||||||
|  |                     default=row["COLUMN_DEFAULT"], | ||||||
|  |                     pk=row["COLUMN_KEY"] == "PRI", | ||||||
|  |                     comment=row["COLUMN_COMMENT"], | ||||||
|  |                     unique=row["COLUMN_KEY"] == "UNI", | ||||||
|  |                     extra=row["EXTRA"], | ||||||
|  |                     unque=unique, | ||||||
|  |                     index=index, | ||||||
|  |                     length=row["CHARACTER_MAXIMUM_LENGTH"], | ||||||
|  |                     max_digits=row["NUMERIC_PRECISION"], | ||||||
|  |                     decimal_places=row["NUMERIC_SCALE"], | ||||||
|  |                 ) | ||||||
|  |             ) | ||||||
|  |         return columns | ||||||
							
								
								
									
										75
									
								
								aerich/inspect/postgres.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										75
									
								
								aerich/inspect/postgres.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,75 @@ | |||||||
|  | from typing import List, Optional | ||||||
|  |  | ||||||
|  | from tortoise import BaseDBAsyncClient | ||||||
|  |  | ||||||
|  | from aerich.inspect import Column, Inspect | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class InspectPostgres(Inspect): | ||||||
|  |     def __init__(self, conn: BaseDBAsyncClient, tables: Optional[List[str]] = None): | ||||||
|  |         super().__init__(conn, tables) | ||||||
|  |         self.schema = self.conn.server_settings.get("schema") or "public" | ||||||
|  |  | ||||||
|  |     @property | ||||||
|  |     def field_map(self) -> dict: | ||||||
|  |         return { | ||||||
|  |             "int4": self.int_field, | ||||||
|  |             "int8": self.int_field, | ||||||
|  |             "smallint": self.smallint_field, | ||||||
|  |             "varchar": self.char_field, | ||||||
|  |             "text": self.text_field, | ||||||
|  |             "bigint": self.bigint_field, | ||||||
|  |             "timestamptz": self.datetime_field, | ||||||
|  |             "float4": self.float_field, | ||||||
|  |             "float8": self.float_field, | ||||||
|  |             "date": self.date_field, | ||||||
|  |             "time": self.time_field, | ||||||
|  |             "decimal": self.decimal_field, | ||||||
|  |             "uuid": self.uuid_field, | ||||||
|  |             "jsonb": self.json_field, | ||||||
|  |             "bytea": self.binary_field, | ||||||
|  |             "bool": self.bool_field, | ||||||
|  |             "timestamp": self.datetime_field, | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |     async def get_all_tables(self) -> List[str]: | ||||||
|  |         sql = "select TABLE_NAME from information_schema.TABLES where table_catalog=$1 and table_schema=$2" | ||||||
|  |         ret = await self.conn.execute_query_dict(sql, [self.database, self.schema]) | ||||||
|  |         return list(map(lambda x: x["table_name"], ret)) | ||||||
|  |  | ||||||
|  |     async def get_columns(self, table: str) -> List[Column]: | ||||||
|  |         columns = [] | ||||||
|  |         sql = f"""select c.column_name, | ||||||
|  |        col_description('public.{table}'::regclass, ordinal_position) as column_comment, | ||||||
|  |        t.constraint_type as column_key, | ||||||
|  |        udt_name as data_type, | ||||||
|  |        is_nullable, | ||||||
|  |        column_default, | ||||||
|  |        character_maximum_length, | ||||||
|  |        numeric_precision, | ||||||
|  |        numeric_scale | ||||||
|  | from information_schema.constraint_column_usage const | ||||||
|  |          join information_schema.table_constraints t | ||||||
|  |               using (table_catalog, table_schema, table_name, constraint_catalog, constraint_schema, constraint_name) | ||||||
|  |          right join information_schema.columns c using (column_name, table_catalog, table_schema, table_name) | ||||||
|  | where c.table_catalog = $1 | ||||||
|  |   and c.table_name = $2 | ||||||
|  |   and c.table_schema = $3""" | ||||||
|  |         ret = await self.conn.execute_query_dict(sql, [self.database, table, self.schema]) | ||||||
|  |         for row in ret: | ||||||
|  |             columns.append( | ||||||
|  |                 Column( | ||||||
|  |                     name=row["column_name"], | ||||||
|  |                     data_type=row["data_type"], | ||||||
|  |                     null=row["is_nullable"] == "YES", | ||||||
|  |                     default=row["column_default"], | ||||||
|  |                     length=row["character_maximum_length"], | ||||||
|  |                     max_digits=row["numeric_precision"], | ||||||
|  |                     decimal_places=row["numeric_scale"], | ||||||
|  |                     comment=row["column_comment"], | ||||||
|  |                     pk=row["column_key"] == "PRIMARY KEY", | ||||||
|  |                     unique=False,  # can't get this simply | ||||||
|  |                     index=False,  # can't get this simply | ||||||
|  |                 ) | ||||||
|  |             ) | ||||||
|  |         return columns | ||||||
							
								
								
									
										61
									
								
								aerich/inspect/sqlite.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								aerich/inspect/sqlite.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,61 @@ | |||||||
|  | from typing import List | ||||||
|  |  | ||||||
|  | from aerich.inspect import Column, Inspect | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class InspectSQLite(Inspect): | ||||||
|  |     @property | ||||||
|  |     def field_map(self) -> dict: | ||||||
|  |         return { | ||||||
|  |             "INTEGER": self.int_field, | ||||||
|  |             "INT": self.bool_field, | ||||||
|  |             "SMALLINT": self.smallint_field, | ||||||
|  |             "VARCHAR": self.char_field, | ||||||
|  |             "TEXT": self.text_field, | ||||||
|  |             "TIMESTAMP": self.datetime_field, | ||||||
|  |             "REAL": self.float_field, | ||||||
|  |             "BIGINT": self.bigint_field, | ||||||
|  |             "DATE": self.date_field, | ||||||
|  |             "TIME": self.time_field, | ||||||
|  |             "JSON": self.json_field, | ||||||
|  |             "BLOB": self.binary_field, | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |     async def get_columns(self, table: str) -> List[Column]: | ||||||
|  |         columns = [] | ||||||
|  |         sql = f"PRAGMA table_info({table})" | ||||||
|  |         ret = await self.conn.execute_query_dict(sql) | ||||||
|  |         columns_index = await self._get_columns_index(table) | ||||||
|  |         for row in ret: | ||||||
|  |             try: | ||||||
|  |                 length = row["type"].split("(")[1].split(")")[0] | ||||||
|  |             except IndexError: | ||||||
|  |                 length = None | ||||||
|  |             columns.append( | ||||||
|  |                 Column( | ||||||
|  |                     name=row["name"], | ||||||
|  |                     data_type=row["type"].split("(")[0], | ||||||
|  |                     null=row["notnull"] == 0, | ||||||
|  |                     default=row["dflt_value"], | ||||||
|  |                     length=length, | ||||||
|  |                     pk=row["pk"] == 1, | ||||||
|  |                     unique=columns_index.get(row["name"]) == "unique", | ||||||
|  |                     index=columns_index.get(row["name"]) == "index", | ||||||
|  |                 ) | ||||||
|  |             ) | ||||||
|  |         return columns | ||||||
|  |  | ||||||
|  |     async def _get_columns_index(self, table: str): | ||||||
|  |         sql = f"PRAGMA index_list ({table})" | ||||||
|  |         indexes = await self.conn.execute_query_dict(sql) | ||||||
|  |         ret = {} | ||||||
|  |         for index in indexes: | ||||||
|  |             sql = f"PRAGMA index_info({index['name']})" | ||||||
|  |             index_info = (await self.conn.execute_query_dict(sql))[0] | ||||||
|  |             ret[index_info["name"]] = "unique" if index["unique"] else "index" | ||||||
|  |         return ret | ||||||
|  |  | ||||||
|  |     async def get_all_tables(self) -> List[str]: | ||||||
|  |         sql = "select tbl_name from sqlite_master where type='table' and name!='sqlite_sequence'" | ||||||
|  |         ret = await self.conn.execute_query_dict(sql) | ||||||
|  |         return list(map(lambda x: x["tbl_name"], ret)) | ||||||
| @@ -1,87 +0,0 @@ | |||||||
| import sys |  | ||||||
| from typing import List, Optional |  | ||||||
|  |  | ||||||
| from ddlparse import DdlParse |  | ||||||
| from tortoise import BaseDBAsyncClient |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class InspectDb: |  | ||||||
|     _table_template = "class {table}(Model):\n" |  | ||||||
|     _field_template_mapping = { |  | ||||||
|         "INT": "    {field} = fields.IntField({pk}{unique}{comment})", |  | ||||||
|         "SMALLINT": "    {field} = fields.IntField({pk}{unique}{comment})", |  | ||||||
|         "TINYINT": "    {field} = fields.BooleanField({null}{default}{comment})", |  | ||||||
|         "VARCHAR": "    {field} = fields.CharField({pk}{unique}{length}{null}{default}{comment})", |  | ||||||
|         "LONGTEXT": "    {field} = fields.TextField({null}{default}{comment})", |  | ||||||
|         "TEXT": "    {field} = fields.TextField({null}{default}{comment})", |  | ||||||
|         "DATETIME": "    {field} = fields.DatetimeField({null}{default}{comment})", |  | ||||||
|         "FLOAT": "    {field} = fields.FloatField({null}{default}{comment})", |  | ||||||
|         "DATE": "    {field} = fields.DateField({null}{default}{comment})", |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     def __init__(self, conn: BaseDBAsyncClient, tables: Optional[List[str]] = None): |  | ||||||
|         self.conn = conn |  | ||||||
|         self.tables = tables |  | ||||||
|         self.DIALECT = conn.schema_generator.DIALECT |  | ||||||
|  |  | ||||||
|     async def show_create_tables(self): |  | ||||||
|         if self.DIALECT == "mysql": |  | ||||||
|             if not self.tables: |  | ||||||
|                 sql_tables = f"SELECT table_name FROM information_schema.tables WHERE table_schema = '{self.conn.database}';"  # nosec: B608 |  | ||||||
|                 ret = await self.conn.execute_query(sql_tables) |  | ||||||
|                 self.tables = map(lambda x: x["TABLE_NAME"], ret[1]) |  | ||||||
|             for table in self.tables: |  | ||||||
|                 sql_show_create_table = f"SHOW CREATE TABLE {table}" |  | ||||||
|                 ret = await self.conn.execute_query(sql_show_create_table) |  | ||||||
|                 yield ret[1][0]["Create Table"] |  | ||||||
|         else: |  | ||||||
|             raise NotImplementedError("Currently only support MySQL") |  | ||||||
|  |  | ||||||
|     async def inspect(self): |  | ||||||
|         ddl_list = self.show_create_tables() |  | ||||||
|         result = "from tortoise import Model, fields\n\n\n" |  | ||||||
|         tables = [] |  | ||||||
|         async for ddl in ddl_list: |  | ||||||
|             parser = DdlParse(ddl, DdlParse.DATABASE.mysql) |  | ||||||
|             table = parser.parse() |  | ||||||
|             name = table.name.title() |  | ||||||
|             columns = table.columns |  | ||||||
|             fields = [] |  | ||||||
|             model = self._table_template.format(table=name) |  | ||||||
|             for column_name, column in columns.items(): |  | ||||||
|                 comment = default = length = unique = null = pk = "" |  | ||||||
|                 if column.primary_key: |  | ||||||
|                     pk = "pk=True, " |  | ||||||
|                 if column.unique: |  | ||||||
|                     unique = "unique=True, " |  | ||||||
|                 if column.data_type == "VARCHAR": |  | ||||||
|                     length = f"max_length={column.length}, " |  | ||||||
|                 if not column.not_null: |  | ||||||
|                     null = "null=True, " |  | ||||||
|                 if column.default is not None: |  | ||||||
|                     if column.data_type == "TINYINT": |  | ||||||
|                         default = f"default={'True' if column.default == '1' else 'False'}, " |  | ||||||
|                     elif column.data_type == "DATETIME": |  | ||||||
|                         if "CURRENT_TIMESTAMP" in column.default: |  | ||||||
|                             if "ON UPDATE CURRENT_TIMESTAMP" in ddl: |  | ||||||
|                                 default = "auto_now_add=True, " |  | ||||||
|                             else: |  | ||||||
|                                 default = "auto_now=True, " |  | ||||||
|                     else: |  | ||||||
|                         default = f"default={column.default}, " |  | ||||||
|  |  | ||||||
|                 if column.comment: |  | ||||||
|                     comment = f"description='{column.comment}', " |  | ||||||
|  |  | ||||||
|                 field = self._field_template_mapping[column.data_type].format( |  | ||||||
|                     field=column_name, |  | ||||||
|                     pk=pk, |  | ||||||
|                     unique=unique, |  | ||||||
|                     length=length, |  | ||||||
|                     null=null, |  | ||||||
|                     default=default, |  | ||||||
|                     comment=comment, |  | ||||||
|                 ) |  | ||||||
|                 fields.append(field) |  | ||||||
|             tables.append(model + "\n".join(fields)) |  | ||||||
|         sys.stdout.write(result + "\n\n\n".join(tables)) |  | ||||||
| @@ -1,12 +1,14 @@ | |||||||
| import os | import os | ||||||
| from datetime import datetime | from datetime import datetime | ||||||
|  | from hashlib import md5 | ||||||
| from pathlib import Path | from pathlib import Path | ||||||
| from typing import Dict, List, Optional, Tuple, Type | from typing import Dict, List, Optional, Tuple, Type, Union | ||||||
|  |  | ||||||
| import click | import click | ||||||
| from dictdiffer import diff | from dictdiffer import diff | ||||||
| from tortoise import BaseDBAsyncClient, Model, Tortoise | from tortoise import BaseDBAsyncClient, Model, Tortoise | ||||||
| from tortoise.exceptions import OperationalError | from tortoise.exceptions import OperationalError | ||||||
|  | from tortoise.indexes import Index | ||||||
|  |  | ||||||
| from aerich.ddl import BaseDDL | from aerich.ddl import BaseDDL | ||||||
| from aerich.models import MAX_VERSION_LENGTH, Aerich | from aerich.models import MAX_VERSION_LENGTH, Aerich | ||||||
| @@ -32,7 +34,7 @@ class Migrate: | |||||||
|     ddl: BaseDDL |     ddl: BaseDDL | ||||||
|     _last_version_content: Optional[dict] = None |     _last_version_content: Optional[dict] = None | ||||||
|     app: str |     app: str | ||||||
|     migrate_location: str |     migrate_location: Path | ||||||
|     dialect: str |     dialect: str | ||||||
|     _db_version: Optional[str] = None |     _db_version: Optional[str] = None | ||||||
|  |  | ||||||
| @@ -157,6 +159,18 @@ class Migrate: | |||||||
|             else: |             else: | ||||||
|                 cls.downgrade_operators.append(operator) |                 cls.downgrade_operators.append(operator) | ||||||
|  |  | ||||||
|  |     @classmethod | ||||||
|  |     def _handle_indexes(cls, model: Type[Model], indexes: List[Union[Tuple[str], Index]]): | ||||||
|  |         ret = [] | ||||||
|  |         for index in indexes: | ||||||
|  |             if isinstance(index, Index): | ||||||
|  |                 index.__hash__ = lambda self: md5(  # nosec: B303 | ||||||
|  |                     self.index_name(cls.ddl.schema_generator, model).encode() | ||||||
|  |                     + self.__class__.__name__.encode() | ||||||
|  |                 ).hexdigest() | ||||||
|  |             ret.append(index) | ||||||
|  |         return ret | ||||||
|  |  | ||||||
|     @classmethod |     @classmethod | ||||||
|     def diff_models(cls, old_models: Dict[str, dict], new_models: Dict[str, dict], upgrade=True): |     def diff_models(cls, old_models: Dict[str, dict], new_models: Dict[str, dict], upgrade=True): | ||||||
|         """ |         """ | ||||||
| @@ -192,8 +206,18 @@ class Migrate: | |||||||
|                 new_unique_together = set( |                 new_unique_together = set( | ||||||
|                     map(lambda x: tuple(x), new_model_describe.get("unique_together")) |                     map(lambda x: tuple(x), new_model_describe.get("unique_together")) | ||||||
|                 ) |                 ) | ||||||
|                 old_indexes = set(map(lambda x: tuple(x), old_model_describe.get("indexes", []))) |                 old_indexes = set( | ||||||
|                 new_indexes = set(map(lambda x: tuple(x), new_model_describe.get("indexes", []))) |                     map( | ||||||
|  |                         lambda x: x if isinstance(x, Index) else tuple(x), | ||||||
|  |                         cls._handle_indexes(model, old_model_describe.get("indexes", [])), | ||||||
|  |                     ) | ||||||
|  |                 ) | ||||||
|  |                 new_indexes = set( | ||||||
|  |                     map( | ||||||
|  |                         lambda x: x if isinstance(x, Index) else tuple(x), | ||||||
|  |                         cls._handle_indexes(model, new_model_describe.get("indexes", [])), | ||||||
|  |                     ) | ||||||
|  |                 ) | ||||||
|                 old_pk_field = old_model_describe.get("pk_field") |                 old_pk_field = old_model_describe.get("pk_field") | ||||||
|                 new_pk_field = new_model_describe.get("pk_field") |                 new_pk_field = new_model_describe.get("pk_field") | ||||||
|                 # pk field |                 # pk field | ||||||
| @@ -463,12 +487,18 @@ class Migrate: | |||||||
|         return ret |         return ret | ||||||
|  |  | ||||||
|     @classmethod |     @classmethod | ||||||
|     def _drop_index(cls, model: Type[Model], fields_name: Tuple[str], unique=False): |     def _drop_index(cls, model: Type[Model], fields_name: Union[Tuple[str], Index], unique=False): | ||||||
|  |         if isinstance(fields_name, Index): | ||||||
|  |             return cls.ddl.drop_index_by_name( | ||||||
|  |                 model, fields_name.index_name(cls.ddl.schema_generator, model) | ||||||
|  |             ) | ||||||
|         fields_name = cls._resolve_fk_fields_name(model, fields_name) |         fields_name = cls._resolve_fk_fields_name(model, fields_name) | ||||||
|         return cls.ddl.drop_index(model, fields_name, unique) |         return cls.ddl.drop_index(model, fields_name, unique) | ||||||
|  |  | ||||||
|     @classmethod |     @classmethod | ||||||
|     def _add_index(cls, model: Type[Model], fields_name: Tuple[str], unique=False): |     def _add_index(cls, model: Type[Model], fields_name: Union[Tuple[str], Index], unique=False): | ||||||
|  |         if isinstance(fields_name, Index): | ||||||
|  |             return fields_name.get_sql(cls.ddl.schema_generator, model, False) | ||||||
|         fields_name = cls._resolve_fk_fields_name(model, fields_name) |         fields_name = cls._resolve_fk_fields_name(model, fields_name) | ||||||
|         return cls.ddl.add_index(model, fields_name, unique) |         return cls.ddl.add_index(model, fields_name, unique) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,12 +1,15 @@ | |||||||
| from tortoise import Model, fields | from tortoise import Model, fields | ||||||
|  |  | ||||||
|  | from aerich.coder import decoder, encoder | ||||||
|  |  | ||||||
| MAX_VERSION_LENGTH = 255 | MAX_VERSION_LENGTH = 255 | ||||||
|  | MAX_APP_LENGTH = 100 | ||||||
|  |  | ||||||
|  |  | ||||||
| class Aerich(Model): | class Aerich(Model): | ||||||
|     version = fields.CharField(max_length=MAX_VERSION_LENGTH) |     version = fields.CharField(max_length=MAX_VERSION_LENGTH) | ||||||
|     app = fields.CharField(max_length=20) |     app = fields.CharField(max_length=MAX_APP_LENGTH) | ||||||
|     content = fields.JSONField() |     content = fields.JSONField(encoder=encoder, decoder=decoder) | ||||||
|  |  | ||||||
|     class Meta: |     class Meta: | ||||||
|         ordering = ["-id"] |         ordering = ["-id"] | ||||||
|   | |||||||
| @@ -1 +1 @@ | |||||||
| __version__ = "0.6.1" | __version__ = "0.6.3" | ||||||
|   | |||||||
							
								
								
									
										434
									
								
								poetry.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										434
									
								
								poetry.lock
									
									
									
										generated
									
									
									
								
							| @@ -11,7 +11,7 @@ typing_extensions = ">=3.7.2" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "asyncmy" | name = "asyncmy" | ||||||
| version = "0.2.3" | version = "0.2.5" | ||||||
| description = "A fast asyncio MySQL driver" | description = "A fast asyncio MySQL driver" | ||||||
| category = "main" | category = "main" | ||||||
| optional = true | optional = true | ||||||
| @@ -43,25 +43,25 @@ python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "attrs" | name = "attrs" | ||||||
| version = "21.2.0" | version = "21.4.0" | ||||||
| description = "Classes Without Boilerplate" | description = "Classes Without Boilerplate" | ||||||
| category = "dev" | category = "dev" | ||||||
| optional = false | optional = false | ||||||
| python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*" | python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*" | ||||||
|  |  | ||||||
| [package.extras] | [package.extras] | ||||||
| dev = ["coverage[toml] (>=5.0.2)", "hypothesis", "pympler", "pytest (>=4.3.0)", "six", "mypy", "pytest-mypy-plugins", "zope.interface", "furo", "sphinx", "sphinx-notfound-page", "pre-commit"] | dev = ["coverage[toml] (>=5.0.2)", "hypothesis", "pympler", "pytest (>=4.3.0)", "six", "mypy", "pytest-mypy-plugins", "zope.interface", "furo", "sphinx", "sphinx-notfound-page", "pre-commit", "cloudpickle"] | ||||||
| docs = ["furo", "sphinx", "zope.interface", "sphinx-notfound-page"] | docs = ["furo", "sphinx", "zope.interface", "sphinx-notfound-page"] | ||||||
| tests = ["coverage[toml] (>=5.0.2)", "hypothesis", "pympler", "pytest (>=4.3.0)", "six", "mypy", "pytest-mypy-plugins", "zope.interface"] | tests = ["coverage[toml] (>=5.0.2)", "hypothesis", "pympler", "pytest (>=4.3.0)", "six", "mypy", "pytest-mypy-plugins", "zope.interface", "cloudpickle"] | ||||||
| tests_no_zope = ["coverage[toml] (>=5.0.2)", "hypothesis", "pympler", "pytest (>=4.3.0)", "six", "mypy", "pytest-mypy-plugins"] | tests_no_zope = ["coverage[toml] (>=5.0.2)", "hypothesis", "pympler", "pytest (>=4.3.0)", "six", "mypy", "pytest-mypy-plugins", "cloudpickle"] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "bandit" | name = "bandit" | ||||||
| version = "1.7.1" | version = "1.7.4" | ||||||
| description = "Security oriented static analyser for python code." | description = "Security oriented static analyser for python code." | ||||||
| category = "dev" | category = "dev" | ||||||
| optional = false | optional = false | ||||||
| python-versions = ">=3.5" | python-versions = ">=3.7" | ||||||
|  |  | ||||||
| [package.dependencies] | [package.dependencies] | ||||||
| colorama = {version = ">=0.3.9", markers = "platform_system == \"Windows\""} | colorama = {version = ">=0.3.9", markers = "platform_system == \"Windows\""} | ||||||
| @@ -69,31 +69,32 @@ GitPython = ">=1.0.1" | |||||||
| PyYAML = ">=5.3.1" | PyYAML = ">=5.3.1" | ||||||
| stevedore = ">=1.20.0" | stevedore = ">=1.20.0" | ||||||
|  |  | ||||||
|  | [package.extras] | ||||||
|  | test = ["coverage (>=4.5.4)", "fixtures (>=3.0.0)", "flake8 (>=4.0.0)", "stestr (>=2.5.0)", "testscenarios (>=0.5.0)", "testtools (>=2.3.0)", "toml", "beautifulsoup4 (>=4.8.0)", "pylint (==1.9.4)"] | ||||||
|  | toml = ["toml"] | ||||||
|  | yaml = ["pyyaml"] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "black" | name = "black" | ||||||
| version = "21.12b0" | version = "22.3.0" | ||||||
| description = "The uncompromising code formatter." | description = "The uncompromising code formatter." | ||||||
| category = "dev" | category = "dev" | ||||||
| optional = false | optional = false | ||||||
| python-versions = ">=3.6.2" | python-versions = ">=3.6.2" | ||||||
|  |  | ||||||
| [package.dependencies] | [package.dependencies] | ||||||
| click = ">=7.1.2" | click = ">=8.0.0" | ||||||
| mypy-extensions = ">=0.4.3" | mypy-extensions = ">=0.4.3" | ||||||
| pathspec = ">=0.9.0,<1" | pathspec = ">=0.9.0" | ||||||
| platformdirs = ">=2" | platformdirs = ">=2" | ||||||
| tomli = ">=0.2.6,<2.0.0" | tomli = {version = ">=1.1.0", markers = "python_version < \"3.11\""} | ||||||
| typed-ast = {version = ">=1.4.2", markers = "python_version < \"3.8\" and implementation_name == \"cpython\""} | typed-ast = {version = ">=1.4.2", markers = "python_version < \"3.8\" and implementation_name == \"cpython\""} | ||||||
| typing-extensions = [ | typing-extensions = {version = ">=3.10.0.0", markers = "python_version < \"3.10\""} | ||||||
|     {version = ">=3.10.0.0", markers = "python_version < \"3.10\""}, |  | ||||||
|     {version = "!=3.10.0.1", markers = "python_version >= \"3.10\""}, |  | ||||||
| ] |  | ||||||
|  |  | ||||||
| [package.extras] | [package.extras] | ||||||
| colorama = ["colorama (>=0.4.3)"] | colorama = ["colorama (>=0.4.3)"] | ||||||
| d = ["aiohttp (>=3.7.4)"] | d = ["aiohttp (>=3.7.4)"] | ||||||
| jupyter = ["ipython (>=7.8.0)", "tokenize-rt (>=3.2.0)"] | jupyter = ["ipython (>=7.8.0)", "tokenize-rt (>=3.2.0)"] | ||||||
| python2 = ["typed-ast (>=1.4.3)"] |  | ||||||
| uvloop = ["uvloop (>=0.15.2)"] | uvloop = ["uvloop (>=0.15.2)"] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| @@ -109,11 +110,11 @@ pycparser = "*" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "click" | name = "click" | ||||||
| version = "8.0.3" | version = "8.1.2" | ||||||
| description = "Composable command line interface toolkit" | description = "Composable command line interface toolkit" | ||||||
| category = "main" | category = "main" | ||||||
| optional = false | optional = false | ||||||
| python-versions = ">=3.6" | python-versions = ">=3.7" | ||||||
|  |  | ||||||
| [package.dependencies] | [package.dependencies] | ||||||
| colorama = {version = "*", markers = "platform_system == \"Windows\""} | colorama = {version = "*", markers = "platform_system == \"Windows\""} | ||||||
| @@ -129,7 +130,7 @@ python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "cryptography" | name = "cryptography" | ||||||
| version = "36.0.0" | version = "36.0.2" | ||||||
| description = "cryptography is a package which provides cryptographic recipes and primitives to Python developers." | description = "cryptography is a package which provides cryptographic recipes and primitives to Python developers." | ||||||
| category = "dev" | category = "dev" | ||||||
| optional = false | optional = false | ||||||
| @@ -146,17 +147,6 @@ sdist = ["setuptools_rust (>=0.11.4)"] | |||||||
| ssh = ["bcrypt (>=3.1.5)"] | ssh = ["bcrypt (>=3.1.5)"] | ||||||
| test = ["pytest (>=6.2.0)", "pytest-cov", "pytest-subtests", "pytest-xdist", "pretend", "iso8601", "pytz", "hypothesis (>=1.11.4,!=3.79.2)"] | test = ["pytest (>=6.2.0)", "pytest-cov", "pytest-subtests", "pytest-xdist", "pretend", "iso8601", "pytz", "hypothesis (>=1.11.4,!=3.79.2)"] | ||||||
|  |  | ||||||
| [[package]] |  | ||||||
| name = "ddlparse" |  | ||||||
| version = "1.10.0" |  | ||||||
| description = "DDL parase and Convert to BigQuery JSON schema" |  | ||||||
| category = "main" |  | ||||||
| optional = false |  | ||||||
| python-versions = "*" |  | ||||||
|  |  | ||||||
| [package.dependencies] |  | ||||||
| pyparsing = "*" |  | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "dictdiffer" | name = "dictdiffer" | ||||||
| version = "0.9.0" | version = "0.9.0" | ||||||
| @@ -209,7 +199,7 @@ smmap = ">=3.0.1,<6" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "gitpython" | name = "gitpython" | ||||||
| version = "3.1.24" | version = "3.1.27" | ||||||
| description = "GitPython is a python library used to interact with Git repositories" | description = "GitPython is a python library used to interact with Git repositories" | ||||||
| category = "dev" | category = "dev" | ||||||
| optional = false | optional = false | ||||||
| @@ -217,7 +207,7 @@ python-versions = ">=3.7" | |||||||
|  |  | ||||||
| [package.dependencies] | [package.dependencies] | ||||||
| gitdb = ">=4.0.1,<5" | gitdb = ">=4.0.1,<5" | ||||||
| typing-extensions = {version = ">=3.7.4.3", markers = "python_version < \"3.10\""} | typing-extensions = {version = ">=3.7.4.3", markers = "python_version < \"3.8\""} | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "importlib-metadata" | name = "importlib-metadata" | ||||||
| @@ -245,11 +235,11 @@ python-versions = "*" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "iso8601" | name = "iso8601" | ||||||
| version = "0.1.16" | version = "1.0.2" | ||||||
| description = "Simple module to parse ISO 8601 dates" | description = "Simple module to parse ISO 8601 dates" | ||||||
| category = "main" | category = "main" | ||||||
| optional = false | optional = false | ||||||
| python-versions = "*" | python-versions = ">=3.6.2,<4.0" | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "isort" | name = "isort" | ||||||
| @@ -302,7 +292,7 @@ python-versions = "!=3.0.*,!=3.1.*,!=3.2.*,!=3.3.*,!=3.4.*,>=2.7" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "pbr" | name = "pbr" | ||||||
| version = "5.8.0" | version = "5.8.1" | ||||||
| description = "Python Build Reasonableness" | description = "Python Build Reasonableness" | ||||||
| category = "dev" | category = "dev" | ||||||
| optional = false | optional = false | ||||||
| @@ -310,11 +300,11 @@ python-versions = ">=2.6" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "platformdirs" | name = "platformdirs" | ||||||
| version = "2.4.0" | version = "2.5.1" | ||||||
| description = "A small Python module for determining appropriate platform-specific dirs, e.g. a \"user data dir\"." | description = "A small Python module for determining appropriate platform-specific dirs, e.g. a \"user data dir\"." | ||||||
| category = "dev" | category = "dev" | ||||||
| optional = false | optional = false | ||||||
| python-versions = ">=3.6" | python-versions = ">=3.7" | ||||||
|  |  | ||||||
| [package.extras] | [package.extras] | ||||||
| docs = ["Sphinx (>=4)", "furo (>=2021.7.5b38)", "proselint (>=0.10.2)", "sphinx-autodoc-typehints (>=1.12)"] | docs = ["Sphinx (>=4)", "furo (>=2021.7.5b38)", "proselint (>=0.10.2)", "sphinx-autodoc-typehints (>=1.12)"] | ||||||
| @@ -359,6 +349,21 @@ category = "dev" | |||||||
| optional = false | optional = false | ||||||
| python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" | python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "pydantic" | ||||||
|  | version = "1.9.0" | ||||||
|  | description = "Data validation and settings management using python 3.6 type hinting" | ||||||
|  | category = "main" | ||||||
|  | optional = false | ||||||
|  | python-versions = ">=3.6.1" | ||||||
|  |  | ||||||
|  | [package.dependencies] | ||||||
|  | typing-extensions = ">=3.7.4.3" | ||||||
|  |  | ||||||
|  | [package.extras] | ||||||
|  | dotenv = ["python-dotenv (>=0.10.4)"] | ||||||
|  | email = ["email-validator (>=1.0.3)"] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "pyflakes" | name = "pyflakes" | ||||||
| version = "2.4.0" | version = "2.4.0" | ||||||
| @@ -369,9 +374,9 @@ python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "pyparsing" | name = "pyparsing" | ||||||
| version = "3.0.6" | version = "3.0.7" | ||||||
| description = "Python parsing module" | description = "Python parsing module" | ||||||
| category = "main" | category = "dev" | ||||||
| optional = false | optional = false | ||||||
| python-versions = ">=3.6" | python-versions = ">=3.6" | ||||||
|  |  | ||||||
| @@ -380,19 +385,31 @@ diagrams = ["jinja2", "railroad-diagrams"] | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "pypika-tortoise" | name = "pypika-tortoise" | ||||||
| version = "0.1.1" | version = "0.1.4" | ||||||
| description = "Forked from pypika and streamline just for tortoise-orm" | description = "Forked from pypika and streamline just for tortoise-orm" | ||||||
| category = "main" | category = "main" | ||||||
| optional = false | optional = false | ||||||
| python-versions = ">=3.7,<4.0" | python-versions = ">=3.7,<4.0" | ||||||
|  |  | ||||||
|  | [[package]] | ||||||
|  | name = "pyproject-flake8" | ||||||
|  | version = "0.0.1a3" | ||||||
|  | description = "pyproject-flake8 (`pflake8`), a monkey patching wrapper to connect flake8 with pyproject.toml configuration" | ||||||
|  | category = "dev" | ||||||
|  | optional = false | ||||||
|  | python-versions = "*" | ||||||
|  |  | ||||||
|  | [package.dependencies] | ||||||
|  | flake8 = "*" | ||||||
|  | tomli = {version = "*", markers = "python_version < \"3.11.0a7\""} | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "pytest" | name = "pytest" | ||||||
| version = "6.2.5" | version = "7.1.1" | ||||||
| description = "pytest: simple powerful testing with Python" | description = "pytest: simple powerful testing with Python" | ||||||
| category = "dev" | category = "dev" | ||||||
| optional = false | optional = false | ||||||
| python-versions = ">=3.6" | python-versions = ">=3.7" | ||||||
|  |  | ||||||
| [package.dependencies] | [package.dependencies] | ||||||
| atomicwrites = {version = ">=1.0", markers = "sys_platform == \"win32\""} | atomicwrites = {version = ">=1.0", markers = "sys_platform == \"win32\""} | ||||||
| @@ -403,32 +420,33 @@ iniconfig = "*" | |||||||
| packaging = "*" | packaging = "*" | ||||||
| pluggy = ">=0.12,<2.0" | pluggy = ">=0.12,<2.0" | ||||||
| py = ">=1.8.2" | py = ">=1.8.2" | ||||||
| toml = "*" | tomli = ">=1.0.0" | ||||||
|  |  | ||||||
| [package.extras] | [package.extras] | ||||||
| testing = ["argcomplete", "hypothesis (>=3.56)", "mock", "nose", "requests", "xmlschema"] | testing = ["argcomplete", "hypothesis (>=3.56)", "mock", "nose", "pygments (>=2.7.2)", "requests", "xmlschema"] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "pytest-asyncio" | name = "pytest-asyncio" | ||||||
| version = "0.16.0" | version = "0.18.3" | ||||||
| description = "Pytest support for asyncio." | description = "Pytest support for asyncio" | ||||||
| category = "dev" | category = "dev" | ||||||
| optional = false | optional = false | ||||||
| python-versions = ">= 3.6" | python-versions = ">=3.7" | ||||||
|  |  | ||||||
| [package.dependencies] | [package.dependencies] | ||||||
| pytest = ">=5.4.0" | pytest = ">=6.1.0" | ||||||
|  | typing-extensions = {version = ">=3.7.2", markers = "python_version < \"3.8\""} | ||||||
|  |  | ||||||
| [package.extras] | [package.extras] | ||||||
| testing = ["coverage", "hypothesis (>=5.7.1)"] | testing = ["coverage (==6.2)", "hypothesis (>=5.7.1)", "flaky (>=3.5.0)", "mypy (==0.931)", "pytest-trio (>=0.7.0)"] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "pytest-forked" | name = "pytest-forked" | ||||||
| version = "1.3.0" | version = "1.4.0" | ||||||
| description = "run tests in isolated forked subprocesses" | description = "run tests in isolated forked subprocesses" | ||||||
| category = "dev" | category = "dev" | ||||||
| optional = false | optional = false | ||||||
| python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*" | python-versions = ">=3.6" | ||||||
|  |  | ||||||
| [package.dependencies] | [package.dependencies] | ||||||
| py = "*" | py = "*" | ||||||
| @@ -436,11 +454,11 @@ pytest = ">=3.10" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "pytest-mock" | name = "pytest-mock" | ||||||
| version = "3.6.1" | version = "3.7.0" | ||||||
| description = "Thin-wrapper around the mock package for easier use with pytest" | description = "Thin-wrapper around the mock package for easier use with pytest" | ||||||
| category = "dev" | category = "dev" | ||||||
| optional = false | optional = false | ||||||
| python-versions = ">=3.6" | python-versions = ">=3.7" | ||||||
|  |  | ||||||
| [package.dependencies] | [package.dependencies] | ||||||
| pytest = ">=5.0" | pytest = ">=5.0" | ||||||
| @@ -450,7 +468,7 @@ dev = ["pre-commit", "tox", "pytest-asyncio"] | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "pytest-xdist" | name = "pytest-xdist" | ||||||
| version = "2.4.0" | version = "2.5.0" | ||||||
| description = "pytest xdist plugin for distributed testing and loop-on-failing modes" | description = "pytest xdist plugin for distributed testing and loop-on-failing modes" | ||||||
| category = "dev" | category = "dev" | ||||||
| optional = false | optional = false | ||||||
| @@ -458,7 +476,7 @@ python-versions = ">=3.6" | |||||||
|  |  | ||||||
| [package.dependencies] | [package.dependencies] | ||||||
| execnet = ">=1.1" | execnet = ">=1.1" | ||||||
| pytest = ">=6.0.0" | pytest = ">=6.2.0" | ||||||
| pytest-forked = "*" | pytest-forked = "*" | ||||||
|  |  | ||||||
| [package.extras] | [package.extras] | ||||||
| @@ -468,7 +486,7 @@ testing = ["filelock"] | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "pytz" | name = "pytz" | ||||||
| version = "2021.3" | version = "2022.1" | ||||||
| description = "World timezone definitions, modern and historical" | description = "World timezone definitions, modern and historical" | ||||||
| category = "main" | category = "main" | ||||||
| optional = false | optional = false | ||||||
| @@ -502,33 +520,25 @@ python-versions = ">=3.6" | |||||||
| importlib-metadata = {version = ">=1.7.0", markers = "python_version < \"3.8\""} | importlib-metadata = {version = ">=1.7.0", markers = "python_version < \"3.8\""} | ||||||
| pbr = ">=2.0.0,<2.1.0 || >2.1.0" | pbr = ">=2.0.0,<2.1.0 || >2.1.0" | ||||||
|  |  | ||||||
| [[package]] |  | ||||||
| name = "toml" |  | ||||||
| version = "0.10.2" |  | ||||||
| description = "Python Library for Tom's Obvious, Minimal Language" |  | ||||||
| category = "dev" |  | ||||||
| optional = false |  | ||||||
| python-versions = ">=2.6, !=3.0.*, !=3.1.*, !=3.2.*" |  | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "tomli" | name = "tomli" | ||||||
| version = "1.2.2" | version = "2.0.1" | ||||||
| description = "A lil' TOML parser" | description = "A lil' TOML parser" | ||||||
| category = "dev" | category = "dev" | ||||||
| optional = false | optional = false | ||||||
| python-versions = ">=3.6" | python-versions = ">=3.7" | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "tomlkit" | name = "tomlkit" | ||||||
| version = "0.7.2" | version = "0.10.1" | ||||||
| description = "Style preserving TOML library" | description = "Style preserving TOML library" | ||||||
| category = "main" | category = "main" | ||||||
| optional = false | optional = false | ||||||
| python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*" | python-versions = ">=3.6,<4.0" | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "tortoise-orm" | name = "tortoise-orm" | ||||||
| version = "0.17.8" | version = "0.19.0" | ||||||
| description = "Easy async ORM for python, built with relations in mind" | description = "Easy async ORM for python, built with relations in mind" | ||||||
| category = "main" | category = "main" | ||||||
| optional = false | optional = false | ||||||
| @@ -536,19 +546,20 @@ python-versions = ">=3.7,<4.0" | |||||||
|  |  | ||||||
| [package.dependencies] | [package.dependencies] | ||||||
| aiosqlite = ">=0.16.0,<0.18.0" | aiosqlite = ">=0.16.0,<0.18.0" | ||||||
| iso8601 = ">=0.1.13,<0.2.0" | iso8601 = ">=1.0.2,<2.0.0" | ||||||
| pypika-tortoise = ">=0.1.1,<0.2.0" | pypika-tortoise = ">=0.1.4,<0.2.0" | ||||||
| pytz = "*" | pytz = "*" | ||||||
|  |  | ||||||
| [package.extras] | [package.extras] | ||||||
| aiomysql = ["aiomysql"] | aiomysql = ["aiomysql"] | ||||||
| asyncmy = ["asyncmy"] | asyncmy = ["asyncmy (>=0.2.4,<0.3.0)"] | ||||||
| asyncpg = ["asyncpg"] | asyncpg = ["asyncpg"] | ||||||
| accel = ["ciso8601 (>=2.1.2,<3.0.0)", "python-rapidjson", "uvloop (>=0.14.0,<0.15.0)"] | accel = ["ciso8601", "orjson", "uvloop"] | ||||||
|  | psycopg = ["psycopg"] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "typed-ast" | name = "typed-ast" | ||||||
| version = "1.5.1" | version = "1.5.2" | ||||||
| description = "a fork of Python 2 and 3 ast modules with type comment support" | description = "a fork of Python 2 and 3 ast modules with type comment support" | ||||||
| category = "dev" | category = "dev" | ||||||
| optional = false | optional = false | ||||||
| @@ -556,7 +567,7 @@ python-versions = ">=3.6" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "typing-extensions" | name = "typing-extensions" | ||||||
| version = "4.0.1" | version = "4.1.1" | ||||||
| description = "Backported and Experimental Type Hints for Python 3.6+" | description = "Backported and Experimental Type Hints for Python 3.6+" | ||||||
| category = "main" | category = "main" | ||||||
| optional = false | optional = false | ||||||
| @@ -564,15 +575,15 @@ python-versions = ">=3.6" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "zipp" | name = "zipp" | ||||||
| version = "3.6.0" | version = "3.7.0" | ||||||
| description = "Backport of pathlib-compatible object wrapper for zip files" | description = "Backport of pathlib-compatible object wrapper for zip files" | ||||||
| category = "main" | category = "main" | ||||||
| optional = false | optional = false | ||||||
| python-versions = ">=3.6" | python-versions = ">=3.7" | ||||||
|  |  | ||||||
| [package.extras] | [package.extras] | ||||||
| docs = ["sphinx", "jaraco.packaging (>=8.2)", "rst.linker (>=1.9)"] | docs = ["sphinx", "jaraco.packaging (>=8.2)", "rst.linker (>=1.9)"] | ||||||
| testing = ["pytest (>=4.6)", "pytest-checkdocs (>=2.4)", "pytest-flake8", "pytest-cov", "pytest-enabler (>=1.0.1)", "jaraco.itertools", "func-timeout", "pytest-black (>=0.3.7)", "pytest-mypy"] | testing = ["pytest (>=6)", "pytest-checkdocs (>=2.4)", "pytest-flake8", "pytest-cov", "pytest-enabler (>=1.0.1)", "jaraco.itertools", "func-timeout", "pytest-black (>=0.3.7)", "pytest-mypy"] | ||||||
|  |  | ||||||
| [extras] | [extras] | ||||||
| asyncmy = ["asyncmy"] | asyncmy = ["asyncmy"] | ||||||
| @@ -581,7 +592,7 @@ asyncpg = ["asyncpg"] | |||||||
| [metadata] | [metadata] | ||||||
| lock-version = "1.1" | lock-version = "1.1" | ||||||
| python-versions = "^3.7" | python-versions = "^3.7" | ||||||
| content-hash = "f142797f751e246cf1730cf0c4f2f1c6026a812f9ed7b3b8dddae4496320ff73" | content-hash = "37c6a73133abae4ce337962636160ae207f38b301b34ecfb6cb2547c3a25be3e" | ||||||
|  |  | ||||||
| [metadata.files] | [metadata.files] | ||||||
| aiosqlite = [ | aiosqlite = [ | ||||||
| @@ -589,19 +600,19 @@ aiosqlite = [ | |||||||
|     {file = "aiosqlite-0.17.0.tar.gz", hash = "sha256:f0e6acc24bc4864149267ac82fb46dfb3be4455f99fe21df82609cc6e6baee51"}, |     {file = "aiosqlite-0.17.0.tar.gz", hash = "sha256:f0e6acc24bc4864149267ac82fb46dfb3be4455f99fe21df82609cc6e6baee51"}, | ||||||
| ] | ] | ||||||
| asyncmy = [ | asyncmy = [ | ||||||
|     {file = "asyncmy-0.2.3-cp310-cp310-macosx_10_15_x86_64.whl", hash = "sha256:c9dc38b56e3091d75ccda1ed598f90dac0489f4e6700bb3aae89b9a8b4635ad3"}, |     {file = "asyncmy-0.2.5-cp310-cp310-macosx_10_16_x86_64.whl", hash = "sha256:f176b55c82d3bdb10f0ecb3a518a54777f3d247e00f06add138f63df4edc0e3d"}, | ||||||
|     {file = "asyncmy-0.2.3-cp310-cp310-manylinux_2_31_x86_64.whl", hash = "sha256:38d6c2e658d13213ced685b5e41e35df1122174423b38f2bc27a6a4535de05b2"}, |     {file = "asyncmy-0.2.5-cp310-cp310-manylinux_2_31_x86_64.whl", hash = "sha256:f404d351d4f9fc741cdb8b49da8278e63a8551be6ccd03b514c2c0828500633d"}, | ||||||
|     {file = "asyncmy-0.2.3-cp310-cp310-win_amd64.whl", hash = "sha256:2b6dbfe7f4f7ffbcaa190f477f79361cbbc79248eeb05ee8c338b295b18a0119"}, |     {file = "asyncmy-0.2.5-cp310-cp310-win_amd64.whl", hash = "sha256:9824184d180753d23101b1d9fdc7955783b08fbc6f3cc88d6acce7ff019c0eaf"}, | ||||||
|     {file = "asyncmy-0.2.3-cp37-cp37m-macosx_10_15_x86_64.whl", hash = "sha256:28a534ceab5fbc2e20a29b2167c05c94f2cc1e2735a96fcc24b684890bb1109a"}, |     {file = "asyncmy-0.2.5-cp37-cp37m-macosx_10_16_x86_64.whl", hash = "sha256:02add8063bd00762a469dcb9915563f66520ffda598851a957443b1012182f43"}, | ||||||
|     {file = "asyncmy-0.2.3-cp37-cp37m-manylinux_2_31_x86_64.whl", hash = "sha256:0c7db0d0b7c0f47fcb656c1db41f5845b3a5e7e83013264c83e943e53c4abb60"}, |     {file = "asyncmy-0.2.5-cp37-cp37m-manylinux_2_31_x86_64.whl", hash = "sha256:a341d8a22d9a1f3236a81f17836002291567aa7d878ab75b37ed9bf4ce401290"}, | ||||||
|     {file = "asyncmy-0.2.3-cp37-cp37m-win_amd64.whl", hash = "sha256:22ab5de34356a7331443d0076c47c78aedd3b1c41e1b6baf4017b2f207fd39d4"}, |     {file = "asyncmy-0.2.5-cp37-cp37m-win_amd64.whl", hash = "sha256:2dc25f0bb723a71445d5c5b46ab2ae71c9dd3123fea9eae1bee4c36af5eda2bc"}, | ||||||
|     {file = "asyncmy-0.2.3-cp38-cp38-macosx_10_15_x86_64.whl", hash = "sha256:2b14ebd0c1e050a6ee0a314111527327fdb53fe490169af6ed9361a921fba2fa"}, |     {file = "asyncmy-0.2.5-cp38-cp38-macosx_10_16_x86_64.whl", hash = "sha256:e184e701fa153dd456f6b351136c0a7a7524b8f5959f7f4b47848efe434a9c7d"}, | ||||||
|     {file = "asyncmy-0.2.3-cp38-cp38-manylinux_2_31_x86_64.whl", hash = "sha256:ef785957e480902d9b1a34f23e29157de84606bf758ddbfbabc1afe93f91ece3"}, |     {file = "asyncmy-0.2.5-cp38-cp38-manylinux_2_31_x86_64.whl", hash = "sha256:2275cc0036fa39f888c0770173ffb8ed16b89eecf2e380499275bfa6bf4ee088"}, | ||||||
|     {file = "asyncmy-0.2.3-cp38-cp38-win_amd64.whl", hash = "sha256:804fda2c96e16de5b4a7740a49cf21207fe6b856875608f28a75a486e4903b3d"}, |     {file = "asyncmy-0.2.5-cp38-cp38-win_amd64.whl", hash = "sha256:527ccc24a9bd76d565f1024f4a50ee6fd92cac518e6d884281ad61ffc424e7cd"}, | ||||||
|     {file = "asyncmy-0.2.3-cp39-cp39-macosx_10_15_x86_64.whl", hash = "sha256:4be0f01f79974adf7c064c3c23bd30cd24627c081a39a03461bd4fea0a59562b"}, |     {file = "asyncmy-0.2.5-cp39-cp39-macosx_10_16_x86_64.whl", hash = "sha256:6606e296dc161d71629f1163c3c82dda97431e25ee7240b6b7f139c2c35cff94"}, | ||||||
|     {file = "asyncmy-0.2.3-cp39-cp39-manylinux_2_31_x86_64.whl", hash = "sha256:3167337d2e778b560fc109ec9d388562b4e9b0241e6d31ca2de15bf7437c781d"}, |     {file = "asyncmy-0.2.5-cp39-cp39-manylinux_2_31_x86_64.whl", hash = "sha256:61ed1b9e69dafe476f02c20962b8ee4ec5ba130b760bdf504015fcb80bbe6787"}, | ||||||
|     {file = "asyncmy-0.2.3-cp39-cp39-win_amd64.whl", hash = "sha256:5577b695c38e01377e7ef4f5bd3877aada11d1174f80b6354be55a5447f9d1f8"}, |     {file = "asyncmy-0.2.5-cp39-cp39-win_amd64.whl", hash = "sha256:f5dcc1a29d608cc5270f37328253032c554321b85bcf5653f1affa01f185c29c"}, | ||||||
|     {file = "asyncmy-0.2.3.tar.gz", hash = "sha256:769f749d8b03b28a31b185b77c54e8f8f363ee8a3c3719bad8a71e4e9a0ce8a6"}, |     {file = "asyncmy-0.2.5.tar.gz", hash = "sha256:cf3ef3d1ada385d231f23fffcbf1fe040bae8575b187746633fbef6e7cff2844"}, | ||||||
| ] | ] | ||||||
| asyncpg = [ | asyncpg = [ | ||||||
|     {file = "asyncpg-0.25.0-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:bf5e3408a14a17d480f36ebaf0401a12ff6ae5457fdf45e4e2775c51cc9517d3"}, |     {file = "asyncpg-0.25.0-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:bf5e3408a14a17d480f36ebaf0401a12ff6ae5457fdf45e4e2775c51cc9517d3"}, | ||||||
| @@ -636,16 +647,37 @@ atomicwrites = [ | |||||||
|     {file = "atomicwrites-1.4.0.tar.gz", hash = "sha256:ae70396ad1a434f9c7046fd2dd196fc04b12f9e91ffb859164193be8b6168a7a"}, |     {file = "atomicwrites-1.4.0.tar.gz", hash = "sha256:ae70396ad1a434f9c7046fd2dd196fc04b12f9e91ffb859164193be8b6168a7a"}, | ||||||
| ] | ] | ||||||
| attrs = [ | attrs = [ | ||||||
|     {file = "attrs-21.2.0-py2.py3-none-any.whl", hash = "sha256:149e90d6d8ac20db7a955ad60cf0e6881a3f20d37096140088356da6c716b0b1"}, |     {file = "attrs-21.4.0-py2.py3-none-any.whl", hash = "sha256:2d27e3784d7a565d36ab851fe94887c5eccd6a463168875832a1be79c82828b4"}, | ||||||
|     {file = "attrs-21.2.0.tar.gz", hash = "sha256:ef6aaac3ca6cd92904cdd0d83f629a15f18053ec84e6432106f7a4d04ae4f5fb"}, |     {file = "attrs-21.4.0.tar.gz", hash = "sha256:626ba8234211db98e869df76230a137c4c40a12d72445c45d5f5b716f076e2fd"}, | ||||||
| ] | ] | ||||||
| bandit = [ | bandit = [ | ||||||
|     {file = "bandit-1.7.1-py3-none-any.whl", hash = "sha256:f5acd838e59c038a159b5c621cf0f8270b279e884eadd7b782d7491c02add0d4"}, |     {file = "bandit-1.7.4-py3-none-any.whl", hash = "sha256:412d3f259dab4077d0e7f0c11f50f650cc7d10db905d98f6520a95a18049658a"}, | ||||||
|     {file = "bandit-1.7.1.tar.gz", hash = "sha256:a81b00b5436e6880fa8ad6799bc830e02032047713cbb143a12939ac67eb756c"}, |     {file = "bandit-1.7.4.tar.gz", hash = "sha256:2d63a8c573417bae338962d4b9b06fbc6080f74ecd955a092849e1e65c717bd2"}, | ||||||
| ] | ] | ||||||
| black = [ | black = [ | ||||||
|     {file = "black-21.12b0-py3-none-any.whl", hash = "sha256:a615e69ae185e08fdd73e4715e260e2479c861b5740057fde6e8b4e3b7dd589f"}, |     {file = "black-22.3.0-cp310-cp310-macosx_10_9_universal2.whl", hash = "sha256:2497f9c2386572e28921fa8bec7be3e51de6801f7459dffd6e62492531c47e09"}, | ||||||
|     {file = "black-21.12b0.tar.gz", hash = "sha256:77b80f693a569e2e527958459634f18df9b0ba2625ba4e0c2d5da5be42e6f2b3"}, |     {file = "black-22.3.0-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:5795a0375eb87bfe902e80e0c8cfaedf8af4d49694d69161e5bd3206c18618bb"}, | ||||||
|  |     {file = "black-22.3.0-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:e3556168e2e5c49629f7b0f377070240bd5511e45e25a4497bb0073d9dda776a"}, | ||||||
|  |     {file = "black-22.3.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:67c8301ec94e3bcc8906740fe071391bce40a862b7be0b86fb5382beefecd968"}, | ||||||
|  |     {file = "black-22.3.0-cp310-cp310-win_amd64.whl", hash = "sha256:fd57160949179ec517d32ac2ac898b5f20d68ed1a9c977346efbac9c2f1e779d"}, | ||||||
|  |     {file = "black-22.3.0-cp36-cp36m-macosx_10_9_x86_64.whl", hash = "sha256:cc1e1de68c8e5444e8f94c3670bb48a2beef0e91dddfd4fcc29595ebd90bb9ce"}, | ||||||
|  |     {file = "black-22.3.0-cp36-cp36m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:6d2fc92002d44746d3e7db7cf9313cf4452f43e9ea77a2c939defce3b10b5c82"}, | ||||||
|  |     {file = "black-22.3.0-cp36-cp36m-win_amd64.whl", hash = "sha256:a6342964b43a99dbc72f72812bf88cad8f0217ae9acb47c0d4f141a6416d2d7b"}, | ||||||
|  |     {file = "black-22.3.0-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:328efc0cc70ccb23429d6be184a15ce613f676bdfc85e5fe8ea2a9354b4e9015"}, | ||||||
|  |     {file = "black-22.3.0-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:06f9d8846f2340dfac80ceb20200ea5d1b3f181dd0556b47af4e8e0b24fa0a6b"}, | ||||||
|  |     {file = "black-22.3.0-cp37-cp37m-win_amd64.whl", hash = "sha256:ad4efa5fad66b903b4a5f96d91461d90b9507a812b3c5de657d544215bb7877a"}, | ||||||
|  |     {file = "black-22.3.0-cp38-cp38-macosx_10_9_universal2.whl", hash = "sha256:e8477ec6bbfe0312c128e74644ac8a02ca06bcdb8982d4ee06f209be28cdf163"}, | ||||||
|  |     {file = "black-22.3.0-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:637a4014c63fbf42a692d22b55d8ad6968a946b4a6ebc385c5505d9625b6a464"}, | ||||||
|  |     {file = "black-22.3.0-cp38-cp38-macosx_11_0_arm64.whl", hash = "sha256:863714200ada56cbc366dc9ae5291ceb936573155f8bf8e9de92aef51f3ad0f0"}, | ||||||
|  |     {file = "black-22.3.0-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:10dbe6e6d2988049b4655b2b739f98785a884d4d6b85bc35133a8fb9a2233176"}, | ||||||
|  |     {file = "black-22.3.0-cp38-cp38-win_amd64.whl", hash = "sha256:cee3e11161dde1b2a33a904b850b0899e0424cc331b7295f2a9698e79f9a69a0"}, | ||||||
|  |     {file = "black-22.3.0-cp39-cp39-macosx_10_9_universal2.whl", hash = "sha256:5891ef8abc06576985de8fa88e95ab70641de6c1fca97e2a15820a9b69e51b20"}, | ||||||
|  |     {file = "black-22.3.0-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:30d78ba6bf080eeaf0b7b875d924b15cd46fec5fd044ddfbad38c8ea9171043a"}, | ||||||
|  |     {file = "black-22.3.0-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:ee8f1f7228cce7dffc2b464f07ce769f478968bfb3dd1254a4c2eeed84928aad"}, | ||||||
|  |     {file = "black-22.3.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:6ee227b696ca60dd1c507be80a6bc849a5a6ab57ac7352aad1ffec9e8b805f21"}, | ||||||
|  |     {file = "black-22.3.0-cp39-cp39-win_amd64.whl", hash = "sha256:9b542ced1ec0ceeff5b37d69838106a6348e60db7b8fdd245294dc1d26136265"}, | ||||||
|  |     {file = "black-22.3.0-py3-none-any.whl", hash = "sha256:bc58025940a896d7e5356952228b68f793cf5fcb342be703c3a2669a1488cb72"}, | ||||||
|  |     {file = "black-22.3.0.tar.gz", hash = "sha256:35020b8886c022ced9282b51b5a875b6d1ab0c387b31a065b84db7c33085ca79"}, | ||||||
| ] | ] | ||||||
| cffi = [ | cffi = [ | ||||||
|     {file = "cffi-1.15.0-cp27-cp27m-macosx_10_9_x86_64.whl", hash = "sha256:c2502a1a03b6312837279c8c1bd3ebedf6c12c4228ddbad40912d671ccc8a962"}, |     {file = "cffi-1.15.0-cp27-cp27m-macosx_10_9_x86_64.whl", hash = "sha256:c2502a1a03b6312837279c8c1bd3ebedf6c12c4228ddbad40912d671ccc8a962"}, | ||||||
| @@ -700,39 +732,34 @@ cffi = [ | |||||||
|     {file = "cffi-1.15.0.tar.gz", hash = "sha256:920f0d66a896c2d99f0adbb391f990a84091179542c205fa53ce5787aff87954"}, |     {file = "cffi-1.15.0.tar.gz", hash = "sha256:920f0d66a896c2d99f0adbb391f990a84091179542c205fa53ce5787aff87954"}, | ||||||
| ] | ] | ||||||
| click = [ | click = [ | ||||||
|     {file = "click-8.0.3-py3-none-any.whl", hash = "sha256:353f466495adaeb40b6b5f592f9f91cb22372351c84caeb068132442a4518ef3"}, |     {file = "click-8.1.2-py3-none-any.whl", hash = "sha256:24e1a4a9ec5bf6299411369b208c1df2188d9eb8d916302fe6bf03faed227f1e"}, | ||||||
|     {file = "click-8.0.3.tar.gz", hash = "sha256:410e932b050f5eed773c4cda94de75971c89cdb3155a72a0831139a79e5ecb5b"}, |     {file = "click-8.1.2.tar.gz", hash = "sha256:479707fe14d9ec9a0757618b7a100a0ae4c4e236fac5b7f80ca68028141a1a72"}, | ||||||
| ] | ] | ||||||
| colorama = [ | colorama = [ | ||||||
|     {file = "colorama-0.4.4-py2.py3-none-any.whl", hash = "sha256:9f47eda37229f68eee03b24b9748937c7dc3868f906e8ba69fbcbdd3bc5dc3e2"}, |     {file = "colorama-0.4.4-py2.py3-none-any.whl", hash = "sha256:9f47eda37229f68eee03b24b9748937c7dc3868f906e8ba69fbcbdd3bc5dc3e2"}, | ||||||
|     {file = "colorama-0.4.4.tar.gz", hash = "sha256:5941b2b48a20143d2267e95b1c2a7603ce057ee39fd88e7329b0c292aa16869b"}, |     {file = "colorama-0.4.4.tar.gz", hash = "sha256:5941b2b48a20143d2267e95b1c2a7603ce057ee39fd88e7329b0c292aa16869b"}, | ||||||
| ] | ] | ||||||
| cryptography = [ | cryptography = [ | ||||||
|     {file = "cryptography-36.0.0-cp36-abi3-macosx_10_10_universal2.whl", hash = "sha256:9511416e85e449fe1de73f7f99b21b3aa04fba4c4d335d30c486ba3756e3a2a6"}, |     {file = "cryptography-36.0.2-cp36-abi3-macosx_10_10_universal2.whl", hash = "sha256:4e2dddd38a5ba733be6a025a1475a9f45e4e41139d1321f412c6b360b19070b6"}, | ||||||
|     {file = "cryptography-36.0.0-cp36-abi3-macosx_10_10_x86_64.whl", hash = "sha256:97199a13b772e74cdcdb03760c32109c808aff7cd49c29e9cf4b7754bb725d1d"}, |     {file = "cryptography-36.0.2-cp36-abi3-macosx_10_10_x86_64.whl", hash = "sha256:4881d09298cd0b669bb15b9cfe6166f16fc1277b4ed0d04a22f3d6430cb30f1d"}, | ||||||
|     {file = "cryptography-36.0.0-cp36-abi3-macosx_11_0_arm64.whl", hash = "sha256:494106e9cd945c2cadfce5374fa44c94cfadf01d4566a3b13bb487d2e6c7959e"}, |     {file = "cryptography-36.0.2-cp36-abi3-manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:ea634401ca02367c1567f012317502ef3437522e2fc44a3ea1844de028fa4b84"}, | ||||||
|     {file = "cryptography-36.0.0-cp36-abi3-manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:6fbbbb8aab4053fa018984bb0e95a16faeb051dd8cca15add2a27e267ba02b58"}, |     {file = "cryptography-36.0.2-cp36-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.manylinux_2_24_aarch64.whl", hash = "sha256:7be666cc4599b415f320839e36367b273db8501127b38316f3b9f22f17a0b815"}, | ||||||
|     {file = "cryptography-36.0.0-cp36-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.manylinux_2_24_aarch64.whl", hash = "sha256:684993ff6f67000a56454b41bdc7e015429732d65a52d06385b6e9de6181c71e"}, |     {file = "cryptography-36.0.2-cp36-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:8241cac0aae90b82d6b5c443b853723bcc66963970c67e56e71a2609dc4b5eaf"}, | ||||||
|     {file = "cryptography-36.0.0-cp36-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:4c702855cd3174666ef0d2d13dcc879090aa9c6c38f5578896407a7028f75b9f"}, |     {file = "cryptography-36.0.2-cp36-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:7b2d54e787a884ffc6e187262823b6feb06c338084bbe80d45166a1cb1c6c5bf"}, | ||||||
|     {file = "cryptography-36.0.0-cp36-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:d91bc9f535599bed58f6d2e21a2724cb0c3895bf41c6403fe881391d29096f1d"}, |     {file = "cryptography-36.0.2-cp36-abi3-manylinux_2_24_x86_64.whl", hash = "sha256:c2c5250ff0d36fd58550252f54915776940e4e866f38f3a7866d92b32a654b86"}, | ||||||
|     {file = "cryptography-36.0.0-cp36-abi3-manylinux_2_24_x86_64.whl", hash = "sha256:b17d83b3d1610e571fedac21b2eb36b816654d6f7496004d6a0d32f99d1d8120"}, |     {file = "cryptography-36.0.2-cp36-abi3-musllinux_1_1_aarch64.whl", hash = "sha256:ec6597aa85ce03f3e507566b8bcdf9da2227ec86c4266bd5e6ab4d9e0cc8dab2"}, | ||||||
|     {file = "cryptography-36.0.0-cp36-abi3-musllinux_1_1_aarch64.whl", hash = "sha256:8982c19bb90a4fa2aad3d635c6d71814e38b643649b4000a8419f8691f20ac44"}, |     {file = "cryptography-36.0.2-cp36-abi3-musllinux_1_1_x86_64.whl", hash = "sha256:ca9f686517ec2c4a4ce930207f75c00bf03d94e5063cbc00a1dc42531511b7eb"}, | ||||||
|     {file = "cryptography-36.0.0-cp36-abi3-musllinux_1_1_x86_64.whl", hash = "sha256:24469d9d33217ffd0ce4582dfcf2a76671af115663a95328f63c99ec7ece61a4"}, |     {file = "cryptography-36.0.2-cp36-abi3-win32.whl", hash = "sha256:f64b232348ee82f13aac22856515ce0195837f6968aeaa94a3d0353ea2ec06a6"}, | ||||||
|     {file = "cryptography-36.0.0-cp36-abi3-win32.whl", hash = "sha256:f6a5a85beb33e57998dc605b9dbe7deaa806385fdf5c4810fb849fcd04640c81"}, |     {file = "cryptography-36.0.2-cp36-abi3-win_amd64.whl", hash = "sha256:53e0285b49fd0ab6e604f4c5d9c5ddd98de77018542e88366923f152dbeb3c29"}, | ||||||
|     {file = "cryptography-36.0.0-cp36-abi3-win_amd64.whl", hash = "sha256:2deab5ec05d83ddcf9b0916319674d3dae88b0e7ee18f8962642d3cde0496568"}, |     {file = "cryptography-36.0.2-pp37-pypy37_pp73-manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:32db5cc49c73f39aac27574522cecd0a4bb7384e71198bc65a0d23f901e89bb7"}, | ||||||
|     {file = "cryptography-36.0.0-pp37-pypy37_pp73-manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:2049f8b87f449fc6190350de443ee0c1dd631f2ce4fa99efad2984de81031681"}, |     {file = "cryptography-36.0.2-pp37-pypy37_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:d2b3d199647468d410994dbeb8cec5816fb74feb9368aedf300af709ef507e3e"}, | ||||||
|     {file = "cryptography-36.0.0-pp37-pypy37_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:a776bae1629c8d7198396fd93ec0265f8dd2341c553dc32b976168aaf0e6a636"}, |     {file = "cryptography-36.0.2-pp37-pypy37_pp73-manylinux_2_24_x86_64.whl", hash = "sha256:da73d095f8590ad437cd5e9faf6628a218aa7c387e1fdf67b888b47ba56a17f0"}, | ||||||
|     {file = "cryptography-36.0.0-pp37-pypy37_pp73-manylinux_2_24_x86_64.whl", hash = "sha256:aa94d617a4cd4cdf4af9b5af65100c036bce22280ebb15d8b5262e8273ebc6ba"}, |     {file = "cryptography-36.0.2-pp38-pypy38_pp73-macosx_10_10_x86_64.whl", hash = "sha256:0a3bf09bb0b7a2c93ce7b98cb107e9170a90c51a0162a20af1c61c765b90e60b"}, | ||||||
|     {file = "cryptography-36.0.0-pp38-pypy38_pp73-macosx_10_10_x86_64.whl", hash = "sha256:5c49c9e8fb26a567a2b3fa0343c89f5d325447956cc2fc7231c943b29a973712"}, |     {file = "cryptography-36.0.2-pp38-pypy38_pp73-manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:8897b7b7ec077c819187a123174b645eb680c13df68354ed99f9b40a50898f77"}, | ||||||
|     {file = "cryptography-36.0.0-pp38-pypy38_pp73-manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:ef216d13ac8d24d9cd851776662f75f8d29c9f2d05cdcc2d34a18d32463a9b0b"}, |     {file = "cryptography-36.0.2-pp38-pypy38_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:82740818f2f240a5da8dfb8943b360e4f24022b093207160c77cadade47d7c85"}, | ||||||
|     {file = "cryptography-36.0.0-pp38-pypy38_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:231c4a69b11f6af79c1495a0e5a85909686ea8db946935224b7825cfb53827ed"}, |     {file = "cryptography-36.0.2-pp38-pypy38_pp73-manylinux_2_24_x86_64.whl", hash = "sha256:1f64a62b3b75e4005df19d3b5235abd43fa6358d5516cfc43d87aeba8d08dd51"}, | ||||||
|     {file = "cryptography-36.0.0-pp38-pypy38_pp73-manylinux_2_24_x86_64.whl", hash = "sha256:f92556f94e476c1b616e6daec5f7ddded2c082efa7cee7f31c7aeda615906ed8"}, |     {file = "cryptography-36.0.2-pp38-pypy38_pp73-win_amd64.whl", hash = "sha256:e167b6b710c7f7bc54e67ef593f8731e1f45aa35f8a8a7b72d6e42ec76afd4b3"}, | ||||||
|     {file = "cryptography-36.0.0-pp38-pypy38_pp73-win_amd64.whl", hash = "sha256:d73e3a96c38173e0aa5646c31bf8473bc3564837977dd480f5cbeacf1d7ef3a3"}, |     {file = "cryptography-36.0.2.tar.gz", hash = "sha256:70f8f4f7bb2ac9f340655cbac89d68c527af5bb4387522a8413e841e3e6628c9"}, | ||||||
|     {file = "cryptography-36.0.0.tar.gz", hash = "sha256:52f769ecb4ef39865719aedc67b4b7eae167bafa48dbc2a26dd36fa56460507f"}, |  | ||||||
| ] |  | ||||||
| ddlparse = [ |  | ||||||
|     {file = "ddlparse-1.10.0-py3-none-any.whl", hash = "sha256:71761b3457c8720853af3aeef266e2da1b6edef50936969492d586d7046a2ac2"}, |  | ||||||
|     {file = "ddlparse-1.10.0.tar.gz", hash = "sha256:6418681baa848eb01251ab79eb3d0ad7e140e6ab1deaae5a019353ddb3a908da"}, |  | ||||||
| ] | ] | ||||||
| dictdiffer = [ | dictdiffer = [ | ||||||
|     {file = "dictdiffer-0.9.0-py2.py3-none-any.whl", hash = "sha256:442bfc693cfcadaf46674575d2eba1c53b42f5e404218ca2c2ff549f2df56595"}, |     {file = "dictdiffer-0.9.0-py2.py3-none-any.whl", hash = "sha256:442bfc693cfcadaf46674575d2eba1c53b42f5e404218ca2c2ff549f2df56595"}, | ||||||
| @@ -751,8 +778,8 @@ gitdb = [ | |||||||
|     {file = "gitdb-4.0.9.tar.gz", hash = "sha256:bac2fd45c0a1c9cf619e63a90d62bdc63892ef92387424b855792a6cabe789aa"}, |     {file = "gitdb-4.0.9.tar.gz", hash = "sha256:bac2fd45c0a1c9cf619e63a90d62bdc63892ef92387424b855792a6cabe789aa"}, | ||||||
| ] | ] | ||||||
| gitpython = [ | gitpython = [ | ||||||
|     {file = "GitPython-3.1.24-py3-none-any.whl", hash = "sha256:dc0a7f2f697657acc8d7f89033e8b1ea94dd90356b2983bca89dc8d2ab3cc647"}, |     {file = "GitPython-3.1.27-py3-none-any.whl", hash = "sha256:5b68b000463593e05ff2b261acff0ff0972df8ab1b70d3cdbd41b546c8b8fc3d"}, | ||||||
|     {file = "GitPython-3.1.24.tar.gz", hash = "sha256:df83fdf5e684fef7c6ee2c02fc68a5ceb7e7e759d08b694088d0cacb4eba59e5"}, |     {file = "GitPython-3.1.27.tar.gz", hash = "sha256:1c885ce809e8ba2d88a29befeb385fcea06338d3640712b59ca623c220bb5704"}, | ||||||
| ] | ] | ||||||
| importlib-metadata = [ | importlib-metadata = [ | ||||||
|     {file = "importlib_metadata-4.2.0-py3-none-any.whl", hash = "sha256:057e92c15bc8d9e8109738a48db0ccb31b4d9d5cfbee5a8670879a30be66304b"}, |     {file = "importlib_metadata-4.2.0-py3-none-any.whl", hash = "sha256:057e92c15bc8d9e8109738a48db0ccb31b4d9d5cfbee5a8670879a30be66304b"}, | ||||||
| @@ -763,8 +790,8 @@ iniconfig = [ | |||||||
|     {file = "iniconfig-1.1.1.tar.gz", hash = "sha256:bc3af051d7d14b2ee5ef9969666def0cd1a000e121eaea580d4a313df4b37f32"}, |     {file = "iniconfig-1.1.1.tar.gz", hash = "sha256:bc3af051d7d14b2ee5ef9969666def0cd1a000e121eaea580d4a313df4b37f32"}, | ||||||
| ] | ] | ||||||
| iso8601 = [ | iso8601 = [ | ||||||
|     {file = "iso8601-0.1.16-py2.py3-none-any.whl", hash = "sha256:906714829fedbc89955d52806c903f2332e3948ed94e31e85037f9e0226b8376"}, |     {file = "iso8601-1.0.2-py3-none-any.whl", hash = "sha256:d7bc01b1c2a43b259570bb307f057abc578786ea734ba2b87b836c5efc5bd443"}, | ||||||
|     {file = "iso8601-0.1.16.tar.gz", hash = "sha256:36532f77cc800594e8f16641edae7f1baf7932f05d8e508545b95fc53c6dc85b"}, |     {file = "iso8601-1.0.2.tar.gz", hash = "sha256:27f503220e6845d9db954fb212b95b0362d8b7e6c1b2326a87061c3de93594b1"}, | ||||||
| ] | ] | ||||||
| isort = [ | isort = [ | ||||||
|     {file = "isort-5.10.1-py3-none-any.whl", hash = "sha256:6f62d78e2f89b4500b080fe3a81690850cd254227f27f75c3a0c491a1f351ba7"}, |     {file = "isort-5.10.1-py3-none-any.whl", hash = "sha256:6f62d78e2f89b4500b080fe3a81690850cd254227f27f75c3a0c491a1f351ba7"}, | ||||||
| @@ -787,12 +814,12 @@ pathspec = [ | |||||||
|     {file = "pathspec-0.9.0.tar.gz", hash = "sha256:e564499435a2673d586f6b2130bb5b95f04a3ba06f81b8f895b651a3c76aabb1"}, |     {file = "pathspec-0.9.0.tar.gz", hash = "sha256:e564499435a2673d586f6b2130bb5b95f04a3ba06f81b8f895b651a3c76aabb1"}, | ||||||
| ] | ] | ||||||
| pbr = [ | pbr = [ | ||||||
|     {file = "pbr-5.8.0-py2.py3-none-any.whl", hash = "sha256:176e8560eaf61e127817ef93d8a844803abb27a4d4637f0ff3bb783129be2e0a"}, |     {file = "pbr-5.8.1-py2.py3-none-any.whl", hash = "sha256:27108648368782d07bbf1cb468ad2e2eeef29086affd14087a6d04b7de8af4ec"}, | ||||||
|     {file = "pbr-5.8.0.tar.gz", hash = "sha256:672d8ebee84921862110f23fcec2acea191ef58543d34dfe9ef3d9f13c31cddf"}, |     {file = "pbr-5.8.1.tar.gz", hash = "sha256:66bc5a34912f408bb3925bf21231cb6f59206267b7f63f3503ef865c1a292e25"}, | ||||||
| ] | ] | ||||||
| platformdirs = [ | platformdirs = [ | ||||||
|     {file = "platformdirs-2.4.0-py3-none-any.whl", hash = "sha256:8868bbe3c3c80d42f20156f22e7131d2fb321f5bc86a2a345375c6481a67021d"}, |     {file = "platformdirs-2.5.1-py3-none-any.whl", hash = "sha256:bcae7cab893c2d310a711b70b24efb93334febe65f8de776ee320b517471e227"}, | ||||||
|     {file = "platformdirs-2.4.0.tar.gz", hash = "sha256:367a5e80b3d04d2428ffa76d33f124cf11e8fff2acdaa9b43d545f5c7d661ef2"}, |     {file = "platformdirs-2.5.1.tar.gz", hash = "sha256:7535e70dfa32e84d4b34996ea99c5e432fa29a708d0f4e394bbcb2a8faa4f16d"}, | ||||||
| ] | ] | ||||||
| pluggy = [ | pluggy = [ | ||||||
|     {file = "pluggy-1.0.0-py2.py3-none-any.whl", hash = "sha256:74134bbf457f031a36d68416e1509f34bd5ccc019f0bcc952c7b909d06b37bd3"}, |     {file = "pluggy-1.0.0-py2.py3-none-any.whl", hash = "sha256:74134bbf457f031a36d68416e1509f34bd5ccc019f0bcc952c7b909d06b37bd3"}, | ||||||
| @@ -810,41 +837,83 @@ pycparser = [ | |||||||
|     {file = "pycparser-2.21-py2.py3-none-any.whl", hash = "sha256:8ee45429555515e1f6b185e78100aea234072576aa43ab53aefcae078162fca9"}, |     {file = "pycparser-2.21-py2.py3-none-any.whl", hash = "sha256:8ee45429555515e1f6b185e78100aea234072576aa43ab53aefcae078162fca9"}, | ||||||
|     {file = "pycparser-2.21.tar.gz", hash = "sha256:e644fdec12f7872f86c58ff790da456218b10f863970249516d60a5eaca77206"}, |     {file = "pycparser-2.21.tar.gz", hash = "sha256:e644fdec12f7872f86c58ff790da456218b10f863970249516d60a5eaca77206"}, | ||||||
| ] | ] | ||||||
|  | pydantic = [ | ||||||
|  |     {file = "pydantic-1.9.0-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:cb23bcc093697cdea2708baae4f9ba0e972960a835af22560f6ae4e7e47d33f5"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:1d5278bd9f0eee04a44c712982343103bba63507480bfd2fc2790fa70cd64cf4"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:ab624700dc145aa809e6f3ec93fb8e7d0f99d9023b713f6a953637429b437d37"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp310-cp310-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:c8d7da6f1c1049eefb718d43d99ad73100c958a5367d30b9321b092771e96c25"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp310-cp310-musllinux_1_1_i686.whl", hash = "sha256:3c3b035103bd4e2e4a28da9da7ef2fa47b00ee4a9cf4f1a735214c1bcd05e0f6"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp310-cp310-musllinux_1_1_x86_64.whl", hash = "sha256:3011b975c973819883842c5ab925a4e4298dffccf7782c55ec3580ed17dc464c"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp310-cp310-win_amd64.whl", hash = "sha256:086254884d10d3ba16da0588604ffdc5aab3f7f09557b998373e885c690dd398"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp36-cp36m-macosx_10_9_x86_64.whl", hash = "sha256:0fe476769acaa7fcddd17cadd172b156b53546ec3614a4d880e5d29ea5fbce65"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp36-cp36m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:c8e9dcf1ac499679aceedac7e7ca6d8641f0193c591a2d090282aaf8e9445a46"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp36-cp36m-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:d1e4c28f30e767fd07f2ddc6f74f41f034d1dd6bc526cd59e63a82fe8bb9ef4c"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp36-cp36m-musllinux_1_1_i686.whl", hash = "sha256:c86229333cabaaa8c51cf971496f10318c4734cf7b641f08af0a6fbf17ca3054"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp36-cp36m-musllinux_1_1_x86_64.whl", hash = "sha256:c0727bda6e38144d464daec31dff936a82917f431d9c39c39c60a26567eae3ed"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp36-cp36m-win_amd64.whl", hash = "sha256:dee5ef83a76ac31ab0c78c10bd7d5437bfdb6358c95b91f1ba7ff7b76f9996a1"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:d9c9bdb3af48e242838f9f6e6127de9be7063aad17b32215ccc36a09c5cf1070"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:2ee7e3209db1e468341ef41fe263eb655f67f5c5a76c924044314e139a1103a2"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp37-cp37m-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:0b6037175234850ffd094ca77bf60fb54b08b5b22bc85865331dd3bda7a02fa1"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp37-cp37m-musllinux_1_1_i686.whl", hash = "sha256:b2571db88c636d862b35090ccf92bf24004393f85c8870a37f42d9f23d13e032"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp37-cp37m-musllinux_1_1_x86_64.whl", hash = "sha256:8b5ac0f1c83d31b324e57a273da59197c83d1bb18171e512908fe5dc7278a1d6"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp37-cp37m-win_amd64.whl", hash = "sha256:bbbc94d0c94dd80b3340fc4f04fd4d701f4b038ebad72c39693c794fd3bc2d9d"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:e0896200b6a40197405af18828da49f067c2fa1f821491bc8f5bde241ef3f7d7"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp38-cp38-macosx_11_0_arm64.whl", hash = "sha256:7bdfdadb5994b44bd5579cfa7c9b0e1b0e540c952d56f627eb227851cda9db77"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:574936363cd4b9eed8acdd6b80d0143162f2eb654d96cb3a8ee91d3e64bf4cf9"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp38-cp38-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:c556695b699f648c58373b542534308922c46a1cda06ea47bc9ca45ef5b39ae6"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp38-cp38-musllinux_1_1_i686.whl", hash = "sha256:f947352c3434e8b937e3aa8f96f47bdfe6d92779e44bb3f41e4c213ba6a32145"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp38-cp38-musllinux_1_1_x86_64.whl", hash = "sha256:5e48ef4a8b8c066c4a31409d91d7ca372a774d0212da2787c0d32f8045b1e034"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp38-cp38-win_amd64.whl", hash = "sha256:96f240bce182ca7fe045c76bcebfa0b0534a1bf402ed05914a6f1dadff91877f"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:815ddebb2792efd4bba5488bc8fde09c29e8ca3227d27cf1c6990fc830fd292b"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:6c5b77947b9e85a54848343928b597b4f74fc364b70926b3c4441ff52620640c"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl", hash = "sha256:4c68c3bc88dbda2a6805e9a142ce84782d3930f8fdd9655430d8576315ad97ce"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp39-cp39-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl", hash = "sha256:5a79330f8571faf71bf93667d3ee054609816f10a259a109a0738dac983b23c3"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp39-cp39-musllinux_1_1_i686.whl", hash = "sha256:f5a64b64ddf4c99fe201ac2724daada8595ada0d102ab96d019c1555c2d6441d"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp39-cp39-musllinux_1_1_x86_64.whl", hash = "sha256:a733965f1a2b4090a5238d40d983dcd78f3ecea221c7af1497b845a9709c1721"}, | ||||||
|  |     {file = "pydantic-1.9.0-cp39-cp39-win_amd64.whl", hash = "sha256:2cc6a4cb8a118ffec2ca5fcb47afbacb4f16d0ab8b7350ddea5e8ef7bcc53a16"}, | ||||||
|  |     {file = "pydantic-1.9.0-py3-none-any.whl", hash = "sha256:085ca1de245782e9b46cefcf99deecc67d418737a1fd3f6a4f511344b613a5b3"}, | ||||||
|  |     {file = "pydantic-1.9.0.tar.gz", hash = "sha256:742645059757a56ecd886faf4ed2441b9c0cd406079c2b4bee51bcc3fbcd510a"}, | ||||||
|  | ] | ||||||
| pyflakes = [ | pyflakes = [ | ||||||
|     {file = "pyflakes-2.4.0-py2.py3-none-any.whl", hash = "sha256:3bb3a3f256f4b7968c9c788781e4ff07dce46bdf12339dcda61053375426ee2e"}, |     {file = "pyflakes-2.4.0-py2.py3-none-any.whl", hash = "sha256:3bb3a3f256f4b7968c9c788781e4ff07dce46bdf12339dcda61053375426ee2e"}, | ||||||
|     {file = "pyflakes-2.4.0.tar.gz", hash = "sha256:05a85c2872edf37a4ed30b0cce2f6093e1d0581f8c19d7393122da7e25b2b24c"}, |     {file = "pyflakes-2.4.0.tar.gz", hash = "sha256:05a85c2872edf37a4ed30b0cce2f6093e1d0581f8c19d7393122da7e25b2b24c"}, | ||||||
| ] | ] | ||||||
| pyparsing = [ | pyparsing = [ | ||||||
|     {file = "pyparsing-3.0.6-py3-none-any.whl", hash = "sha256:04ff808a5b90911829c55c4e26f75fa5ca8a2f5f36aa3a51f68e27033341d3e4"}, |     {file = "pyparsing-3.0.7-py3-none-any.whl", hash = "sha256:a6c06a88f252e6c322f65faf8f418b16213b51bdfaece0524c1c1bc30c63c484"}, | ||||||
|     {file = "pyparsing-3.0.6.tar.gz", hash = "sha256:d9bdec0013ef1eb5a84ab39a3b3868911598afa494f5faa038647101504e2b81"}, |     {file = "pyparsing-3.0.7.tar.gz", hash = "sha256:18ee9022775d270c55187733956460083db60b37d0d0fb357445f3094eed3eea"}, | ||||||
| ] | ] | ||||||
| pypika-tortoise = [ | pypika-tortoise = [ | ||||||
|     {file = "pypika-tortoise-0.1.1.tar.gz", hash = "sha256:6831d0a56e5e0ecefac3307dd9bdb3e5073fdac5d617401601d3a6713e059f3c"}, |     {file = "pypika-tortoise-0.1.4.tar.gz", hash = "sha256:f4b4e6c72fc13f49058181928e66930b59fee988823c8fd01498f95e2ff788ca"}, | ||||||
|     {file = "pypika_tortoise-0.1.1-py3-none-any.whl", hash = "sha256:860020094e01058ea80602c90d4a843d0a42cffefcf4f3cb1a7f2c18b880c638"}, |     {file = "pypika_tortoise-0.1.4-py3-none-any.whl", hash = "sha256:bdc7e63c88791679a8b3f0b008582b6d3fcd21830650d274db35a7012e7b8bcd"}, | ||||||
|  | ] | ||||||
|  | pyproject-flake8 = [ | ||||||
|  |     {file = "pyproject-flake8-0.0.1a3.tar.gz", hash = "sha256:4e3e704c639e61d9ab75aadf44dbf31a07281035896ad7d725ed7f386fd79674"}, | ||||||
|  |     {file = "pyproject_flake8-0.0.1a3-py2.py3-none-any.whl", hash = "sha256:1f434780791df82e9ca2358f4c542a2b2fdd3a77e666a6ad3f60a6a1464da4e2"}, | ||||||
| ] | ] | ||||||
| pytest = [ | pytest = [ | ||||||
|     {file = "pytest-6.2.5-py3-none-any.whl", hash = "sha256:7310f8d27bc79ced999e760ca304d69f6ba6c6649c0b60fb0e04a4a77cacc134"}, |     {file = "pytest-7.1.1-py3-none-any.whl", hash = "sha256:92f723789a8fdd7180b6b06483874feca4c48a5c76968e03bb3e7f806a1869ea"}, | ||||||
|     {file = "pytest-6.2.5.tar.gz", hash = "sha256:131b36680866a76e6781d13f101efb86cf674ebb9762eb70d3082b6f29889e89"}, |     {file = "pytest-7.1.1.tar.gz", hash = "sha256:841132caef6b1ad17a9afde46dc4f6cfa59a05f9555aae5151f73bdf2820ca63"}, | ||||||
| ] | ] | ||||||
| pytest-asyncio = [ | pytest-asyncio = [ | ||||||
|     {file = "pytest-asyncio-0.16.0.tar.gz", hash = "sha256:7496c5977ce88c34379df64a66459fe395cd05543f0a2f837016e7144391fcfb"}, |     {file = "pytest-asyncio-0.18.3.tar.gz", hash = "sha256:7659bdb0a9eb9c6e3ef992eef11a2b3e69697800ad02fb06374a210d85b29f91"}, | ||||||
|     {file = "pytest_asyncio-0.16.0-py3-none-any.whl", hash = "sha256:5f2a21273c47b331ae6aa5b36087047b4899e40f03f18397c0e65fa5cca54e9b"}, |     {file = "pytest_asyncio-0.18.3-1-py3-none-any.whl", hash = "sha256:16cf40bdf2b4fb7fc8e4b82bd05ce3fbcd454cbf7b92afc445fe299dabb88213"}, | ||||||
|  |     {file = "pytest_asyncio-0.18.3-py3-none-any.whl", hash = "sha256:8fafa6c52161addfd41ee7ab35f11836c5a16ec208f93ee388f752bea3493a84"}, | ||||||
| ] | ] | ||||||
| pytest-forked = [ | pytest-forked = [ | ||||||
|     {file = "pytest-forked-1.3.0.tar.gz", hash = "sha256:6aa9ac7e00ad1a539c41bec6d21011332de671e938c7637378ec9710204e37ca"}, |     {file = "pytest-forked-1.4.0.tar.gz", hash = "sha256:8b67587c8f98cbbadfdd804539ed5455b6ed03802203485dd2f53c1422d7440e"}, | ||||||
|     {file = "pytest_forked-1.3.0-py2.py3-none-any.whl", hash = "sha256:dc4147784048e70ef5d437951728825a131b81714b398d5d52f17c7c144d8815"}, |     {file = "pytest_forked-1.4.0-py3-none-any.whl", hash = "sha256:bbbb6717efc886b9d64537b41fb1497cfaf3c9601276be8da2cccfea5a3c8ad8"}, | ||||||
| ] | ] | ||||||
| pytest-mock = [ | pytest-mock = [ | ||||||
|     {file = "pytest-mock-3.6.1.tar.gz", hash = "sha256:40217a058c52a63f1042f0784f62009e976ba824c418cced42e88d5f40ab0e62"}, |     {file = "pytest-mock-3.7.0.tar.gz", hash = "sha256:5112bd92cc9f186ee96e1a92efc84969ea494939c3aead39c50f421c4cc69534"}, | ||||||
|     {file = "pytest_mock-3.6.1-py3-none-any.whl", hash = "sha256:30c2f2cc9759e76eee674b81ea28c9f0b94f8f0445a1b87762cadf774f0df7e3"}, |     {file = "pytest_mock-3.7.0-py3-none-any.whl", hash = "sha256:6cff27cec936bf81dc5ee87f07132b807bcda51106b5ec4b90a04331cba76231"}, | ||||||
| ] | ] | ||||||
| pytest-xdist = [ | pytest-xdist = [ | ||||||
|     {file = "pytest-xdist-2.4.0.tar.gz", hash = "sha256:89b330316f7fc475f999c81b577c2b926c9569f3d397ae432c0c2e2496d61ff9"}, |     {file = "pytest-xdist-2.5.0.tar.gz", hash = "sha256:4580deca3ff04ddb2ac53eba39d76cb5dd5edeac050cb6fbc768b0dd712b4edf"}, | ||||||
|     {file = "pytest_xdist-2.4.0-py3-none-any.whl", hash = "sha256:7b61ebb46997a0820a263553179d6d1e25a8c50d8a8620cd1aa1e20e3be99168"}, |     {file = "pytest_xdist-2.5.0-py3-none-any.whl", hash = "sha256:6fe5c74fec98906deb8f2d2b616b5c782022744978e7bd4695d39c8f42d0ce65"}, | ||||||
| ] | ] | ||||||
| pytz = [ | pytz = [ | ||||||
|     {file = "pytz-2021.3-py2.py3-none-any.whl", hash = "sha256:3672058bc3453457b622aab7a1c3bfd5ab0bdae451512f6cf25f64ed37f5b87c"}, |     {file = "pytz-2022.1-py2.py3-none-any.whl", hash = "sha256:e68985985296d9a66a881eb3193b0906246245294a881e7c8afe623866ac6a5c"}, | ||||||
|     {file = "pytz-2021.3.tar.gz", hash = "sha256:acad2d8b20a1af07d4e4c9d2e9285c5ed9104354062f275f3fcd88dcef4f1326"}, |     {file = "pytz-2022.1.tar.gz", hash = "sha256:1e760e2fe6a8163bc0b3d9a19c4f84342afa0a2affebfaa84b01b978a02ecaa7"}, | ||||||
| ] | ] | ||||||
| pyyaml = [ | pyyaml = [ | ||||||
|     {file = "PyYAML-6.0-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:d4db7c7aef085872ef65a8fd7d6d09a14ae91f691dec3e87ee5ee0539d516f53"}, |     {file = "PyYAML-6.0-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:d4db7c7aef085872ef65a8fd7d6d09a14ae91f691dec3e87ee5ee0539d516f53"}, | ||||||
| @@ -889,48 +958,49 @@ stevedore = [ | |||||||
|     {file = "stevedore-3.5.0-py3-none-any.whl", hash = "sha256:a547de73308fd7e90075bb4d301405bebf705292fa90a90fc3bcf9133f58616c"}, |     {file = "stevedore-3.5.0-py3-none-any.whl", hash = "sha256:a547de73308fd7e90075bb4d301405bebf705292fa90a90fc3bcf9133f58616c"}, | ||||||
|     {file = "stevedore-3.5.0.tar.gz", hash = "sha256:f40253887d8712eaa2bb0ea3830374416736dc8ec0e22f5a65092c1174c44335"}, |     {file = "stevedore-3.5.0.tar.gz", hash = "sha256:f40253887d8712eaa2bb0ea3830374416736dc8ec0e22f5a65092c1174c44335"}, | ||||||
| ] | ] | ||||||
| toml = [ |  | ||||||
|     {file = "toml-0.10.2-py2.py3-none-any.whl", hash = "sha256:806143ae5bfb6a3c6e736a764057db0e6a0e05e338b5630894a5f779cabb4f9b"}, |  | ||||||
|     {file = "toml-0.10.2.tar.gz", hash = "sha256:b3bda1d108d5dd99f4a20d24d9c348e91c4db7ab1b749200bded2f839ccbe68f"}, |  | ||||||
| ] |  | ||||||
| tomli = [ | tomli = [ | ||||||
|     {file = "tomli-1.2.2-py3-none-any.whl", hash = "sha256:f04066f68f5554911363063a30b108d2b5a5b1a010aa8b6132af78489fe3aade"}, |     {file = "tomli-2.0.1-py3-none-any.whl", hash = "sha256:939de3e7a6161af0c887ef91b7d41a53e7c5a1ca976325f429cb46ea9bc30ecc"}, | ||||||
|     {file = "tomli-1.2.2.tar.gz", hash = "sha256:c6ce0015eb38820eaf32b5db832dbc26deb3dd427bd5f6556cf0acac2c214fee"}, |     {file = "tomli-2.0.1.tar.gz", hash = "sha256:de526c12914f0c550d15924c62d72abc48d6fe7364aa87328337a31007fe8a4f"}, | ||||||
| ] | ] | ||||||
| tomlkit = [ | tomlkit = [ | ||||||
|     {file = "tomlkit-0.7.2-py2.py3-none-any.whl", hash = "sha256:173ad840fa5d2aac140528ca1933c29791b79a374a0861a80347f42ec9328117"}, |     {file = "tomlkit-0.10.1-py3-none-any.whl", hash = "sha256:3eba517439dcb2f84cf39f4f85fd2c3398309823a3c75ac3e73003638daf7915"}, | ||||||
|     {file = "tomlkit-0.7.2.tar.gz", hash = "sha256:d7a454f319a7e9bd2e249f239168729327e4dd2d27b17dc68be264ad1ce36754"}, |     {file = "tomlkit-0.10.1.tar.gz", hash = "sha256:3c517894eadef53e9072d343d37e4427b8f0b6200a70b7c9a19b2ebd1f53b951"}, | ||||||
| ] | ] | ||||||
| tortoise-orm = [ | tortoise-orm = [ | ||||||
|     {file = "tortoise-orm-0.17.8.tar.gz", hash = "sha256:1f5020e9964d32a4d6ed685d466b5d7285de328a63ee92ee988c1e4baf8fefbf"}, |     {file = "tortoise-orm-0.19.0.tar.gz", hash = "sha256:ad9f0c59ec2ed889c77b58857125038561cbe3846438cf20d39a7919ea62aecb"}, | ||||||
|     {file = "tortoise_orm-0.17.8-py3-none-any.whl", hash = "sha256:f18c41bb83be4748a6ca259ed7309ca954b35f5790971824bbc79a11d2b1ef3b"}, |     {file = "tortoise_orm-0.19.0-py3-none-any.whl", hash = "sha256:c2a8be9f8906577d47e03fcc11ce3ee9b8bd9302b29954bf1e319428b487daab"}, | ||||||
| ] | ] | ||||||
| typed-ast = [ | typed-ast = [ | ||||||
|     {file = "typed_ast-1.5.1-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:5d8314c92414ce7481eee7ad42b353943679cf6f30237b5ecbf7d835519e1212"}, |     {file = "typed_ast-1.5.2-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:183b183b7771a508395d2cbffd6db67d6ad52958a5fdc99f450d954003900266"}, | ||||||
|     {file = "typed_ast-1.5.1-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:b53ae5de5500529c76225d18eeb060efbcec90ad5e030713fe8dab0fb4531631"}, |     {file = "typed_ast-1.5.2-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:676d051b1da67a852c0447621fdd11c4e104827417bf216092ec3e286f7da596"}, | ||||||
|     {file = "typed_ast-1.5.1-cp310-cp310-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:24058827d8f5d633f97223f5148a7d22628099a3d2efe06654ce872f46f07cdb"}, |     {file = "typed_ast-1.5.2-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:bc2542e83ac8399752bc16e0b35e038bdb659ba237f4222616b4e83fb9654985"}, | ||||||
|     {file = "typed_ast-1.5.1-cp310-cp310-win_amd64.whl", hash = "sha256:a6d495c1ef572519a7bac9534dbf6d94c40e5b6a608ef41136133377bba4aa08"}, |     {file = "typed_ast-1.5.2-cp310-cp310-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:74cac86cc586db8dfda0ce65d8bcd2bf17b58668dfcc3652762f3ef0e6677e76"}, | ||||||
|     {file = "typed_ast-1.5.1-cp36-cp36m-macosx_10_9_x86_64.whl", hash = "sha256:de4ecae89c7d8b56169473e08f6bfd2df7f95015591f43126e4ea7865928677e"}, |     {file = "typed_ast-1.5.2-cp310-cp310-win_amd64.whl", hash = "sha256:18fe320f354d6f9ad3147859b6e16649a0781425268c4dde596093177660e71a"}, | ||||||
|     {file = "typed_ast-1.5.1-cp36-cp36m-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:256115a5bc7ea9e665c6314ed6671ee2c08ca380f9d5f130bd4d2c1f5848d695"}, |     {file = "typed_ast-1.5.2-cp36-cp36m-macosx_10_9_x86_64.whl", hash = "sha256:31d8c6b2df19a777bc8826770b872a45a1f30cfefcfd729491baa5237faae837"}, | ||||||
|     {file = "typed_ast-1.5.1-cp36-cp36m-win_amd64.whl", hash = "sha256:7c42707ab981b6cf4b73490c16e9d17fcd5227039720ca14abe415d39a173a30"}, |     {file = "typed_ast-1.5.2-cp36-cp36m-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:963a0ccc9a4188524e6e6d39b12c9ca24cc2d45a71cfdd04a26d883c922b4b78"}, | ||||||
|     {file = "typed_ast-1.5.1-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:71dcda943a471d826ea930dd449ac7e76db7be778fcd722deb63642bab32ea3f"}, |     {file = "typed_ast-1.5.2-cp36-cp36m-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:0eb77764ea470f14fcbb89d51bc6bbf5e7623446ac4ed06cbd9ca9495b62e36e"}, | ||||||
|     {file = "typed_ast-1.5.1-cp37-cp37m-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:4f30a2bcd8e68adbb791ce1567fdb897357506f7ea6716f6bbdd3053ac4d9471"}, |     {file = "typed_ast-1.5.2-cp36-cp36m-win_amd64.whl", hash = "sha256:294a6903a4d087db805a7656989f613371915fc45c8cc0ddc5c5a0a8ad9bea4d"}, | ||||||
|     {file = "typed_ast-1.5.1-cp37-cp37m-win_amd64.whl", hash = "sha256:ca9e8300d8ba0b66d140820cf463438c8e7b4cdc6fd710c059bfcfb1531d03fb"}, |     {file = "typed_ast-1.5.2-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:26a432dc219c6b6f38be20a958cbe1abffcc5492821d7e27f08606ef99e0dffd"}, | ||||||
|     {file = "typed_ast-1.5.1-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:9caaf2b440efb39ecbc45e2fabde809cbe56272719131a6318fd9bf08b58e2cb"}, |     {file = "typed_ast-1.5.2-cp37-cp37m-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:c7407cfcad702f0b6c0e0f3e7ab876cd1d2c13b14ce770e412c0c4b9728a0f88"}, | ||||||
|     {file = "typed_ast-1.5.1-cp38-cp38-macosx_11_0_arm64.whl", hash = "sha256:c9bcad65d66d594bffab8575f39420fe0ee96f66e23c4d927ebb4e24354ec1af"}, |     {file = "typed_ast-1.5.2-cp37-cp37m-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:f30ddd110634c2d7534b2d4e0e22967e88366b0d356b24de87419cc4410c41b7"}, | ||||||
|     {file = "typed_ast-1.5.1-cp38-cp38-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:591bc04e507595887160ed7aa8d6785867fb86c5793911be79ccede61ae96f4d"}, |     {file = "typed_ast-1.5.2-cp37-cp37m-win_amd64.whl", hash = "sha256:8c08d6625bb258179b6e512f55ad20f9dfef019bbfbe3095247401e053a3ea30"}, | ||||||
|     {file = "typed_ast-1.5.1-cp38-cp38-win_amd64.whl", hash = "sha256:a80d84f535642420dd17e16ae25bb46c7f4c16ee231105e7f3eb43976a89670a"}, |     {file = "typed_ast-1.5.2-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:90904d889ab8e81a956f2c0935a523cc4e077c7847a836abee832f868d5c26a4"}, | ||||||
|     {file = "typed_ast-1.5.1-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:38cf5c642fa808300bae1281460d4f9b7617cf864d4e383054a5ef336e344d32"}, |     {file = "typed_ast-1.5.2-cp38-cp38-macosx_11_0_arm64.whl", hash = "sha256:bbebc31bf11762b63bf61aaae232becb41c5bf6b3461b80a4df7e791fabb3aca"}, | ||||||
|     {file = "typed_ast-1.5.1-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:5b6ab14c56bc9c7e3c30228a0a0b54b915b1579613f6e463ba6f4eb1382e7fd4"}, |     {file = "typed_ast-1.5.2-cp38-cp38-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:c29dd9a3a9d259c9fa19d19738d021632d673f6ed9b35a739f48e5f807f264fb"}, | ||||||
|     {file = "typed_ast-1.5.1-cp39-cp39-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:a2b8d7007f6280e36fa42652df47087ac7b0a7d7f09f9468f07792ba646aac2d"}, |     {file = "typed_ast-1.5.2-cp38-cp38-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:58ae097a325e9bb7a684572d20eb3e1809802c5c9ec7108e85da1eb6c1a3331b"}, | ||||||
|     {file = "typed_ast-1.5.1-cp39-cp39-win_amd64.whl", hash = "sha256:b6d17f37f6edd879141e64a5db17b67488cfeffeedad8c5cec0392305e9bc775"}, |     {file = "typed_ast-1.5.2-cp38-cp38-win_amd64.whl", hash = "sha256:da0a98d458010bf4fe535f2d1e367a2e2060e105978873c04c04212fb20543f7"}, | ||||||
|     {file = "typed_ast-1.5.1.tar.gz", hash = "sha256:484137cab8ecf47e137260daa20bafbba5f4e3ec7fda1c1e69ab299b75fa81c5"}, |     {file = "typed_ast-1.5.2-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:33b4a19ddc9fc551ebabca9765d54d04600c4a50eda13893dadf67ed81d9a098"}, | ||||||
|  |     {file = "typed_ast-1.5.2-cp39-cp39-macosx_11_0_arm64.whl", hash = "sha256:1098df9a0592dd4c8c0ccfc2e98931278a6c6c53cb3a3e2cf7e9ee3b06153344"}, | ||||||
|  |     {file = "typed_ast-1.5.2-cp39-cp39-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:42c47c3b43fe3a39ddf8de1d40dbbfca60ac8530a36c9b198ea5b9efac75c09e"}, | ||||||
|  |     {file = "typed_ast-1.5.2-cp39-cp39-manylinux_2_5_x86_64.manylinux1_x86_64.manylinux_2_12_x86_64.manylinux2010_x86_64.whl", hash = "sha256:f290617f74a610849bd8f5514e34ae3d09eafd521dceaa6cf68b3f4414266d4e"}, | ||||||
|  |     {file = "typed_ast-1.5.2-cp39-cp39-win_amd64.whl", hash = "sha256:df05aa5b241e2e8045f5f4367a9f6187b09c4cdf8578bb219861c4e27c443db5"}, | ||||||
|  |     {file = "typed_ast-1.5.2.tar.gz", hash = "sha256:525a2d4088e70a9f75b08b3f87a51acc9cde640e19cc523c7e41aa355564ae27"}, | ||||||
| ] | ] | ||||||
| typing-extensions = [ | typing-extensions = [ | ||||||
|     {file = "typing_extensions-4.0.1-py3-none-any.whl", hash = "sha256:7f001e5ac290a0c0401508864c7ec868be4e701886d5b573a9528ed3973d9d3b"}, |     {file = "typing_extensions-4.1.1-py3-none-any.whl", hash = "sha256:21c85e0fe4b9a155d0799430b0ad741cdce7e359660ccbd8b530613e8df88ce2"}, | ||||||
|     {file = "typing_extensions-4.0.1.tar.gz", hash = "sha256:4ca091dea149f945ec56afb48dae714f21e8692ef22a395223bcd328961b6a0e"}, |     {file = "typing_extensions-4.1.1.tar.gz", hash = "sha256:1a9462dcc3347a79b1f1c0271fbe79e844580bb598bafa1ed208b94da3cdcd42"}, | ||||||
| ] | ] | ||||||
| zipp = [ | zipp = [ | ||||||
|     {file = "zipp-3.6.0-py3-none-any.whl", hash = "sha256:9fe5ea21568a0a70e50f273397638d39b03353731e6cbbb3fd8502a33fec40bc"}, |     {file = "zipp-3.7.0-py3-none-any.whl", hash = "sha256:b47250dd24f92b7dd6a0a8fc5244da14608f3ca90a5efcd37a3b1642fac9a375"}, | ||||||
|     {file = "zipp-3.6.0.tar.gz", hash = "sha256:71c644c5369f4a6e07636f0aa966270449561fcea2e3d6747b8d23efaa9d7832"}, |     {file = "zipp-3.7.0.tar.gz", hash = "sha256:9f50f446828eb9d45b267433fd3e9da8d801f614129124863f9c51ebceafb87d"}, | ||||||
| ] | ] | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| [tool.poetry] | [tool.poetry] | ||||||
| name = "aerich" | name = "aerich" | ||||||
| version = "0.6.1" | version = "0.6.3" | ||||||
| description = "A database migrations tool for Tortoise ORM." | description = "A database migrations tool for Tortoise ORM." | ||||||
| authors = ["long2ice <long2ice@gmail.com>"] | authors = ["long2ice <long2ice@gmail.com>"] | ||||||
| license = "Apache-2.0" | license = "Apache-2.0" | ||||||
| @@ -16,11 +16,11 @@ include = ["CHANGELOG.md", "LICENSE", "README.md"] | |||||||
|  |  | ||||||
| [tool.poetry.dependencies] | [tool.poetry.dependencies] | ||||||
| python = "^3.7" | python = "^3.7" | ||||||
| tortoise-orm = "^0.17.7" | tortoise-orm = "*" | ||||||
| click = "*" | click = "*" | ||||||
| asyncpg = { version = "*", optional = true } | asyncpg = { version = "*", optional = true } | ||||||
| asyncmy = { version = "*", optional = true } | asyncmy = { version = "*", optional = true } | ||||||
| ddlparse = "*" | pydantic = "*" | ||||||
| dictdiffer = "*" | dictdiffer = "*" | ||||||
| tomlkit = "*" | tomlkit = "*" | ||||||
|  |  | ||||||
| @@ -34,14 +34,34 @@ pytest-asyncio = "*" | |||||||
| bandit = "*" | bandit = "*" | ||||||
| pytest-mock = "*" | pytest-mock = "*" | ||||||
| cryptography = "*" | cryptography = "*" | ||||||
|  | pyproject-flake8 = "*" | ||||||
|  |  | ||||||
| [tool.poetry.extras] | [tool.poetry.extras] | ||||||
| asyncmy = ["asyncmy"] | asyncmy = ["asyncmy"] | ||||||
| asyncpg = ["asyncpg"] | asyncpg = ["asyncpg"] | ||||||
|  |  | ||||||
|  | [tool.aerich] | ||||||
|  | tortoise_orm = "conftest.tortoise_orm" | ||||||
|  | location = "./migrations" | ||||||
|  | src_folder = "./." | ||||||
|  |  | ||||||
| [build-system] | [build-system] | ||||||
| requires = ["poetry>=0.12"] | requires = ["poetry>=0.12"] | ||||||
| build-backend = "poetry.masonry.api" | build-backend = "poetry.masonry.api" | ||||||
|  |  | ||||||
| [tool.poetry.scripts] | [tool.poetry.scripts] | ||||||
| aerich = "aerich.cli:main" | aerich = "aerich.cli:main" | ||||||
|  |  | ||||||
|  | [tool.black] | ||||||
|  | line-length = 100 | ||||||
|  | target-version = ['py36', 'py37', 'py38', 'py39'] | ||||||
|  |  | ||||||
|  | [tool.pytest.ini_options] | ||||||
|  | asyncio_mode = 'auto' | ||||||
|  |  | ||||||
|  | [tool.mypy] | ||||||
|  | pretty = true | ||||||
|  | ignore_missing_imports = true | ||||||
|  |  | ||||||
|  | [tool.flake8] | ||||||
|  | ignore = 'E501,W503,E203' | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user