refactor all the things

This commit is contained in:
Tobias Brunner 2025-01-28 13:55:43 +01:00
parent 8ed39690f1
commit bb5cb708bd
No known key found for this signature in database
36 changed files with 1563 additions and 931 deletions

View file

@ -1,9 +1,43 @@
# Generated by Django 5.1.5 on 2025-01-27 12:25
# Generated by Django 5.1.5 on 2025-01-29 08:34
import django.db.models.deletion
import services.models
from django.db import migrations, models
def create_initial_currencies(apps, schema_editor):
Currency = apps.get_model("services", "Currency")
currencies = [
{"code": "USD", "name": "US Dollar", "symbol": "$"},
{"code": "CHF", "name": "Swiss Franc", "symbol": "CHF"},
{"code": "EUR", "name": "Euro", "symbol": ""},
]
for currency_data in currencies:
Currency.objects.create(**currency_data)
def create_initial_terms(apps, schema_editor):
Term = apps.get_model("services", "Term")
terms = [
{"name": "Monthly (30d)", "order": 1},
{"name": "Yearly", "order": 2},
{"name": "One-time", "order": 3},
]
for term_data in terms:
Term.objects.create(**term_data)
def create_initial_categories(apps, schema_editor):
Category = apps.get_model("services", "Category")
categories = [
{"name": "Database", "slug": "database", "order": 1},
{"name": "Cache", "slug": "cache", "order": 2},
{"name": "SaaS", "slug": "saas", "order": 3},
]
for category_data in categories:
Category.objects.create(**category_data)
class Migration(migrations.Migration):
initial = True
@ -24,11 +58,22 @@ class Migration(migrations.Migration):
),
),
("name", models.CharField(max_length=100)),
("description", models.TextField(blank=True)),
("slug", models.SlugField(unique=True)),
("description", models.TextField()),
("website", models.URLField()),
(
"logo",
models.ImageField(
blank=True,
null=True,
upload_to="cloud_provider_logos/",
validators=[services.models.validate_image_size],
),
),
],
),
migrations.CreateModel(
name="Country",
name="Currency",
fields=[
(
"id",
@ -39,15 +84,17 @@ class Migration(migrations.Migration):
verbose_name="ID",
),
),
("name", models.CharField(max_length=100)),
("code", models.CharField(max_length=2)),
("code", models.CharField(max_length=3, unique=True)),
("name", models.CharField(max_length=50)),
("symbol", models.CharField(max_length=5)),
],
options={
"verbose_name_plural": "Countries",
"verbose_name_plural": "Currencies",
"ordering": ["code"],
},
),
migrations.CreateModel(
name="ServiceLevel",
name="Plan",
fields=[
(
"id",
@ -60,8 +107,67 @@ class Migration(migrations.Migration):
),
("name", models.CharField(max_length=100)),
("description", models.TextField()),
("response_time", models.CharField(max_length=50)),
("is_default", models.BooleanField(default=False)),
("features", models.TextField(blank=True)),
("order", models.IntegerField(default=0)),
("created_at", models.DateTimeField(auto_now_add=True)),
("updated_at", models.DateTimeField(auto_now=True)),
],
options={
"ordering": ["order", "name"],
},
),
migrations.CreateModel(
name="Term",
fields=[
(
"id",
models.BigAutoField(
auto_created=True,
primary_key=True,
serialize=False,
verbose_name="ID",
),
),
("name", models.CharField(max_length=100)),
("description", models.TextField(blank=True)),
("order", models.IntegerField(default=0)),
],
options={
"ordering": ["order", "name"],
},
),
migrations.CreateModel(
name="Category",
fields=[
(
"id",
models.BigAutoField(
auto_created=True,
primary_key=True,
serialize=False,
verbose_name="ID",
),
),
("name", models.CharField(max_length=100)),
("slug", models.SlugField(unique=True)),
("description", models.TextField(blank=True)),
("order", models.IntegerField(default=0)),
(
"parent",
models.ForeignKey(
blank=True,
null=True,
on_delete=django.db.models.deletion.CASCADE,
related_name="children",
to="services.category",
),
),
],
options={
"verbose_name_plural": "Categories",
"ordering": ["order", "name"],
},
),
migrations.CreateModel(
name="Service",
@ -76,26 +182,235 @@ class Migration(migrations.Migration):
),
),
("name", models.CharField(max_length=200)),
("slug", models.SlugField(max_length=250, unique=True)),
("description", models.TextField()),
("price", models.DecimalField(decimal_places=2, max_digits=10)),
(
"logo",
models.ImageField(
blank=True,
null=True,
upload_to="service_logos/",
validators=[services.models.validate_image_size],
),
),
("features", models.TextField()),
("created_at", models.DateTimeField(auto_now_add=True)),
("updated_at", models.DateTimeField(auto_now=True)),
(
"categories",
models.ManyToManyField(
related_name="services", to="services.category"
),
),
],
),
migrations.CreateModel(
name="Lead",
fields=[
(
"id",
models.BigAutoField(
auto_created=True,
primary_key=True,
serialize=False,
verbose_name="ID",
),
),
("name", models.CharField(max_length=200)),
("company", models.CharField(max_length=200)),
("email", models.EmailField(max_length=254)),
("phone", models.CharField(max_length=50)),
("created_at", models.DateTimeField(auto_now_add=True)),
("odoo_lead_id", models.IntegerField(blank=True, null=True)),
(
"plan",
models.ForeignKey(
blank=True,
null=True,
on_delete=django.db.models.deletion.SET_NULL,
to="services.plan",
),
),
(
"service",
models.ForeignKey(
on_delete=django.db.models.deletion.CASCADE,
to="services.service",
),
),
],
),
migrations.CreateModel(
name="ExternalLink",
fields=[
(
"id",
models.BigAutoField(
auto_created=True,
primary_key=True,
serialize=False,
verbose_name="ID",
),
),
("url", models.URLField()),
("description", models.CharField(max_length=200)),
("order", models.IntegerField(default=0)),
("created_at", models.DateTimeField(auto_now_add=True)),
("updated_at", models.DateTimeField(auto_now=True)),
(
"service",
models.ForeignKey(
on_delete=django.db.models.deletion.CASCADE,
related_name="external_links",
to="services.service",
),
),
],
options={
"verbose_name": "External Link",
"verbose_name_plural": "External Links",
"ordering": ["order", "description"],
},
),
migrations.CreateModel(
name="ConsultingPartner",
fields=[
(
"id",
models.BigAutoField(
auto_created=True,
primary_key=True,
serialize=False,
verbose_name="ID",
),
),
("name", models.CharField(max_length=200)),
("slug", models.SlugField(unique=True)),
("description", models.TextField()),
(
"logo",
models.ImageField(
blank=True,
null=True,
upload_to="partner_logos/",
validators=[services.models.validate_image_size],
),
),
("website", models.URLField(blank=True)),
("created_at", models.DateTimeField(auto_now_add=True)),
("updated_at", models.DateTimeField(auto_now=True)),
(
"cloud_providers",
models.ManyToManyField(
blank=True,
related_name="consulting_partners",
to="services.cloudprovider",
),
),
(
"services",
models.ManyToManyField(
related_name="consulting_partners", to="services.service"
),
),
],
),
migrations.CreateModel(
name="ServiceOffering",
fields=[
(
"id",
models.BigAutoField(
auto_created=True,
primary_key=True,
serialize=False,
verbose_name="ID",
),
),
("slug", models.SlugField(max_length=250, unique=True)),
(
"description",
models.TextField(
help_text="Provider-specific details and features"
),
),
("created_at", models.DateTimeField(auto_now_add=True)),
("updated_at", models.DateTimeField(auto_now=True)),
(
"cloud_provider",
models.ForeignKey(
on_delete=django.db.models.deletion.CASCADE,
related_name="offerings",
to="services.cloudprovider",
),
),
("countries", models.ManyToManyField(to="services.country")),
(
"service_level",
"service",
models.ForeignKey(
on_delete=django.db.models.deletion.CASCADE,
to="services.servicelevel",
related_name="offerings",
to="services.service",
),
),
],
options={
"ordering": ["service__name", "cloud_provider__name"],
"unique_together": {("service", "cloud_provider")},
},
),
migrations.AddField(
model_name="plan",
name="offering",
field=models.ForeignKey(
on_delete=django.db.models.deletion.CASCADE,
related_name="plans",
to="services.serviceoffering",
),
),
migrations.AlterUniqueTogether(
name="plan",
unique_together={("offering", "name")},
),
migrations.CreateModel(
name="PlanPrice",
fields=[
(
"id",
models.BigAutoField(
auto_created=True,
primary_key=True,
serialize=False,
verbose_name="ID",
),
),
("price", models.DecimalField(decimal_places=2, max_digits=10)),
(
"currency",
models.ForeignKey(
on_delete=django.db.models.deletion.PROTECT,
to="services.currency",
),
),
(
"plan",
models.ForeignKey(
on_delete=django.db.models.deletion.CASCADE,
related_name="prices",
to="services.plan",
),
),
(
"term",
models.ForeignKey(
on_delete=django.db.models.deletion.PROTECT, to="services.term"
),
),
],
options={
"unique_together": {("plan", "currency", "term")},
},
),
migrations.RunPython(create_initial_currencies),
migrations.RunPython(create_initial_terms),
migrations.RunPython(create_initial_categories),
]

View file

@ -1,34 +0,0 @@
# Generated by Django 5.1.5 on 2025-01-27 14:10
import services.models
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
("services", "0001_initial"),
]
operations = [
migrations.AddField(
model_name="cloudprovider",
name="logo",
field=models.ImageField(
blank=True,
null=True,
upload_to="cloud_provider_logos/",
validators=[services.models.validate_image_size],
),
),
migrations.AddField(
model_name="service",
name="logo",
field=models.ImageField(
blank=True,
null=True,
upload_to="service_logos/",
validators=[services.models.validate_image_size],
),
),
]

View file

@ -1,4 +1,4 @@
# Generated by Django 5.1.5 on 2025-01-28 09:48
# Generated by Django 5.1.5 on 2025-01-29 16:11
import django.db.models.deletion
from django.db import migrations, models
@ -7,18 +7,18 @@ from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
("services", "0010_remove_service_price"),
("services", "0001_initial"),
]
operations = [
migrations.AddField(
model_name="lead",
name="plan",
name="offering",
field=models.ForeignKey(
blank=True,
null=True,
on_delete=django.db.models.deletion.SET_NULL,
to="services.plan",
to="services.serviceoffering",
),
),
]

View file

@ -1,53 +0,0 @@
# Generated by Django 5.1.5 on 2025-01-27 14:19
import django.db.models.deletion
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
("services", "0002_cloudprovider_logo_service_logo"),
]
operations = [
migrations.CreateModel(
name="Category",
fields=[
(
"id",
models.BigAutoField(
auto_created=True,
primary_key=True,
serialize=False,
verbose_name="ID",
),
),
("name", models.CharField(max_length=100)),
("slug", models.SlugField(unique=True)),
("description", models.TextField(blank=True)),
("order", models.IntegerField(default=0)),
(
"parent",
models.ForeignKey(
blank=True,
null=True,
on_delete=django.db.models.deletion.CASCADE,
related_name="children",
to="services.category",
),
),
],
options={
"verbose_name_plural": "Categories",
"ordering": ["order", "name"],
},
),
migrations.AddField(
model_name="service",
name="categories",
field=models.ManyToManyField(
related_name="services", to="services.category"
),
),
]

