Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
steering
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Container Registry
Model registry
Operate
Environments
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
AURA
steering
Commits
bb9218c3
Verified
Commit
bb9218c3
authored
1 year ago
by
Ernesto Rico Schmidt
Browse files
Options
Downloads
Patches
Plain Diff
refactor: use _id suffix for object references
Closes:
#155
parent
9f31015d
No related branches found
No related tags found
No related merge requests found
Pipeline
#3407
passed
1 year ago
Stage: build
Changes
2
Pipelines
1
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
program/serializers.py
+95
-64
95 additions, 64 deletions
program/serializers.py
program/services.py
+13
-13
13 additions, 13 deletions
program/services.py
with
108 additions
and
77 deletions
program/serializers.py
+
95
−
64
View file @
bb9218c3
...
@@ -385,28 +385,38 @@ class ShowLinkSerializer(serializers.ModelSerializer):
...
@@ -385,28 +385,38 @@ class ShowLinkSerializer(serializers.ModelSerializer):
class
ShowSerializer
(
serializers
.
HyperlinkedModelSerializer
):
class
ShowSerializer
(
serializers
.
HyperlinkedModelSerializer
):
category
=
serializers
.
PrimaryKeyRelatedField
(
queryset
=
Category
.
objects
.
all
(),
many
=
True
)
category_ids
=
serializers
.
PrimaryKeyRelatedField
(
funding_category
=
serializers
.
PrimaryKeyRelatedField
(
queryset
=
FundingCategory
.
objects
.
all
())
many
=
True
,
queryset
=
Category
.
objects
.
all
(),
source
=
"
category
"
hosts
=
serializers
.
PrimaryKeyRelatedField
(
queryset
=
Host
.
objects
.
all
(),
many
=
True
)
)
image
=
serializers
.
PrimaryKeyRelatedField
(
funding_category_id
=
serializers
.
PrimaryKeyRelatedField
(
allow_null
=
True
,
queryset
=
FundingCategory
.
objects
.
all
()
queryset
=
Image
.
objects
.
all
(),
)
required
=
False
,
host_ids
=
serializers
.
PrimaryKeyRelatedField
(
many
=
True
,
queryset
=
Host
.
objects
.
all
(),
source
=
"
hosts
"
)
image_id
=
serializers
.
PrimaryKeyRelatedField
(
allow_null
=
True
,
queryset
=
Image
.
objects
.
all
(),
required
=
False
)
language_ids
=
serializers
.
PrimaryKeyRelatedField
(
many
=
True
,
queryset
=
Language
.
objects
.
all
(),
source
=
"
language
"
)
)
language
=
serializers
.
PrimaryKeyRelatedField
(
queryset
=
Language
.
objects
.
all
(),
many
=
True
)
links
=
HostLinkSerializer
(
many
=
True
,
required
=
False
)
links
=
HostLinkSerializer
(
many
=
True
,
required
=
False
)
logo
=
serializers
.
PrimaryKeyRelatedField
(
logo_id
=
serializers
.
PrimaryKeyRelatedField
(
allow_null
=
True
,
allow_null
=
True
,
queryset
=
Image
.
objects
.
all
(),
required
=
False
queryset
=
Image
.
objects
.
all
(),
)
required
=
False
,
music_focus_ids
=
serializers
.
PrimaryKeyRelatedField
(
many
=
True
,
queryset
=
MusicFocus
.
objects
.
all
(),
source
=
"
music_focus
"
)
)
music_focus
=
serializers
.
PrimaryKeyRelatedField
(
queryset
=
MusicFocus
.
objects
.
all
(),
many
=
True
)
owner_ids
=
serializers
.
PrimaryKeyRelatedField
(
owners
=
serializers
.
PrimaryKeyRelatedField
(
queryset
=
User
.
objects
.
all
(),
many
=
True
)
many
=
True
,
queryset
=
User
.
objects
.
all
(),
source
=
"
owners
"
predecessor
=
serializers
.
PrimaryKeyRelatedField
(
queryset
=
Show
.
objects
.
all
(),
required
=
False
,
allow_null
=
True
)
)
topic
=
serializers
.
PrimaryKeyRelatedField
(
queryset
=
Topic
.
objects
.
all
(),
many
=
True
)
predecessor_id
=
serializers
.
PrimaryKeyRelatedField
(
type
=
serializers
.
PrimaryKeyRelatedField
(
queryset
=
Type
.
objects
.
all
())
allow_null
=
True
,
queryset
=
Show
.
objects
.
all
(),
required
=
False
)
topic_ids
=
serializers
.
PrimaryKeyRelatedField
(
many
=
True
,
queryset
=
Topic
.
objects
.
all
(),
source
=
"
topic
"
)
type_id
=
serializers
.
PrimaryKeyRelatedField
(
queryset
=
Type
.
objects
.
all
())
class
Meta
:
class
Meta
:
model
=
Show
model
=
Show
...
@@ -417,29 +427,29 @@ class ShowSerializer(serializers.HyperlinkedModelSerializer):
...
@@ -417,29 +427,29 @@ class ShowSerializer(serializers.HyperlinkedModelSerializer):
"
updated_by
"
,
"
updated_by
"
,
)
)
fields
=
(
fields
=
(
"
category
"
,
"
category
_ids
"
,
"
cba_series_id
"
,
"
cba_series_id
"
,
"
default_playlist_id
"
,
"
default_playlist_id
"
,
"
description
"
,
"
description
"
,
"
email
"
,
"
email
"
,
"
funding_category
"
,
"
funding_category
_id
"
,
"
hosts
"
,
"
host
_id
s
"
,
"
id
"
,
"
id
"
,
"
image
"
,
"
image
_id
"
,
"
internal_note
"
,
"
internal_note
"
,
"
is_active
"
,
"
is_active
"
,
"
is_public
"
,
"
is_public
"
,
"
language
"
,
"
language
_ids
"
,
"
links
"
,
"
links
"
,
"
logo
"
,
"
logo
_id
"
,
"
music_focus
"
,
"
music_focus
_ids
"
,
"
name
"
,
"
name
"
,
"
owners
"
,
"
owner
_id
s
"
,
"
predecessor
"
,
"
predecessor
_id
"
,
"
short_description
"
,
"
short_description
"
,
"
slug
"
,
"
slug
"
,
"
topic
"
,
"
topic
_ids
"
,
"
type
"
,
"
type
_id
"
,
)
+
read_only_fields
)
+
read_only_fields
def
create
(
self
,
validated_data
):
def
create
(
self
,
validated_data
):
...
@@ -455,8 +465,18 @@ class ShowSerializer(serializers.HyperlinkedModelSerializer):
...
@@ -455,8 +465,18 @@ class ShowSerializer(serializers.HyperlinkedModelSerializer):
music_focus
=
validated_data
.
pop
(
"
music_focus
"
)
music_focus
=
validated_data
.
pop
(
"
music_focus
"
)
links_data
=
validated_data
.
pop
(
"
links
"
,
[])
links_data
=
validated_data
.
pop
(
"
links
"
,
[])
# required
validated_data
[
"
funding_category
"
]
=
validated_data
.
pop
(
"
funding_category_id
"
)
validated_data
[
"
type
"
]
=
validated_data
.
pop
(
"
type_id
"
)
# optional
validated_data
[
"
image
"
]
=
validated_data
.
pop
(
"
image_id
"
,
None
)
validated_data
[
"
logo
"
]
=
validated_data
.
pop
(
"
logo_id
"
,
None
)
validated_data
[
"
predecessor
"
]
=
validated_data
.
pop
(
"
predecessor_id
"
,
None
)
show
=
Show
.
objects
.
create
(
show
=
Show
.
objects
.
create
(
created_by
=
self
.
context
.
get
(
"
request
"
).
user
.
username
,
**
validated_data
created_by
=
self
.
context
.
get
(
"
request
"
).
user
.
username
,
**
validated_data
,
)
)
# Save many-to-many relationships
# Save many-to-many relationships
...
@@ -486,20 +506,20 @@ class ShowSerializer(serializers.HyperlinkedModelSerializer):
...
@@ -486,20 +506,20 @@ class ShowSerializer(serializers.HyperlinkedModelSerializer):
instance
.
description
=
validated_data
.
get
(
"
description
"
,
instance
.
description
)
instance
.
description
=
validated_data
.
get
(
"
description
"
,
instance
.
description
)
instance
.
email
=
validated_data
.
get
(
"
email
"
,
instance
.
email
)
instance
.
email
=
validated_data
.
get
(
"
email
"
,
instance
.
email
)
instance
.
funding_category
=
validated_data
.
get
(
instance
.
funding_category
=
validated_data
.
get
(
"
funding_category
"
,
instance
.
funding_category
"
funding_category
_id
"
,
instance
.
funding_category
)
)
instance
.
image
=
validated_data
.
get
(
"
image
"
,
instance
.
image
)
instance
.
image
=
validated_data
.
get
(
"
image
_id
"
,
instance
.
image
)
instance
.
internal_note
=
validated_data
.
get
(
"
internal_note
"
,
instance
.
internal_note
)
instance
.
internal_note
=
validated_data
.
get
(
"
internal_note
"
,
instance
.
internal_note
)
instance
.
is_active
=
validated_data
.
get
(
"
is_active
"
,
instance
.
is_active
)
instance
.
is_active
=
validated_data
.
get
(
"
is_active
"
,
instance
.
is_active
)
instance
.
is_public
=
validated_data
.
get
(
"
is_public
"
,
instance
.
is_public
)
instance
.
is_public
=
validated_data
.
get
(
"
is_public
"
,
instance
.
is_public
)
instance
.
logo
=
validated_data
.
get
(
"
logo
"
,
instance
.
logo
)
instance
.
logo
=
validated_data
.
get
(
"
logo
_id
"
,
instance
.
logo
)
instance
.
name
=
validated_data
.
get
(
"
name
"
,
instance
.
name
)
instance
.
name
=
validated_data
.
get
(
"
name
"
,
instance
.
name
)
instance
.
predecessor
=
validated_data
.
get
(
"
predecessor
"
,
instance
.
predecessor
)
instance
.
predecessor
=
validated_data
.
get
(
"
predecessor
_id
"
,
instance
.
predecessor
)
instance
.
short_description
=
validated_data
.
get
(
instance
.
short_description
=
validated_data
.
get
(
"
short_description
"
,
instance
.
short_description
"
short_description
"
,
instance
.
short_description
)
)
instance
.
slug
=
validated_data
.
get
(
"
slug
"
,
instance
.
slug
)
instance
.
slug
=
validated_data
.
get
(
"
slug
"
,
instance
.
slug
)
instance
.
type
=
validated_data
.
get
(
"
type
"
,
instance
.
type
)
instance
.
type
=
validated_data
.
get
(
"
type
_id
"
,
instance
.
type
)
instance
.
category
.
set
(
validated_data
.
get
(
"
category
"
,
instance
.
category
))
instance
.
category
.
set
(
validated_data
.
get
(
"
category
"
,
instance
.
category
))
instance
.
hosts
.
set
(
validated_data
.
get
(
"
hosts
"
,
instance
.
hosts
))
instance
.
hosts
.
set
(
validated_data
.
get
(
"
hosts
"
,
instance
.
hosts
))
...
@@ -544,8 +564,8 @@ class ScheduleSerializer(serializers.ModelSerializer):
...
@@ -544,8 +564,8 @@ class ScheduleSerializer(serializers.ModelSerializer):
"
id
"
,
"
id
"
,
"
is_repetition
"
,
"
is_repetition
"
,
"
last_date
"
,
"
last_date
"
,
"
rrule
"
,
"
rrule
_id
"
,
"
show
"
,
"
show
_id
"
,
"
start_time
"
,
"
start_time
"
,
)
)
...
@@ -577,20 +597,18 @@ class ScheduleInRequestSerializer(ScheduleSerializer):
...
@@ -577,20 +597,18 @@ class ScheduleInRequestSerializer(ScheduleSerializer):
"
first_date
"
,
"
first_date
"
,
"
is_repetition
"
,
"
is_repetition
"
,
"
last_date
"
,
"
last_date
"
,
"
rrule
"
,
"
rrule
_id
"
,
"
show
"
,
"
show
_id
"
,
"
start_time
"
,
"
start_time
"
,
)
)
def
create
(
self
,
validated_data
):
def
create
(
self
,
validated_data
):
"""
Create and return a new Schedule instance, given the validated data.
"""
"""
Create and return a new Schedule instance, given the validated data.
"""
rrule
=
validated_data
.
pop
(
"
rrule
"
)
validated_data
[
"
rrule
"
]
=
validated_data
.
pop
(
"
rrule
_id
"
)
show
=
validated_data
.
pop
(
"
show
"
)
validated_data
[
"
show
"
]
=
validated_data
.
pop
(
"
show
_id
"
)
schedule
=
Schedule
.
objects
.
create
(
**
validated_data
)
schedule
=
Schedule
.
objects
.
create
(
**
validated_data
)
schedule
.
rrule
=
rrule
schedule
.
show
=
show
schedule
.
save
()
schedule
.
save
()
return
schedule
return
schedule
...
@@ -607,8 +625,8 @@ class ScheduleInRequestSerializer(ScheduleSerializer):
...
@@ -607,8 +625,8 @@ class ScheduleInRequestSerializer(ScheduleSerializer):
instance
.
default_playlist_id
=
validated_data
.
get
(
instance
.
default_playlist_id
=
validated_data
.
get
(
"
default_playlist_id
"
,
instance
.
default_playlist_id
"
default_playlist_id
"
,
instance
.
default_playlist_id
)
)
instance
.
rrule
=
validated_data
.
get
(
"
rrule
"
,
instance
.
rrule
)
instance
.
rrule
=
validated_data
.
get
(
"
rrule
_id
"
,
instance
.
rrule
)
instance
.
show
=
validated_data
.
get
(
"
show
"
,
instance
.
show
)
instance
.
show
=
validated_data
.
get
(
"
show
_id
"
,
instance
.
show
)
instance
.
add_days_no
=
validated_data
.
get
(
"
add_days_no
"
,
instance
.
add_days_no
)
instance
.
add_days_no
=
validated_data
.
get
(
"
add_days_no
"
,
instance
.
add_days_no
)
instance
.
add_business_days_only
=
validated_data
.
get
(
instance
.
add_business_days_only
=
validated_data
.
get
(
"
add_business_days_only
"
,
instance
.
add_business_days_only
"
add_business_days_only
"
,
instance
.
add_business_days_only
...
@@ -623,10 +641,10 @@ class CollisionSerializer(serializers.Serializer):
...
@@ -623,10 +641,10 @@ class CollisionSerializer(serializers.Serializer):
start
=
serializers
.
DateTimeField
()
start
=
serializers
.
DateTimeField
()
end
=
serializers
.
DateTimeField
()
end
=
serializers
.
DateTimeField
()
playlist_id
=
serializers
.
IntegerField
(
allow_null
=
True
)
playlist_id
=
serializers
.
IntegerField
(
allow_null
=
True
)
show
=
serializers
.
IntegerField
()
show
_id
=
serializers
.
IntegerField
()
show_name
=
serializers
.
CharField
()
show_name
=
serializers
.
CharField
()
repetition_of
=
serializers
.
IntegerField
(
allow_null
=
True
)
repetition_of
=
serializers
.
IntegerField
(
allow_null
=
True
)
schedule
=
serializers
.
IntegerField
()
schedule
_id
=
serializers
.
IntegerField
()
memo
=
serializers
.
CharField
()
memo
=
serializers
.
CharField
()
note_id
=
serializers
.
IntegerField
(
allow_null
=
True
)
note_id
=
serializers
.
IntegerField
(
allow_null
=
True
)
...
@@ -642,11 +660,13 @@ class ProjectedTimeSlotSerializer(serializers.Serializer):
...
@@ -642,11 +660,13 @@ class ProjectedTimeSlotSerializer(serializers.Serializer):
class
DryRunTimeSlotSerializer
(
serializers
.
Serializer
):
class
DryRunTimeSlotSerializer
(
serializers
.
Serializer
):
id
=
serializers
.
PrimaryKeyRelatedField
(
queryset
=
TimeSlot
.
objects
.
all
(),
allow_null
=
True
)
id
=
serializers
.
PrimaryKeyRelatedField
(
queryset
=
TimeSlot
.
objects
.
all
(),
allow_null
=
True
)
schedule
=
serializers
.
PrimaryKeyRelatedField
(
queryset
=
Schedule
.
objects
.
all
(),
allow_null
=
True
)
schedule_id
=
serializers
.
PrimaryKeyRelatedField
(
queryset
=
Schedule
.
objects
.
all
(),
allow_null
=
True
)
playlist_id
=
serializers
.
IntegerField
(
allow_null
=
True
)
playlist_id
=
serializers
.
IntegerField
(
allow_null
=
True
)
start
=
serializers
.
DateField
()
start
=
serializers
.
DateField
()
end
=
serializers
.
DateField
()
end
=
serializers
.
DateField
()
repetition_of
=
serializers
.
IntegerField
(
allow_null
=
True
)
repetition_of
_id
=
serializers
.
IntegerField
(
allow_null
=
True
)
memo
=
serializers
.
CharField
()
memo
=
serializers
.
CharField
()
...
@@ -678,9 +698,11 @@ class ScheduleDryRunResponseSerializer(serializers.Serializer):
...
@@ -678,9 +698,11 @@ class ScheduleDryRunResponseSerializer(serializers.Serializer):
class
TimeSlotSerializer
(
serializers
.
ModelSerializer
):
class
TimeSlotSerializer
(
serializers
.
ModelSerializer
):
show
=
serializers
.
PrimaryKeyRelatedField
(
queryset
=
Show
.
objects
.
all
(),
required
=
False
)
show_id
=
serializers
.
PrimaryKeyRelatedField
(
queryset
=
Show
.
objects
.
all
(),
required
=
False
)
schedule
=
serializers
.
PrimaryKeyRelatedField
(
queryset
=
Schedule
.
objects
.
all
(),
required
=
False
)
schedule_id
=
serializers
.
PrimaryKeyRelatedField
(
repetition_of
=
serializers
.
PrimaryKeyRelatedField
(
queryset
=
Schedule
.
objects
.
all
(),
required
=
False
)
repetition_of_id
=
serializers
.
PrimaryKeyRelatedField
(
allow_null
=
True
,
allow_null
=
True
,
queryset
=
TimeSlot
.
objects
.
all
(),
queryset
=
TimeSlot
.
objects
.
all
(),
required
=
False
,
required
=
False
,
...
@@ -691,14 +713,14 @@ class TimeSlotSerializer(serializers.ModelSerializer):
...
@@ -691,14 +713,14 @@ class TimeSlotSerializer(serializers.ModelSerializer):
read_only_fields
=
(
read_only_fields
=
(
"
id
"
,
"
id
"
,
"
end
"
,
"
end
"
,
"
schedule
"
,
"
schedule
_id
"
,
"
show
"
,
"
show
_id
"
,
"
start
"
,
"
start
"
,
)
)
fields
=
(
fields
=
(
"
memo
"
,
"
memo
"
,
"
playlist_id
"
,
"
playlist_id
"
,
"
repetition_of
"
,
"
repetition_of
_id
"
,
)
+
read_only_fields
)
+
read_only_fields
def
update
(
self
,
instance
,
validated_data
):
def
update
(
self
,
instance
,
validated_data
):
...
@@ -706,7 +728,7 @@ class TimeSlotSerializer(serializers.ModelSerializer):
...
@@ -706,7 +728,7 @@ class TimeSlotSerializer(serializers.ModelSerializer):
# Only save certain fields
# Only save certain fields
instance
.
memo
=
validated_data
.
get
(
"
memo
"
,
instance
.
memo
)
instance
.
memo
=
validated_data
.
get
(
"
memo
"
,
instance
.
memo
)
instance
.
repetition_of
=
validated_data
.
get
(
"
repetition_of
"
,
instance
.
repetition_of
)
instance
.
repetition_of
=
validated_data
.
get
(
"
repetition_of
"
,
instance
.
repetition_of
_id
)
instance
.
playlist_id
=
validated_data
.
get
(
"
playlist_id
"
,
instance
.
playlist_id
)
instance
.
playlist_id
=
validated_data
.
get
(
"
playlist_id
"
,
instance
.
playlist_id
)
instance
.
save
()
instance
.
save
()
return
instance
return
instance
...
@@ -720,11 +742,14 @@ class NoteLinkSerializer(serializers.ModelSerializer):
...
@@ -720,11 +742,14 @@ class NoteLinkSerializer(serializers.ModelSerializer):
class
NoteSerializer
(
serializers
.
ModelSerializer
):
class
NoteSerializer
(
serializers
.
ModelSerializer
):
contributors
=
serializers
.
PrimaryKeyRelatedField
(
queryset
=
Host
.
objects
.
all
(),
many
=
True
)
contributors
=
serializers
.
PrimaryKeyRelatedField
(
queryset
=
Host
.
objects
.
all
(),
many
=
True
)
image
=
serializers
.
PrimaryKeyRelatedField
(
image
_id
=
serializers
.
PrimaryKeyRelatedField
(
queryset
=
Image
.
objects
.
all
(),
required
=
False
,
allow_null
=
True
queryset
=
Image
.
objects
.
all
(),
required
=
False
,
allow_null
=
True
)
)
links
=
NoteLinkSerializer
(
many
=
True
,
required
=
False
)
links
=
NoteLinkSerializer
(
many
=
True
,
required
=
False
)
timeslot
=
serializers
.
PrimaryKeyRelatedField
(
queryset
=
TimeSlot
.
objects
.
all
(),
required
=
False
)
playlist_id
=
serializers
.
IntegerField
(
required
=
False
)
timeslot_id
=
serializers
.
PrimaryKeyRelatedField
(
queryset
=
TimeSlot
.
objects
.
all
(),
required
=
False
)
class
Meta
:
class
Meta
:
model
=
Note
model
=
Note
...
@@ -740,14 +765,14 @@ class NoteSerializer(serializers.ModelSerializer):
...
@@ -740,14 +765,14 @@ class NoteSerializer(serializers.ModelSerializer):
"
content
"
,
"
content
"
,
"
contributors
"
,
"
contributors
"
,
"
id
"
,
"
id
"
,
"
image
"
,
"
image
_id
"
,
"
links
"
,
"
links
"
,
"
owner
"
,
"
owner
_id
"
,
"
playlist
"
,
"
playlist
_id
"
,
"
slug
"
,
"
slug
"
,
"
summary
"
,
"
summary
"
,
"
tags
"
,
"
tags
"
,
"
timeslot
"
,
"
timeslot
_id
"
,
"
title
"
,
"
title
"
,
)
+
read_only_fields
)
+
read_only_fields
...
@@ -757,6 +782,12 @@ class NoteSerializer(serializers.ModelSerializer):
...
@@ -757,6 +782,12 @@ class NoteSerializer(serializers.ModelSerializer):
links_data
=
validated_data
.
pop
(
"
links
"
,
[])
links_data
=
validated_data
.
pop
(
"
links
"
,
[])
contributors
=
validated_data
.
pop
(
"
contributors
"
,
[])
contributors
=
validated_data
.
pop
(
"
contributors
"
,
[])
# required
validated_data
[
"
timeslot
"
]
=
validated_data
.
pop
(
"
timeslot_id
"
)
# optional
validated_data
[
"
image
"
]
=
validated_data
.
pop
(
"
image_id
"
,
None
)
# the creator of the note is the owner
# the creator of the note is the owner
note
=
Note
.
objects
.
create
(
note
=
Note
.
objects
.
create
(
created_by
=
self
.
context
.
get
(
"
request
"
).
user
.
username
,
created_by
=
self
.
context
.
get
(
"
request
"
).
user
.
username
,
...
@@ -791,10 +822,10 @@ class NoteSerializer(serializers.ModelSerializer):
...
@@ -791,10 +822,10 @@ class NoteSerializer(serializers.ModelSerializer):
instance
.
cba_id
=
validated_data
.
get
(
"
cba_id
"
,
instance
.
cba_id
)
instance
.
cba_id
=
validated_data
.
get
(
"
cba_id
"
,
instance
.
cba_id
)
instance
.
content
=
validated_data
.
get
(
"
content
"
,
instance
.
content
)
instance
.
content
=
validated_data
.
get
(
"
content
"
,
instance
.
content
)
instance
.
image
=
validated_data
.
get
(
"
image
"
,
instance
.
image
)
instance
.
image
=
validated_data
.
get
(
"
image
"
,
instance
.
image
_id
)
instance
.
slug
=
validated_data
.
get
(
"
slug
"
,
instance
.
slug
)
instance
.
slug
=
validated_data
.
get
(
"
slug
"
,
instance
.
slug
)
instance
.
summary
=
validated_data
.
get
(
"
summary
"
,
instance
.
summary
)
instance
.
summary
=
validated_data
.
get
(
"
summary
"
,
instance
.
summary
)
instance
.
timeslot
=
validated_data
.
get
(
"
timeslot
"
,
instance
.
timeslot
)
instance
.
timeslot
=
validated_data
.
get
(
"
timeslot
"
,
instance
.
timeslot
_id
)
instance
.
title
=
validated_data
.
get
(
"
title
"
,
instance
.
title
)
instance
.
title
=
validated_data
.
get
(
"
title
"
,
instance
.
title
)
instance
.
contributors
.
set
(
validated_data
.
get
(
"
contributors
"
,
instance
.
contributors
))
instance
.
contributors
.
set
(
validated_data
.
get
(
"
contributors
"
,
instance
.
contributors
))
...
...
This diff is collapsed.
Click to expand it.
program/services.py
+
13
−
13
View file @
bb9218c3
...
@@ -47,19 +47,19 @@ class ScheduleData(TypedDict):
...
@@ -47,19 +47,19 @@ class ScheduleData(TypedDict):
id
:
int
|
None
id
:
int
|
None
is_repetition
:
bool
|
None
is_repetition
:
bool
|
None
last_date
:
str
|
None
last_date
:
str
|
None
rrule
:
int
rrule
_id
:
int
show
:
int
|
None
show
_id
:
int
|
None
start_time
:
str
start_time
:
str
class
Collision
(
TypedDict
):
class
Collision
(
TypedDict
):
end
:
str
end
:
str
id
:
int
timeslot_
id
:
int
memo
:
str
memo
:
str
note_id
:
int
|
None
note_id
:
int
|
None
playlist_id
:
int
|
None
playlist_id
:
int
|
None
schedule
:
int
schedule
_id
:
int
show
:
int
show
_id
:
int
show_name
:
str
show_name
:
str
start
:
str
start
:
str
...
@@ -190,7 +190,7 @@ def resolve_conflicts(data: ScheduleCreateUpdateData, schedule_pk: int | None, s
...
@@ -190,7 +190,7 @@ def resolve_conflicts(data: ScheduleCreateUpdateData, schedule_pk: int | None, s
# Delete collision(s)
# Delete collision(s)
for
collision
in
timeslot
[
"
collisions
"
]:
for
collision
in
timeslot
[
"
collisions
"
]:
try
:
try
:
to_delete
.
append
(
TimeSlot
.
objects
.
get
(
pk
=
collision
[
"
id
"
]))
to_delete
.
append
(
TimeSlot
.
objects
.
get
(
pk
=
collision
[
"
timeslot_
id
"
]))
except
ObjectDoesNotExist
:
except
ObjectDoesNotExist
:
pass
pass
...
@@ -212,7 +212,7 @@ def resolve_conflicts(data: ScheduleCreateUpdateData, schedule_pk: int | None, s
...
@@ -212,7 +212,7 @@ def resolve_conflicts(data: ScheduleCreateUpdateData, schedule_pk: int | None, s
),
),
)
)
existing_ts
=
TimeSlot
.
objects
.
get
(
pk
=
existing
[
"
id
"
])
existing_ts
=
TimeSlot
.
objects
.
get
(
pk
=
existing
[
"
timeslot_
id
"
])
existing_ts
.
start
=
parse_datetime
(
timeslot
[
"
end
"
])
existing_ts
.
start
=
parse_datetime
(
timeslot
[
"
end
"
])
to_update
.
append
(
existing_ts
)
to_update
.
append
(
existing_ts
)
...
@@ -232,7 +232,7 @@ def resolve_conflicts(data: ScheduleCreateUpdateData, schedule_pk: int | None, s
...
@@ -232,7 +232,7 @@ def resolve_conflicts(data: ScheduleCreateUpdateData, schedule_pk: int | None, s
),
),
)
)
existing_ts
=
TimeSlot
.
objects
.
get
(
pk
=
existing
[
"
id
"
])
existing_ts
=
TimeSlot
.
objects
.
get
(
pk
=
existing
[
"
timeslot_
id
"
])
existing_ts
.
end
=
parse_datetime
(
timeslot
[
"
start
"
])
existing_ts
.
end
=
parse_datetime
(
timeslot
[
"
start
"
])
to_update
.
append
(
existing_ts
)
to_update
.
append
(
existing_ts
)
...
@@ -260,7 +260,7 @@ def resolve_conflicts(data: ScheduleCreateUpdateData, schedule_pk: int | None, s
...
@@ -260,7 +260,7 @@ def resolve_conflicts(data: ScheduleCreateUpdateData, schedule_pk: int | None, s
),
),
)
)
existing_ts
=
TimeSlot
.
objects
.
get
(
pk
=
existing
[
"
id
"
])
existing_ts
=
TimeSlot
.
objects
.
get
(
pk
=
existing
[
"
timeslot_
id
"
])
existing_ts
.
end
=
parse_datetime
(
timeslot
[
"
start
"
])
existing_ts
.
end
=
parse_datetime
(
timeslot
[
"
start
"
])
to_update
.
append
(
existing_ts
)
to_update
.
append
(
existing_ts
)
...
@@ -366,7 +366,7 @@ def instantiate_upcoming_schedule(
...
@@ -366,7 +366,7 @@ def instantiate_upcoming_schedule(
If the data does not contain a last_date, the Schedule instance will not contain a last_date.
If the data does not contain a last_date, the Schedule instance will not contain a last_date.
"""
"""
rrule
=
RRule
.
objects
.
get
(
pk
=
data
[
"
rrule
"
])
rrule
=
RRule
.
objects
.
get
(
pk
=
data
[
"
rrule
_id
"
])
show
=
Show
.
objects
.
get
(
pk
=
show_pk
)
show
=
Show
.
objects
.
get
(
pk
=
show_pk
)
is_repetition
=
data
[
"
is_repetition
"
]
if
"
is_repetition
"
in
data
else
False
is_repetition
=
data
[
"
is_repetition
"
]
if
"
is_repetition
"
in
data
else
False
...
@@ -635,13 +635,13 @@ def generate_conflicts(timeslots: list[TimeSlot]) -> Conflicts:
...
@@ -635,13 +635,13 @@ def generate_conflicts(timeslots: list[TimeSlot]) -> Conflicts:
for
c
in
collision_list
:
for
c
in
collision_list
:
# Add the collision
# Add the collision
collision
=
{
collision
=
{
"
id
"
:
c
.
id
,
"
timeslot_
id
"
:
c
.
id
,
"
start
"
:
str
(
c
.
start
),
"
start
"
:
str
(
c
.
start
),
"
end
"
:
str
(
c
.
end
),
"
end
"
:
str
(
c
.
end
),
"
playlist_id
"
:
c
.
playlist_id
,
"
playlist_id
"
:
c
.
playlist_id
,
"
show
"
:
c
.
show
.
id
,
"
show
_id
"
:
c
.
show
.
id
,
"
show_name
"
:
c
.
show
.
name
,
"
show_name
"
:
c
.
show
.
name
,
"
schedule
"
:
c
.
schedule_id
,
"
schedule
_id
"
:
c
.
schedule_id
,
"
memo
"
:
c
.
memo
,
"
memo
"
:
c
.
memo
,
}
}
...
...
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment