summary refs log tree commit diff
diff options
context:
space:
mode:
authorHubert Chathi <hubert@uhoreg.ca>2020-02-04 12:03:54 -0500
committerErik Johnston <erik@matrix.org>2020-02-05 10:54:49 +0000
commit60d06724268891ad3b1e9dc6fe7cd080f9ba21b7 (patch)
treed9ab334821e673530356b8f3c044eea6ffe17d02
parentFix detecting unknown devices from remote encrypted events. (#6848) (diff)
downloadsynapse-60d06724268891ad3b1e9dc6fe7cd080f9ba21b7.tar.xz
Merge pull request #6844 from matrix-org/uhoreg/cross_signing_fix_device_fed
add device signatures to device key query results
-rw-r--r--changelog.d/6844.bugfix1
-rw-r--r--synapse/storage/data_stores/main/devices.py10
2 files changed, 11 insertions, 0 deletions
diff --git a/changelog.d/6844.bugfix b/changelog.d/6844.bugfix
new file mode 100644

index 0000000000..e84aa1029f --- /dev/null +++ b/changelog.d/6844.bugfix
@@ -0,0 +1 @@ +Fix an issue with cross-signing where device signatures were not sent to remote servers. diff --git a/synapse/storage/data_stores/main/devices.py b/synapse/storage/data_stores/main/devices.py
index ea0503476f..b7617efb80 100644 --- a/synapse/storage/data_stores/main/devices.py +++ b/synapse/storage/data_stores/main/devices.py
@@ -320,6 +320,11 @@ class DeviceWorkerStore(SQLBaseStore): device_display_name = device.get("device_display_name", None) if device_display_name: result["device_display_name"] = device_display_name + if "signatures" in device: + for sig_user_id, sigs in device["signatures"].items(): + result["keys"].setdefault("signatures", {}).setdefault( + sig_user_id, {} + ).update(sigs) else: result["deleted"] = True @@ -524,6 +529,11 @@ class DeviceWorkerStore(SQLBaseStore): device_display_name = device.get("device_display_name", None) if device_display_name: result["device_display_name"] = device_display_name + if "signatures" in device: + for sig_user_id, sigs in device["signatures"].items(): + result["keys"].setdefault("signatures", {}).setdefault( + sig_user_id, {} + ).update(sigs) results.append(result)