View file

@ -1,40 +0,0 @@
# Generated by Django 5.1.5 on 2025-01-27 14:49
from django.db import migrations, models
from django.utils.text import slugify
def generate_provider_slugs(apps, schema_editor):
CloudProvider = apps.get_model("services", "CloudProvider")
for provider in CloudProvider.objects.all():
provider.slug = slugify(provider.name)
counter = 1
while CloudProvider.objects.filter(slug=provider.slug).exists():
provider.slug = f"{slugify(provider.name)}-{counter}"
counter += 1
provider.save()
class Migration(migrations.Migration):
dependencies = [
("services", "0003_category_service_categories"),
]
operations = [
migrations.AddField(
model_name="cloudprovider",
name="slug",
field=models.SlugField(unique=True, null=True),
preserve_default=False,
),
migrations.RunPython(
generate_provider_slugs, reverse_code=migrations.RunPython.noop
),
migrations.AlterField(
model_name="cloudprovider",
name="slug",
field=models.SlugField(unique=True),
preserve_default=False,
),
]

View file

@ -1,41 +0,0 @@
# Generated by Django 5.1.5 on 2025-01-27 15:21
import django.db.models.deletion
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
("services", "0004_cloudprovider_slug"),
]
operations = [
migrations.CreateModel(
name="Lead",
fields=[
(
"id",
models.BigAutoField(
auto_created=True,
primary_key=True,
serialize=False,
verbose_name="ID",
),
),
("name", models.CharField(max_length=200)),
("company", models.CharField(max_length=200)),
("email", models.EmailField(max_length=254)),
("phone", models.CharField(max_length=50)),
("created_at", models.DateTimeField(auto_now_add=True)),
("odoo_lead_id", models.IntegerField(blank=True, null=True)),
(
"service",
models.ForeignKey(
on_delete=django.db.models.deletion.CASCADE,
to="services.service",
),
),
],
),
]

