diff options
| author | 2014-05-21 12:07:53 +0200 | |
|---|---|---|
| committer | 2014-05-21 12:07:53 +0200 | |
| commit | 03b606324e1ee5dd93cee4e8b9d6a6151b01cec4 (patch) | |
| tree | fd7ddf11678b6a708aabaef1c801ee11c2f9a35c | |
| parent | 4563ad4d2e6ad75e42737e6ae381a0648b65f958 (diff) | |
| download | libimobiledevice-03b606324e1ee5dd93cee4e8b9d6a6151b01cec4.tar.gz libimobiledevice-03b606324e1ee5dd93cee4e8b9d6a6151b01cec4.tar.bz2 | |
ideviceprovision: Add new dump command to print profile information
| -rw-r--r-- | tools/Makefile.am | 2 | ||||
| -rw-r--r-- | tools/ideviceprovision.c | 149 | 
2 files changed, 111 insertions, 40 deletions
| diff --git a/tools/Makefile.am b/tools/Makefile.am index 8a91234..959bdc4 100644 --- a/tools/Makefile.am +++ b/tools/Makefile.am @@ -62,7 +62,7 @@ idevicedate_LDADD = $(top_builddir)/src/libimobiledevice.la  ideviceprovision_SOURCES = ideviceprovision.c  ideviceprovision_CFLAGS = $(AM_CFLAGS) -ideviceprovision_LDFLAGS = $(AM_LDFLAGS) +ideviceprovision_LDFLAGS = $(top_builddir)/common/libinternalcommon.la $(AM_LDFLAGS)  ideviceprovision_LDADD = $(top_builddir)/src/libimobiledevice.la  idevicedebugserverproxy_SOURCES = idevicedebugserverproxy.c diff --git a/tools/ideviceprovision.c b/tools/ideviceprovision.c index 13fd239..82e929d 100644 --- a/tools/ideviceprovision.c +++ b/tools/ideviceprovision.c @@ -32,6 +32,7 @@  #include <libimobiledevice/libimobiledevice.h>  #include <libimobiledevice/lockdown.h>  #include <libimobiledevice/misagent.h> +#include "common/utils.h"  static void print_usage(int argc, char **argv)  { @@ -47,10 +48,13 @@ static void print_usage(int argc, char **argv)  	printf("  copy PATH\tRetrieves all provisioning profiles from the device and\n");  	printf("           \tstores them into the existing directory specified by PATH.\n");  	printf("           \tThe files will be stored as UUID.mobileprovision\n"); -	printf("  remove UUID\tRemoves the provisioning profile identified by UUID.\n\n"); +	printf("  remove UUID\tRemoves the provisioning profile identified by UUID.\n"); +	printf("  dump FILE\tPrints detailed information about the provisioning profile\n"); +	printf("           \tspecified by FILE.\n\n");  	printf(" The following OPTIONS are accepted:\n");  	printf("  -d, --debug      enable communication debugging\n");  	printf("  -u, --udid UDID  target specific device by its 40-digit device UDID\n"); +	printf("  -x, --xml        print XML output when using the 'dump' command\n");  	printf("  -h, --help       prints usage information\n");  	printf("\n");  } @@ -60,6 +64,7 @@ enum {  	OP_LIST,  	OP_COPY,  	OP_REMOVE, +	OP_DUMP,  	NUM_OPS  }; @@ -190,6 +195,52 @@ static plist_t profile_get_embedded_plist(plist_t profile)  	return pl;  } +static int profile_read_from_file(const char* path, unsigned char **profile_data, unsigned int *profile_size) +{ +	FILE* f = fopen(path, "rb"); +	if (!f) { +		fprintf(stderr, "Could not open file '%s'\n", path); +		return -1; +	} +	fseek(f, 0, SEEK_END); +	long int size = ftell(f); +	fseek(f, 0, SEEK_SET); + +	if (size >= 0x1000000) { +		fprintf(stderr, "The file '%s' is too large for processing.\n", path); +		fclose(f); +		return -1; +	} + +	unsigned char* buf = malloc(size); +	if (!buf) { +		fprintf(stderr, "Could not allocate memory...\n"); +		fclose(f); +		return -1; +	} + +	long int cur = 0; +	while (cur < size) { +		ssize_t r = fread(buf+cur, 1, 512, f); +		if (r <= 0) { +			break; +		} +		cur += r; +	} +	fclose(f); + +	if (cur != size) { +		free(buf); +		fprintf(stderr, "Could not read in file '%s' (size %ld read %ld)\n", path, size, cur); +		return -1; +	} + +	*profile_data = buf; +	*profile_size = (unsigned int)size; + +	return 0; +} +  int main(int argc, char *argv[])  {  	lockdownd_client_t client = NULL; @@ -198,6 +249,7 @@ int main(int argc, char *argv[])  	idevice_error_t ret = IDEVICE_E_UNKNOWN_ERROR;  	int i;  	int op = -1; +	int output_xml = 0;  	const char* udid = NULL;  	const char* param = NULL; @@ -249,6 +301,20 @@ int main(int argc, char *argv[])  			op = OP_REMOVE;  			continue;  		} +		else if (!strcmp(argv[i], "dump")) { +			i++; +			if (!argv[i] || (strlen(argv[i]) < 1)) { +				print_usage(argc, argv); +				return 0; +			} +			param = argv[i]; +			op = OP_DUMP; +			continue; +		} +		else if (!strcmp(argv[i], "-x") || !strcmp(argv[i], "--xml")) { +			output_xml = 1; +			continue; +		}  		else if (!strcmp(argv[i], "-h") || !strcmp(argv[i], "--help")) {  			print_usage(argc, argv);  			return 0; @@ -264,6 +330,43 @@ int main(int argc, char *argv[])  		return 0;  	} +	if (op == OP_DUMP) { +		int res = 0; +		unsigned char* profile_data = NULL; +		unsigned int profile_size = 0; +		if (profile_read_from_file(param, &profile_data, &profile_size) != 0) { +			return -1; +		} +		plist_t pdata = plist_new_data((char*)profile_data, profile_size); +		plist_t pl = profile_get_embedded_plist(pdata); +		plist_free(pdata); +		free(profile_data); + +		if (pl) { +			if (output_xml) { +				char* xml = NULL; +				uint32_t xlen = 0; +				plist_to_xml(pl, &xml, &xlen); +				if (xml) { +					printf("%s\n", xml); +					free(xml); +				} +			} else { +				if (pl && (plist_get_node_type(pl) == PLIST_DICT)) { +					plist_print_to_stream(pl, stdout); +				} else { +					fprintf(stderr, "ERROR: unexpected node type in profile plist (not PLIST_DICT)\n"); +					res = -1; +				} +			} +		} else { +			fprintf(stderr, "ERROR: could not extract embedded plist from profile!\n"); +		} +		plist_free(pl); + +		return res; +	} +  	ret = idevice_new(&device, udid);  	if (ret != IDEVICE_E_SUCCESS) {  		if (udid) { @@ -304,46 +407,15 @@ int main(int argc, char *argv[])  	switch (op) {  		case OP_INSTALL:  		{ -			FILE* f = fopen(param, "rb"); -			if (!f) { -				fprintf(stderr, "Could not open file '%s'\n", param); -				break; -			} -			fseek(f, 0, SEEK_END); -			long int size = ftell(f); -			fseek(f, 0, SEEK_SET); - -			if (size >= 0x1000000) { -				fprintf(stderr, "The file '%s' is too large for processing.\n", param); -				fclose(f); -				break; -			} - -			char* buf = malloc(size); -			if (!buf) { -				fprintf(stderr, "Could not allocate memory...\n"); -				fclose(f); -				break; -			} - -			long int cur = 0; -			while (cur < size) { -				ssize_t r = fread(buf+cur, 1, 512, f); -				if (r <= 0) { -					break; -				} -				cur += r; -			} -			fclose(f); - -			if (cur != size) { -				free(buf); -				fprintf(stderr, "Could not read in file '%s' (size %ld read %ld)\n", param, size, cur); +			unsigned char* profile_data = NULL; +			unsigned int profile_size = 0;	 +			if (profile_read_from_file(param, &profile_data, &profile_size) != 0) {  				break;  			} -			uint64_t psize = size; -			plist_t pdata = plist_new_data(buf, psize); +			uint64_t psize = profile_size; +			plist_t pdata = plist_new_data((const char*)profile_data, psize); +			free(profile_data);  			if (misagent_install(mis, pdata) == MISAGENT_E_SUCCESS) {  				printf("Profile '%s' installed successfully.\n", param); @@ -351,7 +423,6 @@ int main(int argc, char *argv[])  				int sc = misagent_get_status_code(mis);  				fprintf(stderr, "Could not install profile '%s', status code: 0x%x\n", param, sc);  			} -			free(buf);  		}  			break;  		case OP_LIST: | 
