diff --git a/installer/build-server.py b/installer/build-server.py index 7d1ed8479d..d80ffa71e8 100644 --- a/installer/build-server.py +++ b/installer/build-server.py @@ -33,7 +33,6 @@ import datetime import platform import shutil -from slacker import Slacker import re import stat import subprocess @@ -42,6 +41,8 @@ import time import traceback from github3 import login +from requests.auth import HTTPBasicAuth +from requests import post # Access info class (for version info) sys.path.append(os.path.join(PATH, 'src', 'classes')) @@ -50,8 +51,7 @@ freeze_command = None errors_detected = [] make_command = "make" -slack_token = None -slack_object = None +zulip_token = None s3_access_key = None s3_secret_key = None s3_connection = None @@ -75,6 +75,7 @@ def run_command(command, working_dir=None): stderr=subprocess.STDOUT) return iter(p.stdout.readline, b"") + def output(line): """Append output to list and print it""" print(line) @@ -86,6 +87,7 @@ def output(line): line += "\n" log.write(line) + def error(line): """Append error output to list and print it""" print("Error: %s" % line) @@ -95,6 +97,7 @@ def error(line): else: log.write(line) + def truncate(message, max=256): """Truncate the message with ellipses""" if len(message) < max: @@ -102,36 +105,45 @@ def truncate(message, max=256): else: return "%s..." % message[:max] -def slack(message): - """Append a message to slack #build-server channel""" - print("Slack: %s" % message) - if slack_object: - slack_object.chat.post_message("#build-server", truncate(message[:256])) -def slack_upload_log(log, title, comment=None): - """Upload a file to slack and notify a slack channel""" +def zulip_upload_log(log, title, comment=None): + """Upload a file to zulip and notify a zulip channel""" + output("Zulip Upload: %s" % log_path) + # Close log file log.close() - print("Slack Upload: %s" % log_path) - if slack_object: - for attempt in range(3): - try: - # Upload build log to slack (and append platform icon to comment [:linux:, :windows:, or :darwin:]) - slack_object.files.upload(log_path, filetype="txt", filename="%s-build-server.txt" % platform.system(), - title=title, initial_comment=':%s: %s' % (platform.system().lower(), comment), channels="#build-server") - # Successfully uploaded! - break - except Exception as ex: - # Quietly fail, and try again - if attempt < 2: - output("Upload log to Slack failed... trying again") - else: - # Throw loud exception - raise Exception('Log upload to Slack failed: %s' % log_path, ex) + # Authentication for Zulip + zulip_auth = HTTPBasicAuth('builder-bot@openshot.zulipchat.com', zulip_token) + filename = "%s-build-server.txt" % platform.system() + + # Upload file to Zulip + zulip_url = 'https://openshot.zulipchat.com/api/v1/user_uploads' + zulip_upload_url = '' + resp = post(zulip_url, data={}, auth=zulip_auth, files={filename: (filename, open(log_path, "rb"))}) + if resp.ok: + zulip_upload_url = resp.json().get("uri", "") + print(resp) + + # Determine topic + topic = "Successful Builds" + if "skull" in comment: + topic = "Failed Builds" + + # SEND MESSAGE + zulip_url = 'https://openshot.zulipchat.com/api/v1/messages' + zulip_data = { + "type": "stream", + "to": "build-server", + "subject": topic, + "content": ':%s: %s [Build Log](%s)' % (platform.system().lower(), comment, zulip_upload_url) + } + + resp = post(zulip_url, data=zulip_data, auth=zulip_auth) # Re-open the log (for append) log = open(log_path, "a") + print(resp) def get_release(repo, tag_name): """Fetch the GitHub release tagged with the given tag and return it @@ -191,8 +203,7 @@ def parse_version_info(version_path): try: # Validate command-line arguments if len(sys.argv) >= 2: - slack_token = sys.argv[1] - slack_object = Slacker(slack_token) + zulip_token = sys.argv[1] if len(sys.argv) >= 4: s3_access_key = sys.argv[2] s3_secret_key = sys.argv[3] @@ -492,8 +503,8 @@ def parse_version_info(version_path): # Torrent succeeded! Upload the torrent to github url = upload(torrent_path, github_release) - # Notify Slack - slack_upload_log(log, "%s: Build logs for %s" % (platform.system(), app_name), "Successful *%s* build: %s" % (git_branch_name, download_url)) + # Notify Zulip + zulip_upload_log(log, "%s: Build logs for %s" % (platform.system(), app_name), "Successful *%s* build: %s" % (git_branch_name, download_url)) except Exception as ex: tb = traceback.format_exc() @@ -502,6 +513,6 @@ def parse_version_info(version_path): # Report any errors detected if errors_detected: - slack_upload_log(log, "%s: Error log for *%s* build" % (platform.system(), git_branch_name), ":skull_and_crossbones: %s" % truncate(errors_detected[0], 150)) + zulip_upload_log(log, "%s: Error log for *%s* build" % (platform.system(), git_branch_name), ":skull_and_crossbones: %s" % truncate(errors_detected[0], 100)) exit(1) diff --git a/src/__init__.py b/src/__init__.py new file mode 100644 index 0000000000..d4daea2b3d --- /dev/null +++ b/src/__init__.py @@ -0,0 +1,31 @@ +""" + @file openshot_qt/__init__.py + @brief Initialization code used when running OpenShot installed as a Python module + @author FeRD (Frank Dana) + + @section LICENSE + + Copyright (c) 2008-2018 OpenShot Studios, LLC + (http://www.openshotstudios.com). This file is part of + OpenShot Video Editor (http://www.openshot.org), an open-source project + dedicated to delivering high quality video editing and animation solutions + to the world. + + OpenShot Video Editor is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + OpenShot Video Editor is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with OpenShot Library. If not, see . + """ + +import os + +# Determine path to this module +OPENSHOT_PATH = os.path.dirname(os.path.realpath(__file__)) diff --git a/src/launch.py b/src/launch.py index 33df3dd549..45c242f804 100755 --- a/src/launch.py +++ b/src/launch.py @@ -47,8 +47,9 @@ from classes import info print("Loaded modules from current directory: %s" % info.PATH) except ImportError: - from openshot_qt.classes import info - sys.path.append(info.PATH) + import openshot_qt + sys.path.append(openshot_qt.OPENSHOT_PATH) + from classes import info print("Loaded modules from installed directory: %s" % info.PATH) from classes.app import OpenShotApp