Skip to content

Commit

Permalink
refactor user settings
Browse files Browse the repository at this point in the history
  • Loading branch information
Sneezry committed Apr 14, 2024
1 parent 053d5c4 commit 3559fd4
Show file tree
Hide file tree
Showing 19 changed files with 513 additions and 431 deletions.
66 changes: 17 additions & 49 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@
"devDependencies": {
"@types/argon2-browser": "^1.18.1",
"@types/chai": "^4.2.14",
"@types/chrome": "^0.0.210",
"@types/chrome": "^0.0.266",
"@types/crypto-js": "^4.1.1",
"@types/mocha": "^10.0.6",
"@types/sinon": "^17.0.2",
Expand Down
45 changes: 18 additions & 27 deletions src/background.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,15 +8,13 @@ import { CodeState } from "./models/otp";

import { getOTPAuthPerLineFromOPTAuthMigration } from "./models/migration";
import { isChrome, isFirefox } from "./browser";
import { UserSettings, UserSettingsData } from "./models/settings";

let contentTab: chrome.tabs.Tab | undefined;
let LocalStorage: {
[key: string]: any;
};
let userSettings: UserSettingsData;

chrome.runtime.onMessage.addListener(async (message, sender) => {
LocalStorage =
(await chrome.storage.local.get("LocalStorage")).LocalStorage || {};
userSettings = await UserSettings.getAllItems();

if (message.action === "getCapture") {
if (!sender.tab) {
Expand Down Expand Up @@ -273,8 +271,8 @@ function getBackupToken(service: string) {
if (!value) {
return false;
}
LocalStorage.driveToken = value;
chrome.storage.local.set({ LocalStorage });
userSettings.driveToken = value;
UserSettings.setItems(userSettings);
chrome.runtime.sendMessage({ action: "drivetoken", value });
return true;
}
Expand Down Expand Up @@ -308,10 +306,7 @@ function getBackupToken(service: string) {
authUrl = `https://login.microsoftonline.com/common/oauth2/v2.0/authorize?client_id=${
getCredentials().onedrive.client_id
}&response_type=code&redirect_uri=${redirUrl}&scope=https%3A%2F%2Fgraph.microsoft.com%2FFiles.ReadWrite${
LocalStorage.oneDriveBusiness !== "true" &&
LocalStorage.oneDriveBusiness !== true
? ".AppFolder"
: ""
userSettings.oneDriveBusiness !== true ? ".AppFolder" : ""
}%20https%3A%2F%2Fgraph.microsoft.com%2FUser.Read%20offline_access&response_mode=query&prompt=consent`;
}
chrome.identity.launchWebAuthFlow(
Expand Down Expand Up @@ -345,8 +340,8 @@ function getBackupToken(service: string) {
const value = kvMatches[2];
if (key === "access_token") {
if (service === "dropbox") {
LocalStorage.dropboxToken = value;
chrome.storage.local.set({ LocalStorage });
userSettings.dropboxToken = value;
UserSettings.setItems(userSettings);
uploadBackup("dropbox");
return;
}
Expand Down Expand Up @@ -379,9 +374,9 @@ function getBackupToken(service: string) {
if (res.error) {
console.error(res.error_description);
} else {
LocalStorage.driveToken = res.access_token;
LocalStorage.driveRefreshToken = res.refresh_token;
chrome.storage.local.set({ LocalStorage });
userSettings.driveToken = res.access_token;
userSettings.driveRefreshToken = res.refresh_token;
UserSettings.setItems(userSettings);
success = true;
}
} catch (error) {
Expand Down Expand Up @@ -412,9 +407,9 @@ function getBackupToken(service: string) {
if (res.error) {
console.error(res.error_description);
} else {
LocalStorage.oneDriveToken = res.access_token;
LocalStorage.oneDriveRefreshToken = res.refresh_token;
chrome.storage.local.set({ LocalStorage });
userSettings.oneDriveToken = res.access_token;
userSettings.oneDriveRefreshToken = res.refresh_token;
UserSettings.setItems(userSettings);
success = true;
}
} catch (error) {
Expand Down Expand Up @@ -558,27 +553,23 @@ async function setAutolock() {
return;
}

if (Number(LocalStorage.autolock) > 0) {
if (Number(userSettings.autolock) > 0) {
chrome.alarms.create("autolock", {
delayInMinutes: Number(LocalStorage.autolock),
delayInMinutes: Number(userSettings.autolock),
});
}
}

async function updateContextMenu() {
LocalStorage =
(await chrome.storage.local.get("LocalStorage")).LocalStorage || {};
userSettings = await UserSettings.getAllItems();

chrome.permissions.contains(
{
permissions: ["contextMenus"],
},
(result) => {
if (result) {
if (
LocalStorage.enableContextMenu === "true" ||
LocalStorage.enableContextMenu === true
) {
if (userSettings.enableContextMenu === true) {
chrome.contextMenus.removeAll();
chrome.contextMenus.create({
id: "otpContextMenu",
Expand Down
32 changes: 14 additions & 18 deletions src/components/Popup/DrivePage.vue
Original file line number Diff line number Diff line change
Expand Up @@ -36,19 +36,20 @@
import Vue from "vue";
import { isChrome } from "../../browser";
import { Drive } from "../../models/backup";
import { UserSettings, UserSettingsData } from "../../models/settings";
const service = "drive";
export default Vue.extend({
data: function () {
return {
email: this.i18n.loading,
LocalStorage: {} as { [key: string]: any },
userSettings: {} as UserSettingsData,
};
},
created() {
chrome.storage.local.get("LocalStorage").then((res) => {
this.LocalStorage = res.LocalStorage || {};
UserSettings.getAllItems().then((res) => {
this.userSettings = res;
});
},
computed: {
Expand All @@ -57,17 +58,17 @@ export default Vue.extend({
},
isEncrypted: {
get(): boolean {
if (this.LocalStorage[`${service}Encrypted`] === null) {
if (this.userSettings[`${service}Encrypted`] === null) {
this.$store.commit("backup/setEnc", { service, value: true });
this.LocalStorage[`${service}Encrypted`] = true;
chrome.storage.local.set({ LocalStorage: this.LocalStorage });
this.userSettings[`${service}Encrypted`] = true;
UserSettings.setItems(this.userSettings);
return true;
}
return this.$store.state.backup.driveEncrypted;
},
set(newValue: string) {
this.LocalStorage.driveEncrypted = newValue;
chrome.storage.local.set({ LocalStorage: this.LocalStorage });
this.userSettings.driveEncrypted = newValue === "true";
UserSettings.setItems(this.userSettings);
this.$store.commit("backup/setEnc", { service, value: newValue });
},
},
Expand All @@ -85,13 +86,13 @@ export default Vue.extend({
xhr.open(
"POST",
"https://accounts.google.com/o/oauth2/revoke?token=" +
this.LocalStorage.driveToken
this.userSettings.driveToken
);
xhr.onreadystatechange = () => {
if (xhr.readyState === 4) {
if (isChrome) {
chrome.identity.removeCachedAuthToken(
{ token: this.LocalStorage.driveToken },
{ token: this.userSettings.driveToken as string },
() => {
resolve(true);
}
Expand All @@ -104,8 +105,7 @@ export default Vue.extend({
};
xhr.send();
});
this.LocalStorage.driveToken = undefined;
chrome.storage.local.set({ LocalStorage: this.LocalStorage });
UserSettings.removeItem("driveToken");
this.$store.commit("backup/setToken", { service, value: false });
this.$store.commit("style/hideInfo");
},
Expand All @@ -116,16 +116,12 @@ export default Vue.extend({
);
if (response === true) {
this.$store.commit("notification/alert", this.i18n.updateSuccess);
} else if (
this.LocalStorage.driveRevoked === "true" ||
this.LocalStorage.driveRevoked === true
) {
} else if (this.userSettings.driveRevoked === true) {
this.$store.commit(
"notification/alert",
chrome.i18n.getMessage("token_revoked", ["Google Drive"])
);
this.LocalStorage.driveRevoked = undefined;
chrome.storage.local.set({ LocalStorage: this.LocalStorage });
UserSettings.removeItem("driveRevoked");
this.$store.commit("backup/setToken", { service, value: false });
} else {
this.$store.commit("notification/alert", this.i18n.updateFailure);
Expand Down
Loading

0 comments on commit 3559fd4

Please sign in to comment.