Prepare for Production
Learn how to prepare your Inbox for production by enabling HMAC encryption for security and managing Novu's branding.
Before deploying the Inbox UI to production, you should secure your integration and configure the correct environment. You can also remove Novu's branding from your notifications.
This ensures that your end users receive notifications safely, without exposure to unnecessary risks, and in a way that aligns with your product branding.
Set the correct environment
Novu supports multiple environments, including development, production, and any custom environments you create.
When preparing for deployment, choose the environment that will serve as your production environment and update your configuration accordingly:
-
Use the API keys for your selected production environment from the API Keys page in your application.
-
Store keys in
.env
file or your server’s environment variables. -
Confirm your
applicationIdentifier
andsubscriber
match the configuration for your chosen production environment. -
Add these two props, if using the EU region:
apiUrl
with value https://eu.api.novu.cosocketUrl
with value wss://eu.socket.novu.co
Secure your Inbox with HMAC encryption
When you add the Inbox to your application, you're required to pass:
subscriberId
: Identifies the current subscriber.applicationIdentifier
: A public key to communicate with the notification feed API.
subscriberId
and use your public applicationIdentifier
to view that user's notifications.You can prevent this by enabling HMAC (Hash-based Message Authentication Code) encryption. This process uses a secret key to create a secure signature (subscriberHash
) for each subscriberId
. Novu then verifies this hash to ensure that requests to view a notification feed are authentic and not from an impersonator.
Follow these steps to enable HMAC encryption.
1. Enable HMAC in the dashboard
Activate the HMAC security feature within your Novu in-app provider settings.
- Go to Novu Dashboard.
- Navigate to the Integrations Store page.
- Click on the Novu In-App for your chosen production environment
- A side panel opens from the right side of the screen with the provider settings, enable
Security HMAC encryption
toggle in Integration Credentials section.
2. Generate HMAC hash on the server side
Next, use your secret key from the API Keys page on the Novu dashboard to generate an HMAC hash of the subscriberId
on the server side.
NOVU_SECRET_KEY
secure and never expose it to the client.3. Use the HMAC hash in the Inbox component
Send the hmacHash
generated in the previous step to the client side application. You can include it in the initial data payload when a subscriber or user logs in or fetch it from a dedicated API endpoint.
Pass the hash to the subscriberHash
prop in your Inbox component.
If HMAC encryption is active in In-App provider settings and subscriberHash
along with
subscriberId
is not provided, then Inbox will not load
Remove Novu branding
Users on a paid plan can remove the "Inbox by Novu" branding from the Inbox UI.
To remove the branding:
- Go to Novu Dashboard.
- Navigate to the Settings page.
- Under the Organization tab, find the Branding & Integrations section.
- Enable the Remove Novu branding toggle.