mirror of
https://github.com/owntone/owntone-server.git
synced 2025-01-16 01:03:16 -05:00
[raop] Fix crash when keys of incorrect length are used for legacy pairing
Happens if the user has paied with Airplay 2, and afterwards activates Airplay 1 for the same device, since the keys in device->auth_keys will then be incorrect length. Closes #1703
This commit is contained in:
parent
3fe4c9f289
commit
c28d108b96
@ -2748,7 +2748,7 @@ payload_make_pair_verify1(struct evrtsp_request *req, struct airplay_session *rs
|
|||||||
rs->pair_verify_ctx = pair_verify_new(rs->pair_type, device->auth_key, NULL, NULL, device_id_hex);
|
rs->pair_verify_ctx = pair_verify_new(rs->pair_type, device->auth_key, NULL, NULL, device_id_hex);
|
||||||
if (!rs->pair_verify_ctx)
|
if (!rs->pair_verify_ctx)
|
||||||
{
|
{
|
||||||
DPRINTF(E_LOG, L_AIRPLAY, "Out of memory for verification verify context\n");
|
DPRINTF(E_LOG, L_AIRPLAY, "Couldn't create verification verify context (invalid auth key?)\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3966,7 +3966,15 @@ raop_pair_verify(struct raop_session *rs)
|
|||||||
if (!device)
|
if (!device)
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
CHECK_NULL(L_RAOP, rs->pair_verify_ctx = pair_verify_new(PAIR_CLIENT_FRUIT, device->auth_key, NULL, NULL, NULL));
|
rs->pair_verify_ctx = pair_verify_new(PAIR_CLIENT_FRUIT, device->auth_key, NULL, NULL, NULL);
|
||||||
|
if (!rs->pair_verify_ctx)
|
||||||
|
{
|
||||||
|
DPRINTF(E_LOG, L_RAOP, "Verification authorization key invalid, resetting\n");
|
||||||
|
|
||||||
|
free(device->auth_key);
|
||||||
|
device->auth_key = NULL;
|
||||||
|
goto error;
|
||||||
|
}
|
||||||
|
|
||||||
ret = raop_pair_request_send(4, rs, raop_cb_pair_verify_step1);
|
ret = raop_pair_request_send(4, rs, raop_cb_pair_verify_step1);
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
@ -4450,11 +4458,17 @@ raop_device_start_generic(struct output_device *device, int callback_id, bool on
|
|||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
if (device->auth_key)
|
if (device->auth_key)
|
||||||
|
{
|
||||||
ret = raop_pair_verify(rs);
|
ret = raop_pair_verify(rs);
|
||||||
else if (device->requires_auth)
|
}
|
||||||
|
|
||||||
|
if (!device->auth_key) // If no auth keys or if raop_pair_verify() cleared the key
|
||||||
|
{
|
||||||
|
if (device->requires_auth)
|
||||||
ret = raop_send_req_pin_start(rs, raop_cb_pin_start, "device_start");
|
ret = raop_send_req_pin_start(rs, raop_cb_pin_start, "device_start");
|
||||||
else
|
else
|
||||||
ret = raop_send_req_options(rs, raop_cb_startup_options, "device_start");
|
ret = raop_send_req_options(rs, raop_cb_startup_options, "device_start");
|
||||||
|
}
|
||||||
|
|
||||||
if (ret < 0)
|
if (ret < 0)
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user