mirror of
https://github.com/Tautulli/Tautulli.git
synced 2025-07-06 21:21:15 -07:00
Change home stats type to 'plays' or 'duration'
This commit is contained in:
parent
e36be32b8e
commit
d93390f8ed
3 changed files with 12 additions and 6 deletions
2
API.md
2
API.md
|
@ -733,7 +733,7 @@ Required parameters:
|
||||||
Optional parameters:
|
Optional parameters:
|
||||||
grouping (int): 0 or 1
|
grouping (int): 0 or 1
|
||||||
time_range (str): The time range to calculate statistics, '30'
|
time_range (str): The time range to calculate statistics, '30'
|
||||||
stats_type (int): 0 for plays, 1 for duration
|
stats_type (str): plays or duration
|
||||||
stats_count (str): The number of top items to list, '5'
|
stats_count (str): The number of top items to list, '5'
|
||||||
|
|
||||||
Returns:
|
Returns:
|
||||||
|
|
|
@ -261,7 +261,7 @@ class DataFactory(object):
|
||||||
|
|
||||||
return dict
|
return dict
|
||||||
|
|
||||||
def get_home_stats(self, grouping=None, time_range=None, stats_type=None, stats_count=None, stats_cards=None):
|
def get_home_stats(self, grouping=None, time_range=30, stats_type='plays', stats_count=10, stats_cards=None):
|
||||||
monitor_db = database.MonitorDatabase()
|
monitor_db = database.MonitorDatabase()
|
||||||
|
|
||||||
if grouping is None:
|
if grouping is None:
|
||||||
|
@ -280,7 +280,7 @@ class DataFactory(object):
|
||||||
music_watched_percent = plexpy.CONFIG.MUSIC_WATCHED_PERCENT
|
music_watched_percent = plexpy.CONFIG.MUSIC_WATCHED_PERCENT
|
||||||
|
|
||||||
group_by = 'session_history.reference_id' if grouping else 'session_history.id'
|
group_by = 'session_history.reference_id' if grouping else 'session_history.id'
|
||||||
sort_type = 'total_duration' if helpers.cast_to_int(stats_type) == 1 else 'total_plays'
|
sort_type = 'total_duration' if stats_type == 'duration' else 'total_plays'
|
||||||
|
|
||||||
home_stats = []
|
home_stats = []
|
||||||
|
|
||||||
|
|
|
@ -293,7 +293,7 @@ class WebInterface(object):
|
||||||
|
|
||||||
@cherrypy.expose
|
@cherrypy.expose
|
||||||
@requireAuth()
|
@requireAuth()
|
||||||
def home_stats(self, time_range=30, stats_type=0, stats_count=10, **kwargs):
|
def home_stats(self, time_range=30, stats_type='plays', stats_count=10, **kwargs):
|
||||||
data_factory = datafactory.DataFactory()
|
data_factory = datafactory.DataFactory()
|
||||||
stats_data = data_factory.get_home_stats(time_range=time_range,
|
stats_data = data_factory.get_home_stats(time_range=time_range,
|
||||||
stats_type=stats_type,
|
stats_type=stats_type,
|
||||||
|
@ -5321,7 +5321,7 @@ class WebInterface(object):
|
||||||
@cherrypy.tools.json_out()
|
@cherrypy.tools.json_out()
|
||||||
@requireAuth(member_of("admin"))
|
@requireAuth(member_of("admin"))
|
||||||
@addtoapi()
|
@addtoapi()
|
||||||
def get_home_stats(self, grouping=0, time_range='30', stats_type=0, stats_count='10', **kwargs):
|
def get_home_stats(self, grouping=0, time_range=30, stats_type='plays', stats_count=10, **kwargs):
|
||||||
""" Get the homepage watch statistics.
|
""" Get the homepage watch statistics.
|
||||||
|
|
||||||
```
|
```
|
||||||
|
@ -5331,7 +5331,7 @@ class WebInterface(object):
|
||||||
Optional parameters:
|
Optional parameters:
|
||||||
grouping (int): 0 or 1
|
grouping (int): 0 or 1
|
||||||
time_range (str): The time range to calculate statistics, '30'
|
time_range (str): The time range to calculate statistics, '30'
|
||||||
stats_type (int): 0 for plays, 1 for duration
|
stats_type (str): plays or duration
|
||||||
stats_count (str): The number of top items to list, '5'
|
stats_count (str): The number of top items to list, '5'
|
||||||
|
|
||||||
Returns:
|
Returns:
|
||||||
|
@ -5395,6 +5395,12 @@ class WebInterface(object):
|
||||||
]
|
]
|
||||||
```
|
```
|
||||||
"""
|
"""
|
||||||
|
# For backwards compatibility
|
||||||
|
if stats_type in (0, "0"):
|
||||||
|
stats_type = 'plays'
|
||||||
|
elif stats_type in (1, '1'):
|
||||||
|
stats_type = 'duration'
|
||||||
|
|
||||||
data_factory = datafactory.DataFactory()
|
data_factory = datafactory.DataFactory()
|
||||||
result = data_factory.get_home_stats(grouping=grouping,
|
result = data_factory.get_home_stats(grouping=grouping,
|
||||||
time_range=time_range,
|
time_range=time_range,
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue