chrome.events

Description

L'espace de noms chrome.events contient des types courants utilisés par les API qui envoient des événements pour vous avertir lorsqu'un événement intéressant se produit.

Concepts et utilisation

Un Event est un objet qui vous permet d'être averti lorsqu'un événement intéressant se produit. Voici un Exemple d'utilisation de l'événement chrome.alarms.onAlarm pour être averti à la fin d'une alarme:

chrome.alarms.onAlarm.addListener((alarm) => {
  appendToLog(`alarms.onAlarm -- name: ${alarm.name}, scheduledTime: ${alarm.scheduledTime}`);
});

Comme le montre l'exemple, vous vous inscrivez aux notifications à l'aide de addListener(). L'argument de addListener() est toujours une fonction que vous définissez pour gérer l'événement, mais les paramètres de la dépendent de l'événement que vous gérez. Consultez la documentation de alarms.onAlarm. vous pouvez voir que la fonction comporte un seul paramètre: un objet alarms.Alarm dont les détails sur l'alarme écoulée.

Exemples d'API utilisant des événements: alarms, i18n, identity, runtime. La plupart des chromes les API.

Gestionnaires d'événements déclaratifs

Les gestionnaires d'événements déclaratifs permettent de définir des règles constituées de conditions déclaratives. et des actions. Les conditions sont évaluées dans le navigateur plutôt que dans le moteur JavaScript, qui réduit les latences aller-retour et permet une efficacité très élevée.

Les gestionnaires d'événements déclaratifs sont utilisés, par exemple, API Declarative Content : Cette page décrit les concepts sous-jacents de tous les événements déclaratifs gestionnaires.

Règles

La règle la plus simple est constituée d'une ou de plusieurs conditions et d'une ou plusieurs actions:

const rule = {
  conditions: [ /* my conditions */ ],
  actions: [ /* my actions */ ]
};

Si l'une des conditions est remplie, toutes les actions sont exécutées.

En plus des conditions et des actions, vous pouvez attribuer un identifiant à chaque règle, ce qui simplifie l'annulation de l'enregistrement des règles précédemment enregistrées, ainsi qu'une priorité permettant de définir des priorités entre les règles. Les priorités ne sont prises en compte que si les règles sont en conflit ou doivent être exécutées dans un commande. Les actions sont exécutées dans l'ordre décroissant de la priorité de leurs règles.

const rule = {
  id: "my rule",  // optional, will be generated if not set.
  priority: 100,  // optional, defaults to 100.
  conditions: [ /* my conditions */ ],
  actions: [ /* my actions */ ]
};

Objets "Événement"

Les objets "Événement" peuvent être compatibles avec les règles. Ces objets d'événement n'appellent pas de fonction de rappel lorsque événements se produisent, mais vérifiez si une règle enregistrée a au moins une condition remplie et exécutez les actions associées à cette règle. Les objets d'événement qui prennent en charge l'API déclarative disposent de trois méthodes pertinentes: events.Event.addRules(), events.Event.removeRules() et events.Event.getRules()

Ajouter des règles

Pour ajouter des règles, appelez la fonction addRules() de l'objet événement. Il prend un tableau d'instances de règle comme premier paramètre et une fonction de rappel appelée à la fin.

const rule_list = [rule1, rule2, ...];
addRules(rule_list, (details) => {...});

Si les règles ont bien été insérées, le paramètre details contient un tableau de règles insérées. apparaissent dans le même ordre que dans l'élément rule_list transmis, où les paramètres facultatifs id et priority ont été renseignés avec les valeurs générées. Si une règle n'est pas valide, par exemple parce qu'elle contient une condition ou une action non valide, aucune règle n'est ajoutée et la variable runtime.lastError est défini lorsque la fonction de rappel est appelée. Chaque règle dans rule_list doit contenir un seul qui n'est pas déjà utilisé par une autre règle ou un identifiant vide.

Supprimer la règle

Pour supprimer des règles, appelez la fonction removeRules(). Elle accepte un tableau facultatif d'identifiants de règles comme premier paramètre et une fonction de rappel en tant que deuxième paramètre.

const rule_ids = ["id1", "id2", ...];
removeRules(rule_ids, () => {...});

