From 64b1b1aa1eb53e47e3826f08f0cdc29d43a972b5 Mon Sep 17 00:00:00 2001 From: Martin Szulecki Date: Wed, 28 Jan 2015 01:32:54 +0100 Subject: Remove dev tools which are not installed and unmaintained anyways Some might return as proper tools or be used as examples within the website documentation sooner or later. --- dev/housearresttest.c | 219 -------------------------------------------------- 1 file changed, 219 deletions(-) delete mode 100644 dev/housearresttest.c (limited to 'dev/housearresttest.c') diff --git a/dev/housearresttest.c b/dev/housearresttest.c deleted file mode 100644 index 6586787..0000000 --- a/dev/housearresttest.c +++ /dev/null @@ -1,219 +0,0 @@ -/* - * housearresttest.c - * Simple Test program showing the usage of the house_arrest interface. - * - * Copyright (c) 2010 Nikias Bassen 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 - */ -#include -#include -#include - -#include -#include -#include -#include - -static void print_usage(int argc, char **argv) -{ - char *name = NULL; - - name = strrchr(argv[0], '/'); - printf("Usage: %s [OPTIONS] APPID\n", (name ? name + 1: argv[0])); - printf("Test the house_arrest service.\n\n"); - printf(" -d, --debug\t\tenable communication debugging\n"); - printf(" -u, --udid UDID\ttarget specific device by its 40-digit device UDID\n"); - printf(" -t, --test\t\ttest creating, writing, and deleting a file\n"); - printf(" -h, --help\t\tprints usage information\n"); - printf("\n"); -} - -int main(int argc, char **argv) -{ - idevice_t dev = NULL; - lockdownd_client_t client = NULL; - house_arrest_client_t hac = NULL; - house_arrest_error_t res; - int i; - char *udid = NULL; - const char *appid = NULL; - int test_file_io = 0; - - /* parse cmdline args */ - for (i = 1; i < argc; i++) { - if (!strcmp(argv[i], "-d") || !strcmp(argv[i], "--debug")) { - idevice_set_debug_level(1); - continue; - } - else if (!strcmp(argv[i], "-u") || !strcmp(argv[i], "--udid")) { - i++; - if (!argv[i] || (strlen(argv[i]) != 40)) { - print_usage(argc, argv); - return 0; - } - udid = strdup(argv[i]); - continue; - } - else if (!strcmp(argv[i], "-t") || !strcmp(argv[i], "--test")) { - test_file_io = 1; - continue; - } - else if (!strcmp(argv[i], "-h") || !strcmp(argv[i], "--help")) { - print_usage(argc, argv); - return 0; - } - else { - appid = argv[i]; - break; - } - } - - if (!appid) { - print_usage(argc, argv); - return 0; - } - - if (idevice_new(&dev, udid) != IDEVICE_E_SUCCESS) { - printf("no device connected?!\n"); - goto leave_cleanup; - } - - if (lockdownd_client_new_with_handshake(dev, &client, NULL) != LOCKDOWN_E_SUCCESS) { - printf("could not connect to lockdownd!\n"); - goto leave_cleanup; - } - - lockdownd_service_descriptor_t service = NULL; - if (lockdownd_start_service(client, "com.apple.mobile.house_arrest", &service) != LOCKDOWN_E_SUCCESS) { - printf("could not start house_arrest service!\n"); - goto leave_cleanup; - } - - if (client) { - lockdownd_client_free(client); - client = NULL; - } - - if (house_arrest_client_new(dev, service, &hac) != HOUSE_ARREST_E_SUCCESS) { - printf("could not connect to house_arrest service!\n"); - goto leave_cleanup; - } - - if (service) { - lockdownd_service_descriptor_free(service); - service = NULL; - } - - res = house_arrest_send_command(hac, "VendDocuments", appid); - if (res != HOUSE_ARREST_E_SUCCESS) { - printf("error %d when trying to get VendDocuments\n", res); - goto leave_cleanup; - } - - plist_t dict = NULL; - if (house_arrest_get_result(hac, &dict) != HOUSE_ARREST_E_SUCCESS) { - if (house_arrest_get_result(hac, &dict) != HOUSE_ARREST_E_SUCCESS) { - printf("hmmm....\n"); - goto leave_cleanup; - } - } - - plist_t node = plist_dict_get_item(dict, "Error"); - if (node) { - char *str = NULL; - plist_get_string_val(node, &str); - printf("Error: %s\n", str); - if (str) free(str); - plist_free(dict); - dict = NULL; - goto leave_cleanup; - } - node = plist_dict_get_item(dict, "Status"); - if (node) { - char *str = NULL; - plist_get_string_val(node, &str); - if (str && (strcmp(str, "Complete") != 0)) { - printf("Warning: Status is not 'Complete' but '%s'\n", str); - } - if (str) free(str); - plist_free(dict); - dict = NULL; - } - if (dict) { - plist_free(dict); - } - - afc_client_t afc = NULL; - afc_error_t ae = afc_client_new_from_house_arrest_client(hac, &afc); - if (ae != AFC_E_SUCCESS) { - printf("afc error %d\n", ae); - } - if (ae == AFC_E_SUCCESS) { - char **list = NULL; - afc_read_directory(afc, "/", &list); - printf("Directory contents:\n"); - if (list) { - while (list[0]) { - if (strcmp(list[0], ".") && strcmp(list[0], "..")) { - puts(list[0]); - } - list++; - } - } - - if (test_file_io) { - uint64_t tf = 0; - printf("\n==== Performing file tests ====\n"); - printf("Opening file 'foobar' for writing: "); - if (afc_file_open(afc, "/foobar", AFC_FOPEN_RW, &tf) == AFC_E_SUCCESS) { - uint32_t wb = 0; - printf("OK\n"); - - printf("Writing to file: "); - if (afc_file_write(afc, tf, "test\r\n", 6, &wb) != AFC_E_SUCCESS) { - printf("ERROR\n"); - } else { - printf("OK\n"); - } - afc_file_close(afc, tf); - printf("Deleting file 'foobar': "); - if (afc_remove_path(afc, "/foobar") == AFC_E_SUCCESS) { - printf("OK\n"); - } else { - printf("ERROR\n"); - } - } else { - printf("ERROR\n"); - } - } - afc_client_free(afc); - } else { - printf("failed to connect to afc service, error %d\n", ae); - } - -leave_cleanup: - if (hac) { - house_arrest_client_free(hac); - } - if (client) { - lockdownd_client_free(client); - } - if (dev) { - idevice_free(dev); - } - - return 0; -} -- cgit v1.1-32-gdbae