Change photo slug to filename

This commit is contained in:
Nyymix 2025-03-31 22:05:29 +03:00
parent bac62c6d6d
commit 26a12450f4
4 changed files with 43 additions and 48 deletions

View file

@ -1,9 +1,11 @@
import os
import random
from datetime import datetime
from django.db import models
from django.db.models.signals import post_save
from django.dispatch import receiver
from django.urls import reverse
from django.utils.text import slugify
from imagekit.models import ImageSpecField
from imagekit.processors import ResizeToFit
@ -17,10 +19,9 @@ def get_upload_path(instance, filename):
class Photo(models.Model):
album = models.ForeignKey(Album, on_delete=models.CASCADE, related_name='photos', verbose_name="Album")
slug = models.CharField(unique=True, max_length=15, editable=False, verbose_name="Photo Slug")
slug = models.CharField(max_length=50, verbose_name="Photo Slug")
photo = models.ImageField(upload_to=get_upload_path, height_field='height', width_field='width', verbose_name="Photo")
# Thumbnail-versiot
photo_sm = ImageSpecField(source='photo', processors=[ResizeToFit(320, 320)], format='JPEG', options={'quality': 70})
photo_md = ImageSpecField(source='photo', processors=[ResizeToFit(720, 720)], format='JPEG', options={'quality': 80})
photo_bg = ImageSpecField(source='photo', processors=[ResizeToFit(1920, 1920)], format='JPEG', options={'quality': 90})
@ -40,20 +41,12 @@ class Photo(models.Model):
@property
def aspect_ratio(self):
return self.width / self.height
def save(self, *args, **kwargs):
if not self.slug:
self.slug = os.path.basename(self.photo.name)
super().save(*args, **kwargs)
@staticmethod
def generate_unique_slug(album, datetime_taken):
"""
Luo uniikin slugin, joka perustuu ottopäivämäärään.
Lisää tarvittaessa satunnaisluvun, jos slug on jo olemassa.
"""
base_slug = datetime_taken.strftime('%y%m%d%H%M%S') # esim. 240304153045
slug = f"{base_slug}{random.randint(0, 9)}"
while Photo.objects.filter(slug=slug).exists():
slug = f"{base_slug}{random.randint(10, 99)}" # Jos törmäys, lisää 2 satunnaisnumeroa
return slug
def add_like(self):
self.likes += 1
@ -69,34 +62,26 @@ class Photo(models.Model):
def get_prev(self):
return self.__class__.objects.filter(taken_at__lt=self.taken_at, album=self.album).order_by('-taken_at').first()
def extract_metadata(self):
"""Lukee Exif-metadatan ja asettaa tiedot ennen kuvan tallennusta."""
if not self.photo:
return # Jos kuvaa ei ole, ei tehdä mitään
try:
exif_data = Exif(self.photo.file) # Luetaan Exif-metadata suoraan muistista
self.taken_at = exif_data.datetimeoriginal or datetime.now()
self.exif = exif_data.data or None
except Exception as e:
print(f"Exif-tiedon lukeminen epäonnistui: {e}")
self.taken_at = datetime.now()
def save(self, *args, **kwargs):
"""Ennen tallennusta luetaan Exif ja asetetaan slug, jos se puuttuu."""
if not self.slug:
self.extract_metadata() # Varmistetaan, että ottoaika on saatavilla
self.slug = self.generate_unique_slug(self.album, self.taken_at or datetime.now())
super().save(*args, **kwargs)
def get_absolute_url(self):
return reverse('gallery:photo_url', kwargs={'album_slug': self.album.slug, 'photo_slug': self.slug})
class Meta:
constraints = [models.UniqueConstraint(fields=['slug'], name='unique_photo_slug')]
unique_together = ('album', "slug")
verbose_name_plural = "Photos"
ordering = ('-taken_at',)
def __str__(self):
return f'{self.slug} ({self.orientation}) {self.is_favorite}'
return f'{self.slug} ({self.orientation}) {self.is_favorite}'
def create_photo(sender, instance, created, **kwargs):
if created:
""" Add exif metadata """
exif = Exif(instance.photo.path)
instance.exif = exif.data
""" Update taken datetime """
instance.taken_at = exif.datetimeoriginal('Europe/Helsinki')
instance.save()
post_save.connect(create_photo, sender=Photo)