From 70cbfb199d42c2c0fd36a45bce8c1464d2540d6f Mon Sep 17 00:00:00 2001 From: obscuren Date: Sat, 7 Mar 2015 13:16:13 +0100 Subject: Added deploy scripts from go-build --- deploy/osx/Ethereal.icns | Bin 0 -> 61268 bytes deploy/osx/Mist.icns | Bin 0 -> 268355 bytes deploy/osx/background-source-pm.pxm | Bin 0 -> 3239597 bytes deploy/osx/background-source.psd | Bin 0 -> 5644498 bytes deploy/osx/background.png | Bin 0 -> 1044884 bytes deploy/osx/background@2x.png | Bin 0 -> 1044884 bytes deploy/osx/build.py | 238 ++++++++++++++++++++++++++++++++++++ deploy/osx/dmg_spec.json | 10 ++ deploy/osx/script.sh | 35 ++++++ 9 files changed, 283 insertions(+) create mode 100644 deploy/osx/Ethereal.icns create mode 100644 deploy/osx/Mist.icns create mode 100644 deploy/osx/background-source-pm.pxm create mode 100644 deploy/osx/background-source.psd create mode 100644 deploy/osx/background.png create mode 100644 deploy/osx/background@2x.png create mode 100644 deploy/osx/build.py create mode 100644 deploy/osx/dmg_spec.json create mode 100644 deploy/osx/script.sh (limited to 'deploy/osx') diff --git a/deploy/osx/Ethereal.icns b/deploy/osx/Ethereal.icns new file mode 100644 index 000000000..b02ad0ca3 Binary files /dev/null and b/deploy/osx/Ethereal.icns differ diff --git a/deploy/osx/Mist.icns b/deploy/osx/Mist.icns new file mode 100644 index 000000000..3ba75a432 Binary files /dev/null and b/deploy/osx/Mist.icns differ diff --git a/deploy/osx/background-source-pm.pxm b/deploy/osx/background-source-pm.pxm new file mode 100644 index 000000000..4cf97f8ea Binary files /dev/null and b/deploy/osx/background-source-pm.pxm differ diff --git a/deploy/osx/background-source.psd b/deploy/osx/background-source.psd new file mode 100644 index 000000000..8fb1b33ce Binary files /dev/null and b/deploy/osx/background-source.psd differ diff --git a/deploy/osx/background.png b/deploy/osx/background.png new file mode 100644 index 000000000..54bbab35d Binary files /dev/null and b/deploy/osx/background.png differ diff --git a/deploy/osx/background@2x.png b/deploy/osx/background@2x.png new file mode 100644 index 000000000..20bbc6ace Binary files /dev/null and b/deploy/osx/background@2x.png differ diff --git a/deploy/osx/build.py b/deploy/osx/build.py new file mode 100644 index 000000000..f5e731efd --- /dev/null +++ b/deploy/osx/build.py @@ -0,0 +1,238 @@ +import sys, os, argparse, logging, shutil, subprocess, stat,glob +from os.path import isfile + +# TODO handle icns +# TODO create dmg +# TODO Add client qml files and png files +# CHMOD +x the main binary + +logging.basicConfig( + stream=sys.stdout, + format='%(asctime)s : %(levelname)s\t : %(message)s', + datefmt='%m/%d/%Y %I:%M:%S %p', + level=logging.DEBUG +) + +XML_PLIST = """ + + + + + CFBundleGetInfoString + Mist + CFBundleExecutable + Mist + CFBundleIdentifier + com.ethereum.mist + CFBundleName + Mist + CFBundleIconFile + Mist.icns + CFBundleShortVersionString + POC8 + CFBundleInfoDictionaryVersion + POC8 + CFBundlePackageType + APPL + IFMajorVersion + 0 + IFMinorVersion + 5 + + +""" + +RUN_SCRIPT =""" +#!/bin/bash +cd "${0%/*}" +./go-ethereum +""" + +class AppBundler: + def copytree(self, src, dst, symlinks=False, ignore=None): + for item in os.listdir(src): + s = os.path.join(src, item) + d = os.path.join(dst, item) + if os.path.isdir(s): + shutil.copytree(s, d, symlinks, ignore) + else: + shutil.copy2(s, d) + + # If macdeployqt handles qmldir then runs on app + def runMacDeployQT(self): + exe = '/usr/local/opt/qt5/bin/macdeployqt' + if not os.path.exists(exe): exe = 'macdeployqt' + p = subprocess.Popen(exe, stdout=subprocess.PIPE, stderr=subprocess.STDOUT) + handles_qml = False + for line in p.stdout.readlines(): + if '-qmldir=' in line: + handles_qml = True + break + if handles_qml and self.go_path is not None: + qml_path = os.path.join(self.go_path, 'src/github.com/ethereum/go-ethereum/cmd/mist/assets/qml/') #TODO this is terrible + out = os.path.join(self.output_dir + '/Mist.app') + command = exe + ' ' + out + ' -executable='+out+'/Contents/MacOS/Mist' + ' -qmldir=' + qml_path #TODO this is terrible + logging.info('Running macdeployqt with options') + p = subprocess.Popen(command, shell=True, stdout=subprocess.PIPE, stderr=subprocess.STDOUT) + for line in p.stdout.readlines(): + logging.info('macdeployqt: ' + line.strip()) + else: + logging.error('Your version of macdeployqt does not handle qmldir') + + # Add ICNS file to + def insertICNS(self): + path = os.path.join(self.output_dir, 'Mist.app/Contents/Resources/Mist.icns') + + try: + shutil.copyfile('./Mist.icns',path) # TODO this is horrible + logging.info('Inserted Mist.icns') + except Exception as e: + logging.error(str(e)) + + def insertQMLnPNG(self): + pass # TODO + + #def signApp(self): + # after macdeployqt copy /usr/local/opt/qt5/lib/QtCore.framework/Contents/Info.plist to .app/Contents/Resources/QtCore.framework/Resources/Info.plist + # codesign --verbose --force --sign "Developer ID Application: <>" /Users/_/Dropbox/Experiments/EthereumBuild/Ethereal.app/Contents/Frameworks/QtCore.framework + # do for rest + # codesign --verbose --deep --force --sign "Developer ID Application: <>" Ethereal.app + # codesign --verify --verbose=4 Ethereal.app + + def insertAssets(self): + asset_path = os.path.join(self.go_path, 'src/github.com/ethereum/go-ethereum/cmd/mist/assets') + self.copytree(asset_path,"Mist.app/Contents/Resources/") + # Copy mnemonic word list + #shutil.copy(os.path.join(self.go_path, 'src/github.com/ethereum/eth-go/ethcrypto/mnemonic.words.lst'),"Mist.app/Contents/Resources/") + + # Insert all QML files and other resource files Mist needs + def insertResources(self): + qml_path = os.path.join(self.go_path, 'src/github.com/ethereum/go-ethereum/cmd/mist/assets/qml/') + target_folder = "Mist.app/Contents/Resources/" + target_folder_qml = target_folder + "qml/" + + os.makedirs(target_folder_qml) + + files = glob.glob(qml_path) + for f in files: + print "Copying %s to %s" % (f, target_folder_qml) + if isfile(f): + shutil.copy(f, target_folder_qml) + else: + self.copytree(f, target_folder_qml) + + files = glob.glob(os.path.join(self.go_path, 'src/github.com/ethereum/go-ethereum/cmd/mist/assets/*')) + for f in files: + print "Copying %s to %s" % (f, target_folder) + if isfile(f): + shutil.copy(f, target_folder) + else: + self.copytree(f, target_folder) + # Finds go-etherum binary and copies to app bundle + + def insertGoBinary(self): + if self.go_path is not None: + binary = os.path.join(self.go_path, 'bin/mist') + if os.path.exists(binary): + try: + shutil.copyfile(binary, os.path.join(self.output_dir, 'Mist.app/Contents/MacOS/Mist')) # TODO this is horrible + os.chmod(os.path.join(self.output_dir, 'Mist.app/Contents/MacOS/Mist'), 0711) + logging.info('Inserted go-ethereum binary') + except Exception as e: + logging.error(str(e)) + else: + logging.error('Cannot find go-etherum binary') + if self.handleHumanInput('Run "go get -u github.com/ethereum/go-ethereum" ?'): + logging.debug('Not Implemented') + pass + else: + logging.error('GOPATH not found, cannot continue') + + # Write the Info.plist + def writePList(self): + try: + with open(os.path.join(self.output_dir, 'Mist.app/Contents/Info.plist'), 'wb') as f: # TODO this is horrible + f.write(XML_PLIST) + f.close() + logging.info('Info.plist written') + except Exception as e: + logging.error(str(e)) + + # Building out directory structure + def buildStructure(self, root, structure): + if root is not self.output_dir: + try: + os.mkdir(root) + logging.info('Created ' + root) + except Exception as e: + logging.error(str(e)) + if self.handleHumanInput('Remove Directory?'): + try: + shutil.rmtree(root) + self.buildStructure(root, structure) + return + except Exception as e: + logging.error(str(e)) + for item in structure.keys(): + self.buildStructure( + os.path.join(root, item), + structure[item] + ) + + # Convert human input to boolean + def handleHumanInput(self, question=''): + if self.force: return True + try: + answer = raw_input(question + " [Y/n]: ").lower() + except: + return True + if answer is '' or answer[0:1] == 'y': return True + return False + + logging.info('Copying QTWebProcess') + libexec_path = self.output_dir + '/Mist.app/Contents/libexec' + try: + os.mkdir(libexec_path) + shutil.copy2(path, libexec_path) + return True + except OSError as e: + print("Problem getting QTWebprocess on path %s. Error: %s" % (path, e)) + return False + + # Setup Variables + def __init__(self, args): + self.force = args['force'] + self.output_dir = args['output'] + self.app_name = "".join(x for x in args['name'] if x.isalnum()) # Simple Santize + self.app_structure = { + '%s.app' % self.app_name : { + 'Contents' : { + 'MacOS' : {}, + 'Resources' : {} + } + } + } + self.go_path = os.environ.get('GOPATH') + self.buildStructure(self.output_dir, self.app_structure) + self.writePList() + self.insertICNS() + self.insertGoBinary() + self.insertAssets() + + #self.insertResources() + + self.runMacDeployQT() + os.system("sh script.sh " + self.output_dir + "/Mist.app/Contents") + os.system("appdmg dmg_spec.json Mist.dmg") + + logging.info("fin'") + + +if __name__ == "__main__": + parser = argparse.ArgumentParser(description='Standalone Mist Go Client App Bundler') + parser.add_argument('-n','--name', help='Name of app bundle', default='Mist', required=False) + parser.add_argument('-q','--qtwebpath', help='Location of QtWebProcess', default='Mist', required=False) + parser.add_argument('-o','--output', help='Directory to write app bundle', default=os.getcwd(), required=False) + parser.add_argument('-f','--force', help='Force Fresh Build', default=False, required=False) + args = vars(parser.parse_args()) + AppBundler(args) diff --git a/deploy/osx/dmg_spec.json b/deploy/osx/dmg_spec.json new file mode 100644 index 000000000..c43312496 --- /dev/null +++ b/deploy/osx/dmg_spec.json @@ -0,0 +1,10 @@ +{ + "title": "Mist Installer", + "icon": "Mist.icns", + "background": "background.png", + "icon-size": 144, + "contents": [ + { "x": 900, "y": 244, "type": "link", "path": "/Applications" }, + { "x": 140, "y": 244, "type": "file", "path": "Mist.app" } + ] +} diff --git a/deploy/osx/script.sh b/deploy/osx/script.sh new file mode 100644 index 000000000..345ab5ae8 --- /dev/null +++ b/deploy/osx/script.sh @@ -0,0 +1,35 @@ +#!/bin/bash + +BUILD_FOLDER_PATH=$1 +BUILD_QML_FOLDER_PATH="$BUILD_FOLDER_PATH/Resources/qml" +BUILD_PLUGINS_FOLDER_PATH="$BUILD_FOLDER_PATH/PlugIns" + +declare -a BROKEN_FILES; +k=0; +for j in $(find ${BUILD_QML_FOLDER_PATH} -name *.dylib); do + BROKEN_FILES[${k}]=$j + + ((k=k+1)) +done + + +for i in "${BROKEN_FILES[@]}"; do + REPLACE_STRING="$BUILD_FOLDER_PATH/" + APP_CONTENT_FILE=${i//$REPLACE_STRING/""} + IFS='/' read -a array <<< "$APP_CONTENT_FILE" + LENGTH=${#array[@]} + LAST_ITEM_INDEX=$((LENGTH-1)) + FILE=${array[${LENGTH} - 1]} + + ORIGINE_PATH=$(find ${BUILD_PLUGINS_FOLDER_PATH} -name ${FILE}) + ORIGINE_PATH=${ORIGINE_PATH//$REPLACE_STRING/""} + s="" + for((l=0;l<${LAST_ITEM_INDEX};l++)) do + s=$s"../" + done + s=$s$ORIGINE_PATH + echo "s: $s" + + REMOVE_BROKEN_ALIAS=$(rm -rf $i) + RESULT=$(ln -s $s $i) +done -- cgit v1.2.3