Hosted preference center
Learn how to use Knock's hosted preference center to let your users manage notification preferences without writing any code.
Knock's hosted preference center is a page where your users manage their notification preferences. Knock hosts and renders the page, you configure it from the dashboard, so you can launch a preference center without building or hosting any UI yourself.
This is the fastest way to give your users a preference center. If you need more control over the experience, you can still 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 environment-level preference center configuration shape. When the user clicks Save preferences, Knock writes their changes back to the recipient's default preference set. The link never expires.
The page reflects the recipient it was generated for, including the account branding, the preference options you've configured, and a row for commercial messages opt-out.
Enable and 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.
For example, imagine the new-comment workflow belongs to the collaboration category, and your preference center has a row for the collaboration category and a separate row for the new-comment workflow. If a user opts out of either the collaboration category row or the new-comment workflow row, the comment notification won't be delivered, because both preferences must evaluate to true for the notification to send.
Linking users to the preference center
#To send users to their preference center, include the manage-preferences URL in your email templates using the built-in variable:
This sits alongside the existing vars.commercial_unsubscribe_url variable, which links to the one-click commercial unsubscribe flow. Use vars.manage_preferences_url when you want to give users full control over their preferences, and vars.commercial_unsubscribe_url for a single-click opt-out of commercial messages.
You can also add the preference center link to your emails without editing template code by configuring footer links in your email layout settings.
Copying configuration between environments
#Your preference center configuration is environment-specific, just like your preference defaults. You can copy the configuration from one environment to another 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. To set up one-click unsubscribe for commercial messaging, see commercial unsubscribe.