View file

@ -1,44 +0,0 @@
# Generated by Django 5.1.5 on 2025-01-27 15:57
from django.db import migrations, models
from django.utils.text import slugify
def generate_service_slugs(apps, schema_editor):
Service = apps.get_model("services", "Service")
for service in Service.objects.all():
base_slug = f"{service.name}-{service.cloud_provider.name}"
slug = slugify(base_slug)
counter = 1
while Service.objects.filter(slug=slug).exists():
slug = f"{slugify(base_slug)}-{counter}"
counter += 1
service.slug = slug
service.save()
class Migration(migrations.Migration):
dependencies = [
("services", "0005_lead"),
]
operations = [
migrations.AddField(
model_name="service",
name="slug",
field=models.SlugField(max_length=250, blank=True),
preserve_default=False,
),
migrations.RunPython(
generate_service_slugs, reverse_code=migrations.RunPython.noop
),
migrations.AlterField(
model_name="service",
name="slug",
field=models.SlugField(max_length=250, unique=True),
),
]

View file

@ -1,50 +0,0 @@
# Generated by Django 5.1.5 on 2025-01-28 07:49
import services.models
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
("services", "0006_service_slug"),
]
operations = [
migrations.CreateModel(
name="ConsultingPartner",
fields=[
(
"id",
models.BigAutoField(
auto_created=True,
primary_key=True,
serialize=False,
verbose_name="ID",
),
),
("name", models.CharField(max_length=200)),
("slug", models.SlugField(unique=True)),
("description", models.TextField(blank=True)),
(
"logo",
models.ImageField(
blank=True,
null=True,
upload_to="partner_logos/",
validators=[services.models.validate_image_size],
),
),
("website", models.URLField(blank=True)),
("created_at", models.DateTimeField(auto_now_add=True)),
("updated_at", models.DateTimeField(auto_now=True)),
],
),
migrations.AddField(
model_name="service",
name="consulting_partners",
field=models.ManyToManyField(
blank=True, related_name="services", to="services.consultingpartner"
),
),
]

View file

@ -1,27 +0,0 @@
# Generated by Django 5.1.5 on 2025-01-28 09:03
from django.db import migrations
class Migration(migrations.Migration):
dependencies = [
("services", "0007_consultingpartner_service_consulting_partners"),
]
operations = [
migrations.RemoveField(
model_name="service",
name="countries",
),
migrations.RemoveField(
model_name="service",
name="service_level",
),
migrations.DeleteModel(
name="Country",
),
migrations.DeleteModel(
name="ServiceLevel",
),
]

