diff options
| author | 2010-06-05 23:41:35 +0200 | |
|---|---|---|
| committer | 2010-06-05 23:41:35 +0200 | |
| commit | e5d4b8e126b0160c80103b814ef59a3f1319f22e (patch) | |
| tree | bbdd8dabd2c13e4f544848c4e0b57bf31d5155d3 | |
| parent | 7a2811b76793b262237b4b61bc777edf9ec37257 (diff) | |
| download | libimobiledevice-e5d4b8e126b0160c80103b814ef59a3f1319f22e.tar.gz libimobiledevice-e5d4b8e126b0160c80103b814ef59a3f1319f22e.tar.bz2 | |
Added function to fetch device values from the QueryType response
| -rw-r--r-- | include/libimobiledevice/restore.h | 1 | ||||
| -rw-r--r-- | src/restore.c | 46 | ||||
| -rw-r--r-- | src/restore.h | 1 | 
3 files changed, 46 insertions, 2 deletions
| diff --git a/include/libimobiledevice/restore.h b/include/libimobiledevice/restore.h index 6f3ff53..9c30b03 100644 --- a/include/libimobiledevice/restore.h +++ b/include/libimobiledevice/restore.h @@ -54,6 +54,7 @@ restored_error_t restored_client_new(idevice_t device, restored_client_t *client  restored_error_t restored_client_free(restored_client_t client);  restored_error_t restored_query_type(restored_client_t client, char **type, uint64_t *version); +restored_error_t restored_get_value(restored_client_t client, const char *key, plist_t *value) ;  restored_error_t restored_send(restored_client_t client, plist_t plist);  restored_error_t restored_receive(restored_client_t client, plist_t *plist);  restored_error_t restored_goodbye(restored_client_t client); diff --git a/src/restore.c b/src/restore.c index 8acefef..ab14c28 100644 --- a/src/restore.c +++ b/src/restore.c @@ -119,6 +119,10 @@ restored_error_t restored_client_free(restored_client_t client)  	if (client->label) {  		free(client->label);  	} +	 +	if (client->info) { +		plist_free(client->info); +	}  	free(client);  	return ret; @@ -154,6 +158,7 @@ restored_error_t restored_receive(restored_client_t client, plist_t *plist)  {  	if (!client || !plist || (plist && *plist))  		return RESTORE_E_INVALID_ARG; +		  	restored_error_t ret = RESTORE_E_SUCCESS;  	property_list_service_error_t err; @@ -229,6 +234,9 @@ restored_error_t restored_query_type(restored_client_t client, char **type, uint  	ret = RESTORE_E_UNKNOWN_ERROR;  	if (restored_check_result(dict) == RESULT_SUCCESS) { +		/* save our device information info */ +		client->info = dict; +		  		/* return the type if requested */  		if (type != NULL) {  			plist_t type_node = plist_dict_get_item(dict, "Type"); @@ -247,13 +255,47 @@ restored_error_t restored_query_type(restored_client_t client, char **type, uint  			ret = RESTORE_E_UNKNOWN_ERROR;  	} -	plist_free(dict); -	dict = NULL;  	return ret;  }  /** + * Retrieves a value from information plist specified by a key. + * + * @param client An initialized restored client. + * @param key The key name to request or NULL to query for all keys + * @param value A plist node representing the result value node + * + * @return RESTORE_E_SUCCESS on success, NP_E_INVALID_ARG when client is NULL, RESTORE_E_PLIST_ERROR if value for key can't be found + */ +restored_error_t restored_get_value(restored_client_t client, const char *key, plist_t *value)  +{ +	if (!client || !value || (value && *value)) +		return RESTORE_E_INVALID_ARG; +		 +	if (!client->info) +		return RESTORE_E_NOT_ENOUGH_DATA; +		 +	restored_error_t ret = RESTORE_E_SUCCESS; +	plist_t item = NULL; +	 +	if (!key) { +		*value = plist_copy(client->info); +		return RESTORE_E_SUCCESS; +	} else { +		item = plist_dict_get_item(client->info, key); +	} +	 +	if (item) { +		*value = plist_copy(item); +	} else { +		ret = RESTORE_E_PLIST_ERROR; +	} +	 +	return ret; +} + +/**   * Creates a new restored client for the device.   *   * @param device The device to create a restored client for diff --git a/src/restore.h b/src/restore.h index 8b4cbbb..d790d01 100644 --- a/src/restore.h +++ b/src/restore.h @@ -31,6 +31,7 @@ struct restored_client_private {  	property_list_service_client_t parent;  	char *uuid;  	char *label; +	plist_t info;  };  #endif | 
