Hosted preference center
Learn how to use Knock's hosted preference center to enable your users to manage notification preferences without writing any code.
Knock's hosted preference center is a page where your users manage their default notification preferences. You configure it from the dashboard; Knock hosts and renders the page, so you can launch a preference center without building or hosting any UI yourself.
This is the fastest way to let your users update their preferences when they receive a notification. If you need more control over the experience, you can build your own preference center UI on top of Knock's preferences API.
How it works
#Knock hosts the preference center at p.knock.app. Each user accesses their own preferences through a signed link that looks like this:
The token identifies the recipient, so users don't need to log in to your product to view or update their preferences.
When a user opens the link, they see their preference settings based on the configuration in your dashboard, with your account branding, preference options, and the ability to opt out of commercial messaging.
When the user clicks Save preferences, Knock writes their changes back to their default preference set. The link never expires.
Configure your preference center
#You configure the preference center from the Knock dashboard under Platform > Preferences > Preference center. Your configuration is environment-specific.
When the preference center is saved and enabled, changes go live in the environment right away. When the preference center is disabled, users can only edit their commercial messages opt-out preference.
How configuration maps to preferences
#Each row in your preference center maps to a key in the recipient's PreferenceSet. A row can point at a category, a workflow, or a channel, and can scope to one or more channel types.
When a user saves their preferences, Knock updates the corresponding keys on the recipient's default preference set. These changes are merged with any environment or tenant defaults during preference evaluation, with the recipient's preferences taking precedence according to the merge hierarchy.
Linking to the preference center
#To link a user directly to their preference center from a notification, include the URL in your message template or email layout using the built-in variable:
Knock renders the user-specific link in the notification. Use vars.manage_preferences_url when you want to give users full control over their preferences via the hosted preference center. For single-click opt-out of commercial messages via the commercial unsubscribe feature, use vars.commercial_unsubscribe_url instead.
Copying configuration between environments
#Your preference center configuration is environment-specific, just like your preference defaults. You can copy it from one environment to another using the "Copy to..." button in the upper right corner of the preference center settings. This enables you to keep your environments in sync as you move from development to production.
Learn more
#To learn more about the preferences model behind the preference center, see the preferences overview.