diff --git a/.travis.yml b/.travis.yml
index 5843441bd..6bd884b0f 100644
--- a/.travis.yml
+++ b/.travis.yml
@@ -10,9 +10,6 @@ branches:
matrix:
fast_finish: true
- allow_failures:
- - rust: beta
- - rust: nightly
include:
- os: linux
env: JOB=verify-commit-format
@@ -27,18 +24,6 @@ matrix:
# the actual compilin'
- os: linux
env: JOB=build-ubuntu-14-04
- - os: linux
- env: JOB=build-rust
- language: rust
- rust: stable
- - os: linux
- env: JOB=build-rust
- language: rust
- rust: beta
- - os: linux
- env: JOB=build-rust
- language: rust
- rust: nightly
- os: osx
osx_image: xcode7.3
env: JOB=build-osx
diff --git a/.travis/build-rust.sh b/.travis/build-rust.sh
deleted file mode 100755
index 6ff00ff1d..000000000
--- a/.travis/build-rust.sh
+++ /dev/null
@@ -1,71 +0,0 @@
-#!/bin/bash
-#
-# Copyright © 2016 by The qTox Project Contributors
-#
-# This program is libre 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.
-#
-# This program 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 this program. If not, see .
-#
-
-# used in travis to:
-# - pull in dependencies for building libsodium
-# - build required libsodium
-
-# Fail out on error
-set -eu -o pipefail
-
-readonly LIBSODIUM_VER="1.0.11"
-
-build_libsodium() {
- sudo apt-get update -qq
- sudo apt-get install -y \
- build-essential \
- libtool \
- autotools-dev \
- automake \
- checkinstall \
- check \
- git \
- yasm \
- pkg-config || yes
-
- git clone https://github.com/jedisct1/libsodium.git libsodium \
- --branch $LIBSODIUM_VER \
- --depth 1
-
- cd libsodium
- ./autogen.sh
- ./configure
- make -j$(nproc)
- sudo checkinstall \
- --install \
- --pkgname libsodium \
- --pkgversion $LIBSODIUM_VER \
- --nodoc \
- -y
- sudo ldconfig
- cd ..
-}
-
-build_rust_bits() {
- # TODO: make it a loop over paths once there are more rust bits
- cd tools/update-server/qtox-updater-sign
- cargo build --verbose
- cargo test --verbose
- # add `cargo doc` once it's needed?
-}
-
-main() {
- build_libsodium
- build_rust_bits
-}
-main
diff --git a/tools/update-server/deployUpdateFTP_32.py b/tools/update-server/deployUpdateFTP_32.py
deleted file mode 100644
index d5e7241de..000000000
--- a/tools/update-server/deployUpdateFTP_32.py
+++ /dev/null
@@ -1,35 +0,0 @@
-#!/usr/bin/python2.7
-
-# This script deploys a qTox update to an FTP server.
-# Pass the path to the root of the local update server as argument, no spaces allowed
-
-import sys
-import os
-
-target = 'win32'
-prefix = '/qtox/'+target+'/'
-uploadcmd1 = "bash -c '"+'ftp -n tux3-dev.tox.chat 0<<<"`echo -ne "user qtox-win-update-upload INSERT-PASSWORD-HERE\ncd '+target+'\nsend '
-uploadcmd2 = '\n"`"'+"'"
-
-def upload(file, rfile):
- #print(uploadcmd1+file+' '+rfile+uploadcmd2)
- os.system(uploadcmd1+file+' '+rfile+uploadcmd2)
-
-# Check our local folders
-if (len(sys.argv) < 2):
- print("ERROR: Needs the path to the local update server in argument")
- sys.exit(1)
-
-localpath = sys.argv[1];
-
-# Upload files/
-filenames = next(os.walk(localpath+prefix+'/files/'))[2]
-for filename in filenames:
- print("Uploading files/"+filename+'...')
- upload(localpath+prefix+'/files/'+filename, 'files/'+filename)
-
-# Upload version and flist
-print("Uploading flist...")
-upload(localpath+prefix+'flist', 'flist')
-print("Uploading version...")
-upload(localpath+prefix+'version', 'version')
diff --git a/tools/update-server/deployUpdateFTP_64.py b/tools/update-server/deployUpdateFTP_64.py
deleted file mode 100644
index 52b01ef44..000000000
--- a/tools/update-server/deployUpdateFTP_64.py
+++ /dev/null
@@ -1,35 +0,0 @@
-#!/usr/bin/python2.7
-
-# This script deploys a qTox update to an FTP server.
-# Pass the path to the root of the local update server as argument, no spaces allowed
-
-import sys
-import os
-
-target = 'win64'
-prefix = '/qtox/'+target+'/'
-uploadcmd1 = "bash -c '"+'ftp -n tux3-dev.tox.chat 0<<<"`echo -ne "user qtox-win-update-upload INSERT-PASSWORD-HERE\ncd '+target+'\nsend '
-uploadcmd2 = '\n"`"'+"'"
-
-def upload(file, rfile):
- #print(uploadcmd1+file+' '+rfile+uploadcmd2)
- os.system(uploadcmd1+file+' '+rfile+uploadcmd2)
-
-# Check our local folders
-if (len(sys.argv) < 2):
- print("ERROR: Needs the path to the local update server in argument")
- sys.exit(1)
-
-localpath = sys.argv[1];
-
-# Upload files/
-filenames = next(os.walk(localpath+prefix+'/files/'))[2]
-for filename in filenames:
- print("Uploading files/"+filename+'...')
- upload(localpath+prefix+'/files/'+filename, 'files/'+filename)
-
-# Upload version and flist
-print("Uploading flist...")
-upload(localpath+prefix+'flist', 'flist')
-print("Uploading version...")
-upload(localpath+prefix+'version', 'version')
diff --git a/tools/update-server/deployUpdateS3.py b/tools/update-server/deployUpdateS3.py
deleted file mode 100644
index 7e71d8588..000000000
--- a/tools/update-server/deployUpdateS3.py
+++ /dev/null
@@ -1,56 +0,0 @@
-#!/usr/bin/python2.7
-
-# This script deploys a qTox update to Amazon S3: It will upload ./qtox/win32/version, ./qtox/win32/flist, and ./qtox/win32/files/*
-# Pass the path to the root of the local update server as argument, no spaces allowed
-
-import sys
-import os
-import boto
-from boto.s3.key import Key
-
-# Check our local folders
-if (len(sys.argv) < 2):
- print("ERROR: Needs the path to the local update server in argument")
- sys.exit(1)
-
-localpath = sys.argv[1];
-prefix = "/qtox/win32/" # We only support Windows for now
-
-# Connect to S3
-conn = boto.connect_s3()
-bucket = conn.get_bucket('qtox-updater')
-print("Connected to S3")
-sys.stdout.flush()
-
-# Delete the old version, so nobody downloads a half-uploaded update
-print("Deleting version ...")
-sys.stdout.flush()
-oldversion = Key(bucket)
-oldversion.key = prefix+'version'
-bucket.delete_key(oldversion)
-
-# Upload files/
-filenames = next(os.walk(localpath+prefix+'/files/'))[2]
-for filename in filenames:
- print("Uploading files/"+filename+'...')
- sys.stdout.flush()
- k = Key(bucket)
- k.key = prefix+'files/'+filename
- k.set_contents_from_filename(localpath+prefix+'/files/'+filename)
- k.make_public()
-
-# Upload version and flist
-print("Uploading flist...")
-sys.stdout.flush()
-flist = Key(bucket)
-flist.key = prefix+'flist'
-flist.set_contents_from_filename(localpath+prefix+'flist')
-flist.make_public()
-
-print("Uploading version...")
-sys.stdout.flush()
-version = Key(bucket)
-version.key = prefix+'version'
-version.set_contents_from_filename(localpath+prefix+'version')
-version.make_public()
-
diff --git a/tools/update-server/pull-update.sh b/tools/update-server/pull-update.sh
deleted file mode 100644
index 9a9a32430..000000000
--- a/tools/update-server/pull-update.sh
+++ /dev/null
@@ -1,37 +0,0 @@
-#!/bin/bash
-
-# win64 update
-rm -f *.zip*
-rm -f gitversion
-rm -rf win64/*
-mkdir -p win64
-wget https://build.tox.chat/view/qtox/job/qTox-stable_build_windows_x86-64_release/lastSuccessfulBuild/artifact/qTox-stable_build_windows_x86-64_release.zip
-wget https://build.tox.chat/view/qtox/job/qTox-stable_build_windows_x86-64_release/lastSuccessfulBuild/artifact/version -O gitversion
-unzip -o qTox-stable_build_windows_x86-64_release.zip -d win64/source
-
-echo -n 3 > win64/version
-qtox-updater-sign `date +%s`!`cat gitversion` >> win64/version
-qtox-updater-genflist win64
-
-rm -rf win64/source
-rm -f /var/www/html/qtox/win64/version
-rm -rf /var/www/html/qtox/win64/*
-cp -r win64/* /var/www/html/qtox/win64/
-
-# win32 update, I don't feel like writing bash functions edition
-rm -f *.zip*
-rm -f gitversion
-rm -rf win32/*
-mkdir -p win32
-wget https://build.tox.chat/view/qtox/job/qTox-stable_build_windows_x86_release/lastSuccessfulBuild/artifact/qTox-stable_build_windows_x86_release.zip
-wget https://build.tox.chat/view/qtox/job/qTox-stable_build_windows_x86_release/lastSuccessfulBuild/artifact/version -O gitversion
-unzip -o qTox-stable_build_windows_x86_release.zip -d win32/source
-
-echo -n 3 > win32/version
-qtox-updater-sign `date +%s`!`cat gitversion` >> win32/version
-qtox-updater-genflist win32
-
-rm -rf win32/source
-rm -f /var/www/html/qtox/win32/version
-rm -rf /var/www/html/qtox/win32/*
-cp -r win32/* /var/www/html/qtox/win32/
diff --git a/tools/update-server/qtox-updater-genflist/main.cpp b/tools/update-server/qtox-updater-genflist/main.cpp
deleted file mode 100644
index eb41432ed..000000000
--- a/tools/update-server/qtox-updater-genflist/main.cpp
+++ /dev/null
@@ -1,154 +0,0 @@
-/*
- Copyright © 2014 by The qTox Project Contributors
-
- This file is part of qTox, a Qt-based graphical interface for Tox.
-
- qTox is libre 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.
-
- qTox 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 qTox. If not, see
-*/
-
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-#include "serialize.h"
-
-using namespace std;
-
-/// Pass the target folder as first argument, no spaces allowed. We'll call that dir $TARGET
-/// Update the content of $TARGET/source/ before calling this tool
-/// We'll generate $TARGET/flist and $TARGET/files/ then exit
-/// We need qtox-updater-skey in our working directory to sign the flist
-///
-/// The generated flist is very simple and just installs everything in the working directory ...
-
-QList scanDir(QDir dir)
-{
- QList files;
- QStack stack;
- stack.push(dir.absolutePath());
- while (!stack.isEmpty())
- {
- QString sSubdir = stack.pop();
- QDir subdir(sSubdir);
-
- // Check for the files.
- QList sublist = subdir.entryList(QDir::Files);
- for (QString& file : sublist)
- file = dir.relativeFilePath(sSubdir + '/' + file);
-
- files += sublist;
-
- QFileInfoList infoEntries = subdir.entryInfoList(QStringList(),
- QDir::AllDirs | QDir::NoSymLinks | QDir::NoDotAndDotDot);
- for (int i = 0; i < infoEntries.size(); i++)
- {
- QFileInfo& item = infoEntries[i];
- stack.push(item.absoluteFilePath());
- }
- }
- return files;
-}
-
-int main(int argc, char* argv[])
-{
- cout << "qTox updater flist generator" << endl;
-
- /// First some basic error handling, prepare our handles, ...
- if (argc != 2)
- {
- cout << "ERROR: qtox-updater-genflist takes the target path in argument" << endl;
- return 1;
- }
-
- QFile skeyFile("qtox-updater-skey");
- if (!skeyFile.open(QIODevice::ReadOnly))
- {
- cout << "ERROR: qtox-updater-genflist can't open the secret (private) key file" << endl;
- return 1;
- }
- QByteArray skeyData = skeyFile.readAll();
- skeyFile.close();
-
- QString target(argv[1]);
-
- QFile flistFile(target+"/flist");
- if (!flistFile.open(QIODevice::Truncate | QIODevice::WriteOnly))
- {
- cout << "ERROR: qtox-updater-genflist can't open the target flist" << endl;
- return 1;
- }
-
- // Wipe the /files/ folder
- QDir(target+"/files/").removeRecursively();
- QDir(target).mkdir("files");
-
- QDir sdir(target+"/source/");
- if (!sdir.isReadable())
- {
- cout << "ERROR: qtox-updater-genflist can't open the target source directory" << endl;
- return 1;
- }
-
- QStringList filesListStr = scanDir(sdir);
-
- /// Serialize the flist data
- QByteArray flistData;
- for (QString fileStr : filesListStr)
- {
- cout << "Adding "<
-*/
-
-
-#include "serialize.h"
-
-QByteArray doubleToData(double num)
-{
- union
- {
- char tab[8];
- double n;
- } castUnion;
- //char n[8];
- //*((double*) n) = num;
-
- castUnion.n=num;
- return QByteArray(castUnion.tab,8);
-}
-
-QByteArray floatToData(float num)
-{
- union
- {
- char tab[4];
- float n;
- } castUnion;
-
- castUnion.n=num;
- return QByteArray(castUnion.tab,4);
-}
-
-float dataToFloat(QByteArray data)
-{
- union
- {
- char tab[4];
- float n;
- } castUnion;
-
- castUnion.tab[0]=data.data()[0];
- castUnion.tab[1]=data.data()[1];
- castUnion.tab[2]=data.data()[2];
- castUnion.tab[3]=data.data()[3];
- return castUnion.n;
-}
-
-// Converts a string into PNet string data
-QByteArray stringToData(QString str)
-{
- QByteArray data(4,0);
- // Write the size in a Uint of variable lenght (8-32 bits)
- int i=0;
- uint num1 = (uint)str.toUtf8().size();
- while (num1 >= 0x80)
- {
- data[i] = (unsigned char)(num1 | 0x80); i++;
- num1 = num1 >> 7;
- }
- data[i]=num1;
- data.resize(i+1);
- data+=str.toUtf8();
- return data;
-}
-
-QString dataToString(QByteArray data)
-{
- // Variable UInt32
- unsigned char num3;
- int num = 0;
- int num2 = 0;
- int i=0;
- do
- {
- num3 = data[i]; i++;
- num |= (num3 & 0x7f) << num2;
- num2 += 7;
- } while ((num3 & 0x80) != 0);
- unsigned int strlen = (uint) num;
-
- if (!strlen)
- return QString();
-
- data = data.right(data.size()-i); // Remove the strlen
- data.truncate(strlen);
- return QString(data);
-}
-
-float dataToRangedSingle(float min, float max, int numberOfBits, QByteArray data)
-{
- uint endvalue=0;
- uint value=0;
- if (numberOfBits <= 8)
- {
- endvalue = (uchar)data[0];
- goto done;
- }
- value = (uchar)data[0];
- numberOfBits -= 8;
- if (numberOfBits <= 8)
- {
- endvalue = (value | ((uint) ((uchar)data[1]) << 8));
- goto done;
- }
- value |= (uint) (((uchar)data[1]) << 8);
- numberOfBits -= 8;
- if (numberOfBits <= 8)
- {
- uint num2 = (uint) (((uchar)data[2]) << 0x10);
- endvalue = (value | num2);
- goto done;
- }
- value |= (uint) (((uchar)data[2]) << 0x10);
- numberOfBits -= 8;
- endvalue = (value | ((uint) (((uchar)data[3]) << 0x18)));
- goto done;
-
- done:
-
- float num = max - min;
- int num2 = (((int) 1) << numberOfBits) - 1;
- float num3 = endvalue;
- float num4 = num3 / ((float) num2);
- return (min + (num4 * num));
-}
-
-QByteArray rangedSingleToData(float value, float min, float max, int numberOfBits)
-{
- QByteArray data;
- float num = max - min;
- float num2 = (value - min) / num;
- int num3 = (((int) 1) << numberOfBits) - 1;
- uint source = num3 * num2;
-
- if (numberOfBits <= 8)
- {
- data += (unsigned char)source;
- return data;
- }
- data += (unsigned char)source;
- numberOfBits -= 8;
- if (numberOfBits <= 8)
- {
- data += (unsigned char)(source>>8);
- return data;
- }
- data += (unsigned char)(source>>8);
- numberOfBits -= 8;
- if (numberOfBits <= 8)
- {
- data += (unsigned char)(source>>16);
- return data;
- }
- data += (unsigned char)(source>>16);
- data += (unsigned char)(source>>24);
-
- return data;
-}
-
-uint8_t dataToUint8(QByteArray data)
-{
- return (uint8_t)data[0];
-}
-
-uint16_t dataToUint16(QByteArray data)
-{
- return ((uint16_t)(uint8_t)data[0])
- +(((uint16_t)(uint8_t)data[1])<<8);
-}
-
-uint32_t dataToUint32(QByteArray data)
-{
- return ((uint32_t)(uint8_t)data[0])
- +(((uint32_t)(uint8_t)data[1])<<8)
- +(((uint32_t)(uint8_t)data[2])<<16)
- +(((uint32_t)(uint8_t)data[3])<<24);
-}
-
-uint64_t dataToUint64(QByteArray data)
-{
- return ((uint64_t)(uint8_t)data[0])
- +(((uint64_t)(uint8_t)data[1])<<8)
- +(((uint64_t)(uint8_t)data[2])<<16)
- +(((uint64_t)(uint8_t)data[3])<<24)
- +(((uint64_t)(uint8_t)data[4])<<32)
- +(((uint64_t)(uint8_t)data[5])<<40)
- +(((uint64_t)(uint8_t)data[6])<<48)
- +(((uint64_t)(uint8_t)data[7])<<56);
-}
-
-unsigned getVUint32Size(QByteArray data)
-{
- unsigned lensize=0;
- {
- unsigned char num3;
- do {
- num3 = data[lensize];
- lensize++;
- } while ((num3 & 0x80) != 0);
- }
- return lensize;
-}
-
-QByteArray uint8ToData(uint8_t num)
-{
- QByteArray data(1,0);
- data[0] = (uint8_t)num;
- return data;
-}
-
-QByteArray uint16ToData(uint16_t num)
-{
- QByteArray data(2,0);
- data[0] = (uint8_t)(num & 0xFF);
- data[1] = (uint8_t)((num>>8) & 0xFF);
- return data;
-}
-
-QByteArray uint32ToData(uint32_t num)
-{
- QByteArray data(4,0);
- data[0] = (uint8_t)(num & 0xFF);
- data[1] = (uint8_t)((num>>8) & 0xFF);
- data[2] = (uint8_t)((num>>16) & 0xFF);
- data[3] = (uint8_t)((num>>24) & 0xFF);
- return data;
-}
-
-QByteArray uint64ToData(uint64_t num)
-{
- QByteArray data(8,0);
- data[0] = (uint8_t)(num & 0xFF);
- data[1] = (uint8_t)((num>>8) & 0xFF);
- data[2] = (uint8_t)((num>>16) & 0xFF);
- data[3] = (uint8_t)((num>>24) & 0xFF);
- data[4] = (uint8_t)((num>>32) & 0xFF);
- data[5] = (uint8_t)((num>>40) & 0xFF);
- data[6] = (uint8_t)((num>>48) & 0xFF);
- data[7] = (uint8_t)((num>>56) & 0xFF);
- return data;
-}
diff --git a/tools/update-server/qtox-updater-genflist/serialize.h b/tools/update-server/qtox-updater-genflist/serialize.h
deleted file mode 100644
index eb5cad62a..000000000
--- a/tools/update-server/qtox-updater-genflist/serialize.h
+++ /dev/null
@@ -1,48 +0,0 @@
-/*
- Copyright © 2014 by The qTox Project Contributors
-
- This file is part of qTox, a Qt-based graphical interface for Tox.
-
- qTox is libre 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.
-
- qTox 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 qTox. If not, see
-*/
-
-
-#ifndef SERIALIZE_H
-#define SERIALIZE_H
-
-#include
-#include
-#include
-
-/// Most of those functions are unsafe unless otherwise specified
-/// Do not use them on untrusted data (e.g. check a signature first)
-
-QByteArray doubleToData(double num);
-QByteArray floatToData(float num);
-float dataToFloat(QByteArray data);
-QByteArray stringToData(QString str);
-QString dataToString(QByteArray data);
-float dataToRangedSingle(float min, float max, int numberOfBits, QByteArray data);
-QByteArray rangedSingleToData(float value, float min, float max, int numberOfBits);
-uint8_t dataToUint8(QByteArray data);
-uint16_t dataToUint16(QByteArray data);
-uint32_t dataToUint32(QByteArray data);
-uint64_t dataToUint64(QByteArray data);
-unsigned getVUint32Size(QByteArray data);
-QByteArray uint8ToData(uint8_t num);
-QByteArray uint16ToData(uint16_t num);
-QByteArray uint32ToData(uint32_t num);
-QByteArray uint64ToData(uint64_t num);
-
-#endif // SERIALIZE_H
diff --git a/tools/update-server/qtox-updater-genkeys/main.cpp b/tools/update-server/qtox-updater-genkeys/main.cpp
deleted file mode 100644
index 55727b508..000000000
--- a/tools/update-server/qtox-updater-genkeys/main.cpp
+++ /dev/null
@@ -1,35 +0,0 @@
-#include
-#include
-#include
-#include
-#include
-
-int main(int argc, char *argv[])
-{
- QCoreApplication a(argc, argv);
- (void) a;
-
- QByteArray skey(crypto_sign_SECRETKEYBYTES, 0);
- QFile skeyFile("qtox-updater-skey");
- if (!skeyFile.open(QIODevice::WriteOnly))
- {
- qCritical() << "Failed to open qtox-updater-skey";
- return 1;
- }
-
- QByteArray pkey(crypto_sign_PUBLICKEYBYTES, 0);
- QFile pkeyFile("qtox-updater-pkey");
- if (!pkeyFile.open(QIODevice::WriteOnly))
- {
- qCritical() << "Failed to open qtox-updater-pkey";
- return 1;
- }
-
- crypto_sign_keypair((uint8_t*)pkey.data(), (uint8_t*)skey.data());
- skeyFile.write(skey);
- pkeyFile.write(pkey);
-
- qDebug() << "Wrote new keys to disk";
- return 0;
-}
-
diff --git a/tools/update-server/qtox-updater-genkeys/qtox-updater-genkeys.pro b/tools/update-server/qtox-updater-genkeys/qtox-updater-genkeys.pro
deleted file mode 100644
index ef4ef29e8..000000000
--- a/tools/update-server/qtox-updater-genkeys/qtox-updater-genkeys.pro
+++ /dev/null
@@ -1,13 +0,0 @@
-QT += core
-QT -= gui
-
-TARGET = qtox-updater-genkeys
-CONFIG += console
-CONFIG -= app_bundle
-
-TEMPLATE = app
-
-SOURCES += main.cpp
-
-
-LIBS += -lsodium
diff --git a/tools/update-server/qtox-updater-sign/Cargo.lock b/tools/update-server/qtox-updater-sign/Cargo.lock
deleted file mode 100644
index 633b2f118..000000000
--- a/tools/update-server/qtox-updater-sign/Cargo.lock
+++ /dev/null
@@ -1,41 +0,0 @@
-[root]
-name = "qtox-updater-sign"
-version = "0.1.0"
-dependencies = [
- "sodiumoxide 0.0.12 (registry+https://github.com/rust-lang/crates.io-index)",
-]
-
-[[package]]
-name = "libc"
-version = "0.2.18"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-
-[[package]]
-name = "libsodium-sys"
-version = "0.0.12"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-dependencies = [
- "libc 0.2.18 (registry+https://github.com/rust-lang/crates.io-index)",
- "pkg-config 0.3.8 (registry+https://github.com/rust-lang/crates.io-index)",
-]
-
-[[package]]
-name = "pkg-config"
-version = "0.3.8"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-
-[[package]]
-name = "serde"
-version = "0.7.15"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-
-[[package]]
-name = "sodiumoxide"
-version = "0.0.12"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-dependencies = [
- "libc 0.2.18 (registry+https://github.com/rust-lang/crates.io-index)",
- "libsodium-sys 0.0.12 (registry+https://github.com/rust-lang/crates.io-index)",
- "serde 0.7.15 (registry+https://github.com/rust-lang/crates.io-index)",
-]
-
diff --git a/tools/update-server/qtox-updater-sign/Cargo.toml b/tools/update-server/qtox-updater-sign/Cargo.toml
deleted file mode 100644
index 3685eb3e0..000000000
--- a/tools/update-server/qtox-updater-sign/Cargo.toml
+++ /dev/null
@@ -1,7 +0,0 @@
-[package]
-name = "qtox-updater-sign"
-version = "0.1.0"
-authors = ["Zetok Zalbavar "]
-
-[dependencies]
-sodiumoxide = "0.0.12"
diff --git a/tools/update-server/qtox-updater-sign/README.md b/tools/update-server/qtox-updater-sign/README.md
deleted file mode 100644
index d3101114d..000000000
--- a/tools/update-server/qtox-updater-sign/README.md
+++ /dev/null
@@ -1,26 +0,0 @@
-# qtox-updater-sign
-
-Simple program for signing releases.
-
-Requires a file named `qtox-updater-skey` in the working directory that
-contains the secret key.
-
-To sign a release, either supply the name of the file to be signed as an
-argument, or pipe data via stdin.
-
-```bash
-./qtox-updater-sign sign-this-binary > signature_file
-# or
-./qtox-updater-sign < sign-this-binary > signature_file
-```
-
-# Compiling
-
-Requires `libsodium` and Rust.
-
-To build a debug version: `cargo build`
-
-To build a release version: `cargo build --release`
-
-This will produce `qtox-updater-sign` binary in `target/debug` or
-`target/release` directory respectively.
diff --git a/tools/update-server/qtox-updater-sign/src/main.rs b/tools/update-server/qtox-updater-sign/src/main.rs
deleted file mode 100644
index 4fb2a865a..000000000
--- a/tools/update-server/qtox-updater-sign/src/main.rs
+++ /dev/null
@@ -1,66 +0,0 @@
-/*
- Copyright © 2016 by The qTox Project Contributors
-
- This file is part of qTox, a Qt-based graphical interface for Tox.
-
- qTox is libre 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.
-
- qTox 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 qTox. If not, see .
-*/
-
-extern crate sodiumoxide;
-
-use std::io::prelude::*;
-use std::io;
-use std::fs::File;
-
-use sodiumoxide::crypto::sign::*;
-
-/// file that contains secret key
-const SKEY_FNAME: &'static str = "qtox-updater-skey";
-
-/// if there is more than just the program name in args, treat "1st" arg as the
-/// data to sign
-/// otherwise just read bytes from stdin
-fn read_from_file_or_stdin(buf: &mut Vec) {
- if std::env::args().count() > 1 {
- let data = std::env::args().nth(1).expect("Failed to get fname");
- buf.extend_from_slice(&data.into_bytes());
- } else {
- io::stdin().read_to_end(buf).expect("Failed to read stdin");
- }
-}
-
-/// get SecretKey from `SKEY_FNAME` file
-fn get_secret_key() -> SecretKey {
- let mut skey_file = File::open(SKEY_FNAME)
- .expect(&format!("ERROR: {} can't open the secret (private) key file\n",
- std::env::args().next().unwrap()));
-
- let mut skey_bytes = Vec::with_capacity(SECRETKEYBYTES);
- skey_file.read_to_end(&mut skey_bytes)
- .expect(&format!("Failed to read {}", SKEY_FNAME));
-
- SecretKey::from_slice(&skey_bytes[..SECRETKEYBYTES])
- .expect("Failed to get right amount of bytes for SecretKey")
-}
-
-
-fn main() {
- let mut plaintext = Vec::new();
- read_from_file_or_stdin(&mut plaintext);
-
- let sk = get_secret_key();
- let signed = sign(&plaintext, &sk);
-
- io::stdout().write_all(&signed).expect("Failed to write signature");
-}