mirror of
https://github.com/netbox-community/netbox.git
synced 2026-03-30 22:32:51 +02:00
* Convert ObjectType to a concrete child model of ContentType * Add public flag to ObjectType * Catch post_migrate signal to update ObjectTypes * Reference ObjectType records instead of registry for feature support * Automatically create ObjectTypes * Introduce has_feature() utility function * ObjectTypeManager should not inherit from ContentTypeManager * Misc cleanup * Don't populate ObjectTypes during migration * Don't automatically create ObjectTypes when a ContentType is created * Fix test * Extend has_feature() to accept a model or OT/CT * Misc cleanup * Deprecate get_for_id() on ObjectTypeManager * Rename contenttypes.py to object_types.py * Add index to features ArrayField * Keep FK & M2M fields pointing to ContentType * Add get_for_models() to ObjectTypeManager * Add tests for manager methods & utility functions * Fix migrations for M2M relations to ObjectType * model_is_public() should return False for non-core & non-plugin models * Order ObjectType by app_label & model name * Resolve migrations conflict
59 lines
2.3 KiB
Python
59 lines
2.3 KiB
Python
import django.contrib.postgres.fields
|
|
import django.db.models.deletion
|
|
from django.conf import settings
|
|
from django.db import migrations, models
|
|
|
|
|
|
class Migration(migrations.Migration):
|
|
dependencies = [
|
|
('core', '0015_remove_redundant_indexes'),
|
|
('extras', '0127_configtemplate_as_attachment_and_more'),
|
|
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
|
|
]
|
|
|
|
operations = [
|
|
migrations.CreateModel(
|
|
name='TableConfig',
|
|
fields=[
|
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False)),
|
|
('created', models.DateTimeField(auto_now_add=True, null=True)),
|
|
('last_updated', models.DateTimeField(auto_now=True, null=True)),
|
|
('table', models.CharField(max_length=100)),
|
|
('name', models.CharField(max_length=100)),
|
|
('description', models.CharField(blank=True, max_length=200)),
|
|
('weight', models.PositiveSmallIntegerField(default=1000)),
|
|
('enabled', models.BooleanField(default=True)),
|
|
('shared', models.BooleanField(default=True)),
|
|
(
|
|
'columns',
|
|
django.contrib.postgres.fields.ArrayField(base_field=models.CharField(max_length=100), size=None),
|
|
),
|
|
(
|
|
'ordering',
|
|
django.contrib.postgres.fields.ArrayField(
|
|
base_field=models.CharField(max_length=100), blank=True, null=True, size=None
|
|
),
|
|
),
|
|
(
|
|
'object_type',
|
|
models.ForeignKey(
|
|
on_delete=django.db.models.deletion.CASCADE,
|
|
related_name='table_configs',
|
|
to='contenttypes.contenttype'
|
|
),
|
|
),
|
|
(
|
|
'user',
|
|
models.ForeignKey(
|
|
blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, to=settings.AUTH_USER_MODEL
|
|
),
|
|
),
|
|
],
|
|
options={
|
|
'verbose_name': 'table config',
|
|
'verbose_name_plural': 'table configs',
|
|
'ordering': ('weight', 'name'),
|
|
},
|
|
),
|
|
]
|