feat(cli): Integrate unlimited IP option for user creation

This commit is contained in:
Whispering Wind
2025-08-11 23:28:51 +03:30
committed by GitHub
parent eac13764e2
commit 85d2e8b81f
3 changed files with 20 additions and 11 deletions

View File

@ -130,9 +130,10 @@ def get_user(username: str):
@click.option('--expiration-days', '-e', required=True, help='Expiration days for the new user', type=int)
@click.option('--password', '-p', required=False, help='Password for the user', type=str)
@click.option('--creation-date', '-c', required=False, help='Creation date for the user (YYYY-MM-DD)', type=str)
def add_user(username: str, traffic_limit: int, expiration_days: int, password: str, creation_date: str):
@click.option('--unlimited', is_flag=True, default=True, help='Exempt user from IP limit checks.')
def add_user(username: str, traffic_limit: int, expiration_days: int, password: str, creation_date: str, unlimited: bool):
try:
cli_api.add_user(username, traffic_limit, expiration_days, password, creation_date)
cli_api.add_user(username, traffic_limit, expiration_days, password, creation_date, unlimited)
click.echo(f"User '{username}' added successfully.")
except Exception as e:
click.echo(f'{e}', err=True)

View File

@ -266,15 +266,23 @@ def get_user(username: str) -> dict[str, Any] | None:
return json.loads(res)
def add_user(username: str, traffic_limit: int, expiration_days: int, password: str | None, creation_date: str | None):
def add_user(username: str, traffic_limit: int, expiration_days: int, password: str | None, creation_date: str | None, unlimited: bool):
'''
Adds a new user with the given parameters.
Adds a new user with the given parameters, respecting positional argument requirements.
'''
if not password:
password = generate_password()
if not creation_date:
creation_date = datetime.now().strftime('%Y-%m-%d')
run_cmd(['python3', Command.ADD_USER.value, username, str(traffic_limit), str(expiration_days), password, creation_date])
command = ['python3', Command.ADD_USER.value, username, str(traffic_limit), str(expiration_days)]
if unlimited:
final_password = password if password else generate_password()
final_creation_date = creation_date if creation_date else datetime.now().strftime('%Y-%m-%d')
command.extend([final_password, final_creation_date, 'true'])
elif creation_date:
final_password = password if password else generate_password()
command.extend([final_password, creation_date])
elif password:
command.append(password)
run_cmd(command)
def edit_user(username: str, new_username: str | None, new_traffic_limit: int | None, new_expiration_days: int | None, renew_password: bool, renew_creation_date: bool, blocked: bool):

View File

@ -9,7 +9,7 @@ from datetime import datetime
from init_paths import *
from paths import *
def add_user(username, traffic_gb, expiration_days, password=None, creation_date=None, unlimited_user=False):
def add_user(username, traffic_gb, expiration_days, password=None, creation_date=None, unlimited_user=True):
"""
Adds a new user to the USERS_FILE.
@ -19,7 +19,7 @@ def add_user(username, traffic_gb, expiration_days, password=None, creation_date
expiration_days (str): The number of days until the account expires.
password (str, optional): The user's password. If None, a random one is generated.
creation_date (str, optional): The account creation date in YYYY-MM-DD format. If None, the current date is used.
unlimited_user (bool, optional): If True, user is exempt from IP limits. Defaults to False.
unlimited_user (bool, optional): If True, user is exempt from IP limits. Defaults to True.
Returns:
int: 0 on success, 1 on failure.