Compare commits
	
		
			5 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 922e3eef16 | ||
|  | 44fd2fe6ae | ||
|  | b147859960 | ||
|  | 793cf2532c | ||
|  | fa85e05d1d | 
							
								
								
									
										1
									
								
								.github/FUNDING.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								.github/FUNDING.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | custom: ["https://sponsor.long2ice.cn"] | ||||||
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -146,3 +146,4 @@ aerich.ini | |||||||
| src | src | ||||||
| .vscode | .vscode | ||||||
| .DS_Store | .DS_Store | ||||||
|  | .python-version | ||||||
| @@ -2,6 +2,11 @@ | |||||||
|  |  | ||||||
| ## 0.5 | ## 0.5 | ||||||
|  |  | ||||||
|  | ### 0.5.3 | ||||||
|  |  | ||||||
|  | - Fix postgre alter null. (#142) | ||||||
|  | - Fix default function when migrate. (#147) | ||||||
|  |  | ||||||
| ### 0.5.2 | ### 0.5.2 | ||||||
|  |  | ||||||
| - Fix rename field on the field add. (#134) | - Fix rename field on the field add. (#134) | ||||||
|   | |||||||
| @@ -1 +1 @@ | |||||||
| __version__ = "0.5.2" | __version__ = "0.5.3" | ||||||
|   | |||||||
| @@ -49,11 +49,7 @@ def coro(f): | |||||||
| @click.group(context_settings={"help_option_names": ["-h", "--help"]}) | @click.group(context_settings={"help_option_names": ["-h", "--help"]}) | ||||||
| @click.version_option(__version__, "-V", "--version") | @click.version_option(__version__, "-V", "--version") | ||||||
| @click.option( | @click.option( | ||||||
|     "-c", |     "-c", "--config", default="aerich.ini", show_default=True, help="Config file.", | ||||||
|     "--config", |  | ||||||
|     default="aerich.ini", |  | ||||||
|     show_default=True, |  | ||||||
|     help="Config file.", |  | ||||||
| ) | ) | ||||||
| @click.option("--app", required=False, help="Tortoise-ORM app name.") | @click.option("--app", required=False, help="Tortoise-ORM app name.") | ||||||
| @click.option( | @click.option( | ||||||
| @@ -122,9 +118,7 @@ async def upgrade(ctx: Context): | |||||||
|                 for upgrade_query in upgrade_query_list: |                 for upgrade_query in upgrade_query_list: | ||||||
|                     await conn.execute_script(upgrade_query) |                     await conn.execute_script(upgrade_query) | ||||||
|                 await Aerich.create( |                 await Aerich.create( | ||||||
|                     version=version_file, |                     version=version_file, app=app, content=get_models_describe(app), | ||||||
|                     app=app, |  | ||||||
|                     content=get_models_describe(app), |  | ||||||
|                 ) |                 ) | ||||||
|             click.secho(f"Success upgrade {version_file}", fg=Color.green) |             click.secho(f"Success upgrade {version_file}", fg=Color.green) | ||||||
|             migrated = True |             migrated = True | ||||||
| @@ -218,17 +212,12 @@ async def history(ctx: Context): | |||||||
|     help="Tortoise-ORM config module dict variable, like settings.TORTOISE_ORM.", |     help="Tortoise-ORM config module dict variable, like settings.TORTOISE_ORM.", | ||||||
| ) | ) | ||||||
| @click.option( | @click.option( | ||||||
|     "--location", |     "--location", default="./migrations", show_default=True, help="Migrate store location.", | ||||||
|     default="./migrations", |  | ||||||
|     show_default=True, |  | ||||||
|     help="Migrate store location.", |  | ||||||
| ) | ) | ||||||
| @click.pass_context | @click.pass_context | ||||||
| @coro | @coro | ||||||
| async def init( | async def init( | ||||||
|     ctx: Context, |     ctx: Context, tortoise_orm, location, | ||||||
|     tortoise_orm, |  | ||||||
|     location, |  | ||||||
| ): | ): | ||||||
|     config_file = ctx.obj["config_file"] |     config_file = ctx.obj["config_file"] | ||||||
|     name = ctx.obj["name"] |     name = ctx.obj["name"] | ||||||
| @@ -280,9 +269,7 @@ async def init_db(ctx: Context, safe): | |||||||
|  |  | ||||||
|     version = await Migrate.generate_version() |     version = await Migrate.generate_version() | ||||||
|     await Aerich.create( |     await Aerich.create( | ||||||
|         version=version, |         version=version, app=app, content=get_models_describe(app), | ||||||
|         app=app, |  | ||||||
|         content=get_models_describe(app), |  | ||||||
|     ) |     ) | ||||||
|     content = { |     content = { | ||||||
|         "upgrade": [schema], |         "upgrade": [schema], | ||||||
| @@ -293,11 +280,7 @@ async def init_db(ctx: Context, safe): | |||||||
|  |  | ||||||
| @cli.command(help="Introspects the database tables to standard output as TortoiseORM model.") | @cli.command(help="Introspects the database tables to standard output as TortoiseORM model.") | ||||||
| @click.option( | @click.option( | ||||||
|     "-t", |     "-t", "--table", help="Which tables to inspect.", multiple=True, required=False, | ||||||
|     "--table", |  | ||||||
|     help="Which tables to inspect.", |  | ||||||
|     multiple=True, |  | ||||||
|     required=False, |  | ||||||
| ) | ) | ||||||
| @click.pass_context | @click.pass_context | ||||||
| @coro | @coro | ||||||
|   | |||||||
| @@ -4,6 +4,8 @@ from typing import List, Type | |||||||
| from tortoise import BaseDBAsyncClient, Model | from tortoise import BaseDBAsyncClient, Model | ||||||
| from tortoise.backends.base.schema_generator import BaseSchemaGenerator | from tortoise.backends.base.schema_generator import BaseSchemaGenerator | ||||||
|  |  | ||||||
|  | from aerich.utils import is_default_function | ||||||
|  |  | ||||||
|  |  | ||||||
| class BaseDDL: | class BaseDDL: | ||||||
|     schema_generator_cls: Type[BaseSchemaGenerator] = BaseSchemaGenerator |     schema_generator_cls: Type[BaseSchemaGenerator] = BaseSchemaGenerator | ||||||
| @@ -76,7 +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 field_describe.get("field_type") in ["UUIDField", "TextField", "JSONField"]: |             if field_describe.get("field_type") in [ | ||||||
|  |                 "UUIDField", | ||||||
|  |                 "TextField", | ||||||
|  |                 "JSONField", | ||||||
|  |             ] or is_default_function(default): | ||||||
|                 default = "" |                 default = "" | ||||||
|             else: |             else: | ||||||
|                 try: |                 try: | ||||||
| @@ -109,9 +115,7 @@ class BaseDDL: | |||||||
|                 nullable="NOT NULL" if not field_describe.get("nullable") else "", |                 nullable="NOT NULL" if not field_describe.get("nullable") else "", | ||||||
|                 unique="UNIQUE" if field_describe.get("unique") else "", |                 unique="UNIQUE" if field_describe.get("unique") else "", | ||||||
|                 comment=self.schema_generator._column_comment_generator( |                 comment=self.schema_generator._column_comment_generator( | ||||||
|                     table=db_table, |                     table=db_table, column=db_column, comment=field_describe.get("description"), | ||||||
|                     column=db_column, |  | ||||||
|                     comment=field_describe.get("description"), |  | ||||||
|                 ) |                 ) | ||||||
|                 if description |                 if description | ||||||
|                 else "", |                 else "", | ||||||
| @@ -227,10 +231,10 @@ class BaseDDL: | |||||||
|         ) |         ) | ||||||
|  |  | ||||||
|     def alter_column_null(self, model: "Type[Model]", field_describe: dict): |     def alter_column_null(self, model: "Type[Model]", field_describe: dict): | ||||||
|         raise NotImplementedError |         return self.modify_column(model, field_describe) | ||||||
|  |  | ||||||
|     def set_comment(self, model: "Type[Model]", field_describe: dict): |     def set_comment(self, model: "Type[Model]", field_describe: dict): | ||||||
|         raise NotImplementedError |         return self.modify_column(model, field_describe) | ||||||
|  |  | ||||||
|     def rename_table(self, model: "Type[Model]", old_table_name: str, new_table_name: str): |     def rename_table(self, model: "Type[Model]", old_table_name: str, new_table_name: str): | ||||||
|         db_table = model._meta.db_table |         db_table = model._meta.db_table | ||||||
|   | |||||||
| @@ -1,10 +1,6 @@ | |||||||
| from typing import Type |  | ||||||
|  |  | ||||||
| from tortoise import Model |  | ||||||
| from tortoise.backends.mysql.schema_generator import MySQLSchemaGenerator | from tortoise.backends.mysql.schema_generator import MySQLSchemaGenerator | ||||||
|  |  | ||||||
| from aerich.ddl import BaseDDL | from aerich.ddl import BaseDDL | ||||||
| from aerich.exceptions import NotSupportError |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class MysqlDDL(BaseDDL): | class MysqlDDL(BaseDDL): | ||||||
| @@ -29,9 +25,3 @@ class MysqlDDL(BaseDDL): | |||||||
|     _M2M_TABLE_TEMPLATE = "CREATE TABLE `{table_name}` (`{backward_key}` {backward_type} NOT NULL REFERENCES `{backward_table}` (`{backward_field}`) ON DELETE CASCADE,`{forward_key}` {forward_type} NOT NULL REFERENCES `{forward_table}` (`{forward_field}`) ON DELETE CASCADE){extra}{comment}" |     _M2M_TABLE_TEMPLATE = "CREATE TABLE `{table_name}` (`{backward_key}` {backward_type} NOT NULL REFERENCES `{backward_table}` (`{backward_field}`) ON DELETE CASCADE,`{forward_key}` {forward_type} NOT NULL REFERENCES `{forward_table}` (`{forward_field}`) ON DELETE CASCADE){extra}{comment}" | ||||||
|     _MODIFY_COLUMN_TEMPLATE = "ALTER TABLE `{table_name}` MODIFY COLUMN {column}" |     _MODIFY_COLUMN_TEMPLATE = "ALTER TABLE `{table_name}` MODIFY COLUMN {column}" | ||||||
|     _RENAME_TABLE_TEMPLATE = "ALTER TABLE `{old_table_name}` RENAME TO `{new_table_name}`" |     _RENAME_TABLE_TEMPLATE = "ALTER TABLE `{old_table_name}` RENAME TO `{new_table_name}`" | ||||||
|  |  | ||||||
|     def alter_column_null(self, model: "Type[Model]", field_describe: dict): |  | ||||||
|         raise NotSupportError("Alter column null is unsupported in MySQL.") |  | ||||||
|  |  | ||||||
|     def set_comment(self, model: "Type[Model]", field_describe: dict): |  | ||||||
|         raise NotSupportError("Alter column comment is unsupported in MySQL.") |  | ||||||
|   | |||||||
| @@ -10,7 +10,12 @@ from tortoise.exceptions import OperationalError | |||||||
|  |  | ||||||
| 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 | ||||||
| from aerich.utils import get_app_connection, get_models_describe, write_version_file | from aerich.utils import ( | ||||||
|  |     get_app_connection, | ||||||
|  |     get_models_describe, | ||||||
|  |     is_default_function, | ||||||
|  |     write_version_file, | ||||||
|  | ) | ||||||
|  |  | ||||||
|  |  | ||||||
| class Migrate: | class Migrate: | ||||||
| @@ -232,14 +237,12 @@ class Migrate: | |||||||
|                 # add unique_together |                 # add unique_together | ||||||
|                 for index in new_unique_together.difference(old_unique_together): |                 for index in new_unique_together.difference(old_unique_together): | ||||||
|                     cls._add_operator( |                     cls._add_operator( | ||||||
|                         cls._add_index(model, index, True), |                         cls._add_index(model, index, True), upgrade, | ||||||
|                         upgrade, |  | ||||||
|                     ) |                     ) | ||||||
|                 # remove unique_together |                 # remove unique_together | ||||||
|                 for index in old_unique_together.difference(new_unique_together): |                 for index in old_unique_together.difference(new_unique_together): | ||||||
|                     cls._add_operator( |                     cls._add_operator( | ||||||
|                         cls._drop_index(model, index, True), |                         cls._drop_index(model, index, True), upgrade, | ||||||
|                         upgrade, |  | ||||||
|                     ) |                     ) | ||||||
|  |  | ||||||
|                 old_data_fields = old_model_describe.get("data_fields") |                 old_data_fields = old_model_describe.get("data_fields") | ||||||
| @@ -263,11 +266,7 @@ class Migrate: | |||||||
|                             # rename field |                             # rename field | ||||||
|                             if ( |                             if ( | ||||||
|                                 changes[0] |                                 changes[0] | ||||||
|                                 == ( |                                 == ("change", "name", (old_data_field_name, new_data_field_name),) | ||||||
|                                     "change", |  | ||||||
|                                     "name", |  | ||||||
|                                     (old_data_field_name, new_data_field_name), |  | ||||||
|                                 ) |  | ||||||
|                                 and changes[1] |                                 and changes[1] | ||||||
|                                 == ( |                                 == ( | ||||||
|                                     "change", |                                     "change", | ||||||
| @@ -298,21 +297,15 @@ class Migrate: | |||||||
|                                         and cls._db_version.startswith("5.") |                                         and cls._db_version.startswith("5.") | ||||||
|                                     ): |                                     ): | ||||||
|                                         cls._add_operator( |                                         cls._add_operator( | ||||||
|                                             cls._modify_field(model, new_data_field), |                                             cls._modify_field(model, new_data_field), upgrade, | ||||||
|                                             upgrade, |  | ||||||
|                                         ) |                                         ) | ||||||
|                                     else: |                                     else: | ||||||
|                                         cls._add_operator( |                                         cls._add_operator( | ||||||
|                                             cls._rename_field(model, *changes[1][2]), |                                             cls._rename_field(model, *changes[1][2]), upgrade, | ||||||
|                                             upgrade, |  | ||||||
|                                         ) |                                         ) | ||||||
|                     if not is_rename: |                     if not is_rename: | ||||||
|                         cls._add_operator( |                         cls._add_operator( | ||||||
|                             cls._add_field( |                             cls._add_field(model, new_data_field,), upgrade, | ||||||
|                                 model, |  | ||||||
|                                 new_data_field, |  | ||||||
|                             ), |  | ||||||
|                             upgrade, |  | ||||||
|                         ) |                         ) | ||||||
|                 # remove fields |                 # remove fields | ||||||
|                 for old_data_field_name in set(old_data_fields_name).difference( |                 for old_data_field_name in set(old_data_fields_name).difference( | ||||||
| @@ -382,28 +375,33 @@ class Migrate: | |||||||
|                             unique = new_data_field.get("unique") |                             unique = new_data_field.get("unique") | ||||||
|                             if old_new[0] is False and old_new[1] is True: |                             if old_new[0] is False and old_new[1] is True: | ||||||
|                                 cls._add_operator( |                                 cls._add_operator( | ||||||
|                                     cls._add_index(model, (field_name,), unique), |                                     cls._add_index(model, (field_name,), unique), upgrade, | ||||||
|                                     upgrade, |  | ||||||
|                                 ) |                                 ) | ||||||
|                             else: |                             else: | ||||||
|                                 cls._add_operator( |                                 cls._add_operator( | ||||||
|                                     cls._drop_index(model, (field_name,), unique), |                                     cls._drop_index(model, (field_name,), unique), upgrade, | ||||||
|                                     upgrade, |  | ||||||
|                                 ) |                                 ) | ||||||
|                         elif option == "db_field_types.": |                         elif option == "db_field_types.": | ||||||
|                             # continue since repeated with others |                             # continue since repeated with others | ||||||
|                             continue |                             continue | ||||||
|                         elif option == "default": |                         elif option == "default": | ||||||
|                             # change column default |                             if not ( | ||||||
|                             cls._add_operator(cls._alter_default(model, new_data_field), upgrade) |                                 is_default_function(old_new[0]) or is_default_function(old_new[1]) | ||||||
|  |                             ): | ||||||
|  |                                 # change column default | ||||||
|  |                                 cls._add_operator( | ||||||
|  |                                     cls._alter_default(model, new_data_field), upgrade | ||||||
|  |                                 ) | ||||||
|                         elif option == "unique": |                         elif option == "unique": | ||||||
|                             # because indexed include it |                             # because indexed include it | ||||||
|                             pass |                             pass | ||||||
|  |                         elif option == "nullable": | ||||||
|  |                             # change nullable | ||||||
|  |                             cls._add_operator(cls._alter_null(model, new_data_field), upgrade) | ||||||
|                         else: |                         else: | ||||||
|                             # modify column |                             # modify column | ||||||
|                             cls._add_operator( |                             cls._add_operator( | ||||||
|                                 cls._modify_field(model, new_data_field), |                                 cls._modify_field(model, new_data_field), upgrade, | ||||||
|                                 upgrade, |  | ||||||
|                             ) |                             ) | ||||||
|  |  | ||||||
|         for old_model in old_models: |         for old_model in old_models: | ||||||
|   | |||||||
| @@ -1,4 +1,5 @@ | |||||||
| import importlib | import importlib | ||||||
|  | import re | ||||||
| from typing import Dict | from typing import Dict | ||||||
|  |  | ||||||
| from click import BadOptionUsage, Context | from click import BadOptionUsage, Context | ||||||
| @@ -16,8 +17,7 @@ def get_app_connection_name(config, app_name: str) -> str: | |||||||
|     if app: |     if app: | ||||||
|         return app.get("default_connection", "default") |         return app.get("default_connection", "default") | ||||||
|     raise BadOptionUsage( |     raise BadOptionUsage( | ||||||
|         option_name="--app", |         option_name="--app", message=f'Can\'t get app named "{app_name}"', | ||||||
|         message=f'Can\'t get app named "{app_name}"', |  | ||||||
|     ) |     ) | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -121,3 +121,7 @@ def get_models_describe(app: str) -> Dict: | |||||||
|         describe = model.describe() |         describe = model.describe() | ||||||
|         ret[describe.get("name")] = describe |         ret[describe.get("name")] = describe | ||||||
|     return ret |     return ret | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def is_default_function(string: str): | ||||||
|  |     return re.match(r"^<function.+>$", str(string or "")) | ||||||
|   | |||||||
| @@ -20,10 +20,7 @@ tortoise_orm = { | |||||||
|         "second": expand_db_url(db_url_second, True), |         "second": expand_db_url(db_url_second, True), | ||||||
|     }, |     }, | ||||||
|     "apps": { |     "apps": { | ||||||
|         "models": { |         "models": {"models": ["tests.models", "aerich.models"], "default_connection": "default"}, | ||||||
|             "models": ["tests.models", "aerich.models"], |  | ||||||
|             "default_connection": "default", |  | ||||||
|         }, |  | ||||||
|         "models_second": {"models": ["tests.models_second"], "default_connection": "second"}, |         "models_second": {"models": ["tests.models_second"], "default_connection": "second"}, | ||||||
|     }, |     }, | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										189
									
								
								poetry.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										189
									
								
								poetry.lock
									
									
									
										generated
									
									
									
								
							| @@ -94,7 +94,7 @@ stevedore = ">=1.20.0" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "black" | name = "black" | ||||||
| version = "20.8b1" | version = "19.10b0" | ||||||
| description = "The uncompromising code formatter." | description = "The uncompromising code formatter." | ||||||
| category = "dev" | category = "dev" | ||||||
| optional = false | optional = false | ||||||
| @@ -102,16 +102,14 @@ python-versions = ">=3.6" | |||||||
|  |  | ||||||
| [package.dependencies] | [package.dependencies] | ||||||
| appdirs = "*" | appdirs = "*" | ||||||
| click = ">=7.1.2" | attrs = ">=18.1.0" | ||||||
| mypy-extensions = ">=0.4.3" | click = ">=6.5" | ||||||
| pathspec = ">=0.6,<1" | pathspec = ">=0.6,<1" | ||||||
| regex = ">=2020.1.8" | regex = "*" | ||||||
| toml = ">=0.10.1" | toml = ">=0.9.4" | ||||||
| typed-ast = ">=1.4.0" | typed-ast = ">=1.4.0" | ||||||
| typing-extensions = ">=3.7.4" |  | ||||||
|  |  | ||||||
| [package.extras] | [package.extras] | ||||||
| colorama = ["colorama (>=0.4.3)"] |  | ||||||
| d = ["aiohttp (>=3.3.2)", "aiohttp-cors"] | d = ["aiohttp (>=3.3.2)", "aiohttp-cors"] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| @@ -143,7 +141,7 @@ python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "cryptography" | name = "cryptography" | ||||||
| version = "3.4.6" | version = "3.4.7" | ||||||
| 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 | ||||||
| @@ -215,14 +213,14 @@ pyflakes = ">=2.3.0,<2.4.0" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "gitdb" | name = "gitdb" | ||||||
| version = "4.0.5" | version = "4.0.7" | ||||||
| description = "Git Object Database" | description = "Git Object Database" | ||||||
| category = "dev" | category = "dev" | ||||||
| optional = false | optional = false | ||||||
| python-versions = ">=3.4" | python-versions = ">=3.4" | ||||||
|  |  | ||||||
| [package.dependencies] | [package.dependencies] | ||||||
| smmap = ">=3.0.1,<4" | smmap = ">=3.0.1,<5" | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "gitpython" | name = "gitpython" | ||||||
| @@ -237,7 +235,7 @@ gitdb = ">=4.0.1,<5" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "importlib-metadata" | name = "importlib-metadata" | ||||||
| version = "3.7.3" | version = "3.10.0" | ||||||
| description = "Read metadata from Python packages" | description = "Read metadata from Python packages" | ||||||
| category = "dev" | category = "dev" | ||||||
| optional = false | optional = false | ||||||
| @@ -249,7 +247,7 @@ zipp = ">=0.5" | |||||||
|  |  | ||||||
| [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 (>=3.5,!=3.7.3)", "pytest-checkdocs (>=1.2.3)", "pytest-flake8", "pytest-cov", "pytest-enabler", "packaging", "pep517", "pyfakefs", "flufl.flake8", "pytest-black (>=0.3.7)", "pytest-mypy", "importlib-resources (>=1.3)"] | testing = ["pytest (>=4.6)", "pytest-checkdocs (>=2.4)", "pytest-flake8", "pytest-cov", "pytest-enabler (>=1.0.1)", "packaging", "pep517", "pyfakefs", "flufl.flake8", "pytest-black (>=0.3.7)", "pytest-mypy", "importlib-resources (>=1.3)"] | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "iniconfig" | name = "iniconfig" | ||||||
| @@ -288,14 +286,6 @@ category = "dev" | |||||||
| optional = false | optional = false | ||||||
| python-versions = "*" | python-versions = "*" | ||||||
|  |  | ||||||
| [[package]] |  | ||||||
| name = "mypy-extensions" |  | ||||||
| version = "0.4.3" |  | ||||||
| description = "Experimental type system extensions for programs checked with the mypy typechecker." |  | ||||||
| category = "dev" |  | ||||||
| optional = false |  | ||||||
| python-versions = "*" |  | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "packaging" | name = "packaging" | ||||||
| version = "20.9" | version = "20.9" | ||||||
| @@ -378,7 +368,7 @@ email = ["email-validator (>=1.0.3)"] | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "pyflakes" | name = "pyflakes" | ||||||
| version = "2.3.0" | version = "2.3.1" | ||||||
| description = "passive checker of Python programs" | description = "passive checker of Python programs" | ||||||
| category = "dev" | category = "dev" | ||||||
| optional = false | optional = false | ||||||
| @@ -413,7 +403,7 @@ python-versions = ">=3.7,<4.0" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "pytest" | name = "pytest" | ||||||
| version = "6.2.2" | version = "6.2.3" | ||||||
| description = "pytest: simple powerful testing with Python" | description = "pytest: simple powerful testing with Python" | ||||||
| category = "dev" | category = "dev" | ||||||
| optional = false | optional = false | ||||||
| @@ -508,7 +498,7 @@ python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*, !=3.5.*" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "regex" | name = "regex" | ||||||
| version = "2021.3.17" | version = "2021.4.4" | ||||||
| description = "Alternative regular expression module, to replace re." | description = "Alternative regular expression module, to replace re." | ||||||
| category = "dev" | category = "dev" | ||||||
| optional = false | optional = false | ||||||
| @@ -524,11 +514,11 @@ python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "smmap" | name = "smmap" | ||||||
| version = "3.0.5" | version = "4.0.0" | ||||||
| description = "A pure Python implementation of a sliding window memory map manager" | description = "A pure Python implementation of a sliding window memory map manager" | ||||||
| category = "dev" | category = "dev" | ||||||
| optional = false | optional = false | ||||||
| python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" | python-versions = ">=3.5" | ||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "stevedore" | name = "stevedore" | ||||||
| @@ -552,7 +542,7 @@ python-versions = ">=2.6, !=3.0.*, !=3.1.*, !=3.2.*" | |||||||
|  |  | ||||||
| [[package]] | [[package]] | ||||||
| name = "tortoise-orm" | name = "tortoise-orm" | ||||||
| version = "0.17.0" | version = "0.17.1" | ||||||
| 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 | ||||||
| @@ -607,7 +597,7 @@ asyncpg = ["asyncpg"] | |||||||
| [metadata] | [metadata] | ||||||
| lock-version = "1.1" | lock-version = "1.1" | ||||||
| python-versions = "^3.7" | python-versions = "^3.7" | ||||||
| content-hash = "3b8e107e2fd01362244f27f783c8dcfd792e4ea3c98a0579e4b987e0c5681b5d" | content-hash = "045cd78a4e69c3ef34fc8a21e374616f67af998d878e207cd21c9557c096892b" | ||||||
|  |  | ||||||
| [metadata.files] | [metadata.files] | ||||||
| aiomysql = [ | aiomysql = [ | ||||||
| @@ -656,7 +646,8 @@ bandit = [ | |||||||
|     {file = "bandit-1.7.0.tar.gz", hash = "sha256:8a4c7415254d75df8ff3c3b15cfe9042ecee628a1e40b44c15a98890fbfc2608"}, |     {file = "bandit-1.7.0.tar.gz", hash = "sha256:8a4c7415254d75df8ff3c3b15cfe9042ecee628a1e40b44c15a98890fbfc2608"}, | ||||||
| ] | ] | ||||||
| black = [ | black = [ | ||||||
|     {file = "black-20.8b1.tar.gz", hash = "sha256:1c02557aa099101b9d21496f8a914e9ed2222ef70336404eeeac8edba836fbea"}, |     {file = "black-19.10b0-py36-none-any.whl", hash = "sha256:1b30e59be925fafc1ee4565e5e08abef6b03fe455102883820fe5ee2e4734e0b"}, | ||||||
|  |     {file = "black-19.10b0.tar.gz", hash = "sha256:c2edb73a08e9e0e6f65a0e6af18b059b8b1cdd5bef997d7a0b181df93dc81539"}, | ||||||
| ] | ] | ||||||
| cffi = [ | cffi = [ | ||||||
|     {file = "cffi-1.14.5-cp27-cp27m-macosx_10_9_x86_64.whl", hash = "sha256:bb89f306e5da99f4d922728ddcd6f7fcebb3241fc40edebcb7284d7514741991"}, |     {file = "cffi-1.14.5-cp27-cp27m-macosx_10_9_x86_64.whl", hash = "sha256:bb89f306e5da99f4d922728ddcd6f7fcebb3241fc40edebcb7284d7514741991"}, | ||||||
| @@ -706,18 +697,18 @@ colorama = [ | |||||||
|     {file = "colorama-0.4.4.tar.gz", hash = "sha256:5941b2b48a20143d2267e95b1c2a7603ce057ee39fd88e7329b0c292aa16869b"}, |     {file = "colorama-0.4.4.tar.gz", hash = "sha256:5941b2b48a20143d2267e95b1c2a7603ce057ee39fd88e7329b0c292aa16869b"}, | ||||||
| ] | ] | ||||||
| cryptography = [ | cryptography = [ | ||||||
|     {file = "cryptography-3.4.6-cp36-abi3-macosx_10_10_x86_64.whl", hash = "sha256:57ad77d32917bc55299b16d3b996ffa42a1c73c6cfa829b14043c561288d2799"}, |     {file = "cryptography-3.4.7-cp36-abi3-macosx_10_10_x86_64.whl", hash = "sha256:3d8427734c781ea5f1b41d6589c293089704d4759e34597dce91014ac125aad1"}, | ||||||
|     {file = "cryptography-3.4.6-cp36-abi3-macosx_11_0_arm64.whl", hash = "sha256:4169a27b818de4a1860720108b55a2801f32b6ae79e7f99c00d79f2a2822eeb7"}, |     {file = "cryptography-3.4.7-cp36-abi3-macosx_11_0_arm64.whl", hash = "sha256:8e56e16617872b0957d1c9742a3f94b43533447fd78321514abbe7db216aa250"}, | ||||||
|     {file = "cryptography-3.4.6-cp36-abi3-manylinux2010_x86_64.whl", hash = "sha256:93cfe5b7ff006de13e1e89830810ecbd014791b042cbe5eec253be11ac2b28f3"}, |     {file = "cryptography-3.4.7-cp36-abi3-manylinux2010_x86_64.whl", hash = "sha256:37340614f8a5d2fb9aeea67fd159bfe4f5f4ed535b1090ce8ec428b2f15a11f2"}, | ||||||
|     {file = "cryptography-3.4.6-cp36-abi3-manylinux2014_aarch64.whl", hash = "sha256:5ecf2bcb34d17415e89b546dbb44e73080f747e504273e4d4987630493cded1b"}, |     {file = "cryptography-3.4.7-cp36-abi3-manylinux2014_aarch64.whl", hash = "sha256:240f5c21aef0b73f40bb9f78d2caff73186700bf1bc6b94285699aff98cc16c6"}, | ||||||
|     {file = "cryptography-3.4.6-cp36-abi3-manylinux2014_x86_64.whl", hash = "sha256:fec7fb46b10da10d9e1d078d1ff8ed9e05ae14f431fdbd11145edd0550b9a964"}, |     {file = "cryptography-3.4.7-cp36-abi3-manylinux2014_x86_64.whl", hash = "sha256:1e056c28420c072c5e3cb36e2b23ee55e260cb04eee08f702e0edfec3fb51959"}, | ||||||
|     {file = "cryptography-3.4.6-cp36-abi3-win32.whl", hash = "sha256:df186fcbf86dc1ce56305becb8434e4b6b7504bc724b71ad7a3239e0c9d14ef2"}, |     {file = "cryptography-3.4.7-cp36-abi3-win32.whl", hash = "sha256:0f1212a66329c80d68aeeb39b8a16d54ef57071bf22ff4e521657b27372e327d"}, | ||||||
|     {file = "cryptography-3.4.6-cp36-abi3-win_amd64.whl", hash = "sha256:66b57a9ca4b3221d51b237094b0303843b914b7d5afd4349970bb26518e350b0"}, |     {file = "cryptography-3.4.7-cp36-abi3-win_amd64.whl", hash = "sha256:de4e5f7f68220d92b7637fc99847475b59154b7a1b3868fb7385337af54ac9ca"}, | ||||||
|     {file = "cryptography-3.4.6-pp36-pypy36_pp73-manylinux2010_x86_64.whl", hash = "sha256:066bc53f052dfeda2f2d7c195cf16fb3e5ff13e1b6b7415b468514b40b381a5b"}, |     {file = "cryptography-3.4.7-pp36-pypy36_pp73-manylinux2010_x86_64.whl", hash = "sha256:26965837447f9c82f1855e0bc8bc4fb910240b6e0d16a664bb722df3b5b06873"}, | ||||||
|     {file = "cryptography-3.4.6-pp36-pypy36_pp73-manylinux2014_x86_64.whl", hash = "sha256:600cf9bfe75e96d965509a4c0b2b183f74a4fa6f5331dcb40fb7b77b7c2484df"}, |     {file = "cryptography-3.4.7-pp36-pypy36_pp73-manylinux2014_x86_64.whl", hash = "sha256:eb8cc2afe8b05acbd84a43905832ec78e7b3873fb124ca190f574dca7389a87d"}, | ||||||
|     {file = "cryptography-3.4.6-pp37-pypy37_pp73-manylinux2010_x86_64.whl", hash = "sha256:0923ba600d00718d63a3976f23cab19aef10c1765038945628cd9be047ad0336"}, |     {file = "cryptography-3.4.7-pp37-pypy37_pp73-manylinux2010_x86_64.whl", hash = "sha256:7ec5d3b029f5fa2b179325908b9cd93db28ab7b85bb6c1db56b10e0b54235177"}, | ||||||
|     {file = "cryptography-3.4.6-pp37-pypy37_pp73-manylinux2014_x86_64.whl", hash = "sha256:9e98b452132963678e3ac6c73f7010fe53adf72209a32854d55690acac3f6724"}, |     {file = "cryptography-3.4.7-pp37-pypy37_pp73-manylinux2014_x86_64.whl", hash = "sha256:ee77aa129f481be46f8d92a1a7db57269a2f23052d5f2433b4621bb457081cc9"}, | ||||||
|     {file = "cryptography-3.4.6.tar.gz", hash = "sha256:2d32223e5b0ee02943f32b19245b61a62db83a882f0e76cc564e1cec60d48f87"}, |     {file = "cryptography-3.4.7.tar.gz", hash = "sha256:3d10de8116d25649631977cb37da6cbdd2d6fa0e0281d014a5b7d337255ca713"}, | ||||||
| ] | ] | ||||||
| ddlparse = [ | ddlparse = [ | ||||||
|     {file = "ddlparse-1.9.0-py3-none-any.whl", hash = "sha256:a7962615a9325be7d0f182cbe34011e6283996473fb98c784c6f675b9783bc18"}, |     {file = "ddlparse-1.9.0-py3-none-any.whl", hash = "sha256:a7962615a9325be7d0f182cbe34011e6283996473fb98c784c6f675b9783bc18"}, | ||||||
| @@ -736,16 +727,16 @@ flake8 = [ | |||||||
|     {file = "flake8-3.9.0.tar.gz", hash = "sha256:78873e372b12b093da7b5e5ed302e8ad9e988b38b063b61ad937f26ca58fc5f0"}, |     {file = "flake8-3.9.0.tar.gz", hash = "sha256:78873e372b12b093da7b5e5ed302e8ad9e988b38b063b61ad937f26ca58fc5f0"}, | ||||||
| ] | ] | ||||||
| gitdb = [ | gitdb = [ | ||||||
|     {file = "gitdb-4.0.5-py3-none-any.whl", hash = "sha256:91f36bfb1ab7949b3b40e23736db18231bf7593edada2ba5c3a174a7b23657ac"}, |     {file = "gitdb-4.0.7-py3-none-any.whl", hash = "sha256:6c4cc71933456991da20917998acbe6cf4fb41eeaab7d6d67fbc05ecd4c865b0"}, | ||||||
|     {file = "gitdb-4.0.5.tar.gz", hash = "sha256:c9e1f2d0db7ddb9a704c2a0217be31214e91a4fe1dea1efad19ae42ba0c285c9"}, |     {file = "gitdb-4.0.7.tar.gz", hash = "sha256:96bf5c08b157a666fec41129e6d327235284cca4c81e92109260f353ba138005"}, | ||||||
| ] | ] | ||||||
| gitpython = [ | gitpython = [ | ||||||
|     {file = "GitPython-3.1.14-py3-none-any.whl", hash = "sha256:3283ae2fba31c913d857e12e5ba5f9a7772bbc064ae2bb09efafa71b0dd4939b"}, |     {file = "GitPython-3.1.14-py3-none-any.whl", hash = "sha256:3283ae2fba31c913d857e12e5ba5f9a7772bbc064ae2bb09efafa71b0dd4939b"}, | ||||||
|     {file = "GitPython-3.1.14.tar.gz", hash = "sha256:be27633e7509e58391f10207cd32b2a6cf5b908f92d9cd30da2e514e1137af61"}, |     {file = "GitPython-3.1.14.tar.gz", hash = "sha256:be27633e7509e58391f10207cd32b2a6cf5b908f92d9cd30da2e514e1137af61"}, | ||||||
| ] | ] | ||||||
| importlib-metadata = [ | importlib-metadata = [ | ||||||
|     {file = "importlib_metadata-3.7.3-py3-none-any.whl", hash = "sha256:b74159469b464a99cb8cc3e21973e4d96e05d3024d337313fedb618a6e86e6f4"}, |     {file = "importlib_metadata-3.10.0-py3-none-any.whl", hash = "sha256:d2d46ef77ffc85cbf7dac7e81dd663fde71c45326131bea8033b9bad42268ebe"}, | ||||||
|     {file = "importlib_metadata-3.7.3.tar.gz", hash = "sha256:742add720a20d0467df2f444ae41704000f50e1234f46174b51f9c6031a1bd71"}, |     {file = "importlib_metadata-3.10.0.tar.gz", hash = "sha256:c9db46394197244adf2f0b08ec5bc3cf16757e9590b02af1fca085c16c0d600a"}, | ||||||
| ] | ] | ||||||
| iniconfig = [ | iniconfig = [ | ||||||
|     {file = "iniconfig-1.1.1-py2.py3-none-any.whl", hash = "sha256:011e24c64b7f47f6ebd835bb12a743f2fbe9a26d4cecaa7f53bc4f35ee9da8b3"}, |     {file = "iniconfig-1.1.1-py2.py3-none-any.whl", hash = "sha256:011e24c64b7f47f6ebd835bb12a743f2fbe9a26d4cecaa7f53bc4f35ee9da8b3"}, | ||||||
| @@ -763,10 +754,6 @@ mccabe = [ | |||||||
|     {file = "mccabe-0.6.1-py2.py3-none-any.whl", hash = "sha256:ab8a6258860da4b6677da4bd2fe5dc2c659cff31b3ee4f7f5d64e79735b80d42"}, |     {file = "mccabe-0.6.1-py2.py3-none-any.whl", hash = "sha256:ab8a6258860da4b6677da4bd2fe5dc2c659cff31b3ee4f7f5d64e79735b80d42"}, | ||||||
|     {file = "mccabe-0.6.1.tar.gz", hash = "sha256:dd8d182285a0fe56bace7f45b5e7d1a6ebcbf524e8f3bd87eb0f125271b8831f"}, |     {file = "mccabe-0.6.1.tar.gz", hash = "sha256:dd8d182285a0fe56bace7f45b5e7d1a6ebcbf524e8f3bd87eb0f125271b8831f"}, | ||||||
| ] | ] | ||||||
| mypy-extensions = [ |  | ||||||
|     {file = "mypy_extensions-0.4.3-py2.py3-none-any.whl", hash = "sha256:090fedd75945a69ae91ce1303b5824f428daf5a028d2f6ab8a299250a846f15d"}, |  | ||||||
|     {file = "mypy_extensions-0.4.3.tar.gz", hash = "sha256:2d82818f5bb3e369420cb3c4060a7970edba416647068eb4c5343488a6c604a8"}, |  | ||||||
| ] |  | ||||||
| packaging = [ | packaging = [ | ||||||
|     {file = "packaging-20.9-py2.py3-none-any.whl", hash = "sha256:67714da7f7bc052e064859c05c595155bd1ee9f69f76557e21f051443c20947a"}, |     {file = "packaging-20.9-py2.py3-none-any.whl", hash = "sha256:67714da7f7bc052e064859c05c595155bd1ee9f69f76557e21f051443c20947a"}, | ||||||
|     {file = "packaging-20.9.tar.gz", hash = "sha256:5b327ac1320dc863dca72f4514ecc086f31186744b84a230374cc1fd776feae5"}, |     {file = "packaging-20.9.tar.gz", hash = "sha256:5b327ac1320dc863dca72f4514ecc086f31186744b84a230374cc1fd776feae5"}, | ||||||
| @@ -820,8 +807,8 @@ pydantic = [ | |||||||
|     {file = "pydantic-1.8.1.tar.gz", hash = "sha256:26cf3cb2e68ec6c0cfcb6293e69fb3450c5fd1ace87f46b64f678b0d29eac4c3"}, |     {file = "pydantic-1.8.1.tar.gz", hash = "sha256:26cf3cb2e68ec6c0cfcb6293e69fb3450c5fd1ace87f46b64f678b0d29eac4c3"}, | ||||||
| ] | ] | ||||||
| pyflakes = [ | pyflakes = [ | ||||||
|     {file = "pyflakes-2.3.0-py2.py3-none-any.whl", hash = "sha256:910208209dcea632721cb58363d0f72913d9e8cf64dc6f8ae2e02a3609aba40d"}, |     {file = "pyflakes-2.3.1-py2.py3-none-any.whl", hash = "sha256:7893783d01b8a89811dd72d7dfd4d84ff098e5eed95cfa8905b22bbffe52efc3"}, | ||||||
|     {file = "pyflakes-2.3.0.tar.gz", hash = "sha256:e59fd8e750e588358f1b8885e5a4751203a0516e0ee6d34811089ac294c8806f"}, |     {file = "pyflakes-2.3.1.tar.gz", hash = "sha256:f5bc8ecabc05bb9d291eb5203d6810b49040f6ff446a756326104746cc00c1db"}, | ||||||
| ] | ] | ||||||
| pymysql = [ | pymysql = [ | ||||||
|     {file = "PyMySQL-0.9.3-py2.py3-none-any.whl", hash = "sha256:3943fbbbc1e902f41daf7f9165519f140c4451c179380677e6a848587042561a"}, |     {file = "PyMySQL-0.9.3-py2.py3-none-any.whl", hash = "sha256:3943fbbbc1e902f41daf7f9165519f140c4451c179380677e6a848587042561a"}, | ||||||
| @@ -836,8 +823,8 @@ pypika-tortoise = [ | |||||||
|     {file = "pypika_tortoise-0.1.0-py3-none-any.whl", hash = "sha256:ec83b0b2964be01ef563f5f019b0332a18177604e841c47ad39d798798c6dfe9"}, |     {file = "pypika_tortoise-0.1.0-py3-none-any.whl", hash = "sha256:ec83b0b2964be01ef563f5f019b0332a18177604e841c47ad39d798798c6dfe9"}, | ||||||
| ] | ] | ||||||
| pytest = [ | pytest = [ | ||||||
|     {file = "pytest-6.2.2-py3-none-any.whl", hash = "sha256:b574b57423e818210672e07ca1fa90aaf194a4f63f3ab909a2c67ebb22913839"}, |     {file = "pytest-6.2.3-py3-none-any.whl", hash = "sha256:6ad9c7bdf517a808242b998ac20063c41532a570d088d77eec1ee12b0b5574bc"}, | ||||||
|     {file = "pytest-6.2.2.tar.gz", hash = "sha256:9d1edf9e7d0b84d72ea3dbcdfd22b35fb543a5e8f2a60092dd578936bf63d7f9"}, |     {file = "pytest-6.2.3.tar.gz", hash = "sha256:671238a46e4df0f3498d1c3270e5deb9b32d25134c99b7d75370a68cfbe9b634"}, | ||||||
| ] | ] | ||||||
| pytest-asyncio = [ | pytest-asyncio = [ | ||||||
|     {file = "pytest-asyncio-0.14.0.tar.gz", hash = "sha256:9882c0c6b24429449f5f969a5158b528f39bde47dc32e85b9f0403965017e700"}, |     {file = "pytest-asyncio-0.14.0.tar.gz", hash = "sha256:9882c0c6b24429449f5f969a5158b528f39bde47dc32e85b9f0403965017e700"}, | ||||||
| @@ -866,72 +853,80 @@ pyyaml = [ | |||||||
|     {file = "PyYAML-5.4.1-cp27-cp27mu-manylinux1_x86_64.whl", hash = "sha256:bb4191dfc9306777bc594117aee052446b3fa88737cd13b7188d0e7aa8162185"}, |     {file = "PyYAML-5.4.1-cp27-cp27mu-manylinux1_x86_64.whl", hash = "sha256:bb4191dfc9306777bc594117aee052446b3fa88737cd13b7188d0e7aa8162185"}, | ||||||
|     {file = "PyYAML-5.4.1-cp36-cp36m-macosx_10_9_x86_64.whl", hash = "sha256:6c78645d400265a062508ae399b60b8c167bf003db364ecb26dcab2bda048253"}, |     {file = "PyYAML-5.4.1-cp36-cp36m-macosx_10_9_x86_64.whl", hash = "sha256:6c78645d400265a062508ae399b60b8c167bf003db364ecb26dcab2bda048253"}, | ||||||
|     {file = "PyYAML-5.4.1-cp36-cp36m-manylinux1_x86_64.whl", hash = "sha256:4e0583d24c881e14342eaf4ec5fbc97f934b999a6828693a99157fde912540cc"}, |     {file = "PyYAML-5.4.1-cp36-cp36m-manylinux1_x86_64.whl", hash = "sha256:4e0583d24c881e14342eaf4ec5fbc97f934b999a6828693a99157fde912540cc"}, | ||||||
|  |     {file = "PyYAML-5.4.1-cp36-cp36m-manylinux2014_aarch64.whl", hash = "sha256:72a01f726a9c7851ca9bfad6fd09ca4e090a023c00945ea05ba1638c09dc3347"}, | ||||||
|  |     {file = "PyYAML-5.4.1-cp36-cp36m-manylinux2014_s390x.whl", hash = "sha256:895f61ef02e8fed38159bb70f7e100e00f471eae2bc838cd0f4ebb21e28f8541"}, | ||||||
|     {file = "PyYAML-5.4.1-cp36-cp36m-win32.whl", hash = "sha256:3bd0e463264cf257d1ffd2e40223b197271046d09dadf73a0fe82b9c1fc385a5"}, |     {file = "PyYAML-5.4.1-cp36-cp36m-win32.whl", hash = "sha256:3bd0e463264cf257d1ffd2e40223b197271046d09dadf73a0fe82b9c1fc385a5"}, | ||||||
|     {file = "PyYAML-5.4.1-cp36-cp36m-win_amd64.whl", hash = "sha256:e4fac90784481d221a8e4b1162afa7c47ed953be40d31ab4629ae917510051df"}, |     {file = "PyYAML-5.4.1-cp36-cp36m-win_amd64.whl", hash = "sha256:e4fac90784481d221a8e4b1162afa7c47ed953be40d31ab4629ae917510051df"}, | ||||||
|     {file = "PyYAML-5.4.1-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:5accb17103e43963b80e6f837831f38d314a0495500067cb25afab2e8d7a4018"}, |     {file = "PyYAML-5.4.1-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:5accb17103e43963b80e6f837831f38d314a0495500067cb25afab2e8d7a4018"}, | ||||||
|     {file = "PyYAML-5.4.1-cp37-cp37m-manylinux1_x86_64.whl", hash = "sha256:e1d4970ea66be07ae37a3c2e48b5ec63f7ba6804bdddfdbd3cfd954d25a82e63"}, |     {file = "PyYAML-5.4.1-cp37-cp37m-manylinux1_x86_64.whl", hash = "sha256:e1d4970ea66be07ae37a3c2e48b5ec63f7ba6804bdddfdbd3cfd954d25a82e63"}, | ||||||
|  |     {file = "PyYAML-5.4.1-cp37-cp37m-manylinux2014_aarch64.whl", hash = "sha256:cb333c16912324fd5f769fff6bc5de372e9e7a202247b48870bc251ed40239aa"}, | ||||||
|  |     {file = "PyYAML-5.4.1-cp37-cp37m-manylinux2014_s390x.whl", hash = "sha256:fe69978f3f768926cfa37b867e3843918e012cf83f680806599ddce33c2c68b0"}, | ||||||
|     {file = "PyYAML-5.4.1-cp37-cp37m-win32.whl", hash = "sha256:dd5de0646207f053eb0d6c74ae45ba98c3395a571a2891858e87df7c9b9bd51b"}, |     {file = "PyYAML-5.4.1-cp37-cp37m-win32.whl", hash = "sha256:dd5de0646207f053eb0d6c74ae45ba98c3395a571a2891858e87df7c9b9bd51b"}, | ||||||
|     {file = "PyYAML-5.4.1-cp37-cp37m-win_amd64.whl", hash = "sha256:08682f6b72c722394747bddaf0aa62277e02557c0fd1c42cb853016a38f8dedf"}, |     {file = "PyYAML-5.4.1-cp37-cp37m-win_amd64.whl", hash = "sha256:08682f6b72c722394747bddaf0aa62277e02557c0fd1c42cb853016a38f8dedf"}, | ||||||
|     {file = "PyYAML-5.4.1-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:d2d9808ea7b4af864f35ea216be506ecec180628aced0704e34aca0b040ffe46"}, |     {file = "PyYAML-5.4.1-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:d2d9808ea7b4af864f35ea216be506ecec180628aced0704e34aca0b040ffe46"}, | ||||||
|     {file = "PyYAML-5.4.1-cp38-cp38-manylinux1_x86_64.whl", hash = "sha256:8c1be557ee92a20f184922c7b6424e8ab6691788e6d86137c5d93c1a6ec1b8fb"}, |     {file = "PyYAML-5.4.1-cp38-cp38-manylinux1_x86_64.whl", hash = "sha256:8c1be557ee92a20f184922c7b6424e8ab6691788e6d86137c5d93c1a6ec1b8fb"}, | ||||||
|  |     {file = "PyYAML-5.4.1-cp38-cp38-manylinux2014_aarch64.whl", hash = "sha256:fd7f6999a8070df521b6384004ef42833b9bd62cfee11a09bda1079b4b704247"}, | ||||||
|  |     {file = "PyYAML-5.4.1-cp38-cp38-manylinux2014_s390x.whl", hash = "sha256:bfb51918d4ff3d77c1c856a9699f8492c612cde32fd3bcd344af9be34999bfdc"}, | ||||||
|     {file = "PyYAML-5.4.1-cp38-cp38-win32.whl", hash = "sha256:fa5ae20527d8e831e8230cbffd9f8fe952815b2b7dae6ffec25318803a7528fc"}, |     {file = "PyYAML-5.4.1-cp38-cp38-win32.whl", hash = "sha256:fa5ae20527d8e831e8230cbffd9f8fe952815b2b7dae6ffec25318803a7528fc"}, | ||||||
|     {file = "PyYAML-5.4.1-cp38-cp38-win_amd64.whl", hash = "sha256:0f5f5786c0e09baddcd8b4b45f20a7b5d61a7e7e99846e3c799b05c7c53fa696"}, |     {file = "PyYAML-5.4.1-cp38-cp38-win_amd64.whl", hash = "sha256:0f5f5786c0e09baddcd8b4b45f20a7b5d61a7e7e99846e3c799b05c7c53fa696"}, | ||||||
|     {file = "PyYAML-5.4.1-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:294db365efa064d00b8d1ef65d8ea2c3426ac366c0c4368d930bf1c5fb497f77"}, |     {file = "PyYAML-5.4.1-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:294db365efa064d00b8d1ef65d8ea2c3426ac366c0c4368d930bf1c5fb497f77"}, | ||||||
|     {file = "PyYAML-5.4.1-cp39-cp39-manylinux1_x86_64.whl", hash = "sha256:74c1485f7707cf707a7aef42ef6322b8f97921bd89be2ab6317fd782c2d53183"}, |     {file = "PyYAML-5.4.1-cp39-cp39-manylinux1_x86_64.whl", hash = "sha256:74c1485f7707cf707a7aef42ef6322b8f97921bd89be2ab6317fd782c2d53183"}, | ||||||
|  |     {file = "PyYAML-5.4.1-cp39-cp39-manylinux2014_aarch64.whl", hash = "sha256:d483ad4e639292c90170eb6f7783ad19490e7a8defb3e46f97dfe4bacae89122"}, | ||||||
|  |     {file = "PyYAML-5.4.1-cp39-cp39-manylinux2014_s390x.whl", hash = "sha256:fdc842473cd33f45ff6bce46aea678a54e3d21f1b61a7750ce3c498eedfe25d6"}, | ||||||
|     {file = "PyYAML-5.4.1-cp39-cp39-win32.whl", hash = "sha256:49d4cdd9065b9b6e206d0595fee27a96b5dd22618e7520c33204a4a3239d5b10"}, |     {file = "PyYAML-5.4.1-cp39-cp39-win32.whl", hash = "sha256:49d4cdd9065b9b6e206d0595fee27a96b5dd22618e7520c33204a4a3239d5b10"}, | ||||||
|     {file = "PyYAML-5.4.1-cp39-cp39-win_amd64.whl", hash = "sha256:c20cfa2d49991c8b4147af39859b167664f2ad4561704ee74c1de03318e898db"}, |     {file = "PyYAML-5.4.1-cp39-cp39-win_amd64.whl", hash = "sha256:c20cfa2d49991c8b4147af39859b167664f2ad4561704ee74c1de03318e898db"}, | ||||||
|     {file = "PyYAML-5.4.1.tar.gz", hash = "sha256:607774cbba28732bfa802b54baa7484215f530991055bb562efbed5b2f20a45e"}, |     {file = "PyYAML-5.4.1.tar.gz", hash = "sha256:607774cbba28732bfa802b54baa7484215f530991055bb562efbed5b2f20a45e"}, | ||||||
| ] | ] | ||||||
| regex = [ | regex = [ | ||||||
|     {file = "regex-2021.3.17-cp36-cp36m-macosx_10_9_x86_64.whl", hash = "sha256:b97ec5d299c10d96617cc851b2e0f81ba5d9d6248413cd374ef7f3a8871ee4a6"}, |     {file = "regex-2021.4.4-cp36-cp36m-macosx_10_9_x86_64.whl", hash = "sha256:619d71c59a78b84d7f18891fe914446d07edd48dc8328c8e149cbe0929b4e000"}, | ||||||
|     {file = "regex-2021.3.17-cp36-cp36m-manylinux1_i686.whl", hash = "sha256:cb4ee827857a5ad9b8ae34d3c8cc51151cb4a3fe082c12ec20ec73e63cc7c6f0"}, |     {file = "regex-2021.4.4-cp36-cp36m-manylinux1_i686.whl", hash = "sha256:47bf5bf60cf04d72bf6055ae5927a0bd9016096bf3d742fa50d9bf9f45aa0711"}, | ||||||
|     {file = "regex-2021.3.17-cp36-cp36m-manylinux1_x86_64.whl", hash = "sha256:633497504e2a485a70a3268d4fc403fe3063a50a50eed1039083e9471ad0101c"}, |     {file = "regex-2021.4.4-cp36-cp36m-manylinux1_x86_64.whl", hash = "sha256:281d2fd05555079448537fe108d79eb031b403dac622621c78944c235f3fcf11"}, | ||||||
|     {file = "regex-2021.3.17-cp36-cp36m-manylinux2010_i686.whl", hash = "sha256:a59a2ee329b3de764b21495d78c92ab00b4ea79acef0f7ae8c1067f773570afa"}, |     {file = "regex-2021.4.4-cp36-cp36m-manylinux2010_i686.whl", hash = "sha256:bd28bc2e3a772acbb07787c6308e00d9626ff89e3bfcdebe87fa5afbfdedf968"}, | ||||||
|     {file = "regex-2021.3.17-cp36-cp36m-manylinux2010_x86_64.whl", hash = "sha256:f85d6f41e34f6a2d1607e312820971872944f1661a73d33e1e82d35ea3305e14"}, |     {file = "regex-2021.4.4-cp36-cp36m-manylinux2010_x86_64.whl", hash = "sha256:7c2a1af393fcc09e898beba5dd59196edaa3116191cc7257f9224beaed3e1aa0"}, | ||||||
|     {file = "regex-2021.3.17-cp36-cp36m-manylinux2014_aarch64.whl", hash = "sha256:4651f839dbde0816798e698626af6a2469eee6d9964824bb5386091255a1694f"}, |     {file = "regex-2021.4.4-cp36-cp36m-manylinux2014_aarch64.whl", hash = "sha256:c38c71df845e2aabb7fb0b920d11a1b5ac8526005e533a8920aea97efb8ec6a4"}, | ||||||
|     {file = "regex-2021.3.17-cp36-cp36m-manylinux2014_i686.whl", hash = "sha256:39c44532d0e4f1639a89e52355b949573e1e2c5116106a395642cbbae0ff9bcd"}, |     {file = "regex-2021.4.4-cp36-cp36m-manylinux2014_i686.whl", hash = "sha256:96fcd1888ab4d03adfc9303a7b3c0bd78c5412b2bfbe76db5b56d9eae004907a"}, | ||||||
|     {file = "regex-2021.3.17-cp36-cp36m-manylinux2014_x86_64.whl", hash = "sha256:3d9a7e215e02bd7646a91fb8bcba30bc55fd42a719d6b35cf80e5bae31d9134e"}, |     {file = "regex-2021.4.4-cp36-cp36m-manylinux2014_x86_64.whl", hash = "sha256:ade17eb5d643b7fead300a1641e9f45401c98eee23763e9ed66a43f92f20b4a7"}, | ||||||
|     {file = "regex-2021.3.17-cp36-cp36m-win32.whl", hash = "sha256:159fac1a4731409c830d32913f13f68346d6b8e39650ed5d704a9ce2f9ef9cb3"}, |     {file = "regex-2021.4.4-cp36-cp36m-win32.whl", hash = "sha256:e8e5b509d5c2ff12f8418006d5a90e9436766133b564db0abaec92fd27fcee29"}, | ||||||
|     {file = "regex-2021.3.17-cp36-cp36m-win_amd64.whl", hash = "sha256:13f50969028e81765ed2a1c5fcfdc246c245cf8d47986d5172e82ab1a0c42ee5"}, |     {file = "regex-2021.4.4-cp36-cp36m-win_amd64.whl", hash = "sha256:11d773d75fa650cd36f68d7ca936e3c7afaae41b863b8c387a22aaa78d3c5c79"}, | ||||||
|     {file = "regex-2021.3.17-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:b9d8d286c53fe0cbc6d20bf3d583cabcd1499d89034524e3b94c93a5ab85ca90"}, |     {file = "regex-2021.4.4-cp37-cp37m-macosx_10_9_x86_64.whl", hash = "sha256:d3029c340cfbb3ac0a71798100ccc13b97dddf373a4ae56b6a72cf70dfd53bc8"}, | ||||||
|     {file = "regex-2021.3.17-cp37-cp37m-manylinux1_i686.whl", hash = "sha256:201e2619a77b21a7780580ab7b5ce43835e242d3e20fef50f66a8df0542e437f"}, |     {file = "regex-2021.4.4-cp37-cp37m-manylinux1_i686.whl", hash = "sha256:18c071c3eb09c30a264879f0d310d37fe5d3a3111662438889ae2eb6fc570c31"}, | ||||||
|     {file = "regex-2021.3.17-cp37-cp37m-manylinux1_x86_64.whl", hash = "sha256:d47d359545b0ccad29d572ecd52c9da945de7cd6cf9c0cfcb0269f76d3555689"}, |     {file = "regex-2021.4.4-cp37-cp37m-manylinux1_x86_64.whl", hash = "sha256:4c557a7b470908b1712fe27fb1ef20772b78079808c87d20a90d051660b1d69a"}, | ||||||
|     {file = "regex-2021.3.17-cp37-cp37m-manylinux2010_i686.whl", hash = "sha256:ea2f41445852c660ba7c3ebf7d70b3779b20d9ca8ba54485a17740db49f46932"}, |     {file = "regex-2021.4.4-cp37-cp37m-manylinux2010_i686.whl", hash = "sha256:01afaf2ec48e196ba91b37451aa353cb7eda77efe518e481707e0515025f0cd5"}, | ||||||
|     {file = "regex-2021.3.17-cp37-cp37m-manylinux2010_x86_64.whl", hash = "sha256:486a5f8e11e1f5bbfcad87f7c7745eb14796642323e7e1829a331f87a713daaa"}, |     {file = "regex-2021.4.4-cp37-cp37m-manylinux2010_x86_64.whl", hash = "sha256:3a9cd17e6e5c7eb328517969e0cb0c3d31fd329298dd0c04af99ebf42e904f82"}, | ||||||
|     {file = "regex-2021.3.17-cp37-cp37m-manylinux2014_aarch64.whl", hash = "sha256:18e25e0afe1cf0f62781a150c1454b2113785401ba285c745acf10c8ca8917df"}, |     {file = "regex-2021.4.4-cp37-cp37m-manylinux2014_aarch64.whl", hash = "sha256:90f11ff637fe8798933fb29f5ae1148c978cccb0452005bf4c69e13db951e765"}, | ||||||
|     {file = "regex-2021.3.17-cp37-cp37m-manylinux2014_i686.whl", hash = "sha256:a2ee026f4156789df8644d23ef423e6194fad0bc53575534101bb1de5d67e8ce"}, |     {file = "regex-2021.4.4-cp37-cp37m-manylinux2014_i686.whl", hash = "sha256:919859aa909429fb5aa9cf8807f6045592c85ef56fdd30a9a3747e513db2536e"}, | ||||||
|     {file = "regex-2021.3.17-cp37-cp37m-manylinux2014_x86_64.whl", hash = "sha256:4c0788010a93ace8a174d73e7c6c9d3e6e3b7ad99a453c8ee8c975ddd9965643"}, |     {file = "regex-2021.4.4-cp37-cp37m-manylinux2014_x86_64.whl", hash = "sha256:339456e7d8c06dd36a22e451d58ef72cef293112b559010db3d054d5560ef439"}, | ||||||
|     {file = "regex-2021.3.17-cp37-cp37m-win32.whl", hash = "sha256:575a832e09d237ae5fedb825a7a5bc6a116090dd57d6417d4f3b75121c73e3be"}, |     {file = "regex-2021.4.4-cp37-cp37m-win32.whl", hash = "sha256:67bdb9702427ceddc6ef3dc382455e90f785af4c13d495f9626861763ee13f9d"}, | ||||||
|     {file = "regex-2021.3.17-cp37-cp37m-win_amd64.whl", hash = "sha256:8e65e3e4c6feadf6770e2ad89ad3deb524bcb03d8dc679f381d0568c024e0deb"}, |     {file = "regex-2021.4.4-cp37-cp37m-win_amd64.whl", hash = "sha256:32e65442138b7b76dd8173ffa2cf67356b7bc1768851dded39a7a13bf9223da3"}, | ||||||
|     {file = "regex-2021.3.17-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:a0df9a0ad2aad49ea3c7f65edd2ffb3d5c59589b85992a6006354f6fb109bb18"}, |     {file = "regex-2021.4.4-cp38-cp38-macosx_10_9_x86_64.whl", hash = "sha256:1e1c20e29358165242928c2de1482fb2cf4ea54a6a6dea2bd7a0e0d8ee321500"}, | ||||||
|     {file = "regex-2021.3.17-cp38-cp38-manylinux1_i686.whl", hash = "sha256:b98bc9db003f1079caf07b610377ed1ac2e2c11acc2bea4892e28cc5b509d8d5"}, |     {file = "regex-2021.4.4-cp38-cp38-manylinux1_i686.whl", hash = "sha256:314d66636c494ed9c148a42731b3834496cc9a2c4251b1661e40936814542b14"}, | ||||||
|     {file = "regex-2021.3.17-cp38-cp38-manylinux1_x86_64.whl", hash = "sha256:808404898e9a765e4058bf3d7607d0629000e0a14a6782ccbb089296b76fa8fe"}, |     {file = "regex-2021.4.4-cp38-cp38-manylinux1_x86_64.whl", hash = "sha256:6d1b01031dedf2503631d0903cb563743f397ccaf6607a5e3b19a3d76fc10480"}, | ||||||
|     {file = "regex-2021.3.17-cp38-cp38-manylinux2010_i686.whl", hash = "sha256:5770a51180d85ea468234bc7987f5597803a4c3d7463e7323322fe4a1b181578"}, |     {file = "regex-2021.4.4-cp38-cp38-manylinux2010_i686.whl", hash = "sha256:741a9647fcf2e45f3a1cf0e24f5e17febf3efe8d4ba1281dcc3aa0459ef424dc"}, | ||||||
|     {file = "regex-2021.3.17-cp38-cp38-manylinux2010_x86_64.whl", hash = "sha256:976a54d44fd043d958a69b18705a910a8376196c6b6ee5f2596ffc11bff4420d"}, |     {file = "regex-2021.4.4-cp38-cp38-manylinux2010_x86_64.whl", hash = "sha256:4c46e22a0933dd783467cf32b3516299fb98cfebd895817d685130cc50cd1093"}, | ||||||
|     {file = "regex-2021.3.17-cp38-cp38-manylinux2014_aarch64.whl", hash = "sha256:63f3ca8451e5ff7133ffbec9eda641aeab2001be1a01878990f6c87e3c44b9d5"}, |     {file = "regex-2021.4.4-cp38-cp38-manylinux2014_aarch64.whl", hash = "sha256:e512d8ef5ad7b898cdb2d8ee1cb09a8339e4f8be706d27eaa180c2f177248a10"}, | ||||||
|     {file = "regex-2021.3.17-cp38-cp38-manylinux2014_i686.whl", hash = "sha256:bcd945175c29a672f13fce13a11893556cd440e37c1b643d6eeab1988c8b209c"}, |     {file = "regex-2021.4.4-cp38-cp38-manylinux2014_i686.whl", hash = "sha256:980d7be47c84979d9136328d882f67ec5e50008681d94ecc8afa8a65ed1f4a6f"}, | ||||||
|     {file = "regex-2021.3.17-cp38-cp38-manylinux2014_x86_64.whl", hash = "sha256:3d9356add82cff75413bec360c1eca3e58db4a9f5dafa1f19650958a81e3249d"}, |     {file = "regex-2021.4.4-cp38-cp38-manylinux2014_x86_64.whl", hash = "sha256:ce15b6d103daff8e9fee13cf7f0add05245a05d866e73926c358e871221eae87"}, | ||||||
|     {file = "regex-2021.3.17-cp38-cp38-win32.whl", hash = "sha256:f5d0c921c99297354cecc5a416ee4280bd3f20fd81b9fb671ca6be71499c3fdf"}, |     {file = "regex-2021.4.4-cp38-cp38-win32.whl", hash = "sha256:a91aa8619b23b79bcbeb37abe286f2f408d2f2d6f29a17237afda55bb54e7aac"}, | ||||||
|     {file = "regex-2021.3.17-cp38-cp38-win_amd64.whl", hash = "sha256:14de88eda0976020528efc92d0a1f8830e2fb0de2ae6005a6fc4e062553031fa"}, |     {file = "regex-2021.4.4-cp38-cp38-win_amd64.whl", hash = "sha256:c0502c0fadef0d23b128605d69b58edb2c681c25d44574fc673b0e52dce71ee2"}, | ||||||
|     {file = "regex-2021.3.17-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:4c2e364491406b7888c2ad4428245fc56c327e34a5dfe58fd40df272b3c3dab3"}, |     {file = "regex-2021.4.4-cp39-cp39-macosx_10_9_x86_64.whl", hash = "sha256:598585c9f0af8374c28edd609eb291b5726d7cbce16be6a8b95aa074d252ee17"}, | ||||||
|     {file = "regex-2021.3.17-cp39-cp39-manylinux1_i686.whl", hash = "sha256:8bd4f91f3fb1c9b1380d6894bd5b4a519409135bec14c0c80151e58394a4e88a"}, |     {file = "regex-2021.4.4-cp39-cp39-manylinux1_i686.whl", hash = "sha256:ee54ff27bf0afaf4c3b3a62bcd016c12c3fdb4ec4f413391a90bd38bc3624605"}, | ||||||
|     {file = "regex-2021.3.17-cp39-cp39-manylinux1_x86_64.whl", hash = "sha256:882f53afe31ef0425b405a3f601c0009b44206ea7f55ee1c606aad3cc213a52c"}, |     {file = "regex-2021.4.4-cp39-cp39-manylinux1_x86_64.whl", hash = "sha256:7d9884d86dd4dd489e981d94a65cd30d6f07203d90e98f6f657f05170f6324c9"}, | ||||||
|     {file = "regex-2021.3.17-cp39-cp39-manylinux2010_i686.whl", hash = "sha256:07ef35301b4484bce843831e7039a84e19d8d33b3f8b2f9aab86c376813d0139"}, |     {file = "regex-2021.4.4-cp39-cp39-manylinux2010_i686.whl", hash = "sha256:bf5824bfac591ddb2c1f0a5f4ab72da28994548c708d2191e3b87dd207eb3ad7"}, | ||||||
|     {file = "regex-2021.3.17-cp39-cp39-manylinux2010_x86_64.whl", hash = "sha256:360a01b5fa2ad35b3113ae0c07fb544ad180603fa3b1f074f52d98c1096fa15e"}, |     {file = "regex-2021.4.4-cp39-cp39-manylinux2010_x86_64.whl", hash = "sha256:563085e55b0d4fb8f746f6a335893bda5c2cef43b2f0258fe1020ab1dd874df8"}, | ||||||
|     {file = "regex-2021.3.17-cp39-cp39-manylinux2014_aarch64.whl", hash = "sha256:709f65bb2fa9825f09892617d01246002097f8f9b6dde8d1bb4083cf554701ba"}, |     {file = "regex-2021.4.4-cp39-cp39-manylinux2014_aarch64.whl", hash = "sha256:b9c3db21af35e3b3c05764461b262d6f05bbca08a71a7849fd79d47ba7bc33ed"}, | ||||||
|     {file = "regex-2021.3.17-cp39-cp39-manylinux2014_i686.whl", hash = "sha256:c66221e947d7207457f8b6f42b12f613b09efa9669f65a587a2a71f6a0e4d106"}, |     {file = "regex-2021.4.4-cp39-cp39-manylinux2014_i686.whl", hash = "sha256:3916d08be28a1149fb97f7728fca1f7c15d309a9f9682d89d79db75d5e52091c"}, | ||||||
|     {file = "regex-2021.3.17-cp39-cp39-manylinux2014_x86_64.whl", hash = "sha256:c782da0e45aff131f0bed6e66fbcfa589ff2862fc719b83a88640daa01a5aff7"}, |     {file = "regex-2021.4.4-cp39-cp39-manylinux2014_x86_64.whl", hash = "sha256:fd45ff9293d9274c5008a2054ecef86a9bfe819a67c7be1afb65e69b405b3042"}, | ||||||
|     {file = "regex-2021.3.17-cp39-cp39-win32.whl", hash = "sha256:dc9963aacb7da5177e40874585d7407c0f93fb9d7518ec58b86e562f633f36cd"}, |     {file = "regex-2021.4.4-cp39-cp39-win32.whl", hash = "sha256:fa4537fb4a98fe8fde99626e4681cc644bdcf2a795038533f9f711513a862ae6"}, | ||||||
|     {file = "regex-2021.3.17-cp39-cp39-win_amd64.whl", hash = "sha256:a0d04128e005142260de3733591ddf476e4902c0c23c1af237d9acf3c96e1b38"}, |     {file = "regex-2021.4.4-cp39-cp39-win_amd64.whl", hash = "sha256:97f29f57d5b84e73fbaf99ab3e26134e6687348e95ef6b48cfd2c06807005a07"}, | ||||||
|     {file = "regex-2021.3.17.tar.gz", hash = "sha256:4b8a1fb724904139149a43e172850f35aa6ea97fb0545244dc0b805e0154ed68"}, |     {file = "regex-2021.4.4.tar.gz", hash = "sha256:52ba3d3f9b942c49d7e4bc105bb28551c44065f139a65062ab7912bef10c9afb"}, | ||||||
| ] | ] | ||||||
| six = [ | six = [ | ||||||
|     {file = "six-1.15.0-py2.py3-none-any.whl", hash = "sha256:8b74bedcbbbaca38ff6d7491d76f2b06b3592611af620f8426e82dddb04a5ced"}, |     {file = "six-1.15.0-py2.py3-none-any.whl", hash = "sha256:8b74bedcbbbaca38ff6d7491d76f2b06b3592611af620f8426e82dddb04a5ced"}, | ||||||
|     {file = "six-1.15.0.tar.gz", hash = "sha256:30639c035cdb23534cd4aa2dd52c3bf48f06e5f4a941509c8bafd8ce11080259"}, |     {file = "six-1.15.0.tar.gz", hash = "sha256:30639c035cdb23534cd4aa2dd52c3bf48f06e5f4a941509c8bafd8ce11080259"}, | ||||||
| ] | ] | ||||||
| smmap = [ | smmap = [ | ||||||
|     {file = "smmap-3.0.5-py2.py3-none-any.whl", hash = "sha256:7bfcf367828031dc893530a29cb35eb8c8f2d7c8f2d0989354d75d24c8573714"}, |     {file = "smmap-4.0.0-py2.py3-none-any.whl", hash = "sha256:a9a7479e4c572e2e775c404dcd3080c8dc49f39918c2cf74913d30c4c478e3c2"}, | ||||||
|     {file = "smmap-3.0.5.tar.gz", hash = "sha256:84c2751ef3072d4f6b2785ec7ee40244c6f45eb934d9e543e2c51f1bd3d54c50"}, |     {file = "smmap-4.0.0.tar.gz", hash = "sha256:7e65386bd122d45405ddf795637b7f7d2b532e7e401d46bbe3fb49b9986d5182"}, | ||||||
| ] | ] | ||||||
| stevedore = [ | stevedore = [ | ||||||
|     {file = "stevedore-3.3.0-py3-none-any.whl", hash = "sha256:50d7b78fbaf0d04cd62411188fa7eedcb03eb7f4c4b37005615ceebe582aa82a"}, |     {file = "stevedore-3.3.0-py3-none-any.whl", hash = "sha256:50d7b78fbaf0d04cd62411188fa7eedcb03eb7f4c4b37005615ceebe582aa82a"}, | ||||||
| @@ -942,8 +937,8 @@ toml = [ | |||||||
|     {file = "toml-0.10.2.tar.gz", hash = "sha256:b3bda1d108d5dd99f4a20d24d9c348e91c4db7ab1b749200bded2f839ccbe68f"}, |     {file = "toml-0.10.2.tar.gz", hash = "sha256:b3bda1d108d5dd99f4a20d24d9c348e91c4db7ab1b749200bded2f839ccbe68f"}, | ||||||
| ] | ] | ||||||
| tortoise-orm = [ | tortoise-orm = [ | ||||||
|     {file = "tortoise-orm-0.17.0.tar.gz", hash = "sha256:d59c9ba2e8f3bb165f6ba7880ae0f0127659aa143750de419850a06329ca27ff"}, |     {file = "tortoise-orm-0.17.1.tar.gz", hash = "sha256:07816a575a1cdf31f212042f4ec399028540cd543f85ad0577531eccb5dc9453"}, | ||||||
|     {file = "tortoise_orm-0.17.0-py3-none-any.whl", hash = "sha256:39da891a61871a9e5e980007776c7d1f9b61e6b8601eb6482c90f89b30334638"}, |     {file = "tortoise_orm-0.17.1-py3-none-any.whl", hash = "sha256:34eeca18d8266806f5c1028e5fd94e46d07554ea615927d660da4a266801c8e8"}, | ||||||
| ] | ] | ||||||
| typed-ast = [ | typed-ast = [ | ||||||
|     {file = "typed_ast-1.4.2-cp35-cp35m-manylinux1_i686.whl", hash = "sha256:7703620125e4fb79b64aa52427ec192822e9f45d37d4b6625ab37ef403e1df70"}, |     {file = "typed_ast-1.4.2-cp35-cp35m-manylinux1_i686.whl", hash = "sha256:7703620125e4fb79b64aa52427ec192822e9f45d37d4b6625ab37ef403e1df70"}, | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| [tool.poetry] | [tool.poetry] | ||||||
| name = "aerich" | name = "aerich" | ||||||
| version = "0.5.2" | version = "0.5.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" | ||||||
| @@ -27,7 +27,7 @@ dictdiffer = "*" | |||||||
| [tool.poetry.dev-dependencies] | [tool.poetry.dev-dependencies] | ||||||
| flake8 = "*" | flake8 = "*" | ||||||
| isort = "*" | isort = "*" | ||||||
| black = "^20.8b1" | black = "19.10b0" | ||||||
| pytest = "*" | pytest = "*" | ||||||
| pytest-xdist = "*" | pytest-xdist = "*" | ||||||
| pytest-asyncio = "*" | pytest-asyncio = "*" | ||||||
|   | |||||||
| @@ -1,4 +1,5 @@ | |||||||
| import datetime | import datetime | ||||||
|  | import uuid | ||||||
| from enum import IntEnum | from enum import IntEnum | ||||||
|  |  | ||||||
| from tortoise import Model, fields | from tortoise import Model, fields | ||||||
| @@ -38,9 +39,13 @@ class Email(Model): | |||||||
|     users = fields.ManyToManyField("models.User") |     users = fields.ManyToManyField("models.User") | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def default_name(): | ||||||
|  |     return uuid.uuid4() | ||||||
|  |  | ||||||
|  |  | ||||||
| class Category(Model): | class Category(Model): | ||||||
|     slug = fields.CharField(max_length=100) |     slug = fields.CharField(max_length=100) | ||||||
|     name = fields.CharField(max_length=200, null=True) |     name = fields.CharField(max_length=200, null=True, default=default_name) | ||||||
|     user = fields.ForeignKeyField("models.User", description="User") |     user = fields.ForeignKeyField("models.User", description="User") | ||||||
|     created_at = fields.DatetimeField(auto_now_add=True) |     created_at = fields.DatetimeField(auto_now_add=True) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -95,13 +95,11 @@ def test_modify_column(): | |||||||
| def test_alter_column_default(): | def test_alter_column_default(): | ||||||
|     if isinstance(Migrate.ddl, SqliteDDL): |     if isinstance(Migrate.ddl, SqliteDDL): | ||||||
|         return |         return | ||||||
|     ret = Migrate.ddl.alter_column_default( |     ret = Migrate.ddl.alter_column_default(User, User._meta.fields_map.get("intro").describe(False)) | ||||||
|         Category, Category._meta.fields_map.get("name").describe(False) |  | ||||||
|     ) |  | ||||||
|     if isinstance(Migrate.ddl, PostgresDDL): |     if isinstance(Migrate.ddl, PostgresDDL): | ||||||
|         assert ret == 'ALTER TABLE "category" ALTER COLUMN "name" DROP DEFAULT' |         assert ret == 'ALTER TABLE "user" ALTER COLUMN "intro" SET DEFAULT \'\'' | ||||||
|     elif isinstance(Migrate.ddl, MysqlDDL): |     elif isinstance(Migrate.ddl, MysqlDDL): | ||||||
|         assert ret == "ALTER TABLE `category` ALTER COLUMN `name` DROP DEFAULT" |         assert ret == "ALTER TABLE `user` ALTER COLUMN `intro` SET DEFAULT ''" | ||||||
|  |  | ||||||
|     ret = Migrate.ddl.alter_column_default( |     ret = Migrate.ddl.alter_column_default( | ||||||
|         Category, Category._meta.fields_map.get("created_at").describe(False) |         Category, Category._meta.fields_map.get("created_at").describe(False) | ||||||
|   | |||||||
| @@ -832,7 +832,7 @@ def test_migrate(mocker: MockerFixture): | |||||||
|     elif isinstance(Migrate.ddl, PostgresDDL): |     elif isinstance(Migrate.ddl, PostgresDDL): | ||||||
|         assert sorted(Migrate.upgrade_operators) == sorted( |         assert sorted(Migrate.upgrade_operators) == sorted( | ||||||
|             [ |             [ | ||||||
|                 'ALTER TABLE "category" ALTER COLUMN "name" TYPE VARCHAR(200) USING "name"::VARCHAR(200)', |                 'ALTER TABLE "category" ALTER COLUMN "name" DROP NOT NULL', | ||||||
|                 'ALTER TABLE "category" ALTER COLUMN "slug" TYPE VARCHAR(100) USING "slug"::VARCHAR(100)', |                 'ALTER TABLE "category" ALTER COLUMN "slug" TYPE VARCHAR(100) USING "slug"::VARCHAR(100)', | ||||||
|                 'ALTER TABLE "config" ADD "user_id" INT NOT NULL', |                 'ALTER TABLE "config" ADD "user_id" INT NOT NULL', | ||||||
|                 'ALTER TABLE "config" ADD CONSTRAINT "fk_config_user_17daa970" FOREIGN KEY ("user_id") REFERENCES "user" ("id") ON DELETE CASCADE', |                 'ALTER TABLE "config" ADD CONSTRAINT "fk_config_user_17daa970" FOREIGN KEY ("user_id") REFERENCES "user" ("id") ON DELETE CASCADE', | ||||||
| @@ -855,7 +855,7 @@ def test_migrate(mocker: MockerFixture): | |||||||
|         ) |         ) | ||||||
|         assert sorted(Migrate.downgrade_operators) == sorted( |         assert sorted(Migrate.downgrade_operators) == sorted( | ||||||
|             [ |             [ | ||||||
|                 'ALTER TABLE "category" ALTER COLUMN "name" TYPE VARCHAR(200) USING "name"::VARCHAR(200)', |                 'ALTER TABLE "category" ALTER COLUMN "name" SET NOT NULL', | ||||||
|                 'ALTER TABLE "category" ALTER COLUMN "slug" TYPE VARCHAR(200) USING "slug"::VARCHAR(200)', |                 'ALTER TABLE "category" ALTER COLUMN "slug" TYPE VARCHAR(200) USING "slug"::VARCHAR(200)', | ||||||
|                 'ALTER TABLE "user" ALTER COLUMN "password" TYPE VARCHAR(200) USING "password"::VARCHAR(200)', |                 'ALTER TABLE "user" ALTER COLUMN "password" TYPE VARCHAR(200) USING "password"::VARCHAR(200)', | ||||||
|                 'ALTER TABLE "config" DROP COLUMN "user_id"', |                 'ALTER TABLE "config" DROP COLUMN "user_id"', | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user