mirror of
https://github.com/bitwarden/browser.git
synced 2025-01-05 18:47:52 +01:00
[Auto-Logout] Refactor LockService and Update Dependencies (#91)
* initial commit for lockService name refactor * Reverted ConstantsService vault timeout key to legacy string value Co-authored-by: Vincent Salucci <vsalucci@bitwarden.com>
This commit is contained in:
parent
31a257407b
commit
64c54cfb86
@ -8,7 +8,6 @@ export { CryptoService } from './crypto.service';
|
|||||||
export { EnvironmentService } from './environment.service';
|
export { EnvironmentService } from './environment.service';
|
||||||
export { FolderService } from './folder.service';
|
export { FolderService } from './folder.service';
|
||||||
export { I18nService } from './i18n.service';
|
export { I18nService } from './i18n.service';
|
||||||
export { LockService } from './lock.service';
|
|
||||||
export { LogService } from './log.service';
|
export { LogService } from './log.service';
|
||||||
export { MessagingService } from './messaging.service';
|
export { MessagingService } from './messaging.service';
|
||||||
export { PasswordGenerationService } from './passwordGeneration.service';
|
export { PasswordGenerationService } from './passwordGeneration.service';
|
||||||
@ -21,3 +20,4 @@ export { SyncService } from './sync.service';
|
|||||||
export { TokenService } from './token.service';
|
export { TokenService } from './token.service';
|
||||||
export { TotpService } from './totp.service';
|
export { TotpService } from './totp.service';
|
||||||
export { UserService } from './user.service';
|
export { UserService } from './user.service';
|
||||||
|
export { VaultTimeoutService } from './vaultTimeout.service';
|
||||||
|
@ -14,6 +14,9 @@ export abstract class PlatformUtilsService {
|
|||||||
isMacAppStore: () => boolean;
|
isMacAppStore: () => boolean;
|
||||||
analyticsId: () => string;
|
analyticsId: () => string;
|
||||||
isViewOpen: () => Promise<boolean>;
|
isViewOpen: () => Promise<boolean>;
|
||||||
|
/**
|
||||||
|
* @deprecated This only ever returns null. Pull from your platform's storage using ConstantsService.vaultTimeoutKey
|
||||||
|
*/
|
||||||
lockTimeout: () => number;
|
lockTimeout: () => number;
|
||||||
launchUri: (uri: string, options?: any) => void;
|
launchUri: (uri: string, options?: any) => void;
|
||||||
saveFile: (win: Window, blobData: any, blobOptions: any, fileName: string) => void;
|
saveFile: (win: Window, blobData: any, blobOptions: any, fileName: string) => void;
|
||||||
|
@ -1,11 +1,12 @@
|
|||||||
import { CipherString } from '../models/domain/cipherString';
|
import { CipherString } from '../models/domain/cipherString';
|
||||||
|
|
||||||
export abstract class LockService {
|
export abstract class VaultTimeoutService {
|
||||||
pinProtectedKey: CipherString;
|
pinProtectedKey: CipherString;
|
||||||
isLocked: () => Promise<boolean>;
|
isLocked: () => Promise<boolean>;
|
||||||
checkLock: () => Promise<void>;
|
checkVaultTimeout: () => Promise<void>;
|
||||||
lock: (allowSoftLock?: boolean) => Promise<void>;
|
lock: (allowSoftLock?: boolean) => Promise<void>;
|
||||||
setLockOption: (lockOption: number) => Promise<void>;
|
logout: () => Promise<void>;
|
||||||
|
setVaultTimeoutOptions: (vaultTimeout: number, vaultTimeoutAction: string) => Promise<void>;
|
||||||
isPinLockSet: () => Promise<[boolean, boolean]>;
|
isPinLockSet: () => Promise<[boolean, boolean]>;
|
||||||
clear: () => Promise<any>;
|
clear: () => Promise<any>;
|
||||||
}
|
}
|
@ -4,12 +4,12 @@ import { Router } from '@angular/router';
|
|||||||
import { CryptoService } from '../../abstractions/crypto.service';
|
import { CryptoService } from '../../abstractions/crypto.service';
|
||||||
import { EnvironmentService } from '../../abstractions/environment.service';
|
import { EnvironmentService } from '../../abstractions/environment.service';
|
||||||
import { I18nService } from '../../abstractions/i18n.service';
|
import { I18nService } from '../../abstractions/i18n.service';
|
||||||
import { LockService } from '../../abstractions/lock.service';
|
|
||||||
import { MessagingService } from '../../abstractions/messaging.service';
|
import { MessagingService } from '../../abstractions/messaging.service';
|
||||||
import { PlatformUtilsService } from '../../abstractions/platformUtils.service';
|
import { PlatformUtilsService } from '../../abstractions/platformUtils.service';
|
||||||
import { StateService } from '../../abstractions/state.service';
|
import { StateService } from '../../abstractions/state.service';
|
||||||
import { StorageService } from '../../abstractions/storage.service';
|
import { StorageService } from '../../abstractions/storage.service';
|
||||||
import { UserService } from '../../abstractions/user.service';
|
import { UserService } from '../../abstractions/user.service';
|
||||||
|
import { VaultTimeoutService } from '../../abstractions/vaultTimeout.service';
|
||||||
|
|
||||||
import { ConstantsService } from '../../services/constants.service';
|
import { ConstantsService } from '../../services/constants.service';
|
||||||
|
|
||||||
@ -35,12 +35,12 @@ export class LockComponent implements OnInit {
|
|||||||
constructor(protected router: Router, protected i18nService: I18nService,
|
constructor(protected router: Router, protected i18nService: I18nService,
|
||||||
protected platformUtilsService: PlatformUtilsService, protected messagingService: MessagingService,
|
protected platformUtilsService: PlatformUtilsService, protected messagingService: MessagingService,
|
||||||
protected userService: UserService, protected cryptoService: CryptoService,
|
protected userService: UserService, protected cryptoService: CryptoService,
|
||||||
protected storageService: StorageService, protected lockService: LockService,
|
protected storageService: StorageService, protected vaultTimeoutService: VaultTimeoutService,
|
||||||
protected environmentService: EnvironmentService, protected stateService: StateService) { }
|
protected environmentService: EnvironmentService, protected stateService: StateService) { }
|
||||||
|
|
||||||
async ngOnInit() {
|
async ngOnInit() {
|
||||||
this.pinSet = await this.lockService.isPinLockSet();
|
this.pinSet = await this.vaultTimeoutService.isPinLockSet();
|
||||||
this.pinLock = (this.pinSet[0] && this.lockService.pinProtectedKey != null) || this.pinSet[1];
|
this.pinLock = (this.pinSet[0] && this.vaultTimeoutService.pinProtectedKey != null) || this.pinSet[1];
|
||||||
this.email = await this.userService.getEmail();
|
this.email = await this.userService.getEmail();
|
||||||
let vaultUrl = this.environmentService.getWebVaultUrl();
|
let vaultUrl = this.environmentService.getWebVaultUrl();
|
||||||
if (vaultUrl == null) {
|
if (vaultUrl == null) {
|
||||||
@ -69,7 +69,7 @@ export class LockComponent implements OnInit {
|
|||||||
try {
|
try {
|
||||||
if (this.pinSet[0]) {
|
if (this.pinSet[0]) {
|
||||||
const key = await this.cryptoService.makeKeyFromPin(this.pin, this.email, kdf, kdfIterations,
|
const key = await this.cryptoService.makeKeyFromPin(this.pin, this.email, kdf, kdfIterations,
|
||||||
this.lockService.pinProtectedKey);
|
this.vaultTimeoutService.pinProtectedKey);
|
||||||
const encKey = await this.cryptoService.getEncKey(key);
|
const encKey = await this.cryptoService.getEncKey(key);
|
||||||
const protectedPin = await this.storageService.get<string>(ConstantsService.protectedPin);
|
const protectedPin = await this.storageService.get<string>(ConstantsService.protectedPin);
|
||||||
const decPin = await this.cryptoService.decryptToUtf8(new CipherString(protectedPin), encKey);
|
const decPin = await this.cryptoService.decryptToUtf8(new CipherString(protectedPin), encKey);
|
||||||
@ -106,7 +106,7 @@ export class LockComponent implements OnInit {
|
|||||||
const encKey = await this.cryptoService.getEncKey(key);
|
const encKey = await this.cryptoService.getEncKey(key);
|
||||||
const decPin = await this.cryptoService.decryptToUtf8(new CipherString(protectedPin), encKey);
|
const decPin = await this.cryptoService.decryptToUtf8(new CipherString(protectedPin), encKey);
|
||||||
const pinKey = await this.cryptoService.makePinKey(decPin, this.email, kdf, kdfIterations);
|
const pinKey = await this.cryptoService.makePinKey(decPin, this.email, kdf, kdfIterations);
|
||||||
this.lockService.pinProtectedKey = await this.cryptoService.encrypt(key.key, pinKey);
|
this.vaultTimeoutService.pinProtectedKey = await this.cryptoService.encrypt(key.key, pinKey);
|
||||||
}
|
}
|
||||||
this.setKeyAndContinue(key);
|
this.setKeyAndContinue(key);
|
||||||
} else {
|
} else {
|
||||||
|
@ -6,14 +6,14 @@ import {
|
|||||||
RouterStateSnapshot,
|
RouterStateSnapshot,
|
||||||
} from '@angular/router';
|
} from '@angular/router';
|
||||||
|
|
||||||
import { LockService } from '../../abstractions/lock.service';
|
|
||||||
import { MessagingService } from '../../abstractions/messaging.service';
|
import { MessagingService } from '../../abstractions/messaging.service';
|
||||||
import { UserService } from '../../abstractions/user.service';
|
import { UserService } from '../../abstractions/user.service';
|
||||||
|
import { VaultTimeoutService } from '../../abstractions/vaultTimeout.service';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class AuthGuardService implements CanActivate {
|
export class AuthGuardService implements CanActivate {
|
||||||
constructor(private lockService: LockService, private userService: UserService, private router: Router,
|
constructor(private vaultTimeoutService: VaultTimeoutService, private userService: UserService,
|
||||||
private messagingService: MessagingService) { }
|
private router: Router, private messagingService: MessagingService) { }
|
||||||
|
|
||||||
async canActivate(route: ActivatedRouteSnapshot, routerState: RouterStateSnapshot) {
|
async canActivate(route: ActivatedRouteSnapshot, routerState: RouterStateSnapshot) {
|
||||||
const isAuthed = await this.userService.isAuthenticated();
|
const isAuthed = await this.userService.isAuthenticated();
|
||||||
@ -22,7 +22,7 @@ export class AuthGuardService implements CanActivate {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
const locked = await this.lockService.isLocked();
|
const locked = await this.vaultTimeoutService.isLocked();
|
||||||
if (locked) {
|
if (locked) {
|
||||||
if (routerState != null) {
|
if (routerState != null) {
|
||||||
this.messagingService.send('lockedUrl', { url: routerState.url });
|
this.messagingService.send('lockedUrl', { url: routerState.url });
|
||||||
|
@ -7,7 +7,8 @@ export class ConstantsService {
|
|||||||
static readonly disableFaviconKey: string = 'disableFavicon';
|
static readonly disableFaviconKey: string = 'disableFavicon';
|
||||||
static readonly disableAutoTotpCopyKey: string = 'disableAutoTotpCopy';
|
static readonly disableAutoTotpCopyKey: string = 'disableAutoTotpCopy';
|
||||||
static readonly enableAutoFillOnPageLoadKey: string = 'enableAutoFillOnPageLoad';
|
static readonly enableAutoFillOnPageLoadKey: string = 'enableAutoFillOnPageLoad';
|
||||||
static readonly lockOptionKey: string = 'lockOption';
|
static readonly vaultTimeoutKey: string = 'lockOption';
|
||||||
|
static readonly vaultTimeoutActionKey: string = 'vaultTimeoutAction';
|
||||||
static readonly lastActiveKey: string = 'lastActive';
|
static readonly lastActiveKey: string = 'lastActive';
|
||||||
static readonly neverDomainsKey: string = 'neverDomains';
|
static readonly neverDomainsKey: string = 'neverDomains';
|
||||||
static readonly installedVersionKey: string = 'installedVersion';
|
static readonly installedVersionKey: string = 'installedVersion';
|
||||||
@ -30,7 +31,8 @@ export class ConstantsService {
|
|||||||
readonly disableFaviconKey: string = ConstantsService.disableFaviconKey;
|
readonly disableFaviconKey: string = ConstantsService.disableFaviconKey;
|
||||||
readonly disableAutoTotpCopyKey: string = ConstantsService.disableAutoTotpCopyKey;
|
readonly disableAutoTotpCopyKey: string = ConstantsService.disableAutoTotpCopyKey;
|
||||||
readonly enableAutoFillOnPageLoadKey: string = ConstantsService.enableAutoFillOnPageLoadKey;
|
readonly enableAutoFillOnPageLoadKey: string = ConstantsService.enableAutoFillOnPageLoadKey;
|
||||||
readonly lockOptionKey: string = ConstantsService.lockOptionKey;
|
readonly vaultTimeoutKey: string = ConstantsService.vaultTimeoutKey;
|
||||||
|
readonly vaultTimeoutActionKey: string = ConstantsService.vaultTimeoutActionKey;
|
||||||
readonly lastActiveKey: string = ConstantsService.lastActiveKey;
|
readonly lastActiveKey: string = ConstantsService.lastActiveKey;
|
||||||
readonly neverDomainsKey: string = ConstantsService.neverDomainsKey;
|
readonly neverDomainsKey: string = ConstantsService.neverDomainsKey;
|
||||||
readonly installedVersionKey: string = ConstantsService.installedVersionKey;
|
readonly installedVersionKey: string = ConstantsService.installedVersionKey;
|
||||||
|
@ -19,10 +19,10 @@ import { Utils } from '../misc/utils';
|
|||||||
import { EEFLongWordList } from '../misc/wordlist';
|
import { EEFLongWordList } from '../misc/wordlist';
|
||||||
|
|
||||||
const Keys = {
|
const Keys = {
|
||||||
key: 'key',
|
key: 'key', // Master Key
|
||||||
encOrgKeys: 'encOrgKeys',
|
encOrgKeys: 'encOrgKeys',
|
||||||
encPrivateKey: 'encPrivateKey',
|
encPrivateKey: 'encPrivateKey',
|
||||||
encKey: 'encKey',
|
encKey: 'encKey', // Generated Symmetric Key
|
||||||
keyHash: 'keyHash',
|
keyHash: 'keyHash',
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -41,7 +41,7 @@ export class CryptoService implements CryptoServiceAbstraction {
|
|||||||
async setKey(key: SymmetricCryptoKey): Promise<any> {
|
async setKey(key: SymmetricCryptoKey): Promise<any> {
|
||||||
this.key = key;
|
this.key = key;
|
||||||
|
|
||||||
const option = await this.storageService.get<number>(ConstantsService.lockOptionKey);
|
const option = await this.storageService.get<number>(ConstantsService.vaultTimeoutKey);
|
||||||
if (option != null) {
|
if (option != null) {
|
||||||
// if we have a lock option set, we do not store the key
|
// if we have a lock option set, we do not store the key
|
||||||
return;
|
return;
|
||||||
@ -290,7 +290,7 @@ export class CryptoService implements CryptoServiceAbstraction {
|
|||||||
|
|
||||||
async toggleKey(): Promise<any> {
|
async toggleKey(): Promise<any> {
|
||||||
const key = await this.getKey();
|
const key = await this.getKey();
|
||||||
const option = await this.storageService.get(ConstantsService.lockOptionKey);
|
const option = await this.storageService.get(ConstantsService.vaultTimeoutKey);
|
||||||
if (option != null || option === 0) {
|
if (option != null || option === 0) {
|
||||||
// if we have a lock option set, clear the key
|
// if we have a lock option set, clear the key
|
||||||
await this.clearKey();
|
await this.clearKey();
|
||||||
|
@ -10,7 +10,6 @@ export { CryptoService } from './crypto.service';
|
|||||||
export { EnvironmentService } from './environment.service';
|
export { EnvironmentService } from './environment.service';
|
||||||
export { FolderService } from './folder.service';
|
export { FolderService } from './folder.service';
|
||||||
export { I18nService } from './i18n.service';
|
export { I18nService } from './i18n.service';
|
||||||
export { LockService } from './lock.service';
|
|
||||||
export { PasswordGenerationService } from './passwordGeneration.service';
|
export { PasswordGenerationService } from './passwordGeneration.service';
|
||||||
export { SettingsService } from './settings.service';
|
export { SettingsService } from './settings.service';
|
||||||
export { StateService } from './state.service';
|
export { StateService } from './state.service';
|
||||||
@ -18,3 +17,4 @@ export { SyncService } from './sync.service';
|
|||||||
export { TokenService } from './token.service';
|
export { TokenService } from './token.service';
|
||||||
export { TotpService } from './totp.service';
|
export { TotpService } from './totp.service';
|
||||||
export { UserService } from './user.service';
|
export { UserService } from './user.service';
|
||||||
|
export { VaultTimeoutService } from './vaultTimeout.service';
|
||||||
|
@ -6,10 +6,10 @@ import { NotificationType } from '../enums/notificationType';
|
|||||||
import { ApiService } from '../abstractions/api.service';
|
import { ApiService } from '../abstractions/api.service';
|
||||||
import { AppIdService } from '../abstractions/appId.service';
|
import { AppIdService } from '../abstractions/appId.service';
|
||||||
import { EnvironmentService } from '../abstractions/environment.service';
|
import { EnvironmentService } from '../abstractions/environment.service';
|
||||||
import { LockService } from '../abstractions/lock.service';
|
|
||||||
import { NotificationsService as NotificationsServiceAbstraction } from '../abstractions/notifications.service';
|
import { NotificationsService as NotificationsServiceAbstraction } from '../abstractions/notifications.service';
|
||||||
import { SyncService } from '../abstractions/sync.service';
|
import { SyncService } from '../abstractions/sync.service';
|
||||||
import { UserService } from '../abstractions/user.service';
|
import { UserService } from '../abstractions/user.service';
|
||||||
|
import { VaultTimeoutService } from '../abstractions/vaultTimeout.service';
|
||||||
|
|
||||||
import {
|
import {
|
||||||
NotificationResponse,
|
NotificationResponse,
|
||||||
@ -27,7 +27,7 @@ export class NotificationsService implements NotificationsServiceAbstraction {
|
|||||||
|
|
||||||
constructor(private userService: UserService, private syncService: SyncService,
|
constructor(private userService: UserService, private syncService: SyncService,
|
||||||
private appIdService: AppIdService, private apiService: ApiService,
|
private appIdService: AppIdService, private apiService: ApiService,
|
||||||
private lockService: LockService, private logoutCallback: () => Promise<void>) { }
|
private vaultTimeoutService: VaultTimeoutService, private logoutCallback: () => Promise<void>) { }
|
||||||
|
|
||||||
async init(environmentService: EnvironmentService): Promise<void> {
|
async init(environmentService: EnvironmentService): Promise<void> {
|
||||||
this.inited = false;
|
this.inited = false;
|
||||||
@ -190,7 +190,7 @@ export class NotificationsService implements NotificationsServiceAbstraction {
|
|||||||
|
|
||||||
private async isAuthedAndUnlocked() {
|
private async isAuthedAndUnlocked() {
|
||||||
if (await this.userService.isAuthenticated()) {
|
if (await this.userService.isAuthenticated()) {
|
||||||
const locked = await this.lockService.isLocked();
|
const locked = await this.vaultTimeoutService.isLocked();
|
||||||
return !locked;
|
return !locked;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
|
@ -1,8 +1,8 @@
|
|||||||
import { LockService } from '../abstractions/lock.service';
|
|
||||||
import { MessagingService } from '../abstractions/messaging.service';
|
import { MessagingService } from '../abstractions/messaging.service';
|
||||||
import { PlatformUtilsService } from '../abstractions/platformUtils.service';
|
import { PlatformUtilsService } from '../abstractions/platformUtils.service';
|
||||||
import { StorageService } from '../abstractions/storage.service';
|
import { StorageService } from '../abstractions/storage.service';
|
||||||
import { SystemService as SystemServiceAbstraction } from '../abstractions/system.service';
|
import { SystemService as SystemServiceAbstraction } from '../abstractions/system.service';
|
||||||
|
import { VaultTimeoutService } from '../abstractions/vaultTimeout.service';
|
||||||
|
|
||||||
import { ConstantsService } from './constants.service';
|
import { ConstantsService } from './constants.service';
|
||||||
|
|
||||||
@ -13,13 +13,13 @@ export class SystemService implements SystemServiceAbstraction {
|
|||||||
private clearClipboardTimeout: any = null;
|
private clearClipboardTimeout: any = null;
|
||||||
private clearClipboardTimeoutFunction: () => Promise<any> = null;
|
private clearClipboardTimeoutFunction: () => Promise<any> = null;
|
||||||
|
|
||||||
constructor(private storageService: StorageService, private lockService: LockService,
|
constructor(private storageService: StorageService, private vaultTimeoutService: VaultTimeoutService,
|
||||||
private messagingService: MessagingService, private platformUtilsService: PlatformUtilsService,
|
private messagingService: MessagingService, private platformUtilsService: PlatformUtilsService,
|
||||||
private reloadCallback: () => Promise<void> = null) {
|
private reloadCallback: () => Promise<void> = null) {
|
||||||
}
|
}
|
||||||
|
|
||||||
startProcessReload(): void {
|
startProcessReload(): void {
|
||||||
if (this.lockService.pinProtectedKey != null || this.reloadInterval != null) {
|
if (this.vaultTimeoutService.pinProtectedKey != null || this.reloadInterval != null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
this.cancelProcessReload();
|
this.cancelProcessReload();
|
||||||
|
@ -4,16 +4,16 @@ import { CipherService } from '../abstractions/cipher.service';
|
|||||||
import { CollectionService } from '../abstractions/collection.service';
|
import { CollectionService } from '../abstractions/collection.service';
|
||||||
import { CryptoService } from '../abstractions/crypto.service';
|
import { CryptoService } from '../abstractions/crypto.service';
|
||||||
import { FolderService } from '../abstractions/folder.service';
|
import { FolderService } from '../abstractions/folder.service';
|
||||||
import { LockService as LockServiceAbstraction } from '../abstractions/lock.service';
|
|
||||||
import { MessagingService } from '../abstractions/messaging.service';
|
import { MessagingService } from '../abstractions/messaging.service';
|
||||||
import { PlatformUtilsService } from '../abstractions/platformUtils.service';
|
import { PlatformUtilsService } from '../abstractions/platformUtils.service';
|
||||||
import { SearchService } from '../abstractions/search.service';
|
import { SearchService } from '../abstractions/search.service';
|
||||||
import { StorageService } from '../abstractions/storage.service';
|
import { StorageService } from '../abstractions/storage.service';
|
||||||
import { UserService } from '../abstractions/user.service';
|
import { UserService } from '../abstractions/user.service';
|
||||||
|
import { VaultTimeoutService as VaultTimeoutServiceAbstraction } from '../abstractions/vaultTimeout.service';
|
||||||
|
|
||||||
import { CipherString } from '../models/domain/cipherString';
|
import { CipherString } from '../models/domain/cipherString';
|
||||||
|
|
||||||
export class LockService implements LockServiceAbstraction {
|
export class VaultTimeoutService implements VaultTimeoutServiceAbstraction {
|
||||||
pinProtectedKey: CipherString = null;
|
pinProtectedKey: CipherString = null;
|
||||||
|
|
||||||
private inited = false;
|
private inited = false;
|
||||||
@ -32,8 +32,8 @@ export class LockService implements LockServiceAbstraction {
|
|||||||
|
|
||||||
this.inited = true;
|
this.inited = true;
|
||||||
if (checkOnInterval) {
|
if (checkOnInterval) {
|
||||||
this.checkLock();
|
this.checkVaultTimeout();
|
||||||
setInterval(() => this.checkLock(), 10 * 1000); // check every 10 seconds
|
setInterval(() => this.checkVaultTimeout(), 10 * 1000); // check every 10 seconds
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -42,12 +42,13 @@ export class LockService implements LockServiceAbstraction {
|
|||||||
return !hasKey;
|
return !hasKey;
|
||||||
}
|
}
|
||||||
|
|
||||||
async checkLock(): Promise<void> {
|
async checkVaultTimeout(): Promise<void> {
|
||||||
if (await this.platformUtilsService.isViewOpen()) {
|
if (await this.platformUtilsService.isViewOpen()) {
|
||||||
// Do not lock
|
// Do not lock
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// "is logged out check" - similar to isLocked, below
|
||||||
const authed = await this.userService.isAuthenticated();
|
const authed = await this.userService.isAuthenticated();
|
||||||
if (!authed) {
|
if (!authed) {
|
||||||
return;
|
return;
|
||||||
@ -59,7 +60,7 @@ export class LockService implements LockServiceAbstraction {
|
|||||||
|
|
||||||
let lockOption = this.platformUtilsService.lockTimeout();
|
let lockOption = this.platformUtilsService.lockTimeout();
|
||||||
if (lockOption == null) {
|
if (lockOption == null) {
|
||||||
lockOption = await this.storageService.get<number>(ConstantsService.lockOptionKey);
|
lockOption = await this.storageService.get<number>(ConstantsService.vaultTimeoutKey);
|
||||||
}
|
}
|
||||||
if (lockOption == null || lockOption < 0) {
|
if (lockOption == null || lockOption < 0) {
|
||||||
return;
|
return;
|
||||||
@ -70,6 +71,7 @@ export class LockService implements LockServiceAbstraction {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO update with vault timeout name and pivot based on action saved
|
||||||
const lockOptionSeconds = lockOption * 60;
|
const lockOptionSeconds = lockOption * 60;
|
||||||
const diffSeconds = ((new Date()).getTime() - lastActive) / 1000;
|
const diffSeconds = ((new Date()).getTime() - lastActive) / 1000;
|
||||||
if (diffSeconds >= lockOptionSeconds) {
|
if (diffSeconds >= lockOptionSeconds) {
|
||||||
@ -101,8 +103,13 @@ export class LockService implements LockServiceAbstraction {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async setLockOption(lockOption: number): Promise<void> {
|
async logout(): Promise<void> {
|
||||||
await this.storageService.save(ConstantsService.lockOptionKey, lockOption);
|
// TODO Add logic for loggedOutCallback
|
||||||
|
}
|
||||||
|
|
||||||
|
async setVaultTimeoutOptions(vaultTimeout: number, vaultTimeoutAction: string): Promise<void> {
|
||||||
|
await this.storageService.save(ConstantsService.vaultTimeoutKey, vaultTimeout);
|
||||||
|
// TODO Add logic for vaultTimeoutAction
|
||||||
await this.cryptoService.toggleKey();
|
await this.cryptoService.toggleKey();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user