2016-12-08 04:40:06 -04:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
|
|
|
"""
|
|
|
|
Upload an ULog file to the logs.px4.io web server.
|
|
|
|
|
|
|
|
@author: Beat Kueng (beat-kueng@gmx.net)
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
|
|
from __future__ import print_function
|
|
|
|
|
|
|
|
from argparse import ArgumentParser
|
2019-12-19 06:05:55 -04:00
|
|
|
from six.moves import input
|
2016-12-08 04:40:06 -04:00
|
|
|
import subprocess
|
|
|
|
import sys
|
|
|
|
|
|
|
|
try:
|
|
|
|
import requests
|
|
|
|
except:
|
|
|
|
print("Failed to import requests.")
|
|
|
|
print("You may need to install it with 'pip install requests'")
|
|
|
|
print("")
|
|
|
|
raise
|
|
|
|
|
|
|
|
|
2017-07-31 02:21:19 -03:00
|
|
|
SERVER = 'https://logs.px4.io'
|
2016-12-08 04:40:06 -04:00
|
|
|
#SERVER = 'http://localhost:5006' # for testing locally
|
|
|
|
UPLOAD_URL = SERVER+'/upload'
|
|
|
|
|
|
|
|
quiet = False
|
|
|
|
|
|
|
|
def ask_value(text, default=None):
|
|
|
|
""" ask the user to provide a certain value """
|
|
|
|
if quiet:
|
|
|
|
return ""
|
|
|
|
|
|
|
|
ask_string = 'Enter ' + text
|
|
|
|
if default != None:
|
|
|
|
ask_string += ' (Press ENTER to use ' + default + ')'
|
|
|
|
ask_string += ': '
|
2019-12-19 06:05:55 -04:00
|
|
|
ret = input(ask_string).strip()
|
2016-12-08 04:40:06 -04:00
|
|
|
if ret == "" and default != None:
|
|
|
|
return default
|
|
|
|
return ret
|
|
|
|
|
|
|
|
def get_git_email():
|
|
|
|
""" get (globally) configured git email """
|
2016-12-12 16:36:55 -04:00
|
|
|
try:
|
|
|
|
output = subprocess.check_output(["git", "config", "--global", "user.email"])
|
|
|
|
except Exception:
|
|
|
|
return ""
|
|
|
|
|
2016-12-08 04:40:06 -04:00
|
|
|
return output.decode("utf-8").replace('\n', '')
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
global quiet
|
|
|
|
parser = ArgumentParser(description=__doc__)
|
|
|
|
parser.add_argument('--quiet', '-q', dest='quiet', action='store_true', default=False,
|
|
|
|
help='Quiet mode: do not ask for values which were not provided as parameters')
|
|
|
|
parser.add_argument("--description", dest="description", type=str,
|
|
|
|
help="Log description", default=None)
|
|
|
|
parser.add_argument("--feedback", dest="feedback", type=str,
|
|
|
|
help="Additional feedback", default=None)
|
|
|
|
parser.add_argument("--source", dest="source", type=str,
|
|
|
|
help="Log source (Eg. CI)", default="webui")
|
|
|
|
parser.add_argument("--email", dest="email", type=str,
|
|
|
|
help="Your e-mail (to send the upload link)", default=None)
|
2019-03-18 08:18:04 -03:00
|
|
|
parser.add_argument("--type", dest="type", type=str, default='flightreport',
|
|
|
|
help="The upload type (either flightreport or personal).")
|
|
|
|
parser.add_argument("--videoUrl", dest="videoUrl", type=str, default='',
|
|
|
|
help="An Url to a video (only used for type flightreport).")
|
|
|
|
parser.add_argument("--rating", dest="rating", type=str, default='notset',
|
|
|
|
help="A rating for the flight (only used for type flightreport).")
|
|
|
|
parser.add_argument("--windSpeed", dest="windSpeed", type=int, default=-1,
|
|
|
|
help="A wind speed category for the flight (only used for flightreport).")
|
|
|
|
parser.add_argument("--public", dest="public", type=bool, default=True,
|
|
|
|
help="Whether the log is uploaded as public (only used for flightreport).")
|
2016-12-08 04:40:06 -04:00
|
|
|
parser.add_argument("FILE", help="ULog file(s)", nargs="+")
|
|
|
|
args = parser.parse_args()
|
|
|
|
|
|
|
|
# arguments
|
|
|
|
quiet = args.quiet
|
|
|
|
if args.description == None:
|
|
|
|
description = ask_value('Log Description')
|
|
|
|
else:
|
|
|
|
description = args.description
|
|
|
|
|
|
|
|
if args.feedback == None:
|
|
|
|
feedback = ask_value('Additional Feedback')
|
|
|
|
else:
|
|
|
|
feedback = args.feedback
|
|
|
|
|
|
|
|
if args.email == None:
|
|
|
|
default_email = get_git_email()
|
|
|
|
email = ask_value('Your e-mail', default_email)
|
|
|
|
else:
|
|
|
|
email = args.email
|
|
|
|
|
2019-03-18 08:18:04 -03:00
|
|
|
payload = {'type': args.type, 'description': description,
|
|
|
|
'feedback': feedback, 'email': email, 'source': args.source}
|
|
|
|
|
|
|
|
if args.type == 'flightreport':
|
|
|
|
payload['videoUrl'] = args.videoUrl
|
|
|
|
payload['rating'] = args.rating
|
|
|
|
payload['windSpeed'] = args.windSpeed
|
|
|
|
payload['public'] = str(args.public).lower()
|
2016-12-08 04:40:06 -04:00
|
|
|
|
|
|
|
for file_name in args.FILE:
|
2016-12-12 16:36:55 -04:00
|
|
|
if not quiet:
|
|
|
|
print('Uploading '+file_name+'...')
|
|
|
|
|
2016-12-08 04:40:06 -04:00
|
|
|
with open(file_name, 'rb') as f:
|
|
|
|
r = requests.post(UPLOAD_URL, data=payload, files={'filearg': f},
|
|
|
|
allow_redirects=False)
|
|
|
|
if r.status_code == 302: # redirect
|
|
|
|
if 'Location' in r.headers:
|
|
|
|
plot_url = r.headers['Location']
|
|
|
|
if len(plot_url) > 0 and plot_url[0] == '/':
|
|
|
|
plot_url = SERVER + plot_url
|
|
|
|
print('URL: '+plot_url)
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
main()
|
|
|
|
|