Merge branch 'master' of https://github.com/synergy/synergy
This commit is contained in:
commit
2a2d095527
|
@ -94,7 +94,10 @@ bool PluginManager::exist(QString name)
|
||||||
void PluginManager::downloadPlugins()
|
void PluginManager::downloadPlugins()
|
||||||
{
|
{
|
||||||
if (m_DataDownloader.isFinished()) {
|
if (m_DataDownloader.isFinished()) {
|
||||||
savePlugin();
|
if (!savePlugin()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (m_DownloadIndex != m_PluginList.size() - 1) {
|
if (m_DownloadIndex != m_PluginList.size() - 1) {
|
||||||
emit downloadNext();
|
emit downloadNext();
|
||||||
}
|
}
|
||||||
|
@ -218,7 +221,7 @@ void PluginManager::generateCertificate()
|
||||||
emit generateCertificateFinished();
|
emit generateCertificateFinished();
|
||||||
}
|
}
|
||||||
|
|
||||||
void PluginManager::savePlugin()
|
bool PluginManager::savePlugin()
|
||||||
{
|
{
|
||||||
// create the path if not exist
|
// create the path if not exist
|
||||||
QDir dir(m_PluginDir);
|
QDir dir(m_PluginDir);
|
||||||
|
@ -234,15 +237,19 @@ void PluginManager::savePlugin()
|
||||||
QFile file(filename);
|
QFile file(filename);
|
||||||
if (!file.open(QIODevice::WriteOnly)) {
|
if (!file.open(QIODevice::WriteOnly)) {
|
||||||
emit error(
|
emit error(
|
||||||
tr("Failed to download '%1' plugin to: %2")
|
tr("Failed to download plugin '%1' to: %2 \n %3")
|
||||||
.arg(m_PluginList.at(m_DownloadIndex))
|
.arg(m_PluginList.at(m_DownloadIndex))
|
||||||
.arg(m_PluginDir));
|
.arg(m_PluginDir)
|
||||||
|
.arg(file.errorString()));
|
||||||
|
|
||||||
return;
|
file.close();
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
file.write(m_DataDownloader.data());
|
file.write(m_DataDownloader.data());
|
||||||
file.close();
|
file.close();
|
||||||
|
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
QString PluginManager::getPluginUrl(const QString& pluginName)
|
QString PluginManager::getPluginUrl(const QString& pluginName)
|
||||||
|
|
|
@ -42,7 +42,7 @@ public slots:
|
||||||
void generateCertificate();
|
void generateCertificate();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void savePlugin();
|
bool savePlugin();
|
||||||
QString getPluginUrl(const QString& pluginName);
|
QString getPluginUrl(const QString& pluginName);
|
||||||
bool checkOpenSslBinary();
|
bool checkOpenSslBinary();
|
||||||
bool runProgram(
|
bool runProgram(
|
||||||
|
|
|
@ -95,6 +95,7 @@ REGISTER_EVENT(IListenSocket, connecting)
|
||||||
//
|
//
|
||||||
|
|
||||||
REGISTER_EVENT(ISocket, disconnected)
|
REGISTER_EVENT(ISocket, disconnected)
|
||||||
|
REGISTER_EVENT(ISocket, stopRetry)
|
||||||
|
|
||||||
//
|
//
|
||||||
// OSXScreen
|
// OSXScreen
|
||||||
|
|
|
@ -281,7 +281,8 @@ private:
|
||||||
class ISocketEvents : public EventTypes {
|
class ISocketEvents : public EventTypes {
|
||||||
public:
|
public:
|
||||||
ISocketEvents() :
|
ISocketEvents() :
|
||||||
m_disconnected(Event::kUnknown) { }
|
m_disconnected(Event::kUnknown),
|
||||||
|
m_stopRetry(Event::kUnknown) { }
|
||||||
|
|
||||||
//! @name accessors
|
//! @name accessors
|
||||||
//@{
|
//@{
|
||||||
|
@ -294,10 +295,18 @@ public:
|
||||||
*/
|
*/
|
||||||
Event::Type disconnected();
|
Event::Type disconnected();
|
||||||
|
|
||||||
|
//! Get stop retry event type
|
||||||
|
/*!
|
||||||
|
Returns the stop retry event type. This is sent when the client
|
||||||
|
doesn't want to reconnect after it disconnects from the server.
|
||||||
|
*/
|
||||||
|
Event::Type stopRetry();
|
||||||
|
|
||||||
//@}
|
//@}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Event::Type m_disconnected;
|
Event::Type m_disconnected;
|
||||||
|
Event::Type m_stopRetry;
|
||||||
};
|
};
|
||||||
|
|
||||||
class OSXScreenEvents : public EventTypes {
|
class OSXScreenEvents : public EventTypes {
|
||||||
|
|
|
@ -60,7 +60,7 @@ Client::Client(
|
||||||
const String& name, const NetworkAddress& address,
|
const String& name, const NetworkAddress& address,
|
||||||
ISocketFactory* socketFactory,
|
ISocketFactory* socketFactory,
|
||||||
synergy::Screen* screen,
|
synergy::Screen* screen,
|
||||||
ClientArgs args) :
|
ClientArgs& args) :
|
||||||
m_mock(false),
|
m_mock(false),
|
||||||
m_name(name),
|
m_name(name),
|
||||||
m_serverAddress(address),
|
m_serverAddress(address),
|
||||||
|
@ -470,6 +470,10 @@ Client::setupConnection()
|
||||||
m_stream->getEventTarget(),
|
m_stream->getEventTarget(),
|
||||||
new TMethodEventJob<Client>(this,
|
new TMethodEventJob<Client>(this,
|
||||||
&Client::handleDisconnected));
|
&Client::handleDisconnected));
|
||||||
|
|
||||||
|
m_events->adoptHandler(m_events->forISocket().stopRetry(),
|
||||||
|
m_stream->getEventTarget(),
|
||||||
|
new TMethodEventJob<Client>(this, &Client::handleStopRetry));
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -525,6 +529,8 @@ Client::cleanupConnection()
|
||||||
m_stream->getEventTarget());
|
m_stream->getEventTarget());
|
||||||
m_events->removeHandler(m_events->forISocket().disconnected(),
|
m_events->removeHandler(m_events->forISocket().disconnected(),
|
||||||
m_stream->getEventTarget());
|
m_stream->getEventTarget());
|
||||||
|
m_events->removeHandler(m_events->forISocket().stopRetry(),
|
||||||
|
m_stream->getEventTarget());
|
||||||
cleanupStream();
|
cleanupStream();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -743,6 +749,11 @@ Client::onFileRecieveCompleted()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
Client::handleStopRetry(const Event&, void*)
|
||||||
|
{
|
||||||
|
m_args.m_restartable = false;
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
Client::writeToDropDirThread(void*)
|
Client::writeToDropDirThread(void*)
|
||||||
|
|
|
@ -60,13 +60,9 @@ public:
|
||||||
const String& name, const NetworkAddress& address,
|
const String& name, const NetworkAddress& address,
|
||||||
ISocketFactory* socketFactory,
|
ISocketFactory* socketFactory,
|
||||||
synergy::Screen* screen,
|
synergy::Screen* screen,
|
||||||
ClientArgs args);
|
ClientArgs& args);
|
||||||
~Client();
|
~Client();
|
||||||
|
|
||||||
#ifdef TEST_ENV
|
|
||||||
Client() : m_mock(true) { }
|
|
||||||
#endif
|
|
||||||
|
|
||||||
//! @name manipulators
|
//! @name manipulators
|
||||||
//@{
|
//@{
|
||||||
|
|
||||||
|
@ -196,6 +192,7 @@ private:
|
||||||
void handleResume(const Event& event, void*);
|
void handleResume(const Event& event, void*);
|
||||||
void handleFileChunkSending(const Event&, void*);
|
void handleFileChunkSending(const Event&, void*);
|
||||||
void handleFileRecieveCompleted(const Event&, void*);
|
void handleFileRecieveCompleted(const Event&, void*);
|
||||||
|
void handleStopRetry(const Event&, void*);
|
||||||
void onFileRecieveCompleted();
|
void onFileRecieveCompleted();
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
@ -226,5 +223,5 @@ private:
|
||||||
Thread* m_writeToDropDirThread;
|
Thread* m_writeToDropDirThread;
|
||||||
TCPSocket* m_socket;
|
TCPSocket* m_socket;
|
||||||
bool m_useSecureNetwork;
|
bool m_useSecureNetwork;
|
||||||
ClientArgs m_args;
|
ClientArgs& m_args;
|
||||||
};
|
};
|
||||||
|
|
|
@ -281,10 +281,8 @@ SecureSocket::secureConnect(int socket)
|
||||||
checkResult(r, fatal, retry);
|
checkResult(r, fatal, retry);
|
||||||
|
|
||||||
if (fatal) {
|
if (fatal) {
|
||||||
// tell user and sleep so the socket isn't hammered.
|
|
||||||
LOG((CLOG_ERR "failed to connect secure socket"));
|
LOG((CLOG_ERR "failed to connect secure socket"));
|
||||||
LOG((CLOG_INFO "server connection may not be secure"));
|
LOG((CLOG_INFO "server connection may not be secure"));
|
||||||
disconnect();
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -299,6 +297,7 @@ SecureSocket::secureConnect(int socket)
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
LOG((CLOG_ERR "failed to verify server certificate fingerprint"));
|
LOG((CLOG_ERR "failed to verify server certificate fingerprint"));
|
||||||
|
sendEvent(getEvents()->forISocket().stopRetry());
|
||||||
disconnect();
|
disconnect();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -331,7 +331,6 @@ ClientApp::handleClientDisconnected(const Event&, void*)
|
||||||
updateStatus();
|
updateStatus();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Client*
|
Client*
|
||||||
ClientApp::openClient(const String& name, const NetworkAddress& address,
|
ClientApp::openClient(const String& name, const NetworkAddress& address,
|
||||||
synergy::Screen* screen)
|
synergy::Screen* screen)
|
||||||
|
|
|
@ -1,37 +0,0 @@
|
||||||
/*
|
|
||||||
* synergy -- mouse and keyboard sharing utility
|
|
||||||
* Copyright (C) 2012 Synergy Si Ltd.
|
|
||||||
* Copyright (C) 2011 Nick Bolton
|
|
||||||
*
|
|
||||||
* This package is free software; you can redistribute it and/or
|
|
||||||
* modify it under the terms of the GNU General Public License
|
|
||||||
* found in the file COPYING that should have accompanied this file.
|
|
||||||
*
|
|
||||||
* This package 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 <http://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#pragma once
|
|
||||||
|
|
||||||
#define TEST_ENV
|
|
||||||
|
|
||||||
#include "client/Client.h"
|
|
||||||
|
|
||||||
#include "test/global/gmock.h"
|
|
||||||
|
|
||||||
class IEventQueue;
|
|
||||||
|
|
||||||
class MockClient : public Client
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
MockClient() : Client() { }
|
|
||||||
MOCK_METHOD2(mouseMove, void(SInt32, SInt32));
|
|
||||||
MOCK_METHOD1(setOptions, void(const OptionsList&));
|
|
||||||
MOCK_METHOD0(handshakeComplete, void());
|
|
||||||
MOCK_METHOD1(setDecryptIv, void(const UInt8*));
|
|
||||||
};
|
|
Loading…
Reference in New Issue