2019-06-21 06:55:11 +00:00
|
|
|
#!/usr/bin/env python
|
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
2017-07-12 18:16:46 +00:00
|
|
|
"""
|
2018-03-19 16:33:44 +00:00
|
|
|
Find when media was added between STARTFRAME and ENDFRAME to Plex through Tautulli.
|
2017-07-12 18:16:46 +00:00
|
|
|
|
2019-06-21 06:55:11 +00:00
|
|
|
Some Exceptions have been commented out to supress what is printed.
|
2017-07-12 18:16:46 +00:00
|
|
|
Uncomment Exceptions if you run into problem and need to investigate.
|
|
|
|
"""
|
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-07-12 18:16:46 +00:00
|
|
|
|
2020-07-04 20:23:47 +00:00
|
|
|
from builtins import str
|
|
|
|
from builtins import object
|
2017-07-12 18:16:46 +00:00
|
|
|
import requests
|
|
|
|
import sys
|
|
|
|
import time
|
|
|
|
|
2019-06-21 06:55:11 +00:00
|
|
|
STARTFRAME = 1480550400 # 2016, Dec 1 in seconds
|
|
|
|
ENDFRAME = 1488326400 # 2017, March 1 in seconds
|
2017-07-12 18:16:46 +00:00
|
|
|
|
|
|
|
TODAY = int(time.time())
|
2019-06-21 06:55:11 +00:00
|
|
|
LASTMONTH = int(TODAY - 2629743) # 2629743 = 1 month in seconds
|
2017-07-12 18:16:46 +00:00
|
|
|
|
|
|
|
# Uncomment to change range to 1 month ago - Today
|
|
|
|
# STARTFRAME = LASTMONTH
|
|
|
|
# ENDFRAME = TODAY
|
|
|
|
|
2019-06-21 06:55:11 +00:00
|
|
|
# ## EDIT THESE SETTINGS ##
|
2018-03-19 16:33:44 +00:00
|
|
|
TAUTULLI_APIKEY = 'XXXXX' # Your Tautulli API key
|
|
|
|
TAUTULLI_URL = 'http://localhost:8181/' # Your Tautulli URL
|
2019-06-21 06:55:11 +00:00
|
|
|
LIBRARY_NAMES = ['TV Shows', 'Movies'] # Names of your libraries you want to check.
|
2017-07-12 18:16:46 +00:00
|
|
|
|
|
|
|
|
|
|
|
class LIBINFO(object):
|
|
|
|
def __init__(self, data=None):
|
|
|
|
d = data or {}
|
|
|
|
self.added_at = d['added_at']
|
|
|
|
self.parent_rating_key = d['parent_rating_key']
|
|
|
|
self.title = d['title']
|
|
|
|
self.rating_key = d['rating_key']
|
|
|
|
self.media_type = d['media_type']
|
|
|
|
|
|
|
|
|
|
|
|
class METAINFO(object):
|
|
|
|
def __init__(self, data=None):
|
|
|
|
d = data or {}
|
|
|
|
self.added_at = d['added_at']
|
|
|
|
self.parent_rating_key = d['parent_rating_key']
|
|
|
|
self.title = d['title']
|
|
|
|
self.rating_key = d['rating_key']
|
|
|
|
self.media_type = d['media_type']
|
|
|
|
self.grandparent_title = d['grandparent_title']
|
|
|
|
self.file_size = d['file_size']
|
|
|
|
|
|
|
|
|
2018-03-19 16:33:44 +00:00
|
|
|
def get_new_rating_keys(rating_key, media_type):
|
2017-07-12 18:16:46 +00:00
|
|
|
# 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-07-12 18:16:46 +00:00
|
|
|
'cmd': 'get_new_rating_keys',
|
|
|
|
'rating_key': rating_key,
|
|
|
|
'media_type': media_type}
|
|
|
|
|
|
|
|
try:
|
2018-03-19 16:33:44 +00:00
|
|
|
r = requests.get(TAUTULLI_URL.rstrip('/') + '/api/v2', params=payload)
|
2017-07-12 18:16:46 +00:00
|
|
|
response = r.json()
|
|
|
|
|
|
|
|
res_data = response['response']['data']
|
|
|
|
show = res_data['0']
|
|
|
|
episode_lst = [episode['rating_key'] for _, season in show['children'].items() for _, episode in
|
|
|
|
season['children'].items()]
|
|
|
|
|
|
|
|
return episode_lst
|
|
|
|
|
|
|
|
except Exception as e:
|
2018-03-24 18:04:47 +00:00
|
|
|
sys.stderr.write("Tautulli API 'get_new_rating_keys' request failed: {0}.".format(e))
|
2017-07-12 18:16:46 +00:00
|
|
|
|
2019-06-21 06:55:11 +00:00
|
|
|
|
2018-03-19 16:33:44 +00:00
|
|
|
def get_library_media_info(section_id):
|
|
|
|
# Get the data on the Tautulli media info tables. Length matters!
|
|
|
|
payload = {'apikey': TAUTULLI_APIKEY,
|
2017-07-12 18:16:46 +00:00
|
|
|
'section_id': section_id,
|
|
|
|
'order_dir ': 'asc',
|
|
|
|
'cmd': 'get_library_media_info',
|
|
|
|
'length': 10000000}
|
|
|
|
|
|
|
|
try:
|
2018-03-19 16:33:44 +00:00
|
|
|
r = requests.get(TAUTULLI_URL.rstrip('/') + '/api/v2', params=payload)
|
2017-07-12 18:16:46 +00:00
|
|
|
response = r.json()
|
|
|
|
|
|
|
|
res_data = response['response']['data']['data']
|
|
|
|
return [LIBINFO(data=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_media_info' request failed: {0}.".format(e))
|
2017-07-12 18:16:46 +00:00
|
|
|
|
2019-06-21 06:55:11 +00:00
|
|
|
|
2018-03-19 16:33:44 +00:00
|
|
|
def get_metadata(rating_key):
|
2017-07-12 18:16:46 +00:00
|
|
|
# Get the metadata for a media item.
|
2018-03-19 16:33:44 +00:00
|
|
|
payload = {'apikey': TAUTULLI_APIKEY,
|
2017-07-12 18:16:46 +00:00
|
|
|
'rating_key': rating_key,
|
|
|
|
'cmd': 'get_metadata',
|
|
|
|
'media_info': True}
|
|
|
|
|
|
|
|
try:
|
2018-03-19 16:33:44 +00:00
|
|
|
r = requests.get(TAUTULLI_URL.rstrip('/') + '/api/v2', params=payload)
|
2017-07-12 18:16:46 +00:00
|
|
|
response = r.json()
|
|
|
|
|
2018-03-24 17:58:47 +00:00
|
|
|
res_data = response['response']['data']
|
2017-07-12 18:16:46 +00:00
|
|
|
if STARTFRAME <= int(res_data['added_at']) <= ENDFRAME:
|
|
|
|
return METAINFO(data=res_data)
|
|
|
|
|
|
|
|
except Exception as e:
|
2018-03-24 18:04:47 +00:00
|
|
|
sys.stderr.write("Tautulli API 'get_metadata' request failed: {0}.".format(e))
|
2017-07-12 18:16:46 +00:00
|
|
|
|
2019-06-21 06:55:11 +00:00
|
|
|
|
2017-07-12 18:16:46 +00:00
|
|
|
def update_library_media_info(section_id):
|
2018-03-19 16:33:44 +00:00
|
|
|
# Get the data on the Tautulli media info tables.
|
|
|
|
payload = {'apikey': TAUTULLI_APIKEY,
|
2017-07-12 18:16:46 +00:00
|
|
|
'cmd': 'get_library_media_info',
|
|
|
|
'section_id': section_id,
|
|
|
|
'refresh': True}
|
|
|
|
|
|
|
|
try:
|
2018-03-19 16:33:44 +00:00
|
|
|
r = requests.get(TAUTULLI_URL.rstrip('/') + '/api/v2', params=payload)
|
2017-07-12 18:16:46 +00:00
|
|
|
response = r.status_code
|
|
|
|
if response != 200:
|
|
|
|
print(r.content)
|
|
|
|
|
|
|
|
except Exception as e:
|
2018-03-19 16:33:44 +00:00
|
|
|
sys.stderr.write("Tautulli API 'update_library_media_info' request failed: {0}.".format(e))
|
2017-07-12 18:16:46 +00:00
|
|
|
|
2019-06-21 06:55:11 +00:00
|
|
|
|
2018-03-19 16:33:44 +00:00
|
|
|
def get_libraries_table():
|
|
|
|
# Get the data on the Tautulli libraries table.
|
|
|
|
payload = {'apikey': TAUTULLI_APIKEY,
|
2017-07-12 18:16:46 +00:00
|
|
|
'cmd': 'get_libraries_table'}
|
|
|
|
|
|
|
|
try:
|
2018-03-19 16:33:44 +00:00
|
|
|
r = requests.get(TAUTULLI_URL.rstrip('/') + '/api/v2', params=payload)
|
2017-07-12 18:16:46 +00:00
|
|
|
response = r.json()
|
|
|
|
|
|
|
|
res_data = response['response']['data']['data']
|
|
|
|
return [d['section_id'] for d in res_data if d['section_name'] in LIBRARY_NAMES]
|
|
|
|
|
|
|
|
except Exception as e:
|
2018-03-19 16:33:44 +00:00
|
|
|
sys.stderr.write("Tautulli API 'get_libraries_table' request failed: {0}.".format(e))
|
2017-07-12 18:16:46 +00:00
|
|
|
|
|
|
|
|
|
|
|
show_lst = []
|
|
|
|
count_lst = []
|
|
|
|
size_lst = []
|
|
|
|
|
2018-03-19 16:33:44 +00:00
|
|
|
glt = [lib for lib in get_libraries_table()]
|
2017-07-12 18:16:46 +00:00
|
|
|
|
|
|
|
# Updating media info for libraries.
|
|
|
|
[update_library_media_info(i) for i in glt]
|
|
|
|
|
|
|
|
for i in glt:
|
|
|
|
try:
|
2018-03-19 16:33:44 +00:00
|
|
|
gglm = get_library_media_info(i)
|
2017-07-12 18:16:46 +00:00
|
|
|
for x in gglm:
|
|
|
|
try:
|
|
|
|
if x.media_type in ['show', 'episode']:
|
|
|
|
# Need to find TV shows rating_key for episode.
|
2018-03-19 16:33:44 +00:00
|
|
|
show_lst += get_new_rating_keys(x.rating_key, x.media_type)
|
2017-07-12 18:16:46 +00:00
|
|
|
else:
|
|
|
|
# Find movie rating_key.
|
|
|
|
show_lst += [int(x.rating_key)]
|
|
|
|
except Exception as e:
|
2020-07-04 20:08:59 +00:00
|
|
|
print(("Rating_key failed: {e}").format(e=e))
|
2017-07-12 18:16:46 +00:00
|
|
|
|
|
|
|
except Exception as e:
|
2020-07-04 20:08:59 +00:00
|
|
|
print(("Library media info failed: {e}").format(e=e))
|
2017-07-12 18:16:46 +00:00
|
|
|
|
|
|
|
# All rating_keys for episodes and movies.
|
|
|
|
# Reserving order will put newest rating_keys first
|
|
|
|
# print(sorted(show_lst, reverse=True))
|
|
|
|
|
|
|
|
for i in sorted(show_lst, reverse=True):
|
|
|
|
try:
|
2018-03-19 16:33:44 +00:00
|
|
|
x = get_metadata(str(i))
|
2017-07-12 18:16:46 +00:00
|
|
|
added = time.ctime(float(x.added_at))
|
|
|
|
count_lst += [x.media_type]
|
|
|
|
size_lst += [int(x.file_size)]
|
|
|
|
if x.grandparent_title == '' or x.media_type == 'movie':
|
|
|
|
# Movies
|
|
|
|
print(u"{x.title} ({x.rating_key}) was added {when}.".format(x=x, when=added))
|
|
|
|
else:
|
|
|
|
# Shows
|
|
|
|
print(u"{x.grandparent_title}: {x.title} ({x.rating_key}) was added {when}.".format(x=x, when=added))
|
|
|
|
|
2019-06-21 06:55:11 +00:00
|
|
|
except Exception:
|
2017-07-12 18:16:46 +00:00
|
|
|
# Remove commented print below to investigate problems.
|
|
|
|
# print("Metadata failed. Likely end of range: {e}").format(e=e)
|
|
|
|
# Remove break if not finding files in range
|
|
|
|
break
|
|
|
|
|
2019-06-21 06:55:11 +00:00
|
|
|
print("There were {amount} files added between {start}:{end}".format(
|
|
|
|
amount=len(count_lst),
|
|
|
|
start=time.ctime(float(STARTFRAME)),
|
|
|
|
end=time.ctime(float(ENDFRAME))))
|
2017-07-12 18:16:46 +00:00
|
|
|
print("Total movies: {}".format(count_lst.count('movie')))
|
|
|
|
print("Total shows: {}".format(count_lst.count('show') + count_lst.count('episode')))
|
2019-06-21 06:55:11 +00:00
|
|
|
print("Total size of files added: {}MB".format(sum(size_lst) >> 20))
|