Si rule_ids est un tableau d'identifiants, toutes les règles ayant des identifiants listés dans le tableau sont supprimés. Si rule_ids répertorie un identifiant, cet identifiant est ignoré sans notification. Si rule_ids est défini sur undefined. Toutes les règles enregistrées de cette extension sont supprimées. callback() est appelée lorsque les règles ont été supprimées.

Récupérer les règles

Pour récupérer la liste des règles enregistrées, appelez la fonction getRules(). Il accepte un tableau facultatif d'identifiants de règles avec la même sémantique que removeRules() et une fonction de rappel.

const rule_ids = ["id1", "id2", ...];
getRules(rule_ids, (details) => {...});

Le paramètre details transmis à la fonction callback() fait référence à un tableau de règles comprenant des paramètres facultatifs renseignés.

Performances

Pour obtenir des performances optimales, tenez compte des consignes suivantes.

Enregistrez et annulez l'enregistrement de règles de manière groupée. Après chaque inscription ou désinscription, Chrome doit mettre à jour les structures de données internes. Cette mise à jour est une opération coûteuse.

au lieu de
const rule1 = {...};
const rule2 = {...};
chrome.declarativeWebRequest.onRequest.addRules([rule1]);
chrome.declarativeWebRequest.onRequest.addRules([rule2]);
Vos préférences
const rule1 = {...};
const rule2 = {...};
chrome.declarativeWebRequest.onRequest.addRules([rule1, rule2]);

Privilégiez la correspondance de sous-chaîne aux expressions régulières dans un élément events.UrlFilter. La correspondance basée sur des sous-chaînes est extrêmement rapide.

au lieu de
const match = new chrome.declarativeWebRequest.RequestMatcher({
  url: {urlMatches: "example.com/[^?]*foo" }
});
Vos préférences
const match = new chrome.declarativeWebRequest.RequestMatcher({
  url: {hostSuffix: "example.com", pathContains: "foo"}
});

Si de nombreuses règles partagent les mêmes actions, fusionnez-les pour n'en faire qu'une seule. Les règles déclenchent leurs actions dès qu'une condition est remplie. Cela permet d'accélérer le et réduit la consommation de mémoire pour les ensembles d'actions en double.

au lieu de
const condition1 = new chrome.declarativeWebRequest.RequestMatcher({
  url: { hostSuffix: 'example.com' }
});
const condition2 = new chrome.declarativeWebRequest.RequestMatcher({
  url: { hostSuffix: 'foobar.com' }
});
const rule1 = { conditions: [condition1],
                actions: [new chrome.declarativeWebRequest.CancelRequest()]
              };
const rule2 = { conditions: [condition2],
                actions: [new chrome.declarativeWebRequest.CancelRequest()]
              };
chrome.declarativeWebRequest.onRequest.addRules([rule1, rule2]);
Vos préférences
const condition1 = new chrome.declarativeWebRequest.RequestMatcher({
  url: { hostSuffix: 'example.com' }
});
const condition2 = new chrome.declarativeWebRequest.RequestMatcher({
  url: { hostSuffix: 'foobar.com' }
});
const rule = { conditions: [condition1, condition2],
              actions: [new chrome.declarativeWebRequest.CancelRequest()]
             };
chrome.declarativeWebRequest.onRequest.addRules([rule]);

Événements filtrés

Les événements filtrés sont un mécanisme qui permet aux écouteurs de spécifier un sous-ensemble d'événements qu'ils qui vous intéressent. Un écouteur qui utilise un filtre ne sera pas appelé pour les événements qui ne transmettent pas la valeur ce qui rend le code d'écoute plus déclaratif et efficace. Les besoins d'un service worker ne pas être réveillé(e) pour gérer les événements dont il n’a pas besoin.

Les événements filtrés sont destinés à permettre une transition depuis le code de filtrage manuel.

au lieu de
chrome.webNavigation.onCommitted.addListener((event) => {
  if (hasHostSuffix(event.url, 'google.com') ||
      hasHostSuffix(event.url, 'google.com.au')) {
    // ...
  }
});
Vos préférences
chrome.webNavigation.onCommitted.addListener((event) => {
  // ...
}, {url: [{hostSuffix: 'google.com'},
          {hostSuffix: 'google.com.au'}]});

