El OneSignal service worker (Documentation Index
Fetch the complete documentation index at: https://documentation.onesignal.com/llms.txt
Use this file to discover all available pages before exploring further.
OneSignalSDKWorker.js) es un archivo JavaScript alojado en tu servidor que es necesario para las notificaciones push web. Permite que tu sitio reciba y muestre notificaciones, incluso cuando el usuario no está en tu página.

Configuración del service worker
Crea un archivoOneSignalSDKWorker.js dedicado para las notificaciones push de OneSignal. Si tu sitio ya tiene un service worker y quieres usar un solo archivo, consulta Combinar múltiples service workers en su lugar.
Descargar o crear OneSignalSDKWorker.js
OneSignalSDKWorker.js con la siguiente línea de código:onesignalsdkworker.js). Si lo haces, simplemente reemplaza OneSignalSDKWorker.js en esta guía con tu nombre de archivo.Subir a tu servidor web
OneSignalSDKWorker.js en tu servidor para que sea accesible públicamente a través de HTTPS. El archivo no debe requerir autenticación o inicio de sesión para acceder.Recomendado: Aloja el archivo en un subdirectorio dedicado que nunca sirva páginas, como /push/onesignal/. Esto evita conflictos con otros service workers en tu sitio (p. ej., un service worker de PWA o AMP) y mantiene estable la ruta URL.- Ejemplo:
https://yoursite.com/push/onesignal/OneSignalSDKWorker.js
https://yoursite.com/OneSignalSDKWorker.js). Puedes subir el archivo al directorio raíz, pero puede entrar en conflicto con otros service workers que necesiten alcance raíz. Por ejemplo, si usas una PWA, coloca OneSignalSDKWorker.js en un subdirectorio.Verificar que el archivo es accesible
https://yoursite.com/push/onesignal/OneSignalSDKWorker.js).Deberías ver la línea importScripts del Paso 1:
Configurar la ruta del SDK (solo subdirectorio)
Configuración típica de sitio
- En el dashboard de OneSignal, ve a Configuración > Push & In-App > Configuración web.
- En Configuración push avanzada, habilita Personalizar rutas y nombres de archivo del service worker.

