refactor(meetings): increase encrypted field lengths and add ID to admin #41
@ -54,7 +54,7 @@ class AdminWeeklyAvailabilityAdmin(admin.ModelAdmin):
|
|||||||
|
|
||||||
@admin.register(AppointmentRequest)
|
@admin.register(AppointmentRequest)
|
||||||
class AppointmentRequestAdmin(admin.ModelAdmin):
|
class AppointmentRequestAdmin(admin.ModelAdmin):
|
||||||
list_display = ['full_name', 'email', 'status', 'formatted_created_at', 'formatted_scheduled_datetime']
|
list_display = ['id','full_name', 'email', 'status', 'formatted_created_at', 'formatted_scheduled_datetime']
|
||||||
list_filter = ['status', 'created_at', 'scheduled_datetime']
|
list_filter = ['status', 'created_at', 'scheduled_datetime']
|
||||||
search_fields = ['first_name', 'last_name', 'email']
|
search_fields = ['first_name', 'last_name', 'email']
|
||||||
readonly_fields = ['id', 'created_at', 'updated_at', 'formatted_created_at', 'formatted_scheduled_datetime']
|
readonly_fields = ['id', 'created_at', 'updated_at', 'formatted_created_at', 'formatted_scheduled_datetime']
|
||||||
|
|||||||
56
meetings/migrations/0001_initial.py
Normal file
56
meetings/migrations/0001_initial.py
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
# Generated by Django 5.2.8 on 2025-11-27 14:43
|
||||||
|
|
||||||
|
import meetings.models
|
||||||
|
import uuid
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
initial = True
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='AdminWeeklyAvailability',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('availability_schedule', models.JSONField(default=dict, help_text='Dictionary with days as keys and lists of time slots as values')),
|
||||||
|
('created_at', models.DateTimeField(auto_now_add=True)),
|
||||||
|
('updated_at', models.DateTimeField(auto_now=True)),
|
||||||
|
],
|
||||||
|
options={
|
||||||
|
'verbose_name': 'Admin Weekly Availability',
|
||||||
|
'verbose_name_plural': 'Admin Weekly Availability',
|
||||||
|
},
|
||||||
|
),
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='AppointmentRequest',
|
||||||
|
fields=[
|
||||||
|
('id', models.UUIDField(default=uuid.uuid4, editable=False, primary_key=True, serialize=False)),
|
||||||
|
('first_name', meetings.models.EncryptedCharField(max_length=255)),
|
||||||
|
('last_name', meetings.models.EncryptedCharField(max_length=255)),
|
||||||
|
('email', meetings.models.EncryptedEmailField(max_length=254)),
|
||||||
|
('phone', meetings.models.EncryptedCharField(blank=True, max_length=255)),
|
||||||
|
('reason', meetings.models.EncryptedTextField(blank=True)),
|
||||||
|
('preferred_dates', models.JSONField(help_text='List of preferred dates (YYYY-MM-DD format)')),
|
||||||
|
('preferred_time_slots', models.JSONField(help_text='List of preferred time slots (morning/afternoon/evening)')),
|
||||||
|
('status', models.CharField(choices=[('pending_review', 'Pending Review'), ('scheduled', 'Scheduled'), ('rejected', 'Rejected'), ('completed', 'Completed'), ('cancelled', 'Cancelled')], default='pending_review', max_length=20)),
|
||||||
|
('scheduled_datetime', models.DateTimeField(blank=True, null=True)),
|
||||||
|
('scheduled_duration', models.PositiveIntegerField(default=60, help_text='Duration in minutes')),
|
||||||
|
('rejection_reason', meetings.models.EncryptedTextField(blank=True)),
|
||||||
|
('jitsi_meet_url', models.URLField(blank=True, help_text='Jitsi Meet URL for the video session')),
|
||||||
|
('jitsi_room_id', models.CharField(blank=True, help_text='Jitsi room ID', max_length=100, unique=True)),
|
||||||
|
('created_at', models.DateTimeField(auto_now_add=True)),
|
||||||
|
('updated_at', models.DateTimeField(auto_now=True)),
|
||||||
|
],
|
||||||
|
options={
|
||||||
|
'verbose_name': 'Appointment Request',
|
||||||
|
'verbose_name_plural': 'Appointment Requests',
|
||||||
|
'ordering': ['-created_at'],
|
||||||
|
'indexes': [models.Index(fields=['status', 'scheduled_datetime'], name='meetings_ap_status_4e4e26_idx'), models.Index(fields=['email', 'created_at'], name='meetings_ap_email_b8ed9d_idx')],
|
||||||
|
},
|
||||||
|
),
|
||||||
|
]
|
||||||
@ -177,10 +177,10 @@ class AppointmentRequest(models.Model):
|
|||||||
]
|
]
|
||||||
|
|
||||||
id = models.UUIDField(primary_key=True, default=uuid.uuid4, editable=False)
|
id = models.UUIDField(primary_key=True, default=uuid.uuid4, editable=False)
|
||||||
first_name = EncryptedCharField(max_length=100)
|
first_name = EncryptedCharField(max_length=255)
|
||||||
last_name = EncryptedCharField(max_length=100)
|
last_name = EncryptedCharField(max_length=255)
|
||||||
email = EncryptedEmailField()
|
email = EncryptedEmailField()
|
||||||
phone = EncryptedCharField(max_length=20, blank=True)
|
phone = EncryptedCharField(max_length=255, blank=True)
|
||||||
reason = EncryptedTextField(blank=True)
|
reason = EncryptedTextField(blank=True)
|
||||||
|
|
||||||
preferred_dates = models.JSONField(
|
preferred_dates = models.JSONField(
|
||||||
|
|||||||
@ -287,7 +287,6 @@ class AppointmentScheduleSerializer(serializers.Serializer):
|
|||||||
return data
|
return data
|
||||||
|
|
||||||
def _convert_to_datetime(self, date_obj, time_slot):
|
def _convert_to_datetime(self, date_obj, time_slot):
|
||||||
"""Convert date and time slot to actual datetime"""
|
|
||||||
time_mapping = {
|
time_mapping = {
|
||||||
'morning': (9, 0),
|
'morning': (9, 0),
|
||||||
'afternoon': (13, 0),
|
'afternoon': (13, 0),
|
||||||
|
|||||||
54
users/migrations/0001_initial.py
Normal file
54
users/migrations/0001_initial.py
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
# Generated by Django 5.2.8 on 2025-11-27 14:43
|
||||||
|
|
||||||
|
import django.db.models.deletion
|
||||||
|
from django.conf import settings
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
initial = True
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('auth', '0012_alter_user_first_name_max_length'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='CustomUser',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('password', models.CharField(max_length=128, verbose_name='password')),
|
||||||
|
('email', models.EmailField(max_length=254, unique=True)),
|
||||||
|
('first_name', models.CharField(max_length=50)),
|
||||||
|
('last_name', models.CharField(max_length=50)),
|
||||||
|
('is_staff', models.BooleanField(default=False)),
|
||||||
|
('is_superuser', models.BooleanField(default=False)),
|
||||||
|
('is_active', models.BooleanField(default=True)),
|
||||||
|
('isVerified', models.BooleanField(default=False)),
|
||||||
|
('verify_otp', models.CharField(blank=True, max_length=6, null=True)),
|
||||||
|
('verify_otp_expiry', models.DateTimeField(blank=True, null=True)),
|
||||||
|
('forgot_password_otp', models.CharField(blank=True, max_length=6, null=True)),
|
||||||
|
('forgot_password_otp_expiry', models.DateTimeField(blank=True, null=True)),
|
||||||
|
('phone_number', models.CharField(blank=True, max_length=20)),
|
||||||
|
('last_login', models.DateTimeField(auto_now=True)),
|
||||||
|
('date_joined', models.DateTimeField(auto_now_add=True)),
|
||||||
|
('groups', models.ManyToManyField(blank=True, help_text='The groups this user belongs to. A user will get all permissions granted to each of their groups.', related_name='user_set', related_query_name='user', to='auth.group', verbose_name='groups')),
|
||||||
|
('user_permissions', models.ManyToManyField(blank=True, help_text='Specific permissions for this user.', related_name='user_set', related_query_name='user', to='auth.permission', verbose_name='user permissions')),
|
||||||
|
],
|
||||||
|
options={
|
||||||
|
'abstract': False,
|
||||||
|
},
|
||||||
|
),
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='UserProfile',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('bio', models.TextField(blank=True, max_length=500)),
|
||||||
|
('timezone', models.CharField(default='UTC', max_length=50)),
|
||||||
|
('created_at', models.DateTimeField(auto_now_add=True)),
|
||||||
|
('updated_at', models.DateTimeField(auto_now=True)),
|
||||||
|
('user', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, related_name='profile', to=settings.AUTH_USER_MODEL)),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
]
|
||||||
Loading…
Reference in New Issue
Block a user