diff options
author | Sebastian <sebasjm@gmail.com> | 2022-09-12 14:28:53 -0300 |
---|---|---|
committer | Sebastian <sebasjm@gmail.com> | 2022-09-12 14:28:53 -0300 |
commit | ad63d4c0e1ab249362e1f684ac9dbe5fae2ef34e (patch) | |
tree | dfc38c13a23e45f4916071c76e26049a57ebd63b /packages/taler-wallet-webextension/src/platform/chrome.ts | |
parent | 27201416c7d234361507e6055ce7ed42c11c650e (diff) | |
download | wallet-core-ad63d4c0e1ab249362e1f684ac9dbe5fae2ef34e.tar.xz |
add clipboard perms
Diffstat (limited to 'packages/taler-wallet-webextension/src/platform/chrome.ts')
-rw-r--r-- | packages/taler-wallet-webextension/src/platform/chrome.ts | 59 |
1 files changed, 54 insertions, 5 deletions
diff --git a/packages/taler-wallet-webextension/src/platform/chrome.ts b/packages/taler-wallet-webextension/src/platform/chrome.ts index 7311354c9..75900882f 100644 --- a/packages/taler-wallet-webextension/src/platform/chrome.ts +++ b/packages/taler-wallet-webextension/src/platform/chrome.ts @@ -77,6 +77,18 @@ const hostPermissions = { origins: ["http://*/*", "https://*/*"], }; +export function containsClipboardPermissions(): Promise<boolean> { + return new Promise((res, rej) => { + chrome.permissions.contains({ permissions: ["clipboardRead"] }, (resp) => { + const le = chrome.runtime.lastError?.message; + if (le) { + rej(le); + } + res(resp); + }); + }); +} + export function containsHostPermissions(): Promise<boolean> { return new Promise((res, rej) => { chrome.permissions.contains(hostPermissions, (resp) => { @@ -89,6 +101,18 @@ export function containsHostPermissions(): Promise<boolean> { }); } +export async function requestClipboardPermissions(): Promise<boolean> { + return new Promise((res, rej) => { + chrome.permissions.request({ permissions: ["clipboardRead"] }, (resp) => { + const le = chrome.runtime.lastError?.message; + if (le) { + rej(le); + } + res(resp); + }) + }); +} + export async function requestHostPermissions(): Promise<boolean> { return new Promise((res, rej) => { chrome.permissions.request(hostPermissions, (resp) => { @@ -155,6 +179,18 @@ export async function removeHostPermissions(): Promise<boolean> { }); } +export function removeClipboardPermissions(): Promise<boolean> { + return new Promise((res, rej) => { + chrome.permissions.remove({ permissions: ["clipboardRead"] }, (resp) => { + const le = chrome.runtime.lastError?.message; + if (le) { + rej(le); + } + res(resp); + }); + }); +} + function addPermissionsListener( callback: (p: Permissions, lastError?: string) => void, ): void { @@ -170,6 +206,9 @@ function getPermissionsApi(): CrossBrowserPermissionsApi { containsHostPermissions, requestHostPermissions, removeHostPermissions, + requestClipboardPermissions, + removeClipboardPermissions, + containsClipboardPermissions, }; } @@ -382,11 +421,9 @@ function registerTalerHeaderListener( } async function tabListener(tabId: number, info: chrome.tabs.TabChangeInfo): Promise<void> { - console.log("tab update", tabId, info) if (tabId < 0) return; if (info.status !== "complete") return; const uri = await findTalerUriInTab(tabId); - console.log("uri", uri) if (!uri) return; logger.info(`Found a Taler URI in the tab ${tabId}`) callback(tabId, uri) @@ -585,7 +622,6 @@ async function registerIconChangeOnTalerContent(): Promise<void> { chrome.tabs.onUpdated.addListener( async (tabId, info: chrome.tabs.TabChangeInfo) => { if (tabId < 0) return; - logger.info("tab updated", tabId, info); if (info.status !== "complete") return; const uri = await findTalerUriInTab(tabId); if (uri) { @@ -690,9 +726,22 @@ async function findTalerUriInTab(tabId: number): Promise<string | undefined> { } } +async function timeout(ms: number): Promise<void> { + return new Promise(resolve => setTimeout(resolve, ms)); +} async function findTalerUriInClipboard(): Promise<string | undefined> { - const textInClipboard = await window.navigator.clipboard.readText(); - return textInClipboard.startsWith("taler://") || textInClipboard.startsWith("taler+http://") ? textInClipboard : undefined + try { + //It looks like clipboard promise does not return, so we need a timeout + const textInClipboard = await Promise.any([ + timeout(100), + window.navigator.clipboard.readText() + ]) + if (!textInClipboard) return; + return textInClipboard.startsWith("taler://") || textInClipboard.startsWith("taler+http://") ? textInClipboard : undefined + } catch (e) { + logger.error("could not read clipboard", e) + return undefined + } } async function findTalerUriInActiveTab(): Promise<string | undefined> { |