mirror of
https://github.com/bitwarden/browser
synced 2025-12-19 01:33:33 +00:00
[PM-4360] Move auth owned code into auth (#6595)
This commit is contained in:
@@ -1,68 +0,0 @@
|
||||
import { Observable, defer, map } from "rxjs";
|
||||
|
||||
import { DevicesServiceAbstraction } from "../../abstractions/devices/devices.service.abstraction";
|
||||
import { DeviceResponse } from "../../abstractions/devices/responses/device.response";
|
||||
import { DeviceView } from "../../abstractions/devices/views/device.view";
|
||||
import { DevicesApiServiceAbstraction } from "../../auth/abstractions/devices-api.service.abstraction";
|
||||
import { ListResponse } from "../../models/response/list.response";
|
||||
|
||||
/**
|
||||
* @class DevicesServiceImplementation
|
||||
* @implements {DevicesServiceAbstraction}
|
||||
* @description Observable based data store service for Devices.
|
||||
* note: defer is used to convert the promises to observables and to ensure
|
||||
* that observables are created for each subscription
|
||||
* (i.e., promsise --> observables are cold until subscribed to)
|
||||
*/
|
||||
export class DevicesServiceImplementation implements DevicesServiceAbstraction {
|
||||
constructor(private devicesApiService: DevicesApiServiceAbstraction) {}
|
||||
|
||||
/**
|
||||
* @description Gets the list of all devices.
|
||||
*/
|
||||
getDevices$(): Observable<Array<DeviceView>> {
|
||||
return defer(() => this.devicesApiService.getDevices()).pipe(
|
||||
map((deviceResponses: ListResponse<DeviceResponse>) => {
|
||||
return deviceResponses.data.map((deviceResponse: DeviceResponse) => {
|
||||
return new DeviceView(deviceResponse);
|
||||
});
|
||||
})
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* @description Gets the device with the specified identifier.
|
||||
*/
|
||||
getDeviceByIdentifier$(deviceIdentifier: string): Observable<DeviceView> {
|
||||
return defer(() => this.devicesApiService.getDeviceByIdentifier(deviceIdentifier)).pipe(
|
||||
map((deviceResponse: DeviceResponse) => new DeviceView(deviceResponse))
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* @description Checks if a device is known for a user by user's email and device's identifier.
|
||||
*/
|
||||
isDeviceKnownForUser$(email: string, deviceIdentifier: string): Observable<boolean> {
|
||||
return defer(() => this.devicesApiService.getKnownDevice(email, deviceIdentifier));
|
||||
}
|
||||
|
||||
/**
|
||||
* @description Updates the keys for the specified device.
|
||||
*/
|
||||
|
||||
updateTrustedDeviceKeys$(
|
||||
deviceIdentifier: string,
|
||||
devicePublicKeyEncryptedUserKey: string,
|
||||
userKeyEncryptedDevicePublicKey: string,
|
||||
deviceKeyEncryptedDevicePrivateKey: string
|
||||
): Observable<DeviceView> {
|
||||
return defer(() =>
|
||||
this.devicesApiService.updateTrustedDeviceKeys(
|
||||
deviceIdentifier,
|
||||
devicePublicKeyEncryptedUserKey,
|
||||
userKeyEncryptedDevicePublicKey,
|
||||
deviceKeyEncryptedDevicePrivateKey
|
||||
)
|
||||
).pipe(map((deviceResponse: DeviceResponse) => new DeviceView(deviceResponse)));
|
||||
}
|
||||
}
|
||||
@@ -1,7 +0,0 @@
|
||||
export class TrustedDeviceKeysRequest {
|
||||
constructor(
|
||||
public encryptedUserKey: string,
|
||||
public encryptedPublicKey: string,
|
||||
public encryptedPrivateKey: string
|
||||
) {}
|
||||
}
|
||||
Reference in New Issue
Block a user