refactor all the things
This commit is contained in:
parent
8ed39690f1
commit
bb5cb708bd
36 changed files with 1563 additions and 931 deletions
|
@ -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),
|
||||
]
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue