Skip to content

Commit

Permalink
Convert longer media varchar fields to text in the API (#4315)
Browse files Browse the repository at this point in the history
* Add text-based URL field, change columns to text

* Add migrations
  • Loading branch information
AetherUnbound authored May 13, 2024
1 parent 9b1aa77 commit 125c65e
Show file tree
Hide file tree
Showing 7 changed files with 183 additions and 37 deletions.
124 changes: 124 additions & 0 deletions api/api/migrations/0061_convert_varchar_to_text.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,124 @@
# Generated by Django 4.2.11 on 2024-05-10 22:07

import api.models.fields
from django.db import migrations, models


class Migration(migrations.Migration):

dependencies = [
('api', '0060_fill_out_help_text'),
]

operations = [
migrations.AlterField(
model_name='audio',
name='audio_set_foreign_identifier',
field=models.TextField(blank=True, help_text='Reference to set of which this track is a part.', null=True),
),
migrations.AlterField(
model_name='audio',
name='creator',
field=models.TextField(blank=True, help_text='The name of the media creator.', null=True),
),
migrations.AlterField(
model_name='audio',
name='creator_url',
field=api.models.fields.URLTextField(blank=True, help_text='A direct link to the media creator.', max_length=2000, null=True),
),
migrations.AlterField(
model_name='audio',
name='foreign_identifier',
field=models.TextField(blank=True, db_index=True, help_text='The identifier provided by the upstream source.', null=True),
),
migrations.AlterField(
model_name='audio',
name='foreign_landing_url',
field=api.models.fields.URLTextField(blank=True, help_text='The landing page of the work.', null=True),
),
migrations.AlterField(
model_name='audio',
name='thumbnail',
field=api.models.fields.URLTextField(blank=True, help_text='The thumbnail for the media.', null=True),
),
migrations.AlterField(
model_name='audio',
name='title',
field=models.TextField(blank=True, help_text='The name of the media.', null=True),
),
migrations.AlterField(
model_name='audio',
name='url',
field=api.models.fields.URLTextField(blank=True, help_text='The actual URL to the media file.', max_length=1000, null=True, unique=True),
),
migrations.AlterField(
model_name='audioset',
name='creator',
field=models.TextField(blank=True, help_text='The name of the media creator.', null=True),
),
migrations.AlterField(
model_name='audioset',
name='creator_url',
field=api.models.fields.URLTextField(blank=True, help_text='A direct link to the media creator.', max_length=2000, null=True),
),
migrations.AlterField(
model_name='audioset',
name='foreign_identifier',
field=models.TextField(blank=True, db_index=True, help_text='The identifier provided by the upstream source.', null=True),
),
migrations.AlterField(
model_name='audioset',
name='foreign_landing_url',
field=api.models.fields.URLTextField(blank=True, help_text='The landing page of the work.', null=True),
),
migrations.AlterField(
model_name='audioset',
name='thumbnail',
field=api.models.fields.URLTextField(blank=True, help_text='The thumbnail for the media.', null=True),
),
migrations.AlterField(
model_name='audioset',
name='title',
field=models.TextField(blank=True, help_text='The name of the media.', null=True),
),
migrations.AlterField(
model_name='audioset',
name='url',
field=api.models.fields.URLTextField(blank=True, help_text='The actual URL to the media file.', max_length=1000, null=True, unique=True),
),
migrations.AlterField(
model_name='image',
name='creator',
field=models.TextField(blank=True, help_text='The name of the media creator.', null=True),
),
migrations.AlterField(
model_name='image',
name='creator_url',
field=api.models.fields.URLTextField(blank=True, help_text='A direct link to the media creator.', max_length=2000, null=True),
),
migrations.AlterField(
model_name='image',
name='foreign_identifier',
field=models.TextField(blank=True, db_index=True, help_text='The identifier provided by the upstream source.', null=True),
),
migrations.AlterField(
model_name='image',
name='foreign_landing_url',
field=api.models.fields.URLTextField(blank=True, help_text='The landing page of the work.', null=True),
),
migrations.AlterField(
model_name='image',
name='thumbnail',
field=api.models.fields.URLTextField(blank=True, help_text='The thumbnail for the media.', null=True),
),
migrations.AlterField(
model_name='image',
name='title',
field=models.TextField(blank=True, help_text='The name of the media.', null=True),
),
migrations.AlterField(
model_name='image',
name='url',
field=api.models.fields.URLTextField(blank=True, help_text='The actual URL to the media file.', max_length=1000, null=True, unique=True),
),
]
3 changes: 1 addition & 2 deletions api/api/models/audio.py
Original file line number Diff line number Diff line change
Expand Up @@ -163,8 +163,7 @@ class Audio(AudioFileMixin, AbstractMedia):
)

