1
0
Fork 0
mirror of https://github.com/mealie-recipes/mealie.git synced 2025-07-19 05:09:40 +02:00

security: implement user lockout (#1552)

* add data-types required for login security

* implement user lockout checking at login

* cleanup legacy patterns

* expose passwords in test_user

* test user lockout after bad attempts

* test user service

* bump alembic version

* save increment to database

* add locked_at to datetime transformer on import

* do proper test cleanup

* implement scheduled task

* spelling

* document env variables

* implement context manager for session

* use context manager

* implement reset script

* cleanup generator

* run generator

* implement API endpoint for resetting locked users

* add button to reset all locked users

* add info when account is locked

* use ignore instead of expect-error
This commit is contained in:
Hayden 2022-08-13 13:18:12 -08:00 committed by GitHub
parent ca64584fd1
commit b3c41a4bd0
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
35 changed files with 450 additions and 46 deletions

View file

@ -99,24 +99,24 @@ def generate_typescript_types() -> None:
generate_typescript_defs(path_as_module, str(out_path), exclude=("MealieModel")) # type: ignore
except Exception as e:
failed_modules.append(module)
log.error(f"Module Error: {e}") # noqa
log.error(f"Module Error: {e}")
log.info("\n📁 Skipped Directories:") # noqa
log.info("\n📁 Skipped Directories:")
for skipped_dir in skipped_dirs:
log.info(" 📁", skipped_dir.name) # noqa
log.info(f" 📁 {skipped_dir.name}")
log.info("📄 Skipped Files:") # noqa
log.info("📄 Skipped Files:")
for f in skipped_files:
log.info(" 📄", f.name) # noqa
log.info(f" 📄 {f.name}")
log.error("❌ Failed Modules:") # noqa
log.error("❌ Failed Modules:")
for f in failed_modules:
log.error("", f.name) # noqa
log.error(f" {f.name}")
if __name__ == "__main__":
log.info("\n-- Starting Global Components Generator --") # noqa
log.info("\n-- Starting Global Components Generator --")
generate_global_components_types()
log.info("\n-- Starting Pydantic To Typescript Generator --") # noqa
log.info("\n-- Starting Pydantic To Typescript Generator --")
generate_typescript_types()