View file

@ -1,118 +0,0 @@
# Generated by Django 5.1.5 on 2025-01-28 09:19
import django.db.models.deletion
from django.db import migrations, models
def create_initial_currencies(apps, schema_editor):
Currency = apps.get_model("services", "Currency")
currencies = [
{"code": "USD", "name": "US Dollar", "symbol": "$"},
{"code": "CHF", "name": "Swiss Franc", "symbol": "CHF"},
{"code": "EUR", "name": "Euro", "symbol": ""},
]
for currency_data in currencies:
Currency.objects.create(**currency_data)
def remove_initial_currencies(apps, schema_editor):
Currency = apps.get_model("services", "Currency")
Currency.objects.all().delete()
class Migration(migrations.Migration):
dependencies = [
("services", "0008_remove_service_countries_and_more"),
]
operations = [
migrations.CreateModel(
name="Currency",
fields=[
(
"id",
models.BigAutoField(
auto_created=True,
primary_key=True,
serialize=False,
verbose_name="ID",
),
),
("code", models.CharField(max_length=3, unique=True)),
("name", models.CharField(max_length=50)),
("symbol", models.CharField(max_length=5)),
],
options={
"verbose_name_plural": "Currencies",
"ordering": ["code"],
},
),
migrations.CreateModel(
name="Plan",
fields=[
(
"id",
models.BigAutoField(
auto_created=True,
primary_key=True,
serialize=False,
verbose_name="ID",
),
),
("name", models.CharField(max_length=100)),
("description", models.TextField()),
("is_default", models.BooleanField(default=False)),
("features", models.TextField(blank=True)),
("order", models.IntegerField(default=0)),
("created_at", models.DateTimeField(auto_now_add=True)),
("updated_at", models.DateTimeField(auto_now=True)),
(
"service",
models.ForeignKey(
on_delete=django.db.models.deletion.CASCADE,
related_name="plans",
to="services.service",
),
),
],
options={
"ordering": ["order", "name"],
"unique_together": {("service", "name")},
},
),
migrations.CreateModel(
name="PlanPrice",
fields=[
(
"id",
models.BigAutoField(
auto_created=True,
primary_key=True,
serialize=False,
verbose_name="ID",
),
),
("price", models.DecimalField(decimal_places=2, max_digits=10)),
(
"currency",
models.ForeignKey(
on_delete=django.db.models.deletion.PROTECT,
to="services.currency",
),
),
(
"plan",
models.ForeignKey(
on_delete=django.db.models.deletion.CASCADE,
related_name="prices",
to="services.plan",
),
),
],
options={
"unique_together": {("plan", "currency")},
},
),
migrations.RunPython(create_initial_currencies, remove_initial_currencies),
]

View file

@ -1,17 +0,0 @@
# Generated by Django 5.1.5 on 2025-01-28 09:28
from django.db import migrations
class Migration(migrations.Migration):
dependencies = [
("services", "0009_currency_plan_planprice"),
]
operations = [
migrations.RemoveField(
model_name="service",
name="price",
),
]

View file

@ -1,46 +0,0 @@
# Generated by Django 5.1.5 on 2025-01-28 09:58
import django.db.models.deletion
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
("services", "0011_lead_plan"),
]
operations = [
migrations.CreateModel(
name="ExternalLink",
fields=[
(
"id",
models.BigAutoField(
auto_created=True,
primary_key=True,
serialize=False,
verbose_name="ID",
),
),
("url", models.URLField()),
("description", models.CharField(max_length=200)),
("order", models.IntegerField(default=0)),
("created_at", models.DateTimeField(auto_now_add=True)),
("updated_at", models.DateTimeField(auto_now=True)),
(
"service",
models.ForeignKey(
on_delete=django.db.models.deletion.CASCADE,
related_name="external_links",
to="services.service",
),
),
],
options={
"verbose_name": "External Link",
"verbose_name_plural": "External Links",
"ordering": ["order", "description"],
},
),
]