# Replaces the foreign key to AudioSet
audio_set_foreign_identifier = models.CharField(
max_length=1000,
audio_set_foreign_identifier = models.TextField(
blank=True,
null=True,
help_text="Reference to set of which this track is a part.",
Expand Down
21 changes: 21 additions & 0 deletions api/api/models/fields.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
from django import forms
from django.core import validators
from django.db import models
from django.utils.translation import gettext_lazy as _


class URLTextField(models.TextField):
"""URL field which uses the underlying Postgres TEXT column type."""

default_validators = [validators.URLValidator()]
description = _("URL")

def formfield(self, **kwargs):
# As with CharField, this will cause URL validation to be performed
# twice.
return super().formfield(
**{
"form_class": forms.URLField,
**kwargs,
}
)
35 changes: 16 additions & 19 deletions api/api/models/mixins.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@

from django.db import models

from api.models import fields


class IdentifierMixin(models.Model):
"""
Expand Down Expand Up @@ -32,11 +34,10 @@ class ForeignIdentifierMixin(models.Model):
This mixin adds
- foreign_identifier: CharField
- foreign_identifier: TextField
"""

foreign_identifier = models.CharField(
max_length=1000,
foreign_identifier = models.TextField(
blank=True,
null=True,
db_index=True,
Expand All @@ -55,34 +56,31 @@ class MediaMixin(models.Model):
The mixin adds
- title: CharField
- foreign_landing_url: CharField
- creator: CharField
- creator_url: CharField
- thumbnail: URLField
- title: TextField
- foreign_landing_url: URLTextField
- creator: TextField
- creator_url: URLTextField
- thumbnail: URLTextField
- provider: CharField
"""

title = models.CharField(
max_length=2000,
title = models.TextField(
blank=True,
null=True,
help_text="The name of the media.",
)
foreign_landing_url = models.CharField(
max_length=1000,
foreign_landing_url = fields.URLTextField(
blank=True,
null=True,
help_text="The landing page of the work.",
)

creator = models.CharField(
max_length=2000,
creator = models.TextField(
blank=True,
null=True,
help_text="The name of the media creator.",
)
creator_url = models.URLField(
creator_url = fields.URLTextField(
max_length=2000,
blank=True,
null=True,
Expand All @@ -92,8 +90,7 @@ class MediaMixin(models.Model):
# Because all forms of media have a thumbnail for visual representation
# For images, this field is not used as images are generated using Photon.
# For audio, this field points to the artwork, or is ``null``.
thumbnail = models.URLField(
max_length=1000,
thumbnail = fields.URLTextField(
blank=True,
null=True,
help_text="The thumbnail for the media.",
Expand All @@ -120,12 +117,12 @@ class FileMixin(models.Model):
This mixin adds
- url: URLField
- url: URLTextField
- filesize: IntegerField
- filetype: CharField
"""

url = models.URLField(
url = fields.URLTextField(
unique=True,
max_length=1000,
help_text="The actual URL to the media file.",
Expand Down
2 changes: 1 addition & 1 deletion api/latest_migrations/api
Original file line number Diff line number Diff line change
Expand Up @@ -2,4 +2,4 @@
# If you have a merge conflict in this file, it means you need to run:
# manage.py makemigrations --merge
# in order to resolve the conflict between migrations.
0060_fill_out_help_text
0061_convert_varchar_to_text
5 changes: 5 additions & 0 deletions api/latest_migrations/django_structlog
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
# This file is autogenerated by makemigrations.
# If you have a merge conflict in this file, it means you need to run:
# manage.py makemigrations --merge
# in order to resolve the conflict between migrations.

Loading

0 comments on commit 125c65e

Please sign in to comment.