diff --git a/ext/toolchain/commands1.py b/ext/toolchain/commands1.py
index 1b476764..b40af000 100644
--- a/ext/toolchain/commands1.py
+++ b/ext/toolchain/commands1.py
@@ -817,12 +817,6 @@ class InternalCommands:
shutil.copy(targetDir + "/synergys", bundleBinDir)
shutil.copy(targetDir + "/syntool", bundleBinDir)
- if self.macSdk == "10.9":
- launchServicesDir = dir + "/Synergy.app/Contents/Library/LaunchServices/"
- if not os.path.exists(launchServicesDir):
- os.makedirs(launchServicesDir)
- shutil.copy(targetDir + "/synmacph", launchServicesDir)
-
if self.enableMakeGui:
self.loadConfig()
diff --git a/src/gui/gui.pro b/src/gui/gui.pro
index 0576f266..c3a37d3e 100644
--- a/src/gui/gui.pro
+++ b/src/gui/gui.pro
@@ -89,9 +89,7 @@ HEADERS += src/MainWindow.h \
src/CommandProcess.h
RESOURCES += res/Synergy.qrc
RC_FILE = res/win/Synergy.rc
-macx {
- HEADERS += src/AXDatabaseCleaner.h
- OBJECTIVE_SOURCES += src/AXDatabaseCleaner.mm
+macx {
QMAKE_INFO_PLIST = res/mac/Info.plist
TARGET = Synergy
QSYNERGY_ICON.files = res/mac/Synergy.icns
diff --git a/src/gui/res/mac/Info.plist b/src/gui/res/mac/Info.plist
index 992df616..c2e4eac7 100644
--- a/src/gui/res/mac/Info.plist
+++ b/src/gui/res/mac/Info.plist
@@ -17,9 +17,5 @@
CFBundleIdentifier
synergy
SMPrivilegedExecutables
-
- synmacph
- anchor apple generic and identifier "synmacph" and (certificate leaf[field.1.2.840.113635.100.6.1.9] /* exists */ or certificate 1[field.1.2.840.113635.100.6.2.6] /* exists */ and certificate leaf[field.1.2.840.113635.100.6.1.13] /* exists */ and certificate leaf[subject.OU] = SP58PFWX5L)
-
diff --git a/src/gui/src/AXDatabaseCleaner.h b/src/gui/src/AXDatabaseCleaner.h
deleted file mode 100644
index dc41f31b..00000000
--- a/src/gui/src/AXDatabaseCleaner.h
+++ /dev/null
@@ -1,42 +0,0 @@
-/*
- * synergy -- mouse and keyboard sharing utility
- * Copyright (C) 2014 Synergy Si Ltd.
- *
- * 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 .
- */
-
-#pragma once
-
-#include
-
-// HACK: ideally this file should not be included in project,
-// if it is below marvericks, but it seems that .pro can't
-// specify mac version
-#if __MAC_OS_X_VERSION_MIN_REQUIRED >= 1090
-
-class AXDatabaseCleaner {
-public:
- AXDatabaseCleaner();
- ~AXDatabaseCleaner();
-
- bool loadPrivilegeHelper();
- bool xpcConnect();
- bool privilegeCommand(const char* command);
-
-private:
- class Private;
- Private* m_private;
- bool m_waitForResponse;
-};
-
-#endif
diff --git a/src/gui/src/AXDatabaseCleaner.mm b/src/gui/src/AXDatabaseCleaner.mm
deleted file mode 100644
index 96435b1e..00000000
--- a/src/gui/src/AXDatabaseCleaner.mm
+++ /dev/null
@@ -1,166 +0,0 @@
-/*
- * synergy -- mouse and keyboard sharing utility
- * Copyright (C) 2014 Synergy Si Ltd.
- *
- * 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 .
- */
-
-#import "AXDatabaseCleaner.h"
-
-#if __MAC_OS_X_VERSION_MIN_REQUIRED >= 1090
-
-#import
-#if __MAC_OS_X_VERSION_MIN_REQUIRED >= 1060
-#import
-#endif
-#import
-#import
-#import
-
-const NSString* const label = @"synmacph";
-
-class AXDatabaseCleaner::Private {
-public:
- NSAutoreleasePool* autoReleasePool;
- AuthorizationRef authRef;
- xpc_connection_t xpcConnection;
-};
-
-AXDatabaseCleaner::AXDatabaseCleaner()
-{
- m_private = new Private;
- m_private->autoReleasePool = [[NSAutoreleasePool alloc] init];
-
- m_waitForResponse = false;
-}
-
-AXDatabaseCleaner::~AXDatabaseCleaner()
-{
- [m_private->autoReleasePool release];
- delete m_private;
-}
-
-bool AXDatabaseCleaner::loadPrivilegeHelper()
-{
-#if __MAC_OS_X_VERSION_MIN_REQUIRED >= 1090 // mavericks
-
- OSStatus status = AuthorizationCreate(NULL, kAuthorizationEmptyEnvironment, kAuthorizationFlagDefaults, &m_private->authRef);
- if (status != errAuthorizationSuccess) {
- assert(NO);
- m_private->authRef = NULL;
- }
-
- AuthorizationItem authItem = {kSMRightBlessPrivilegedHelper, 0, NULL, 0};
- AuthorizationRights authRights = {1, &authItem};
- AuthorizationFlags flags = kAuthorizationFlagDefaults
- | kAuthorizationFlagInteractionAllowed
- | kAuthorizationFlagPreAuthorize
- | kAuthorizationFlagExtendRights;
-
- BOOL result = NO;
- NSError* error = nil;
-
- status = AuthorizationCopyRights(m_private->authRef, &authRights, kAuthorizationEmptyEnvironment, flags, NULL);
- if (status != errAuthorizationSuccess) {
- error = [NSError errorWithDomain:NSOSStatusErrorDomain code:status userInfo:nil];
- }
- else {
- CFErrorRef cfError;
- result = (BOOL)SMJobBless(kSMDomainSystemLaunchd, (CFStringRef)label, m_private->authRef, &cfError);
-
- if (!result) {
- error = CFBridgingRelease(cfError);
- }
- }
-
- if (!result) {
- assert(error != nil);
- NSLog(@"bless error: domain= %@ / code= %d", [error domain], (int) [error code]);
- return false;
- }
-
- return true;
-}
-
-bool AXDatabaseCleaner::xpcConnect()
-{
- const char *cStr = [label cStringUsingEncoding:NSASCIIStringEncoding];
- m_private->xpcConnection = xpc_connection_create_mach_service(
- cStr,
- NULL,
- XPC_CONNECTION_MACH_SERVICE_PRIVILEGED);
-
- if (!m_private->xpcConnection) {
- NSLog(@"failed to create xpc connection");
- return false;
- }
-
- xpc_connection_set_event_handler(m_private->xpcConnection, ^(xpc_object_t event) {
- xpc_type_t type = xpc_get_type(event);
-
- if (type == XPC_TYPE_ERROR) {
- if (event == XPC_ERROR_CONNECTION_INTERRUPTED) {
- NSLog(@"xpc connection interupted");
-
- }
- else if (event == XPC_ERROR_CONNECTION_INVALID) {
- NSLog(@"xpc connection invalid, releasing");
- xpc_release(m_private->xpcConnection);
- }
- else {
- NSLog(@"unexpected xpc connection error");
- }
- }
- else {
- NSLog(@"unexpected xpc connection event");
- }
- });
-
- xpc_connection_resume(m_private->xpcConnection);
-
- return true;
-}
-
-bool AXDatabaseCleaner::privilegeCommand(const char* command)
-{
- xpc_object_t message = xpc_dictionary_create(NULL, NULL, 0);
- xpc_dictionary_set_string(message, "request", command);
- m_waitForResponse = true;
-
- xpc_connection_send_message_with_reply(
- m_private->xpcConnection,
- message,
- dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_BACKGROUND, 0),
- ^(xpc_object_t event) {
- const char* response = xpc_dictionary_get_string(event, "reply");
- NSLog(@"reply from helper tool: %s", response);
- m_waitForResponse = false;
- });
-
- QTime time = QTime::currentTime();
- time.start();
-
- while (m_waitForResponse) {
- sleep(1);
- if (time.elapsed() > 10000) {
- QMessageBox::critical(NULL, "Synergy",
- QObject::tr("No response from helper tool.Restart Synergy may solve this problem."));
- return false;
- }
- }
-#endif
-
- return true;
-}
-
-#endif
diff --git a/src/gui/src/main.cpp b/src/gui/src/main.cpp
index 2e3df613..4bdff3ec 100644
--- a/src/gui/src/main.cpp
+++ b/src/gui/src/main.cpp
@@ -32,10 +32,6 @@
#if defined(Q_OS_MAC)
#include
-#if __MAC_OS_X_VERSION_MIN_REQUIRED >= 1090
-#include "AXDatabaseCleaner.h"
-#endif
-
#endif
class QThreadImpl : public QThread