From c86d933aa05933957e6417fcee7ee1ea7c8415af Mon Sep 17 00:00:00 2001 From: Ivan Hernandez Date: Wed, 25 May 2022 09:53:30 -0400 Subject: [PATCH] Update device detection json output to include the interface over which the device was found (e.g. Wifi, USB, etc) and to correctly start a session before fetching device attributes. Previously without a session, devices connected over wifi would return null for some attributes including BuildVersion and DeviceClass. --- src/ios-deploy/ios-deploy.m | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/src/ios-deploy/ios-deploy.m b/src/ios-deploy/ios-deploy.m index fcb574e9..008ebd42 100644 --- a/src/ios-deploy/ios-deploy.m +++ b/src/ios-deploy/ios-deploy.m @@ -456,6 +456,13 @@ device_desc get_device_desc(CFStringRef model) { return res; } +void connect_and_start_session(AMDeviceRef device) { + AMDeviceConnect(device); + assert(AMDeviceIsPaired(device)); + check_error(AMDeviceValidatePairing(device)); + check_error(AMDeviceStartSession(device)); +} + CFStringRef get_device_full_name(const AMDeviceRef device) { CFStringRef full_name = NULL, device_udid = AMDeviceCopyDeviceIdentifier(device), @@ -521,7 +528,7 @@ CFStringRef get_device_full_name(const AMDeviceRef device) { NSDictionary* get_device_json_dict(const AMDeviceRef device) { NSMutableDictionary *json_dict = [NSMutableDictionary new]; - AMDeviceConnect(device); + connect_and_start_session(device); CFStringRef device_udid = AMDeviceCopyDeviceIdentifier(device); if (device_udid) { @@ -1214,13 +1221,6 @@ void fdvendor_callback(CFSocketRef s, CFSocketCallBackType callbackType, CFDataR CFRelease(s); } -void connect_and_start_session(AMDeviceRef device) { - AMDeviceConnect(device); - assert(AMDeviceIsPaired(device)); - check_error(AMDeviceValidatePairing(device)); - check_error(AMDeviceStartSession(device)); -} - void start_remote_debug_server(AMDeviceRef device) { dbgServiceConnection = NULL; @@ -2539,6 +2539,7 @@ void handle_device(AMDeviceRef device) { if (detect_only) { if (_json_output) { NSLogJSON(@{@"Event": @"DeviceDetected", + @"Interface": (__bridge NSString *)device_interface_name, @"Device": get_device_json_dict(device) }); } else { @@ -2770,6 +2771,7 @@ void device_callback(struct am_device_notification_callback_info *info, void *ar NSLogVerbose(@"[....] Disconnected %@ from %@.", device_uuid, device_interface_name); if (detect_only && _json_output) { NSLogJSON(@{@"Event": @"DeviceDisconnected", + @"Interface": (__bridge NSString *)device_interface_name, @"Device": get_device_json_dict(info->dev) }); }