Estoy creando una extensión web (Chrome) que verifica si la API externa cambió. Esto debería suceder periódicamente (por ejemplo, cada 10 minutos) y en segundo plano. El plan es tener un trabajador de servicio que active estas solicitudes y reemplace el ícono de la extensión cuando se detecte un cambio en la respuesta. Tengo un código de trabajo que hace exactamente eso, pero no puedo persistir en el trabajador del servicio y hacer que se ejecute en la carga del navegador (es decir, en el momento en que se abre la ventana). Logré usar la API de mensajes, pero eso requiere que el usuario haga clic en el botón de extensión para abrirlo y solo entonces la extensión se ejecutaría continuamente en segundo plano.
Este es mi código de trabajador de servicio:
const browser = chrome || browser; self.addEventListener("message", async (event) => { if (event.data && event.data.type === 'CHECK_FOR_NEW_RESOURCES') { communicationPort = event.ports[0]; const compareStructures = setInterval(async () => { const currentStructure = await getStructure(event.data.baseURL + 'webservice/rest/server.php', event.data.token); const {curr, newResources } = findDifferences(event.data.structure.base, currentStructure); if(newResources > 0) { communicationPort.postMessage({different: true, structure: curr, newResources, time: new Date().toISOString()}); browser.action.setIcon({ path: { '48': event.data.newResourcesIcon } }); clearInterval(compareStructures); } else { communicationPort.postMessage({ different: false, time: new Date().toISOString() }); browser.action.setIcon({ path: { '48': event.data.noNewResourcesIcon } }); } }, 900000); } }); const getStructure = async (url, token) => { // Uses fetch() to get the resources ... }; const findDifferences = (newStructure, oldStructure) => { ... };
Si no es posible, ¿cuáles son las opciones viables para lograr el diseño deseado? Podría volver a manifestar ver. 2 ayuda?
Espero que mi descripción tenga sentido, y creo que es posible, ya que he visto que las extensiones envían notificaciones cuando se abre el navegador.