Skip to content

Commit

Permalink
Change sendSelfNotification to use local push
Browse files Browse the repository at this point in the history
Motivation: we are removing support for unauthenticated notif create calls

Update the welcome notification to use sendSelfNotification
  • Loading branch information
rgomezp committed Jul 10, 2024
1 parent 97289d0 commit 6aede1d
Show file tree
Hide file tree
Showing 3 changed files with 37 additions and 20 deletions.
7 changes: 7 additions & 0 deletions express_webpack/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -154,6 +154,12 @@
})
}

function sendSelfNotification() {
OneSignal.push(function() {
OneSignal.sendSelfNotification();
});
}

</script>
<head>
<meta charset="utf-8">
Expand Down Expand Up @@ -189,6 +195,7 @@ <h1>OneSignal WebSDK Sandbox</h1>
<button onclick="javascript:showSmsSlidedown();">Show Sms Slidedown</button>
<button onclick="javascript:showEmailSlidedown();">Show Email Slidedown</button>
<button onclick="javascript:showSmsAndEmailSlidedown();">Show Sms & Email Slidedown</button>
<button onclick="javascript:sendSelfNotification();">Send Self Notification</button>
<br />
<br />
<div class='onesignal-customlink-container'></div>
Expand Down
37 changes: 26 additions & 11 deletions src/OneSignal.ts
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@ import {
awaitOneSignalInitAndSupported,
executeCallback,
getConsoleStyle,
getPlatformNotificationIcon,
isValidEmail,
logMethodCall,
} from './utils';
Expand Down Expand Up @@ -713,16 +714,16 @@ export default class OneSignal {
/**
* @PublicApi
*/
static async sendSelfNotification(title: string = 'OneSignal Test Message',
message: string = 'This is an example notification.',
url: string = `${new URL(location.href).origin}?_osp=do_not_open`,
icon: URL,
data: Map<String, any>,
buttons: Array<NotificationActionButton>): Promise<void> {
static async sendSelfNotification(title = 'OneSignal Test Message',
message = 'This is an example notification.',
url = `${new URL(location.href).origin}?_osp=do_not_open`,
icon?: string,
data?: Record<string, any>,
buttons?: Array<NotificationActionButton>): Promise<void> {
await awaitOneSignalInitAndSupported();
logMethodCall('sendSelfNotification', title, message, url, icon, data, buttons);
const appConfig = await Database.getAppConfig();
const subscription = await Database.getSubscription();

if (!appConfig.appId)
throw new InvalidStateError(InvalidStateReason.MissingAppId);
if (!(await OneSignal.isPushNotificationsEnabled()))
Expand All @@ -731,11 +732,25 @@ export default class OneSignal {
throw new InvalidArgumentError('url', InvalidArgumentReason.Malformed);
if (!ValidatorUtils.isValidUrl(icon, { allowEmpty: true, requireHttps: true }))
throw new InvalidArgumentError('icon', InvalidArgumentReason.Malformed);

if (subscription.deviceId) {
await OneSignalApi.sendNotification(appConfig.appId, [subscription.deviceId], { en : title }, { en : message },
url, icon, data, buttons);
if (!icon) {
// get default icon
const icons = await MainHelper.getNotificationIcons();
icon = getPlatformNotificationIcon(icons);
}

this.context.serviceWorkerManager.getRegistration().then(async (registration) => {
if (!registration) {
Log.error("Service worker registration not available.");
return;
}

const options: NotificationOptions = {
body: message,
data: data,
icon: icon,
};
registration.showNotification(title, options);
});
}

/**
Expand Down
13 changes: 4 additions & 9 deletions src/helpers/EventHelper.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
import Event from '../Event';
import LimitStore from '../LimitStore';
import OneSignalApiShared from '../OneSignalApiShared';
import Database from '../services/Database';
import { ContextSWInterface } from "../models/ContextSW";
import Log from '../libraries/Log';
Expand Down Expand Up @@ -84,8 +83,6 @@ export default class EventHelper {
}
EventHelper.sendingOrSentWelcomeNotification = true;

const { deviceId } = await Database.getSubscription();
const { appId } = await Database.getAppConfig();
let title =
welcome_notification_opts !== undefined &&
welcome_notification_opts['title'] !== undefined &&
Expand All @@ -108,13 +105,11 @@ export default class EventHelper {
message = BrowserUtils.decodeHtmlEntities(message);

Log.debug('Sending welcome notification.');
OneSignalApiShared.sendNotification(
appId,
[deviceId],
{ en: title },
{ en: message },
OneSignal.sendSelfNotification(
title,
message,
url,
null,
undefined,
{ __isOneSignalWelcomeNotification: true },
undefined
);
Expand Down

0 comments on commit 6aede1d

Please sign in to comment.