Beschrijving
Gebruik de chrome.permissions
API om gedeclareerde optionele machtigingen tijdens runtime aan te vragen in plaats van tijdens de installatie, zodat gebruikers begrijpen waarom de machtigingen nodig zijn en alleen de machtigingen verlenen die nodig zijn.
Overzicht
Er bestaan toestemmingswaarschuwingen om de mogelijkheden te beschrijven die door een API worden verleend, maar sommige van deze waarschuwingen zijn misschien niet voor de hand liggend. Met de Permissions API kunnen ontwikkelaars toestemmingswaarschuwingen uitleggen en geleidelijk nieuwe functies introduceren, waardoor gebruikers een risicovrije introductie tot de extensie krijgen. Op deze manier kunnen gebruikers opgeven hoeveel toegang ze willen verlenen en welke functies ze willen inschakelen.
De kernfunctionaliteit van de optionele machtigingsextensie overschrijft bijvoorbeeld de nieuwe tabbladpagina. Eén functie is het weergeven van het doel van de dag van de gebruiker. Voor deze functie zijn alleen opslagrechten vereist, die geen waarschuwing bevatten. De extensie heeft een extra functie die gebruikers kunnen inschakelen door op de volgende knop te klikken:
Voor het weergeven van de topsites van de gebruiker is de toestemming topSites vereist, die de volgende waarschuwing bevat.
Optionele machtigingen implementeren
Stap 1: Bepaal welke machtigingen vereist zijn en welke optioneel zijn
Een extensie kan zowel vereiste als optionele machtigingen declareren. Over het algemeen moet u:
- Gebruik de vereiste machtigingen wanneer deze nodig zijn voor de basisfunctionaliteit van uw extensie.
- Gebruik optionele machtigingen wanneer deze nodig zijn voor optionele functies in uw extensie.
Voordelen van vereiste machtigingen:
- Minder prompts: een extensie kan de gebruiker één keer vragen om alle machtigingen te accepteren.
- Eenvoudiger ontwikkelen: de vereiste machtigingen zijn gegarandeerd aanwezig.
Voordelen van optionele machtigingen:
- Betere beveiliging: Extensies worden uitgevoerd met minder machtigingen, omdat gebruikers alleen machtigingen inschakelen die nodig zijn.
- Betere informatie voor gebruikers: Een extensie kan uitleggen waarom deze een bepaalde toestemming nodig heeft wanneer de gebruiker de betreffende functie inschakelt.
- Gemakkelijkere upgrades: Wanneer u uw extensie upgradet, schakelt Chrome deze niet uit voor uw gebruikers als de upgrade optionele in plaats van vereiste machtigingen toevoegt.
Stap 2: Declareer optionele machtigingen in het manifest
Declareer optionele machtigingen in uw extensiemanifest met de optional_permissions
sleutel, met dezelfde indeling als het machtigingsveld :
{
"name": "My extension",
...
"optional_permissions": ["tabs"],
"optional_host_permissions": ["https://www.google.com/"],
...
}
Als u hosts wilt aanvragen die u alleen tijdens runtime ontdekt, neemt u "https://*/*"
op in het veld optional_host_permissions
van uw extensie. Hiermee kunt u elke oorsprong in Permissions.origins opgeven, zolang deze maar een overeenkomend schema heeft.
Machtigingen die niet als optioneel kunnen worden opgegeven
De meeste machtigingen voor Chrome-extensies kunnen als optioneel worden opgegeven, met de volgende uitzonderingen.
Toestemming | Beschrijving |
---|---|
"debugger" | De chrome.debugger API dient als alternatief transport voor het protocol voor foutopsporing op afstand van Chrome. |
"declarativeNetRequest" | Verleent de extensie toegang tot de chrome.declarativeNetRequest API. |
"devtools" | Staat extensie toe om de Chrome DevTools- functionaliteit uit te breiden. |
"experimental" | Alleen Canary- en Dev-kanaal . Verleent de extensie toegang tot chrome.experimental API's. |
"geolocation" | Hiermee kan de extensie de HTML5- geolocatie -API gebruiken. |
"mdns" | Verleent de extensie toegang tot de chrome.mdns API. |
"proxy" | Verleent de extensie toegang tot de chrome.proxy API om de proxy-instellingen van Chrome te beheren. |
"tts" | De chrome.tts API speelt gesynthetiseerde tekst-naar-spraak (TTS) af. |
"ttsEngine" | De chrome.ttsEngine API implementeert een tekst-naar-spraak-engine (TTS) met behulp van een extensie. |
"wallpaper" | Alleen ChromeOS . Gebruik de chrome.wallpaper API om de ChromeOS-achtergrond te wijzigen. |
Bekijk Machtigingen declareren en gebruikers waarschuwen voor meer informatie over beschikbare machtigingen en hun waarschuwingen.
Stap 3: Vraag optionele machtigingen aan
Vraag de machtigingen aan vanuit een gebruikersgebaar met behulp van permissions.request()
:
document.querySelector('#my-button').addEventListener('click', (event) => {
// Permissions must be requested from inside a user gesture, like a button's
// click handler.
chrome.permissions.request({
permissions: ['tabs'],
origins: ['https://www.google.com/']
}, (granted) => {
// The callback argument will be true if the user granted the permissions.
if (granted) {
doSomething();
} else {
doSomethingElse();
}
});
});
Chrome vraagt de gebruiker of het toevoegen van de rechten resulteert in andere waarschuwingsberichten dan de gebruiker al heeft gezien en geaccepteerd. De vorige code kan bijvoorbeeld resulteren in een prompt als deze:
Stap 4: Controleer de huidige rechten van de extensie
Om te controleren of uw extensie een specifieke machtiging of een reeks machtigingen heeft, gebruikt u permission.contains()
:
chrome.permissions.contains({
permissions: ['tabs'],
origins: ['https://www.google.com/']
}, (result) => {
if (result) {
// The extension has the permissions.
} else {
// The extension doesn't have the permissions.
}
});
Stap 5: Verwijder de machtigingen
U moet machtigingen verwijderen wanneer u deze niet langer nodig heeft. Nadat een machtiging is verwijderd, wordt door het aanroepen van permissions.request()
de machtiging doorgaans weer toegevoegd zonder dat de gebruiker hierom wordt gevraagd.
chrome.permissions.remove({
permissions: ['tabs'],
origins: ['https://www.google.com/']
}, (removed) => {
if (removed) {
// The permissions have been removed.
} else {
// The permissions have not been removed (e.g., you tried to remove
// required permissions).
}
});
Soorten
Permissions
Eigenschappen
- oorsprong
tekenreeks[] optioneel
De lijst met hostmachtigingen, inclusief de machtigingen die zijn opgegeven in de
optional_permissions
ofpermissions
in het manifest, en de machtigingen die zijn gekoppeld aan Content Scripts . - machtigingen
tekenreeks[] optioneel
Lijst met benoemde machtigingen (exclusief hosts of oorsprong).
Methoden
contains()
chrome.permissions.contains(
permissions: Permissions,
callback?: function,
)
Controleert of de extensie de opgegeven rechten heeft.
Parameters
- machtigingen
- terugbellen
functie optioneel
De
callback
parameter ziet er als volgt uit:(result: boolean) => void
- resultaat
Booleaans
Waar als de extensie de opgegeven machtigingen heeft. Als een oorsprong is opgegeven als zowel een optionele machtiging als een overeenkomstpatroon voor het inhoudsscript, retourneert dit
false
tenzij beide machtigingen zijn verleend.
Retouren
Beloof<boolean>
Chroom 96+Beloftes worden alleen ondersteund voor Manifest V3 en hoger, andere platforms moeten callbacks gebruiken.
getAll()
chrome.permissions.getAll(
callback?: function,
)
Haalt de huidige set machtigingen van de extensie op.
Parameters
- terugbellen
functie optioneel
De
callback
parameter ziet er als volgt uit:(permissions: Permissions) => void
- machtigingen
De actieve rechten van de extensie. Houd er rekening mee dat de eigenschap
origins
verleende oorsprongen bevat van de bronnen die zijn opgegeven in depermissions
enoptional_permissions
sleutels in het manifest en die zijn gekoppeld aan inhoudsscripts .
Retouren
Beloof < Toestemmingen >
Chroom 96+Beloftes worden alleen ondersteund voor Manifest V3 en hoger, andere platforms moeten callbacks gebruiken.
remove()
chrome.permissions.remove(
permissions: Permissions,
callback?: function,
)
Verwijdert de toegang tot de opgegeven machtigingen. Als er problemen zijn bij het verwijderen van de machtigingen, wordt runtime.lastError
ingesteld.
Parameters
- machtigingen
- terugbellen
functie optioneel
De
callback
parameter ziet er als volgt uit:(removed: boolean) => void
- VERWIJDERD
Booleaans
Waar als de machtigingen zijn verwijderd.
Retouren
Beloof<boolean>
Chroom 96+Beloftes worden alleen ondersteund voor Manifest V3 en hoger, andere platforms moeten callbacks gebruiken.
request()
chrome.permissions.request(
permissions: Permissions,
callback?: function,
)
Vraagt toegang tot de opgegeven machtigingen en geeft indien nodig een prompt aan de gebruiker weer. Deze machtigingen moeten worden gedefinieerd in het veld optional_permissions
van het manifest, of het moeten vereiste machtigingen zijn die door de gebruiker zijn ingehouden. Paden op oorsprongspatronen worden genegeerd. U kunt subsets van optionele oorsprongsmachtigingen aanvragen; Als u bijvoorbeeld *://*\/*
opgeeft in de sectie optional_permissions
van het manifest, kunt u http://example.com/
aanvragen. Als er problemen zijn bij het aanvragen van de machtigingen, wordt runtime.lastError
ingesteld.
Parameters
- machtigingen
- terugbellen
functie optioneel
De
callback
parameter ziet er als volgt uit:(granted: boolean) => void
- toegekend
Booleaans
Waar als de gebruiker de opgegeven machtigingen heeft verleend.
Retouren
Beloof<boolean>
Chroom 96+Beloftes worden alleen ondersteund voor Manifest V3 en hoger, andere platforms moeten callbacks gebruiken.
Evenementen
onAdded
chrome.permissions.onAdded.addListener(
callback: function,
)
Wordt geactiveerd wanneer de extensie nieuwe machtigingen verkrijgt.
Parameters
- terugbellen
functie
De
callback
parameter ziet er als volgt uit:(permissions: Permissions) => void
- machtigingen
onRemoved
chrome.permissions.onRemoved.addListener(
callback: function,
)
Wordt geactiveerd wanneer de toegang tot machtigingen uit de extensie is verwijderd.
Parameters
- terugbellen
functie
De
callback
parameter ziet er als volgt uit:(permissions: Permissions) => void
- machtigingen