Les événements sont compatibles avec des filtres spécifiques pertinents pour cet événement. La liste des filtres appliqués à un événement sont répertoriés dans la documentation pour cet événement, dans la section "filtres" .

Lorsque les URL sont mises en correspondance (comme dans l'exemple ci-dessus), les filtres d'événement acceptent la même correspondance peuvent être exprimées avec events.UrlFilter, à l'exception de la mise en correspondance de schéma et de port.

Types

Event

Objet qui permet d'ajouter et de supprimer des écouteurs pour un événement Chrome.

Propriétés

  • addListener

    vide

    Enregistre un rappel d'écouteur d'événements dans un événement.

    La fonction addListener se présente comme suit:

    (callback: H) => {...}

    • rappel

      H

      Appelé lorsqu'un événement se produit. Les paramètres de cette fonction dépendent du type d'événement.

  • addRules

    vide

    Enregistre les règles permettant de gérer les événements.

    La fonction addRules se présente comme suit:

    (rules: Rule<anyany>[], callback?: function) => {...}

    • règles

      Règle<any>[]

      Règles à enregistrer. Elles ne remplacent pas les règles enregistrées précédemment.

    • rappel

      function facultatif

      Le paramètre callback se présente comme suit:

      (rules: Rule<anyany>[]) => void

      • règles

        Règle<any>[]

        Règles qui ont été enregistrées, les paramètres facultatifs sont renseignés avec des valeurs.

  • getRules

    vide

    Renvoie les règles actuellement enregistrées.

    La fonction getRules se présente comme suit:

    (ruleIdentifiers?: string[], callback: function) => {...}

    • ruleIdentifiers

      string[] facultatif

      Si un tableau est transmis, seules les règles avec des identifiants contenus dans ce tableau sont renvoyées.

    • rappel

      fonction

      Le paramètre callback se présente comme suit:

      (rules: Rule<anyany>[]) => void

      • règles

        Règle<any>[]

        Règles qui ont été enregistrées, les paramètres facultatifs sont renseignés avec des valeurs.

  • hasListener

    vide

    La fonction hasListener se présente comme suit:

    (callback: H) => {...}

    • rappel

      H

      Écouteur dont l'état d'enregistrement doit être testé.

    • retours

      booléen

      "True" si le rappel est enregistré pour l'événement.

  • hasListeners

    vide

    La fonction hasListeners se présente comme suit:

    () => {...}

    • retours

      booléen

      "True" si des écouteurs d'événements sont enregistrés pour l'événement.

  • removeListener

    vide

    Annule l'enregistrement d'un rappel d'écouteur d'événements dans un événement.

    La fonction removeListener se présente comme suit:

    (callback: H) => {...}

    • rappel

      H

      Écouteur dont l'enregistrement doit être annulé.

  • removeRules

    vide

    Annule l'enregistrement des règles actuellement enregistrées.

    La fonction removeRules se présente comme suit:

    (ruleIdentifiers?: string[], callback?: function) => {...}

    • ruleIdentifiers

      string[] facultatif

      Si un tableau est transmis, seules les règles dont les identifiants sont contenus dans ce tableau sont annulées.

    • rappel

      function facultatif

      Le paramètre callback se présente comme suit:

      () => void

Rule

Description d'une règle déclarative pour la gestion des événements.

Propriétés

  • correctives

    tout[]

    Liste des actions déclenchées si l'une des conditions est remplie.

  • conditions

    tout[]

    Liste des conditions pouvant déclencher les actions.

  • id

    chaîne facultatif

    Identifiant facultatif qui permet de référencer cette règle.

  • priorité

    numéro facultatif

    Priorité facultative de cette règle. La valeur par défaut est 100.

  • tags

    string[] facultatif

    Les tags peuvent être utilisés pour annoter des règles et effectuer des opérations sur des ensembles de règles.

UrlFilter

Filtre les URL en fonction de différents critères. Consultez la section Filtrage des événements. Tous les critères sont sensibles à la casse.

Propriétés

  • cidrBlocks

    string[] facultatif

    Chrome 123 et versions ultérieures

    Correspond si la partie hôte de l'URL est une adresse IP et est contenue dans l'un des blocs CIDR spécifiés dans le tableau.

  • hostContains

    chaîne facultatif

    Correspond si le nom d'hôte de l'URL contient une chaîne spécifiée. Pour vérifier si un composant de nom d'hôte possède un préfixe "foo", utilisez hostContains : ".foo". Cela correspond à "www.foobar.com" et "foo.com", car un point implicite est ajouté au début du nom d'hôte. De la même manière, hostContains peut être utilisé pour établir une correspondance avec le suffixe de composant ("foo.") et avec des composants (".foo."). La correspondance de suffixe et de correspondance exacte des derniers composants doit être effectuée séparément à l'aide de hostSuffix, car aucun point implicite n'est ajouté à la fin du nom d'hôte.

  • hostEquals

    chaîne facultatif

    Correspond si le nom d'hôte de l'URL est égal à une chaîne spécifiée.

  • hostPrefix

    chaîne facultatif

    Correspond si le nom d'hôte de l'URL commence par une chaîne spécifiée.

  • hostSuffix

    chaîne facultatif

    Correspond si le nom d'hôte de l'URL se termine par une chaîne spécifiée.

  • originAndPathMatches

    chaîne facultatif

    Correspond si l'URL sans segment de requête ni identifiant de fragment correspond à une expression régulière spécifiée. Les numéros de port sont supprimés de l'URL s'ils correspondent au numéro de port par défaut. Les expressions régulières utilisent la syntaxe RE2.

  • pathContains

    chaîne facultatif

    Correspond si le segment de chemin d'accès de l'URL contient une chaîne spécifiée.

  • pathEquals

    chaîne facultatif

    Correspond si le segment de chemin d'accès de l'URL est égal à une chaîne spécifiée.

  • pathPrefix

    chaîne facultatif

    Correspond si le segment de chemin d'accès de l'URL commence par une chaîne spécifiée.

  • pathSuffix

    chaîne facultatif

    Correspond si le segment de chemin d'accès de l'URL se termine par une chaîne spécifiée.

  • ports

    (number | number[])[] facultatif

    Correspond si le port de l'URL est contenu dans l'une des listes de ports spécifiées. Par exemple, [80, 443, [1000, 1200]] correspond à toutes les requêtes sur les ports 80 et 443, et comprises entre 1 000 et 1 200.

  • queryContains

    chaîne facultatif

    Correspond si le segment de requête de l'URL contient une chaîne spécifiée.

  • queryEquals

    chaîne facultatif

    Correspond si le segment de requête de l'URL est égal à une chaîne spécifiée.

  • queryPrefix

    chaîne facultatif

    Correspond si le segment de requête de l'URL commence par une chaîne spécifiée.

  • querySuffix

    chaîne facultatif

    Correspond si le segment de requête de l'URL se termine par une chaîne spécifiée.

  • schémas

    string[] facultatif

    Correspond si le schéma de l'URL est égal à l'un des schémas spécifiés dans le tableau.

  • urlContains

    chaîne facultatif

    Vérifie si l'URL (sans identifiant de fragment) contient une chaîne spécifiée. Les numéros de port sont supprimés de l'URL s'ils correspondent au numéro de port par défaut.

  • urlEquals

    chaîne facultatif

    Vérifie si l'URL (sans identifiant de fragment) est égale à une chaîne spécifiée. Les numéros de port sont supprimés de l'URL s'ils correspondent au numéro de port par défaut.

  • urlMatches

    chaîne facultatif

    Correspond si l'URL (sans identifiant de fragment) correspond à une expression régulière spécifiée. Les numéros de port sont supprimés de l'URL s'ils correspondent au numéro de port par défaut. Les expressions régulières utilisent la syntaxe RE2.

  • urlPrefix

    chaîne facultatif

    Correspond si l'URL (sans identifiant de fragment) commence par une chaîne spécifiée. Les numéros de port sont supprimés de l'URL s'ils correspondent au numéro de port par défaut.

  • urlSuffix

    chaîne facultatif

    Correspond si l'URL (sans identifiant de fragment) se termine par une chaîne spécifiée. Les numéros de port sont supprimés de l'URL s'ils correspondent au numéro de port par défaut.