| Campo | Descripción | Ejemplo |
|---|---|---|
| Path to service worker files | Directorio donde está alojado OneSignalSDKWorker.js. | /push/onesignal/ |
| Service worker filename | Nombre del archivo .js. | OneSignalSDKWorker.js |
| Service worker registration scope | Ruta URL que controla el service worker. Debe estar en o por debajo del directorio donde está alojado el archivo. Usa una ruta que nunca sirva páginas orientadas al usuario. | /push/onesignal/ |
Configuración de código personalizado
PasaserviceWorkerPath y serviceWorkerParam en tu llamada a OneSignal.init():| Parámetro | Descripción | Ejemplo |
|---|---|---|
serviceWorkerPath | Ruta relativa desde la raíz del sitio hasta el archivo .js (sin barra diagonal inicial). | "push/onesignal/OneSignalSDKWorker.js" |
serviceWorkerParam.scope | Ruta URL que controla el service worker. Debe estar en o por debajo del directorio donde está alojado el archivo. Usa una ruta que nunca sirva páginas orientadas al usuario. | "/push/onesignal/" |
Revisar los requisitos del service worker
OneSignalSDKWorker.js debe cumplir todos los siguientes requisitos. Si alguno no se cumple, las notificaciones push no funcionarán.| Requisito | Detalles |
|---|---|
| Accesible públicamente | Navega a la URL del archivo en un navegador y confirma que puedes ver el código JavaScript. |
| Tipo de contenido correcto | El servidor debe devolver Content-Type: application/javascript; charset=utf-8. |
| Mismo origen | El archivo debe estar alojado en el mismo dominio que tu sitio. No se permiten CDNs ni subdominios. Consulta MDN: Registering your worker. |
| HTTPS | Los service workers requieren un contexto seguro. localhost es la única excepción durante el desarrollo. |
Configuración del Web SDK
Combinar múltiples service workers
Cada archivo service worker en tu sitio se registra en un alcance — una ruta URL que determina qué páginas controla. Solo un service worker puede estar activo en un alcance dado. Si ya tienes un service worker (por ejemplo, una PWA o un worker de caché) y quieres que OneSignal comparta el mismo archivo, puedes combinarlos. Para combinar, añade la líneaimportScripts de OneSignal a tu archivo service worker existente:
Guía de migración
Esta sección es para clientes existentes de OneSignal que necesitan cambiar la ruta del archivo service worker, el nombre de archivo o el alcance. No sigas estos pasos a menos que tengas una razón específica para cambiar tu configuración actual.Cuándo y cómo migrar tu service worker
Cuándo y cómo migrar tu service worker
- El OneSignal service worker con alcance raíz entra en conflicto con una Progressive Web App (PWA)
- El service worker entra en conflicto con AMP u otro service worker de caché
- Las políticas de seguridad prohíben el código de service worker de terceros en el alcance raíz
OneSignalSDKWorker.js contiene únicamente:serviceWorkerParam como se describe en el Paso 4: Configurar la ruta del SDK. No se necesitan otros cambios.Si tu archivo contiene OneSignal + otro códigoTu service worker puede incluir llamadas importScripts adicionales (p. ej., al seguir la guía Combinar múltiples service workers). Si tu configuración actual sigue funcionando, mantenla como está — separar un service worker fusionado requiere un despliegue en dos fases.Si debes separarlos:Añadir un comentario de retención al archivo existente
importScripts de OneSignal en tu service worker actual, añade:Crear un nuevo service worker dedicado de OneSignal
OneSignalSDKWorker.js en un subdirectorio (p. ej., /push/onesignal/) que contenga solo:Actualizar la configuración de OneSignal
OneSignal.init() como se describe en el Paso 4: Configurar la ruta del SDK.Esperar a que los suscriptores migren
Limpieza
importScripts de OneSignal del archivo service worker original.Crear el nuevo archivo en la nueva ubicación
OneSignalSDKWorker.js (o tu nombre de archivo elegido) en el nuevo directorio con:Actualizar la configuración de OneSignal
Esperar a que los suscriptores migren
Limpieza
Problemas comunes
¿Por qué mi service worker devuelve un 404?
El archivo no está en la URL que espera el SDK. Navega a la URL completa del archivo en tu navegador para confirmar que es accesible. Si colocaste el archivo en un subdirectorio, verifica queserviceWorkerPath (código personalizado) o la configuración de ruta del dashboard coincida con la ubicación real del archivo — incluido el directorio y el nombre de archivo.
¿Por qué las notificaciones no se muestran después de mover el archivo service worker?
Los suscriptores existentes siguen referenciando la URL del service worker anterior. El navegador obtiene la URL registrada (en caché hasta 24 horas) cada vez que llega un push. Si la URL antigua devuelve un 404, esos suscriptores no reciben notificaciones. Continúa alojando el archivo antiguo durante al menos un año mientras los suscriptores migran naturalmente al volver a visitar tu sitio. Consulta la guía de migración y la guía Notificaciones push web no se muestran.¿Puedo alojar el service worker en un CDN o subdominio?
No. Los navegadores requieren que los service workers se sirvan desde el mismo origen que la página que los registra. El archivo debe estar en tu dominio principal — no en un CDN, subdominio o dominio diferente.¿Por qué mi PWA entra en conflicto con el OneSignal service worker?
Probablemente ambos están registrados en el alcance raíz (/) y solo un service worker puede estar registrado en un alcance específico. Mueve el OneSignal service worker a un alcance de subdirectorio (p. ej., /push/onesignal/) para que tu PWA retenga el control del alcance raíz, o combina los service workers como se describe en Combinar múltiples service workers.
¿Puedo renombrar el archivo OneSignalSDKWorker.js?
Sí. Si tu servidor requiere una convención de nombres específica (p. ej., todo en minúsculas), puedes renombrar el archivo a algo comoonesignalsdkworker.js. Si lo haces, actualiza el nombre de archivo en tu configuración de OneSignal — ya sea el campo Service worker filename en el dashboard o el parámetro serviceWorkerPath en tu llamada a OneSignal.init(). Consulta el Paso 4 para más detalles.
¿Qué tipo de contenido debe devolver mi servidor para el archivo service worker?
El servidor debe devolverContent-Type: application/javascript; charset=utf-8. Algunas configuraciones de servidor o CDN pueden devolver un tipo MIME incorrecto, lo que hace que el navegador rechace el registro del service worker.