add sound item in diffusions; move programs.Sound's attribute 'remove' into the type + update its public attribute based on diffusion publication

This commit is contained in:
bkfox
2016-07-28 16:21:01 +02:00
parent 502af1dba0
commit 801a89e503
9 changed files with 123 additions and 31 deletions

View File

@ -26,7 +26,7 @@ class StreamInline(admin.TabularInline):
extra = 1
class SoundInline(admin.TabularInline):
fields = ['type', 'path', 'duration']
fields = ['type', 'path', 'duration','public']
# readonly_fields = fields
model = Sound
extra = 0
@ -66,11 +66,11 @@ class TrackInline(GenericTabularInline):
class SoundAdmin(NameableAdmin):
fields = None
list_display = ['id', 'name', 'duration', 'type', 'mtime',
'public', 'good_quality', 'removed']
'public', 'good_quality']
fieldsets = [
(None, { 'fields': NameableAdmin.fields + ['path', 'type', 'diffusion'] } ),
(None, { 'fields': ['embed', 'duration', 'public', 'mtime'] }),
(None, { 'fields': ['removed', 'good_quality' ] } )
(None, { 'fields': ['good_quality' ] } )
]
readonly_fields = ('path', 'duration',)
inlines = [TrackInline]

View File

@ -79,7 +79,7 @@ class Importer:
position = position,
)
track.in_seconds = pos_in_secs
track.in_seconds = in_seconds
track.info = self.__get(line, 'info')
tags = self.__get(line, 'tags')
if tags:

View File

@ -157,7 +157,7 @@ class SoundInfo:
diffusion = diffusion[0]
logger.info('diffusion %s mathes to sound -> %s', str(diffusion),
sound.path)
self.sound.path)
self.sound.diffusion = diffusion
if save:
self.sound.save()
@ -201,7 +201,7 @@ class MonitorHandler(PatternMatchingEventHandler):
sound = Sound.objects.filter(path = event.src_path)
if sound:
sound = sound[0]
sound.removed = True
sound.type = sound.Type.removed
sound.save()
def on_moved(self, event):
@ -296,7 +296,6 @@ class Command(BaseCommand):
# sounds in directory
for path in os.listdir(subdir):
print(path)
path = os.path.join(subdir, path)
if not path.endswith(settings.AIRCOX_SOUND_FILE_EXT):
continue
@ -319,21 +318,23 @@ class Command(BaseCommand):
import aircox.programs.management.commands.sounds_quality_check \
as quality_check
sounds = Sound.objects.filter(good_quality = False)
# get available sound files
sounds = Sound.objects.filter(good_quality = False) \
.exclude(type = Sound.Type.removed)
if check:
self.check_sounds(sounds)
files = [ sound.path for sound in sounds
if not sound.removed and os.path.exists(sound.path) ]
else:
files = [ sound.path for sound in sounds.filter(removed = False)
if os.path.exists(sound.path) ]
files = [ sound.path for sound in sounds
if os.path.exists(sound.path) ]
# check quality
logger.info('quality check...',)
cmd = quality_check.Command()
cmd.handle( files = files,
**settings.AIRCOX_SOUND_QUALITY )
logger.info('update database')
# update stats
logger.info('update stats in database')
def update_stats(sound_info, sound):
stats = sound_info.get_file_stats()
if stats:

View File

@ -121,6 +121,7 @@ class Sound(Nameable):
other = 0x00,
archive = 0x01,
excerpt = 0x02,
removed = 0x03,
diffusion = models.ForeignKey(
'Diffusion',
@ -157,11 +158,6 @@ class Sound(Nameable):
blank = True, null = True,
help_text = _('last modification date and time'),
)
removed = models.BooleanField(
_('removed'),
default = False,
help_text = _('this sound has been removed from filesystem'),
)
good_quality = models.BooleanField(
_('good quality'),
default = False,
@ -204,15 +200,21 @@ class Sound(Nameable):
needed (do not save). Return True if there was changes.
"""
if not self.file_exists():
if self.removed:
if self.type == self.Type.removed:
return
logger.info('sound %s: has been removed', self.path)
self.removed = True
self.type = self.Type.removed
return True
old_removed = self.removed
self.removed = False
# not anymore removed
changed = False
if self.type == self.Type.removed and self.program:
changed = True
self.type = self.Type.archive \
if self.path.startswith(self.program.archives_path) else \
self.Type.excerpt
# check mtime -> reset quality if changed (assume file changed)
mtime = self.get_mtime()
if self.mtime != mtime:
self.mtime = mtime
@ -220,7 +222,7 @@ class Sound(Nameable):
logger.info('sound %s: m_time has changed. Reset quality info',
self.path)
return True
return old_removed != self.removed
return changed
def check_perms(self):
"""
@ -529,6 +531,18 @@ class Program(Nameable):
os.makedirs(path, exist_ok = True)
return os.path.exists(path)
@property
def archives_path(self):
return os.path.join(
self.path, settings.AIRCOX_SOUND_ARCHIVES_SUBDIR
)
@property
def excerpts_path(self):
return os.path.join(
self.path, settings.AIRCOX_SOUND_ARCHIVES_SUBDIR
)
def find_schedule(self, date):
"""
Return the first schedule that matches a given date.
@ -684,8 +698,15 @@ class Diffusion(models.Model):
ordered by path.
"""
sounds = self.initial.sound_set if self.initial else self.sound_set
return sounds.filter(type = Sound.Type.archive, removed = False). \
order_by('path')
return sounds.filter(type = Sound.Type.archive).order_by('path')
def get_excerpts(self):
"""
Return a list of available archives sounds for the given episode,
ordered by path.
"""
sounds = self.initial.sound_set if self.initial else self.sound_set
return sounds.filter(type = Sound.Type.excerpt).order_by('path')
def is_date_in_range(self, date = None):
"""