pandora_cms/backup_films.py

88 lines
2.9 KiB
Python
Raw Normal View History

2018-05-10 13:30:11 +00:00
#!/usr/bin/env python3
2018-05-10 09:32:03 +00:00
import os
import sys
import unicodedata
import ox
import ox.api
def get_extension(api, oshash):
r = api.findMedia({'query': {
'conditions': [{'key': 'oshash', 'value': oshash}]
}, 'keys': ['extension']})['data']
2018-11-15 11:55:44 +00:00
return r['items'][0]['extension'].lower()
2018-05-10 09:32:03 +00:00
2018-11-15 11:55:44 +00:00
COLON = '\uf022'
COLON = ':'
2018-05-10 09:32:03 +00:00
if __name__ == '__main__':
2018-05-10 13:30:11 +00:00
if len(sys.argv) > 1:
target = sys.argv[1]
else:
target = os.path.join(os.path.dirname(os.path.abspath(__file__)), 'Films')
if not target.endswith('/'):
target += '/'
2018-05-10 09:32:03 +00:00
site = 'pandora.cinemusespace.com'
api = ox.api.signin('https://%s/api/' % site)
keep = []
2018-11-15 11:55:44 +00:00
r = api.find({'range': [0, 10000], 'keys': ['id']})
2018-05-10 09:32:03 +00:00
for i in r['data']['items']:
item = api.get(id=i['id'], keys=['id', 'streams', 'title', 'director', 'year', 'instances'])['data']
director = item.get('director', ['Unknown Director'])
path = os.path.join('; '.join(director), '%s' % (item['title']))
if 'year' in item:
path += ' (%s)' % item['year']
path = ox.decode_html(path)
prefix = ox.decode_html(item['title'])
2018-05-10 13:58:00 +00:00
2018-11-15 11:55:44 +00:00
path = path.replace(':', COLON)
prefix = prefix.replace(':', COLON)
keep.append(unicodedata.normalize('NFD', os.path.join(target, path, 'annotations.json')).lower())
2018-05-10 13:58:00 +00:00
2018-05-10 09:32:03 +00:00
parts = []
if len(item['streams']) == 1:
id = item['streams'][0]
ext = get_extension(api, id)
name = '%s.%s' % (item['title'], ext)
name = ox.decode_html(name)
2018-11-15 11:55:44 +00:00
name = name.replace(':', COLON)
2018-05-10 09:32:03 +00:00
part = 1
parts.append([os.path.join(path, name), item['id'], id, part])
else:
part = 1
for id in item['streams']:
ext = get_extension(api, id)
name = '%s.Part %d.%s' % (prefix, part, ext)
name = ox.decode_html(name)
2018-11-15 11:55:44 +00:00
name = name.replace(':', COLON)
2018-05-10 09:32:03 +00:00
parts.append([os.path.join(path, name), item['id'], id, part])
part += 1
for path, id, oshash, part in parts:
abspath = os.path.join(target, path)
if os.path.exists(abspath) and ox.oshash(abspath) != oshash:
2018-11-15 11:55:44 +00:00
print('file changed', abspath[len(target):])
2018-05-10 09:32:03 +00:00
os.unlink(abspath)
if not os.path.exists(abspath):
url = 'https://%s/%s/download/source/%s' % (site, id, part)
2018-05-10 13:58:00 +00:00
print('downloading', abspath[len(target):])
2018-08-10 10:33:32 +00:00
try:
api.save_url(url, abspath)
except:
print('failed to download', url)
2018-11-15 11:55:44 +00:00
keep.append(unicodedata.normalize('NFD', abspath).lower())
2018-05-10 09:32:03 +00:00
for root, folders, files in os.walk(target):
for f in files:
path = os.path.join(root, f)
2018-11-15 11:55:44 +00:00
if unicodedata.normalize('NFD', path).lower() not in keep:
2018-05-10 09:32:03 +00:00
print('deleting', path)
os.unlink(path)