|
|
@ -41,11 +41,46 @@ def get_authenticated_service(secret): |
|
|
|
return oauth |
|
|
|
|
|
|
|
|
|
|
|
def get_playlist_by_name(user_info, options): |
|
|
|
|
|
|
|
for playlist in user_info["videoChannels"]: |
|
|
|
if playlist['displayName'] == options.get('--playlist'): |
|
|
|
return playlist['id'] |
|
|
|
|
|
|
|
|
|
|
|
def create_playlist(oauth, url, options): |
|
|
|
template = ('Peertube : Playlist %s does not exist, creating it.') |
|
|
|
logging.info(template % (str(options.get('--playlist')))) |
|
|
|
data = '{"displayName":"' + str(options.get('--playlist')) +'", \ |
|
|
|
"description":null}' |
|
|
|
|
|
|
|
headers = { |
|
|
|
'Content-Type': "application/json" |
|
|
|
} |
|
|
|
try: |
|
|
|
response = oauth.post(url + "/api/v1/video-channels/", |
|
|
|
data=data, |
|
|
|
headers=headers) |
|
|
|
except Exception as e: |
|
|
|
if hasattr(e, 'message'): |
|
|
|
logging.error("Error: " + str(e.message)) |
|
|
|
else: |
|
|
|
logging.error("Error: " + str(e)) |
|
|
|
if response is not None: |
|
|
|
if response.status_code == 200: |
|
|
|
jresponse = response.json() |
|
|
|
jresponse = jresponse['videoChannel'] |
|
|
|
return jresponse['id'] |
|
|
|
else: |
|
|
|
logging.error(('Peertube : The upload failed with an unexpected response: ' |
|
|
|
'%s') % response) |
|
|
|
exit(1) |
|
|
|
|
|
|
|
|
|
|
|
def upload_video(oauth, secret, options): |
|
|
|
|
|
|
|
def get_userinfo(): |
|
|
|
user_info = json.loads(oauth.get(url + "/api/v1/users/me").content) |
|
|
|
return str(user_info["id"]) |
|
|
|
return json.loads(oauth.get(url+"/api/v1/users/me").content) |
|
|
|
|
|
|
|
def get_videofile(path): |
|
|
|
mimetypes.init() |
|
|
@ -54,6 +89,7 @@ def upload_video(oauth, secret, options): |
|
|
|
|
|
|
|
path = options.get('--file') |
|
|
|
url = secret.get('peertube', 'peertube_url') |
|
|
|
user_info = get_userinfo() |
|
|
|
|
|
|
|
# We need to transform fields into tuple to deal with tags as |
|
|
|
# MultipartEncoder does not support list refer |
|
|
@ -64,7 +100,6 @@ def upload_video(oauth, secret, options): |
|
|
|
("licence", "1"), |
|
|
|
("description", options.get('--description') or "default description"), |
|
|
|
("nsfw", str(int(options.get('--nsfw')) or "0")), |
|
|
|
("channelId", get_userinfo()), |
|
|
|
("videofile", get_videofile(path)) |
|
|
|
] |
|
|
|
|
|
|
@ -105,12 +140,21 @@ def upload_video(oauth, secret, options): |
|
|
|
else: |
|
|
|
fields.append(("commentsEnabled", "1")) |
|
|
|
|
|
|
|
if options.get('--playlist'): |
|
|
|
playlist_id = get_playlist_by_name(user_info, options) |
|
|
|
if not playlist_id and options.get('--playlistCreate'): |
|
|
|
playlist_id = create_playlist(oauth, url, options) |
|
|
|
else: |
|
|
|
playlist_id = user_info['id'] |
|
|
|
else: |
|
|
|
playlist_id = user_info['id'] |
|
|
|
fields.append(("channelId", str(playlist_id))) |
|
|
|
|
|
|
|
multipart_data = MultipartEncoder(fields) |
|
|
|
|
|
|
|
headers = { |
|
|
|
'Content-Type': multipart_data.content_type |
|
|
|
} |
|
|
|
|
|
|
|
response = oauth.post(url + "/api/v1/videos/upload", |
|
|
|
data=multipart_data, |
|
|
|
headers=headers) |
|
|
|