summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Martin Szulecki2013-08-05 20:10:17 +0200
committerGravatar Martin Szulecki2013-08-05 20:10:17 +0200
commit7567728d13c4d43cffb5fcd0292e2fa4c412344d (patch)
treee14a5ae9bc250e15d89fffd0fc5339e12c8b8b8b
parent3604756139b1a2dde383122745d37fe9d1c95f88 (diff)
downloadlibimobiledevice-7567728d13c4d43cffb5fcd0292e2fa4c412344d.tar.gz
libimobiledevice-7567728d13c4d43cffb5fcd0292e2fa4c412344d.tar.bz2
service: Make generic service public to enable external service implementations
-rw-r--r--include/Makefile.am3
-rw-r--r--include/libimobiledevice/service.h67
-rw-r--r--src/service.h31
3 files changed, 70 insertions, 31 deletions
diff --git a/include/Makefile.am b/include/Makefile.am
index 39a8d60..4ee11b4 100644
--- a/include/Makefile.am
+++ b/include/Makefile.am
@@ -18,4 +18,5 @@ nobase_include_HEADERS = libimobiledevice/libimobiledevice.h \
libimobiledevice/webinspector.h\
libimobiledevice/heartbeat.h\
libimobiledevice/diagnostics_relay.h\
- libimobiledevice/syslog_relay.h \ No newline at end of file
+ libimobiledevice/syslog_relay.h\
+ libimobiledevice/service.h \ No newline at end of file
diff --git a/include/libimobiledevice/service.h b/include/libimobiledevice/service.h
new file mode 100644
index 0000000..6585fe7
--- /dev/null
+++ b/include/libimobiledevice/service.h
@@ -0,0 +1,67 @@
+/**
+ * @file libimobiledevice/service.h
+ * @brief Generic basic service implementation to inherit.
+ * \internal
+ *
+ * Copyright (c) 2013 Martin Szulecki All Rights Reserved.
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library 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
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ */
+
+#ifndef ISERVICE_H
+#define ISERVICE_H
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#include <libimobiledevice/libimobiledevice.h>
+#include <libimobiledevice/lockdown.h>
+
+/** @name Error Codes */
+/*@{*/
+#define SERVICE_E_SUCCESS 0
+#define SERVICE_E_INVALID_ARG -1
+#define SERVICE_E_MUX_ERROR -3
+#define SERVICE_E_SSL_ERROR -4
+#define SERVICE_E_START_SERVICE_ERROR -5
+#define SERVICE_E_UNKNOWN_ERROR -256
+/*@}*/
+
+/** Represents an error code. */
+typedef int16_t service_error_t;
+
+typedef struct service_client_private service_client_private;
+typedef service_client_private* service_client_t; /**< The client handle. */
+
+#define SERVICE_CONSTRUCTOR(x) (int16_t (*)(idevice_t, lockdownd_service_descriptor_t, void**))(x)
+
+/* Interface */
+service_error_t service_client_new(idevice_t device, lockdownd_service_descriptor_t service, service_client_t *client);
+service_error_t service_client_factory_start_service(idevice_t device, const char* service_name, void **client, const char* label, int16_t (*constructor_func)(idevice_t, lockdownd_service_descriptor_t, void**), int16_t *error_code);
+service_error_t service_client_free(service_client_t client);
+
+service_error_t service_send(service_client_t client, const char *data, uint32_t size, uint32_t *sent);
+service_error_t service_receive_with_timeout(service_client_t client, char *data, uint32_t size, uint32_t *received, unsigned int timeout);
+service_error_t service_receive(service_client_t client, char *data, uint32_t size, uint32_t *received);
+
+service_error_t service_enable_ssl(service_client_t client);
+service_error_t service_disable_ssl(service_client_t client);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
diff --git a/src/service.h b/src/service.h
index 8cea7a3..512f9e2 100644
--- a/src/service.h
+++ b/src/service.h
@@ -21,41 +21,12 @@
#ifndef SERVICE_H
#define SERVICE_H
+#include "libimobiledevice/service.h"
#include "libimobiledevice/lockdown.h"
#include "idevice.h"
-/* Error Codes */
-#define SERVICE_E_SUCCESS 0
-#define SERVICE_E_INVALID_ARG -1
-#define SERVICE_E_MUX_ERROR -3
-#define SERVICE_E_SSL_ERROR -4
-#define SERVICE_E_START_SERVICE_ERROR -5
-#define SERVICE_E_UNKNOWN_ERROR -256
-
struct service_client_private {
idevice_connection_t connection;
};
-typedef struct service_client_private *service_client_t;
-
-typedef int16_t service_error_t;
-
-#define SERVICE_CONSTRUCTOR(x) (int16_t (*)(idevice_t, lockdownd_service_descriptor_t, void**))(x)
-
-/* creation and destruction */
-service_error_t service_client_new(idevice_t device, lockdownd_service_descriptor_t service, service_client_t *client);
-service_error_t service_client_factory_start_service(idevice_t device, const char* service_name, void **client, const char* label, int16_t (*constructor_func)(idevice_t, lockdownd_service_descriptor_t, void**), int16_t *error_code);
-service_error_t service_client_free(service_client_t client);
-
-/* sending */
-service_error_t service_send(service_client_t client, const char *data, uint32_t size, uint32_t *sent);
-
-/* receiving */
-service_error_t service_receive_with_timeout(service_client_t client, char *data, uint32_t size, uint32_t *received, unsigned int timeout);
-service_error_t service_receive(service_client_t client, char *data, uint32_t size, uint32_t *received);
-
-/* misc */
-service_error_t service_enable_ssl(service_client_t client);
-service_error_t service_disable_ssl(service_client_t client);
-
#endif