2019-06-21 06:55:11 +00:00
|
|
|
#!/usr/bin/env python
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
2017-12-09 05:51:13 +00:00
|
|
|
"""
|
2018-03-19 16:33:44 +00:00
|
|
|
Use Tautulli to print plays by library from 0, 1, 7, or 30 days ago. 0 = total
|
2017-12-09 05:51:13 +00:00
|
|
|
|
|
|
|
optional arguments:
|
|
|
|
-h, --help show this help message and exit
|
|
|
|
-l [ ...], --libraries [ ...]
|
|
|
|
Space separated list of case sensitive names to process. Allowed names are:
|
|
|
|
(choices: All Library Names)
|
|
|
|
-d [ ...], --days [ ...]
|
|
|
|
Space separated list of case sensitive names to process. Allowed names are:
|
|
|
|
(defaults: [0, 1, 7, 30])
|
|
|
|
(choices: 0, 1, 7, 30)
|
|
|
|
|
|
|
|
Usage:
|
|
|
|
plays_days.py -l "TV Shows" Movies -d 30 1 0
|
|
|
|
Library: Movies
|
|
|
|
Days: 1 : 30 : 0
|
|
|
|
Plays: 5 : 83 : 384
|
|
|
|
Library: TV Shows
|
|
|
|
Days: 1 : 30 : 0
|
|
|
|
Plays: 56 : 754 : 2899
|
|
|
|
|
|
|
|
"""
|
2020-07-04 20:08:59 +00:00
|
|
|
from __future__ import print_function
|
2020-07-04 20:31:02 +00:00
|
|
|
from __future__ import unicode_literals
|
2017-12-09 05:51:13 +00:00
|
|
|
|
2020-07-04 20:23:47 +00:00
|
|
|
from builtins import str
|
2017-12-09 05:51:13 +00:00
|
|
|
import requests
|
|
|
|
import sys
|
|
|
|
import argparse
|
|
|
|
|
2019-06-21 06:55:11 +00:00
|
|
|
# ## EDIT THESE SETTINGS ##
|
2017-12-09 05:51:13 +00:00
|
|
|
|
2018-03-19 16:33:44 +00:00
|
|
|
TAUTULLI_APIKEY = 'xxxxx' # Your Tautulli API key
|
|
|
|
TAUTULLI_URL = 'http://localhost:8181/' # Your Tautulli URL
|
2017-12-09 05:51:13 +00:00
|
|
|
|
|
|
|
OUTPUT = 'Library: {section}\nDays: {days}\nPlays: {plays}'
|
|
|
|
|
2019-06-21 06:55:11 +00:00
|
|
|
# ## CODE BELOW ##
|
|
|
|
|
2017-12-09 05:51:13 +00:00
|
|
|
|
|
|
|
def get_library_names():
|
|
|
|
# Get a list of new rating keys for the PMS of all of the item's parent/children.
|
2018-03-19 16:33:44 +00:00
|
|
|
payload = {'apikey': TAUTULLI_APIKEY,
|
2017-12-09 05:51:13 +00:00
|
|
|
'cmd': 'get_library_names'}
|
|
|
|
|
|
|
|
try:
|
2018-03-19 16:33:44 +00:00
|
|
|
r = requests.get(TAUTULLI_URL.rstrip('/') + '/api/v2', params=payload)
|
2017-12-09 05:51:13 +00:00
|
|
|
response = r.json()
|
|
|
|
# print(json.dumps(response, indent=4, sort_keys=True))
|
|
|
|
|
|
|
|
res_data = response['response']['data']
|
|
|
|
return [d for d in res_data]
|
|
|
|
|
|
|
|
except Exception as e:
|
2018-03-19 16:33:44 +00:00
|
|
|
sys.stderr.write("Tautulli API 'get_library_names' request failed: {0}.".format(e))
|
2017-12-09 05:51:13 +00:00
|
|
|
|
|
|
|
|
|
|
|
def get_library_watch_time_stats(section_id):
|
|
|
|
# Get a list of new rating keys for the PMS of all of the item's parent/children.
|
2018-03-19 16:33:44 +00:00
|
|
|
payload = {'apikey': TAUTULLI_APIKEY,
|
2017-12-09 05:51:13 +00:00
|
|
|
'cmd': 'get_library_watch_time_stats',
|
|
|
|
'section_id': section_id}
|
|
|
|
|
|
|
|
try:
|
2018-03-19 16:33:44 +00:00
|
|
|
r = requests.get(TAUTULLI_URL.rstrip('/') + '/api/v2', params=payload)
|
2017-12-09 05:51:13 +00:00
|
|
|
response = r.json()
|
|
|
|
# print(json.dumps(response, indent=4, sort_keys=True))
|
|
|
|
|
|
|
|
res_data = response['response']['data']
|
|
|
|
return [d for d in res_data]
|
|
|
|
|
|
|
|
except Exception as e:
|
2018-03-19 16:33:44 +00:00
|
|
|
sys.stderr.write("Tautulli API 'get_library_watch_time_stats' request failed: {0}.".format(e))
|
2017-12-09 05:51:13 +00:00
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
|
|
|
|
lib_lst = [section['section_name'] for section in get_library_names()]
|
|
|
|
days_lst = [0, 1, 7, 30]
|
|
|
|
|
2018-03-19 16:33:44 +00:00
|
|
|
parser = argparse.ArgumentParser(description="Use Tautulli to pull plays by library",
|
2017-12-09 05:51:13 +00:00
|
|
|
formatter_class=argparse.RawTextHelpFormatter)
|
|
|
|
parser.add_argument('-l', '--libraries', nargs='+', type=str, default=lib_lst, choices=lib_lst, metavar='',
|
|
|
|
help='Space separated list of case sensitive names to process. Allowed names are: \n'
|
|
|
|
'(defaults: %(default)s)\n (choices: %(choices)s)')
|
|
|
|
parser.add_argument('-d', '--days', nargs='+', type=int, default=days_lst, choices=days_lst, metavar='',
|
|
|
|
help='Space separated list of case sensitive names to process. Allowed names are: \n'
|
|
|
|
'(defaults: %(default)s)\n (choices: %(choices)s)')
|
|
|
|
|
|
|
|
opts = parser.parse_args()
|
|
|
|
|
|
|
|
for section in get_library_names():
|
|
|
|
sec_name = section['section_name']
|
|
|
|
if sec_name in opts.libraries:
|
|
|
|
days = []
|
|
|
|
plays = []
|
|
|
|
section_id = section['section_id']
|
|
|
|
for stats in get_library_watch_time_stats(section_id):
|
|
|
|
if stats['query_days'] in opts.days and stats['total_plays'] > 0:
|
|
|
|
days.append(str(stats['query_days']))
|
|
|
|
plays.append(str(stats['total_plays']))
|
|
|
|
|
|
|
|
print(OUTPUT.format(section=sec_name, days=' : '.join(days), plays=' : '.join(plays)))
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
main()
|