feat(settings): Change model to inherit from CenturionModel for ExternalSettings model

ref: #833 #835
This commit is contained in:
2025-06-16 13:37:59 +09:30
parent cec4b39f5a
commit 278b9e5c08
2 changed files with 145 additions and 33 deletions

View File

@ -0,0 +1,133 @@
# Generated by Django 5.1.9 on 2025-06-16 03:36
import access.models.tenancy_abstract
import django.db.models.deletion
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
("access", "0016_remove_tenant_slug_alter_tenant_manager_and_more"),
("core", "0033_alter_ticketcommentcategory_parent_and_more"),
("settings", "0013_alter_appsettings_global_organization_and_more"),
]
operations = [
migrations.RemoveField(
model_name="externallink",
name="is_global",
),
migrations.AlterField(
model_name="externallink",
name="colour",
field=models.CharField(
blank=True,
help_text="Colour to render the link button. Use HTML colour code",
max_length=80,
null=True,
verbose_name="Button Colour",
),
),
migrations.AlterField(
model_name="externallink",
name="id",
field=models.AutoField(
help_text="ID of the item",
primary_key=True,
serialize=False,
unique=True,
verbose_name="ID",
),
),
migrations.AlterField(
model_name="externallink",
name="model_notes",
field=models.TextField(
blank=True,
help_text="Tid bits of information",
null=True,
verbose_name="Notes",
),
),
migrations.AlterField(
model_name="externallink",
name="organization",
field=models.ForeignKey(
help_text="Tenant this belongs to",
on_delete=django.db.models.deletion.CASCADE,
related_name="+",
to="access.tenant",
validators=[
access.models.tenancy_abstract.TenancyAbstractModel.validatate_organization_exists
],
verbose_name="Tenant",
),
),
migrations.CreateModel(
name="ExternalLinkAuditHistory",
fields=[
(
"centurionaudit_ptr",
models.OneToOneField(
auto_created=True,
on_delete=django.db.models.deletion.CASCADE,
parent_link=True,
primary_key=True,
serialize=False,
to="core.centurionaudit",
),
),
(
"model",
models.ForeignKey(
help_text="Model this history belongs to",
on_delete=django.db.models.deletion.CASCADE,
related_name="audit_history",
to="settings.externallink",
verbose_name="Model",
),
),
],
options={
"verbose_name": "External Link History",
"verbose_name_plural": "External Link Histories",
"db_table": "settings_externallink_audithistory",
"managed": True,
},
bases=("core.centurionaudit",),
),
migrations.CreateModel(
name="ExternalLinkCenturionModelNote",
fields=[
(
"centurionmodelnote_ptr",
models.OneToOneField(
auto_created=True,
on_delete=django.db.models.deletion.CASCADE,
parent_link=True,
primary_key=True,
serialize=False,
to="core.centurionmodelnote",
),
),
(
"model",
models.ForeignKey(
help_text="Model this note belongs to",
on_delete=django.db.models.deletion.CASCADE,
related_name="+",
to="settings.externallink",
verbose_name="Model",
),
),
],
options={
"verbose_name": "External Link Note",
"verbose_name_plural": "External Link Notes",
"db_table": "settings_externallink_centurionmodelnote",
"managed": True,
},
bases=("core.centurionmodelnote",),
),
]

View File

@ -1,9 +1,14 @@
from access.fields import *
from access.models.tenancy import TenancyObject
from django.db import models
from access.fields import AutoLastModifiedField
from core.models.centurion import CenturionModel
class ExternalLink(TenancyObject):
class ExternalLink(
CenturionModel
):
class Meta:
@ -18,14 +23,6 @@ class ExternalLink(TenancyObject):
verbose_name_plural = 'External Links'
id = models.AutoField(
blank=False,
help_text = 'ID for this external link',
primary_key=True,
unique=True,
verbose_name = 'ID'
)
name = models.CharField(
blank = False,
help_text = 'Name to display on link button',
@ -34,8 +31,6 @@ class ExternalLink(TenancyObject):
verbose_name = 'Friendly Name',
)
slug = None
button_text = models.CharField(
blank = True,
help_text = 'Name to display on link button',
@ -55,7 +50,6 @@ class ExternalLink(TenancyObject):
colour = models.CharField(
blank = True,
default = None,
help_text = 'Colour to render the link button. Use HTML colour code',
max_length = 80,
null = True,
@ -64,35 +58,33 @@ class ExternalLink(TenancyObject):
)
cluster = models.BooleanField(
default = False,
blank = False,
default = False,
help_text = 'Render link for clusters',
verbose_name = 'Clusters',
)
devices = models.BooleanField(
default = False,
blank = False,
default = False,
help_text = 'Render link for devices',
verbose_name = 'Devices',
)
service = models.BooleanField(
default = False,
blank = False,
default = False,
help_text = 'Render link for service',
verbose_name = 'Service',
)
software = models.BooleanField(
default = False,
blank = False,
default = False,
help_text = 'Render link for software',
verbose_name = 'Software',
)
created = AutoCreatedField()
modified = AutoLastModifiedField()
@ -160,16 +152,3 @@ class ExternalLink(TenancyObject):
""" Return the Template to render """
return str(self.template)
def save_history(self, before: dict, after: dict) -> bool:
from settings.models.external_link_history import ExternalLinkHistory
history = super().save_history(
before = before,
after = after,
history_model = ExternalLinkHistory,
)
return history