diff options
author | Adam Ierymenko <adam.ierymenko@gmail.com> | 2014-01-03 15:39:09 -0800 |
---|---|---|
committer | Adam Ierymenko <adam.ierymenko@gmail.com> | 2014-01-03 15:39:09 -0800 |
commit | 59b1623477e7cd9081d3cf75ea3fa0411214d58f (patch) | |
tree | e8b37f673d23b45cbe7a63ec5360a0a627d9820f | |
parent | 22b52858e04c25709081251300fed6cdc42810be (diff) | |
download | infinitytier-59b1623477e7cd9081d3cf75ea3fa0411214d58f.tar.gz infinitytier-59b1623477e7cd9081d3cf75ea3fa0411214d58f.zip |
More install/deploy work for mac...
-rw-r--r-- | ZeroTierUI/ZeroTierUI.pro | 14 | ||||
-rw-r--r-- | ZeroTierUI/helpers/mac/ZeroTier One (Authenticate).app/Contents/Info.plist | 2 | ||||
-rw-r--r-- | ZeroTierUI/helpers/mac/ZeroTier One (Authenticate).app/Contents/Resources/Scripts/main.scpt | bin | 1768 -> 2214 bytes | |||
-rw-r--r-- | ZeroTierUI/helpers/mac/ZeroTier One (Install).app/Contents/Info.plist | 2 | ||||
-rw-r--r-- | ZeroTierUI/helpers/mac/ZeroTier One (Install).app/Contents/Resources/Scripts/main.scpt | bin | 2818 -> 3946 bytes | |||
-rw-r--r-- | ZeroTierUI/mainwindow.cpp | 53 | ||||
-rw-r--r-- | ZeroTierUI/mainwindow.h | 6 | ||||
-rw-r--r-- | ext/installfiles/mac/install.tmpl.sh | 32 |
8 files changed, 82 insertions, 27 deletions
diff --git a/ZeroTierUI/ZeroTierUI.pro b/ZeroTierUI/ZeroTierUI.pro index 082477ca..1b735553 100644 --- a/ZeroTierUI/ZeroTierUI.pro +++ b/ZeroTierUI/ZeroTierUI.pro @@ -37,9 +37,9 @@ SOURCES += main.cpp\ ../node/Topology.cpp \ ../node/UdpSocket.cpp \ ../node/Utils.cpp \ - ../ext/lz4/lz4.c \ - ../ext/lz4/lz4hc.c \ - networkwidget.cpp + ../ext/lz4/lz4.c \ + ../ext/lz4/lz4hc.c \ + networkwidget.cpp HEADERS += mainwindow.h \ aboutwindow.h \ @@ -86,13 +86,13 @@ HEADERS += mainwindow.h \ ../node/Thread.hpp \ ../node/Topology.hpp \ ../node/UdpSocket.hpp \ - ../ext/lz4/lz4.h \ - ../ext/lz4/lz4hc.h \ - networkwidget.h + ../ext/lz4/lz4.h \ + ../ext/lz4/lz4hc.h \ + networkwidget.h FORMS += mainwindow.ui \ aboutwindow.ui \ - networkwidget.ui + networkwidget.ui RESOURCES += \ resources.qrc diff --git a/ZeroTierUI/helpers/mac/ZeroTier One (Authenticate).app/Contents/Info.plist b/ZeroTierUI/helpers/mac/ZeroTier One (Authenticate).app/Contents/Info.plist index ca85986a..c658bc21 100644 --- a/ZeroTierUI/helpers/mac/ZeroTier One (Authenticate).app/Contents/Info.plist +++ b/ZeroTierUI/helpers/mac/ZeroTier One (Authenticate).app/Contents/Info.plist @@ -44,7 +44,7 @@ <key>positionOfDivider</key> <real>333</real> <key>savedFrame</key> - <string>36 164 602 597 0 0 1280 778 </string> + <string>239 124 602 597 0 0 1280 778 </string> <key>selectedTabView</key> <string>event log</string> </dict> diff --git a/ZeroTierUI/helpers/mac/ZeroTier One (Authenticate).app/Contents/Resources/Scripts/main.scpt b/ZeroTierUI/helpers/mac/ZeroTier One (Authenticate).app/Contents/Resources/Scripts/main.scpt Binary files differindex cb578574..5707e8e4 100644 --- a/ZeroTierUI/helpers/mac/ZeroTier One (Authenticate).app/Contents/Resources/Scripts/main.scpt +++ b/ZeroTierUI/helpers/mac/ZeroTier One (Authenticate).app/Contents/Resources/Scripts/main.scpt diff --git a/ZeroTierUI/helpers/mac/ZeroTier One (Install).app/Contents/Info.plist b/ZeroTierUI/helpers/mac/ZeroTier One (Install).app/Contents/Info.plist index 2c45edac..11315644 100644 --- a/ZeroTierUI/helpers/mac/ZeroTier One (Install).app/Contents/Info.plist +++ b/ZeroTierUI/helpers/mac/ZeroTier One (Install).app/Contents/Info.plist @@ -42,7 +42,7 @@ <key>positionOfDivider</key> <real>333</real> <key>savedFrame</key> - <string>265 106 602 597 0 0 1280 778 </string> + <string>68 169 602 597 0 0 1280 778 </string> <key>selectedTabView</key> <string>event log</string> </dict> diff --git a/ZeroTierUI/helpers/mac/ZeroTier One (Install).app/Contents/Resources/Scripts/main.scpt b/ZeroTierUI/helpers/mac/ZeroTier One (Install).app/Contents/Resources/Scripts/main.scpt Binary files differindex 6aff34e8..af0d80f5 100644 --- a/ZeroTierUI/helpers/mac/ZeroTier One (Install).app/Contents/Resources/Scripts/main.scpt +++ b/ZeroTierUI/helpers/mac/ZeroTier One (Install).app/Contents/Resources/Scripts/main.scpt diff --git a/ZeroTierUI/mainwindow.cpp b/ZeroTierUI/mainwindow.cpp index 4028b789..521868cc 100644 --- a/ZeroTierUI/mainwindow.cpp +++ b/ZeroTierUI/mainwindow.cpp @@ -23,6 +23,8 @@ #include <QScrollBar> #include <QEventLoop> +QNetworkAccessManager *nam; + // Globally visible ZeroTier::Node::LocalClient *zeroTierClient = (ZeroTier::Node::LocalClient *)0; @@ -51,7 +53,8 @@ static void handleZTMessage(void *arg,unsigned long id,const char *line) MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent), - ui(new Ui::MainWindow) + ui(new Ui::MainWindow), + nam(new QNetworkAccessManager(this)) { ui->setupUi(this); this->startTimer(1000); // poll service every second @@ -59,6 +62,8 @@ MainWindow::MainWindow(QWidget *parent) : mainWindow = this; this->cyclesSinceResponseFromService = 0; + QObject::connect(nam,SIGNAL(finished(QNetworkReply*)),this,SLOT(on_networkReply(QNetworkReply*))); + if (ui->networkListWidget->verticalScrollBar()) ui->networkListWidget->verticalScrollBar()->setSingleStep(8); @@ -79,30 +84,40 @@ void MainWindow::timerEvent(QTimerEvent *event) { event->accept(); -#ifdef __APPLE__ -#else -#endif - if (!zeroTierClient) { - std::string dotAuthFile((QDir::homePath() + QDir::separator() + ".zeroTierOneAuthToken").toStdString()); std::string authToken; - if (!ZeroTier::Utils::readFile(dotAuthFile.c_str(),authToken)) { + if (!ZeroTier::Utils::readFile(ZeroTier::Node::LocalClient::authTokenDefaultUserPath().c_str(),authToken)) { #ifdef __APPLE__ - // Run the little AppleScript hack that asks for admin credentials and - // then installs the auth token file in the current user's home. - QString authHelperPath(QCoreApplication::applicationDirPath() + "/../Resources/helpers/mac/ZeroTier One (Authenticate).app/Contents/MacOS/applet"); - if (!QFile::exists(authHelperPath)) { - // Allow this to also work from the source tree if it's run from there. - // This is for debugging purposes and shouldn't harm the live release - // in any way. - authHelperPath = QCoreApplication::applicationDirPath() + "/../../../../ZeroTierUI/helpers/mac/ZeroTier One (Authenticate).app/Contents/MacOS/applet"; + if (QFile::exists("/Library/Application Support/ZeroTier/One/zerotier-one")) { + // Run the little AppleScript hack that asks for admin credentials and + // then installs the auth token file in the current user's home. + QString authHelperPath(QCoreApplication::applicationDirPath() + "/../Resources/helpers/mac/ZeroTier One (Authenticate).app/Contents/MacOS/applet"); if (!QFile::exists(authHelperPath)) { - QMessageBox::critical(this,"Unable to Locate Helper","Unable to locate authorization helper, cannot obtain authentication token.",QMessageBox::Ok,QMessageBox::NoButton); + // Allow this to also work from the source tree if it's run from there. + // This is for debugging purposes and shouldn't harm the live release + // in any way. + authHelperPath = QCoreApplication::applicationDirPath() + "/../../../../ZeroTierUI/helpers/mac/ZeroTier One (Authenticate).app/Contents/MacOS/applet"; + if (!QFile::exists(authHelperPath)) { + QMessageBox::critical(this,"Unable to Locate Helper","Unable to locate authorization helper, cannot obtain authentication token.",QMessageBox::Ok,QMessageBox::NoButton); + QApplication::exit(1); + return; + } + } + QProcess::execute(authHelperPath,QStringList()); + } else { + // Download the latest version and install it + this->setEnabled(false); + + // Run the little AppleScript hack that asks for admin credentials and + // then installs the auth token file in the current user's home. + QString installHelperPath(QCoreApplication::applicationDirPath() + "/../Resources/helpers/mac/ZeroTier One (Install).app/Contents/MacOS/applet"); + if (!QFile::exists(installHelperPath)) { + QMessageBox::critical(this,"Unable to Locate Helper","Unable to locate install helper, cannot install service.",QMessageBox::Ok,QMessageBox::NoButton); QApplication::exit(1); return; } + QProcess::execute(installHelperPath,QStringList()); } - QProcess::execute(authHelperPath,QStringList()); #endif if (!ZeroTier::Utils::readFile(dotAuthFile.c_str(),authToken)) { @@ -291,3 +306,7 @@ void MainWindow::on_addressButton_clicked() { QApplication::clipboard()->setText(this->myAddress); } + +void MainWindow::on_networkReply(QNetworkReply *reply) +{ +} diff --git a/ZeroTierUI/mainwindow.h b/ZeroTierUI/mainwindow.h index f4ca51b4..d3ec15d8 100644 --- a/ZeroTierUI/mainwindow.h +++ b/ZeroTierUI/mainwindow.h @@ -4,6 +4,10 @@ #include <QMainWindow> #include <QEvent> #include <QString> +#include <QNetworkAccessManager> +#include <QUrl> +#include <QNetworkRequest> +#include <QNetworkReply> #include <map> #include <vector> @@ -51,10 +55,12 @@ private slots: void on_actionAbout_triggered(); void on_networkIdLineEdit_textChanged(const QString &text); void on_addressButton_clicked(); + void on_networkReply(QNetworkReply *reply); private: Ui::MainWindow *ui; + QNetworkAccessManager *nam; QString myAddress; QString myStatus; QString myVersion; diff --git a/ext/installfiles/mac/install.tmpl.sh b/ext/installfiles/mac/install.tmpl.sh index fcb3b69b..a1675b1d 100644 --- a/ext/installfiles/mac/install.tmpl.sh +++ b/ext/installfiles/mac/install.tmpl.sh @@ -15,10 +15,19 @@ fi if [ $dryRun -gt 0 ]; then alias ln="echo '>> dry run: ln'" alias rm="echo '>> dry run: rm'" + alias mv="echo '>> dry run: mv'" + alias chown="echo '>> dry run: chown'" + alias chgrp="echo '>> dry run: chgrp'" alias launchctl="echo '>> dry run: launchctl'" alias zerotier-cli="echo '>> dry run: zerotier-cli'" fi +zthome="/Library/Application Support/ZeroTier/One" +ztapp=`mdfind kMDItemCFBundleIdentifier == 'com.zerotier.ZeroTierOne'` +if [ ! -d "$ztapp" ]; then + ztapp="/Applications/ZeroTier One.app" +fi + scriptPath="`dirname "$0"`/`basename "$0"`" if [ ! -r "$scriptPath" ]; then scriptPath="$0" @@ -46,11 +55,32 @@ else tail -c +$blobStart "$scriptPath" | bunzip2 -c | tar -xvop -C / -f - fi -if [ $dryRun -eq 0 -a ! -f "/Library/LaunchDaemons/com.zerotier.one.plist" ]; then +if [ $dryRun -eq 0 -a ! -d "/Applications/ZeroTierOne_app.LATEST" ]; then echo 'Archive extraction failed, cannot find zerotier-one binary.' exit 2 fi +echo 'Installing/updating ZeroTier One.app...' + +if [ -d "$ztapp" ]; then + # Preserve ownership of existing .app and install new version in the + # same location. + currentAppOwner=`stat -f '%u' "$ztapp"` + currentAppGroup=`stat -f '%g' "$ztapp"` + if [ ! -z "$currentAppOwner" -a ! -z "$currentAppGroup" ]; then + rm -rf "$ztapp" + mv -f "/Application/ZeroTierOne_app.LATEST" "$ztapp" + chown -R $currentAppOwner "$ztapp" + chgrp -R $currentAppGroup "$ztapp" + else + rm -rf "$ztapp" + mv -f "/Application/ZeroTierOne_app.LATEST" "$ztapp" + fi +else + # If there is no existing app, just drop the shipped one into place + mv -f "/Applications/ZeroTierOne_app.LATEST" "/Applications/ZeroTierOne.app" +fi + echo 'Installing zerotier-cli command line utility...' ln -sf "/Library/Application Support/ZeroTier/One/zerotier-one" /usr/bin/zerotier-cli |