2020-08-31 18:08:03 +05:30
|
|
|
/*
|
|
|
|
Copyright 2020 The Matrix.org Foundation C.I.C.
|
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
2021-08-12 02:24:33 +05:30
|
|
|
import {MAX_UNICODE, MIN_UNICODE} from "./common";
|
2021-05-06 18:53:58 +05:30
|
|
|
|
2020-08-31 18:08:03 +05:30
|
|
|
function encodeKey(userId, deviceId) {
|
|
|
|
return `${userId}|${deviceId}`;
|
|
|
|
}
|
|
|
|
|
2020-09-14 19:14:47 +05:30
|
|
|
function decodeKey(key) {
|
|
|
|
const [userId, deviceId] = key.split("|");
|
|
|
|
return {userId, deviceId};
|
|
|
|
}
|
|
|
|
|
2020-08-31 18:08:03 +05:30
|
|
|
export class DeviceIdentityStore {
|
|
|
|
constructor(store) {
|
|
|
|
this._store = store;
|
|
|
|
}
|
|
|
|
|
|
|
|
getAllForUserId(userId) {
|
2021-06-02 16:01:13 +05:30
|
|
|
const range = this._store.IDBKeyRange.lowerBound(encodeKey(userId, ""));
|
2020-08-31 18:08:03 +05:30
|
|
|
return this._store.selectWhile(range, device => {
|
|
|
|
return device.userId === userId;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2020-09-14 19:14:47 +05:30
|
|
|
async getAllDeviceIds(userId) {
|
|
|
|
const deviceIds = [];
|
2021-06-02 16:01:13 +05:30
|
|
|
const range = this._store.IDBKeyRange.lowerBound(encodeKey(userId, ""));
|
2020-09-14 19:14:47 +05:30
|
|
|
await this._store.iterateKeys(range, key => {
|
|
|
|
const decodedKey = decodeKey(key);
|
|
|
|
// prevent running into the next room
|
|
|
|
if (decodedKey.userId === userId) {
|
|
|
|
deviceIds.push(decodedKey.deviceId);
|
|
|
|
return false; // fetch more
|
|
|
|
}
|
|
|
|
return true; // done
|
|
|
|
});
|
|
|
|
return deviceIds;
|
|
|
|
}
|
|
|
|
|
2020-08-31 18:08:03 +05:30
|
|
|
get(userId, deviceId) {
|
|
|
|
return this._store.get(encodeKey(userId, deviceId));
|
|
|
|
}
|
|
|
|
|
|
|
|
set(deviceIdentity) {
|
|
|
|
deviceIdentity.key = encodeKey(deviceIdentity.userId, deviceIdentity.deviceId);
|
2020-09-08 22:00:45 +05:30
|
|
|
this._store.put(deviceIdentity);
|
2020-08-31 18:08:03 +05:30
|
|
|
}
|
2020-09-08 14:20:39 +05:30
|
|
|
|
|
|
|
getByCurve25519Key(curve25519Key) {
|
|
|
|
return this._store.index("byCurve25519Key").get(curve25519Key);
|
|
|
|
}
|
2020-09-14 19:14:47 +05:30
|
|
|
|
|
|
|
remove(userId, deviceId) {
|
|
|
|
this._store.delete(encodeKey(userId, deviceId));
|
|
|
|
}
|
2021-05-06 18:53:58 +05:30
|
|
|
|
|
|
|
removeAllForUser(userId) {
|
|
|
|
// exclude both keys as they are theoretical min and max,
|
|
|
|
// but we should't have a match for just the room id, or room id with max
|
2021-06-02 16:01:13 +05:30
|
|
|
const range = this._store.IDBKeyRange.bound(encodeKey(userId, MIN_UNICODE), encodeKey(userId, MAX_UNICODE), true, true);
|
2021-05-06 18:53:58 +05:30
|
|
|
this._store.delete(range);
|
|
|
|
}
|
2020-08-31 18:08:03 +05:30
|
|
|
}
|