lbry-desktop/ui/util/saved-passwords.js

164 lines
4.2 KiB
JavaScript
Raw Normal View History

// @flow
2019-08-27 22:35:07 -04:00
import { ipcRenderer } from 'electron';
2019-08-20 08:29:59 -04:00
const AUTH_TOKEN = 'auth_token';
const SAVED_PASSWORD = 'saved_password';
const DEPRECATED_SAVED_PASSWORD = 'saved-password';
const domain = window.location.hostname;
const isProduction = process.env.NODE_ENV === 'production';
const maxExpiration = 2147483647;
2019-10-15 17:23:51 -04:00
let sessionPassword;
2020-01-16 17:03:41 -05:00
function setCookie(name: string, value: string, expirationDaysOnWeb: number) {
let expires = '';
2020-01-16 17:03:41 -05:00
if (expirationDaysOnWeb) {
let date = new Date();
2020-01-16 17:03:41 -05:00
date.setTime(date.getTime() + expirationDaysOnWeb * 24 * 60 * 60 * 1000);
// If on PC, set to not expire (max)
expires = `expires=${IS_WEB ? date.toUTCString() : maxExpiration};`;
}
let cookie = `${name}=${value || ''}; ${expires} path=/; SameSite=Lax;`;
if (isProduction) {
cookie += ` domain=${domain}; Secure;`;
}
document.cookie = cookie;
}
function getCookie(name: string) {
const nameEQ = name + '=';
const cookies = document.cookie.split(';');
for (var i = 0; i < cookies.length; i++) {
let cookie = cookies[i];
while (cookie.charAt(0) === ' ') {
cookie = cookie.substring(1, cookie.length);
}
if (cookie.indexOf(nameEQ) === 0) {
return cookie.substring(nameEQ.length, cookie.length);
}
}
return null;
}
function deleteCookie(name: string) {
document.cookie = name + `=; Max-Age=-99999999; domain=${domain}; path=/;`;
2019-11-22 10:32:25 -05:00
// Legacy
// Adding this here to delete any old cookies before we removed the "." in front of the domain
// Remove this if you see it after March 11th, 2021
// https://github.com/lbryio/lbry-desktop/pull/3830
document.cookie = name + `=; Max-Age=-99999999; domain=.${domain}; path=/;`;
}
export const setSavedPassword = (value?: string, saveToDisk: boolean) => {
return new Promise<*>(resolve => {
const password = value === undefined || value === null ? '' : value;
sessionPassword = password;
if (saveToDisk) {
if (password) {
setCookie(SAVED_PASSWORD, password, 14);
} else {
deleteSavedPassword();
}
}
});
2019-08-20 08:29:59 -04:00
};
2019-08-27 22:35:07 -04:00
export const getSavedPassword = () => {
return new Promise<*>(resolve => {
2019-10-15 17:23:51 -04:00
if (sessionPassword) {
resolve(sessionPassword);
}
return getKeychainPassword().then(p => resolve(p));
});
};
2019-10-15 17:23:51 -04:00
export const getKeychainPassword = () => {
return new Promise<*>(resolve => {
2020-01-16 17:03:41 -05:00
let password;
// @if TARGET='web'
// In the future, this will be the only code in this function
// Handling keytar stuff separately so we can easily rip it out later
password = getCookie(SAVED_PASSWORD);
2020-01-16 17:03:41 -05:00
resolve(password);
// @endif
// @if TARGET='app'
password = getCookie(SAVED_PASSWORD);
2020-01-16 17:03:41 -05:00
if (password) {
resolve(password);
2020-01-16 17:03:41 -05:00
} else {
// No password saved in a cookie, get it from the keychain, then delete the value in the keychain
ipcRenderer.once('get-password-response', (event, keychainPassword) => {
resolve(keychainPassword);
if (keychainPassword) {
setSavedPassword(keychainPassword, true);
ipcRenderer.send('delete-password');
}
});
2020-01-16 17:03:41 -05:00
ipcRenderer.send('get-password');
}
2019-10-15 00:20:12 -04:00
// @endif
});
};
export const deleteSavedPassword = () => {
return new Promise<*>(resolve => {
deleteCookie(SAVED_PASSWORD);
2019-10-22 13:57:32 -04:00
resolve();
});
2019-08-26 16:18:30 -04:00
};
2019-08-20 08:29:59 -04:00
export const getAuthToken = () => {
return getCookie(AUTH_TOKEN);
};
export const setAuthToken = (value: string) => {
return setCookie(AUTH_TOKEN, value, 365);
};
2019-09-26 12:07:11 -04:00
export const deleteAuthToken = () => {
return new Promise<*>(resolve => {
deleteCookie(AUTH_TOKEN);
resolve();
});
2019-08-27 22:35:07 -04:00
};
export const doSignOutCleanup = () => {
return new Promise<*>(resolve => {
deleteAuthToken();
deleteSavedPassword();
resolve();
2020-01-16 17:03:41 -05:00
// @if TARGET='app'
ipcRenderer.send('delete-auth-token');
ipcRenderer.send('delete-password');
// @endif;
});
};
2020-03-12 10:56:13 -04:00
export const doAuthTokenRefresh = () => {
const authToken = getAuthToken();
if (authToken) {
deleteAuthToken();
setAuthToken(authToken);
}
2020-03-12 10:56:13 -04:00
};
2020-03-12 10:56:13 -04:00
export const doDeprecatedPasswordMigrationMarch2020 = () => {
const savedPassword = getCookie(DEPRECATED_SAVED_PASSWORD);
if (savedPassword) {
deleteCookie(DEPRECATED_SAVED_PASSWORD);
setSavedPassword(savedPassword, true);
}
2019-08-27 15:11:56 -04:00
};