base setup
This commit is contained in:
@@ -0,0 +1,66 @@
|
||||
# Generated by Django 5.2.6 on 2025-12-29 05:20
|
||||
|
||||
import django.db.models.deletion
|
||||
import django.utils.timezone
|
||||
import uuid
|
||||
from django.conf import settings
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
initial = True
|
||||
|
||||
dependencies = [
|
||||
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.CreateModel(
|
||||
name='SessionConsentModel',
|
||||
fields=[
|
||||
('id', models.UUIDField(default=uuid.uuid4, editable=False, primary_key=True, serialize=False)),
|
||||
('session_id', models.CharField(max_length=255, unique=True)),
|
||||
('accept_all_consent_received', models.BooleanField(default=False)),
|
||||
('essential_only_consent_received', models.BooleanField(default=False)),
|
||||
('received_on', models.DateTimeField(auto_now_add=True)),
|
||||
],
|
||||
options={
|
||||
'abstract': False,
|
||||
},
|
||||
),
|
||||
migrations.CreateModel(
|
||||
name='GeolocationCache',
|
||||
fields=[
|
||||
('id', models.UUIDField(default=uuid.uuid4, editable=False, primary_key=True, serialize=False)),
|
||||
('ip_address', models.CharField(max_length=45, unique=True)),
|
||||
('location', models.CharField(max_length=255)),
|
||||
('last_updated', models.DateTimeField(auto_now=True)),
|
||||
('request_count', models.PositiveIntegerField(default=0)),
|
||||
],
|
||||
options={
|
||||
'indexes': [models.Index(fields=['ip_address'], name='user_activi_ip_addr_664fe3_idx')],
|
||||
},
|
||||
),
|
||||
migrations.CreateModel(
|
||||
name='PageVisit',
|
||||
fields=[
|
||||
('id', models.UUIDField(default=uuid.uuid4, editable=False, primary_key=True, serialize=False)),
|
||||
('session_id', models.CharField(max_length=255)),
|
||||
('url', models.CharField(max_length=255)),
|
||||
('ip_address', models.CharField(max_length=45)),
|
||||
('query_params', models.TextField(blank=True, null=True)),
|
||||
('timestamp', models.DateTimeField(default=django.utils.timezone.now)),
|
||||
('path', models.CharField(max_length=512)),
|
||||
('user_agent', models.TextField(blank=True, null=True)),
|
||||
('session_data', models.JSONField(blank=True, default=dict, null=True)),
|
||||
('location', models.CharField(blank=True, max_length=64, null=True)),
|
||||
('country', models.CharField(blank=True, max_length=64, null=True)),
|
||||
('user', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, to=settings.AUTH_USER_MODEL)),
|
||||
],
|
||||
options={
|
||||
'ordering': ['-timestamp'],
|
||||
'indexes': [models.Index(fields=['session_id', 'timestamp'], name='user_activi_session_a322d8_idx')],
|
||||
},
|
||||
),
|
||||
]
|
||||
@@ -0,0 +1,125 @@
|
||||
# Generated by Django 5.2.6 on 2026-01-05 04:33
|
||||
|
||||
import django.db.models.deletion
|
||||
import uuid
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
('user_activity', '0001_initial'),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.CreateModel(
|
||||
name='ClickEvent',
|
||||
fields=[
|
||||
('id', models.UUIDField(default=uuid.uuid4, editable=False, primary_key=True, serialize=False)),
|
||||
('page_path', models.CharField(blank=True, max_length=512, null=True)),
|
||||
('element_text', models.CharField(blank=True, max_length=255, null=True)),
|
||||
('element_type', models.CharField(blank=True, max_length=50, null=True)),
|
||||
('timestamp', models.DateTimeField(auto_now_add=True, null=True)),
|
||||
],
|
||||
options={
|
||||
'abstract': False,
|
||||
},
|
||||
),
|
||||
migrations.CreateModel(
|
||||
name='DailyUserStats',
|
||||
fields=[
|
||||
('id', models.UUIDField(default=uuid.uuid4, editable=False, primary_key=True, serialize=False)),
|
||||
('date', models.DateField(blank=True, null=True, unique=True)),
|
||||
('new_users', models.PositiveIntegerField(blank=True, null=True)),
|
||||
('returning_users', models.PositiveIntegerField(blank=True, null=True)),
|
||||
('created_at', models.DateTimeField(auto_now_add=True, null=True)),
|
||||
],
|
||||
options={
|
||||
'abstract': False,
|
||||
},
|
||||
),
|
||||
migrations.CreateModel(
|
||||
name='VisitorModel',
|
||||
fields=[
|
||||
('id', models.UUIDField(default=uuid.uuid4, editable=False, primary_key=True, serialize=False)),
|
||||
('visiter_number', models.IntegerField()),
|
||||
('session_id', models.CharField(max_length=255)),
|
||||
],
|
||||
options={
|
||||
'abstract': False,
|
||||
},
|
||||
),
|
||||
migrations.CreateModel(
|
||||
name='VisitorSession',
|
||||
fields=[
|
||||
('id', models.UUIDField(default=uuid.uuid4, editable=False, primary_key=True, serialize=False)),
|
||||
('session_id', models.CharField(blank=True, max_length=255, null=True, unique=True)),
|
||||
('is_bounce', models.BooleanField(blank=True, default=False, null=True)),
|
||||
('started_at', models.DateTimeField(auto_now_add=True, null=True)),
|
||||
('ended_at', models.DateTimeField(blank=True, null=True)),
|
||||
('duration_seconds', models.PositiveIntegerField(blank=True, default=0, null=True)),
|
||||
('visitor', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, to='user_activity.visitormodel')),
|
||||
],
|
||||
options={
|
||||
'abstract': False,
|
||||
},
|
||||
),
|
||||
migrations.DeleteModel(
|
||||
name='GeolocationCache',
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name='pagevisit',
|
||||
name='entered_at',
|
||||
field=models.DateTimeField(auto_now_add=True, null=True),
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name='pagevisit',
|
||||
name='exited_at',
|
||||
field=models.DateTimeField(blank=True, null=True),
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name='pagevisit',
|
||||
name='is_new_user',
|
||||
field=models.BooleanField(default=True),
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name='pagevisit',
|
||||
name='latitude',
|
||||
field=models.CharField(blank=True, max_length=64, null=True),
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name='pagevisit',
|
||||
name='longitude',
|
||||
field=models.CharField(blank=True, max_length=64, null=True),
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name='pagevisit',
|
||||
name='referrer',
|
||||
field=models.CharField(blank=True, max_length=512, null=True),
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name='pagevisit',
|
||||
name='time_spent_seconds',
|
||||
field=models.PositiveIntegerField(blank=True, default=0, null=True),
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name='pagevisit',
|
||||
name='visit_count',
|
||||
field=models.PositiveIntegerField(blank=True, default=1, null=True),
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name='clickevent',
|
||||
name='visitor',
|
||||
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, to='user_activity.visitormodel'),
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name='pagevisit',
|
||||
name='visitor',
|
||||
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='page_visits', to='user_activity.visitormodel'),
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name='clickevent',
|
||||
name='session',
|
||||
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='clicks', to='user_activity.visitorsession'),
|
||||
),
|
||||
]
|
||||
0
at_django_boilerplate/user_activity/migrations/__init__.py
Executable file
0
at_django_boilerplate/user_activity/migrations/__init__.py
Executable file
Binary file not shown.
Binary file not shown.
Binary file not shown.
Reference in New Issue
Block a user