mirror of
https://github.com/vector-im/hydrogen-web.git
synced 2025-01-22 10:11:39 +01:00
support fetching the master signing key for a user in the device tracker
This commit is contained in:
parent
2043541f56
commit
ce5b27f4b8
@ -25,6 +25,7 @@ function createUserIdentity(userId, initialRoomId = undefined) {
|
||||
return {
|
||||
userId: userId,
|
||||
roomIds: initialRoomId ? [initialRoomId] : [],
|
||||
masterKey: undefined,
|
||||
deviceTrackingStatus: TRACKING_STATUS_OUTDATED,
|
||||
};
|
||||
}
|
||||
@ -152,6 +153,26 @@ export class DeviceTracker {
|
||||
}
|
||||
}
|
||||
|
||||
async getMasterKeyForUser(userId, hsApi, log) {
|
||||
return await log.wrap("DeviceTracker.getMasterKeyForUser", async log => {
|
||||
let txn = await this._storage.readTxn([
|
||||
this._storage.storeNames.userIdentities
|
||||
]);
|
||||
let userIdentity = await txn.userIdentities.get(userId);
|
||||
if (userIdentity && userIdentity.deviceTrackingStatus !== TRACKING_STATUS_OUTDATED) {
|
||||
return userIdentity.masterKey;
|
||||
}
|
||||
// fetch from hs
|
||||
await this._queryKeys([userId], hsApi, log);
|
||||
// Retreive from storage now
|
||||
txn = await this._storage.readTxn([
|
||||
this._storage.storeNames.userIdentities
|
||||
]);
|
||||
userIdentity = await txn.userIdentities.get(userId);
|
||||
return userIdentity?.masterKey;
|
||||
});
|
||||
}
|
||||
|
||||
async writeHistoryVisibility(room, historyVisibility, syncTxn, log) {
|
||||
const added = [];
|
||||
const removed = [];
|
||||
@ -224,6 +245,7 @@ export class DeviceTracker {
|
||||
"token": this._getSyncToken()
|
||||
}, {log}).response();
|
||||
|
||||
const masterKeys = log.wrap("master keys", log => this._filterValidMasterKeys(deviceKeyResponse, log));
|
||||
const verifiedKeysPerUser = log.wrap("verify", log => this._filterVerifiedDeviceKeys(deviceKeyResponse["device_keys"], log));
|
||||
const txn = await this._storage.readWriteTxn([
|
||||
this._storage.storeNames.userIdentities,
|
||||
@ -233,7 +255,7 @@ export class DeviceTracker {
|
||||
try {
|
||||
const devicesIdentitiesPerUser = await Promise.all(verifiedKeysPerUser.map(async ({userId, verifiedKeys}) => {
|
||||
const deviceIdentities = verifiedKeys.map(deviceKeysAsDeviceIdentity);
|
||||
return await this._storeQueriedDevicesForUserId(userId, deviceIdentities, txn);
|
||||
return await this._storeQueriedDevicesForUserId(userId, masterKeys.get(userId), deviceIdentities, txn);
|
||||
}));
|
||||
deviceIdentities = devicesIdentitiesPerUser.reduce((all, devices) => all.concat(devices), []);
|
||||
log.set("devices", deviceIdentities.length);
|
||||
@ -245,7 +267,7 @@ export class DeviceTracker {
|
||||
return deviceIdentities;
|
||||
}
|
||||
|
||||
async _storeQueriedDevicesForUserId(userId, deviceIdentities, txn) {
|
||||
async _storeQueriedDevicesForUserId(userId, masterKey, deviceIdentities, txn) {
|
||||
const knownDeviceIds = await txn.deviceIdentities.getAllDeviceIds(userId);
|
||||
// delete any devices that we know off but are not in the response anymore.
|
||||
// important this happens before checking if the ed25519 key changed,
|
||||
@ -286,11 +308,38 @@ export class DeviceTracker {
|
||||
identity = createUserIdentity(userId);
|
||||
}
|
||||
identity.deviceTrackingStatus = TRACKING_STATUS_UPTODATE;
|
||||
identity.masterKey = masterKey;
|
||||
txn.userIdentities.set(identity);
|
||||
|
||||
return allDeviceIdentities;
|
||||
}
|
||||
|
||||
_filterValidMasterKeys(keyQueryResponse, parentLog) {
|
||||
const masterKeysResponse = keyQueryResponse["master_keys"];
|
||||
if (!masterKeysResponse) {
|
||||
return [];
|
||||
}
|
||||
const validMasterKeyResponses = Object.entries(masterKeysResponse).filter(([userId, keyInfo]) => {
|
||||
if (keyInfo["user_id"] !== userId) {
|
||||
return false;
|
||||
}
|
||||
if (!Array.isArray(keyInfo.usage) || !keyInfo.usage.includes("master")) {
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
});
|
||||
const masterKeys = validMasterKeyResponses.reduce((msks, [userId, keyInfo]) => {
|
||||
const keyIds = Object.keys(keyInfo.keys);
|
||||
if (keyIds.length !== 1) {
|
||||
return false;
|
||||
}
|
||||
const masterKey = keyInfo.keys[keyIds[0]];
|
||||
msks.set(userId, masterKey);
|
||||
return msks;
|
||||
}, new Map());
|
||||
return masterKeys;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return {Array<{userId, verifiedKeys: Array<DeviceSection>>}
|
||||
*/
|
||||
|
Loading…
x
Reference in New Issue
Block a user