mirror of
				https://github.com/mealie-recipes/mealie.git
				synced 2025-10-30 17:53:31 -04:00 
			
		
		
		
	* 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
		
			
				
	
	
		
			20 lines
		
	
	
		
			665 B
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			20 lines
		
	
	
		
			665 B
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { BaseCRUDAPI } from "../_base";
 | |
| import { UnlockResults, UserIn, UserOut } from "~/types/api-types/user";
 | |
| 
 | |
| const prefix = "/api";
 | |
| 
 | |
| const routes = {
 | |
|   adminUsers: `${prefix}/admin/users`,
 | |
|   adminUsersId: (tag: string) => `${prefix}/admin/users/${tag}`,
 | |
|   adminResetLockedUsers: (force: boolean) => `${prefix}/admin/users/unlock?force=${force ? "true" : "false"}`,
 | |
| };
 | |
| 
 | |
| export class AdminUsersApi extends BaseCRUDAPI<UserIn, UserOut, UserOut> {
 | |
|   baseRoute: string = routes.adminUsers;
 | |
|   itemRoute = routes.adminUsersId;
 | |
| 
 | |
|   async unlockAllUsers(force = false) {
 | |
|     return await this.requests.post<UnlockResults>(routes.adminResetLockedUsers(force), {});
 | |
|   }
 | |
| }
 |