Upload files to "base/manage/commands"

Signed-off-by: nestict <developer@nestict.com>
This commit is contained in:
2026-01-16 15:39:39 +01:00
parent 7ef7852d0e
commit 63e1843641
3 changed files with 174 additions and 0 deletions

View File

@@ -0,0 +1,75 @@
"""
Horilla management command to create a new user and associated employee.
"""
import uuid
from django.contrib.auth.models import User
from django.core.management.base import BaseCommand, CommandError
from employee.models import Employee
class Command(BaseCommand):
"""
Horilla management command to create a new user and associated employee.
"""
help = "Creates a new user"
def add_arguments(self, parser):
parser.add_argument("--first_name", type=str, help="First name of the new user")
parser.add_argument("--last_name", type=str, help="Last name of the new user")
parser.add_argument("--username", type=str, help="Username of the new user")
parser.add_argument("--password", type=str, help="Password for the new user")
parser.add_argument("--email", type=str, help="Email of the new user")
parser.add_argument("--phone", type=str, help="Phone number of the new user")
def handle(self, *args, **options):
if not options["first_name"]:
first_name = input("Enter first name: ")
last_name = input("Enter last name: ")
username = input("Enter username: ")
password = input("Enter password: ")
email = input("Enter email: ")
phone = input("Enter phone number: ")
else:
first_name = options["first_name"]
last_name = options["last_name"]
username = options["username"]
password = options["password"]
email = options["email"]
phone = options["phone"]
if User.objects.filter(username=username).exists():
self.stdout.write(
self.style.WARNING(f'User with username "{username}" already exists')
)
return
try:
user = User.objects.create_superuser(
username=username, email=email, password=password
)
employee = Employee()
employee.employee_user_id = user
employee.employee_first_name = first_name
employee.employee_last_name = last_name
employee.email = email
employee.phone = phone
employee.save()
bot = User.objects.filter(username="Horilla Bot").first()
if bot is None:
User.objects.create_user(
username="Horilla Bot",
password=str(uuid.uuid4()),
)
self.stdout.write(
self.style.SUCCESS(f'Employee "{employee}" created successfully')
)
except Exception as e:
if "user" in locals():
user.delete()
raise CommandError(f'Error creating user "{username}": {e}') from e

View File

@@ -0,0 +1,55 @@
import os
from django.apps import apps as django_apps
from django.conf import settings
from django.core.management import call_command
from django.core.management.base import BaseCommand
class Command(BaseCommand):
help = "Dump all relevant data to JSON files."
def handle(self, *args, **options):
folder_name = input("Enter the name of the folder to save JSON files: ").strip()
if not folder_name:
self.stderr.write(self.style.ERROR("Folder name cannot be empty."))
return
dump_dir = os.path.join(settings.BASE_DIR, folder_name)
os.makedirs(dump_dir, exist_ok=True)
data_files = [
("auth.User", "user_data.json"),
("employee.Employee", "employee_info_data.json"),
("base", "base_data.json"),
("employee.employeeworkinformation", "work_info_data.json"),
("employee.employeebankdetails", "bank_info_data.json"),
]
optional_apps = [
("attendance", "attendance_data.json"),
("leave", "leave_data.json"),
("asset", "asset_data.json"),
("recruitment", "recruitment_data.json"),
("onboarding", "onboarding_data.json"),
("offboarding", "offboarding_data.json"),
("pms", "pms_data.json"),
("payroll", "payroll_data.json"),
("payroll", "payroll_loanaccount_data.json"),
("project", "project_data.json"),
]
data_files += [
(app, file) for app, file in optional_apps if django_apps.is_installed(app)
]
for data in data_files:
output_path = os.path.join(dump_dir, data[1])
try:
with open(output_path, "w") as f:
call_command("dumpdata", data[0], stdout=f, indent=4)
self.stdout.write(self.style.SUCCESS(f"Dumped: {data[0]}"))
except Exception as e:
self.stderr.write(self.style.ERROR(f"Error dumping {data[0]}: {e}"))

View File

@@ -0,0 +1,44 @@
from django.apps import apps
from django.core.management.base import BaseCommand, CommandError
class Command(BaseCommand):
help = "Save all instances of the specified model"
def add_arguments(self, parser):
parser.add_argument(
"app_label", type=str, help="App label of the model (e.g., attendance)"
)
parser.add_argument(
"model_name",
type=str,
help="Name of the model to save instances for (e.g., Attendance)",
)
def handle(self, *args, **kwargs):
app_label = kwargs["app_label"]
model_name = kwargs["model_name"]
try:
model = apps.get_model(app_label, model_name)
except LookupError:
raise CommandError(
f"Model '{model_name}' not found in the app '{app_label}'."
)
try:
instances = model.objects.all()
print(
f"Saving {len(instances)} instances of '{model_name}' in app '{app_label}'. Please wait....."
)
for instance in instances:
instance.save()
self.stdout.write(
self.style.SUCCESS(
f"All instances of '{model_name}' in app '{app_label}' have been saved."
)
)
except Exception as e:
raise CommandError(
f"An error occurred while saving instances of '{model_name}' in app '{app_label}': {e}"
)