How Fugu is the Web?
Logoafbeelding van item voor How Fugu is the Web?

How Fugu is the Web?

ExtensieOntwikkelaarstools68 gebruikers
Screenshot 2 voor itemmedia
Screenshot 1 voor itemmedia
Screenshot 2 voor itemmedia
Screenshot 1 voor itemmedia
Screenshot 1 voor itemmedia
Screenshot 2 voor itemmedia

Overzicht

An extension to shine light on the Project Fugu 🐡 APIs web apps want to use.

How it works API data The raw data for the different Project Fugu 🐡 APIs is curated in a spreadsheet, which is then turned into JavaScript, so keeping the list of APIs updated is hopefully a straightforward task. API detection The extension monitors the requests a page makes via the chrome.webRequest.onBeforeRequest.addListener() API. Each response body, grouped by main frame, JavaScript, and Web App Manifest response bodies, is then run through a set of regular expressions like /navigator\.hid\.requestDevice\s*\(/g to determine if the code hints at a Project Fugu 🐡 API potentially being used. Browser support detection Most Project Fugu 🐡 APIs are easily feature-detectable by checking for the existence of interfaces or properties, for example, as in 'BarcodeDetector' in window. Other APIs require a ServiceWorkerRegistration, but luckily the popup window in Manifest V3 extensions uses a service worker, so it can be used via an IIFE that can be run in the client or the service worker. An example is (async () => 'periodicSync' in (await navigator.serviceWorker?.ready || self.registration))(). The support categories are listed below: ✔️ Supported by your browser. 🚫 Not supported by your browser. 🤷 Support unknown for your browser. (The only way to know would be user-agent sniffing.) Deep-linking The extension makes use of Text Fragment URLs to deep-link to the occurrence of a detected API, for example https://airhorner.com/scripts/main.min.js#:~:text=navigator.setAppBadge(. For main frame documents, the source code gets rendered in a helper HTML page controlled by the extension, since it is impossible to link to view-source: protocol links. Limitations • The chrome.webRequest.onBeforeRequest.addListener() API unfortunately does not "see" requests that are handled by a service worker (crbug.com/766433). There are three possible workarounds for this: - Hard-reload via ⌘/ctrl+shift+r. - Open DevTools and check the Bypass for network checkbox in the Service Worker section of the Application tab. - Clear storage in the Storage section of the Application tab. • The extension only does static code analysis, that is, there is no guarantee that the app actually uses the code snippet where a Project Fugu 🐡 API was detected. • Heavily minified code will not be detected. For example, if an app minifies navigator.clipboard.write() to const nav = navigator; nav.clipboard.write(), the extension will not detect this. License Apache 2.0.

0 van 5Geen beoordelingen

Google verifieert reviews niet. Meer informatie over resultaten en reviews

Details

  • Versie
    1.17.0
  • Geüpdatet
    10 januari 2024
  • Aangeboden door
    Thomas Steiner
  • Grootte
    125KiB
  • Talen
    English
  • Ontwikkelaar
    Thomas Steiner
    Neanderstr. 3 Hamburg 20459 Germany
    E-mail
    steiner.thomas@gmail.com
  • Geen handelaar
    Deze ontwikkelaar heeft zichzelf niet geïdentificeerd als handelaar. Voor consumenten in de Europese Unie geldt dat consumentenrechten niet van toepassing zijn op contracten tussen jou en deze ontwikkelaar.

Privacy

De ontwikkelaar heeft aangegeven dat je gegevens niet worden verzameld of gebruikt. Bekijk het privacybeleid van de ontwikkelaar voor meer informatie.

Deze ontwikkelaar verklaart dat je gegevens:

  • Niet worden verkocht aan derden, behalve voor de goedgekeurde toepassingen
  • Niet worden gebruikt of overgedragen voor doeleinden die niet zijn gerelateerd aan de kernfunctionaliteit van het item
  • Niet worden gebruikt of overgedragen om de kredietwaardigheid te bepalen of voor doeleinden met betrekking tot leningen

Support

Open deze pagina in je desktopbrowser voor hulp bij vragen, suggesties of problemen

Google-apps