1. What is Gradual Rollout?
Gradual rollout is a feature that allows you to control which users are able to interact with the passkey Corbado Web UI Components. This gives you the flexibility to introduce passkeys to your users in a phased manner, for example, by first enabling it for a small percentage of users and then gradually rolling it out to a wider audience. This is managed through a set of rules that determine whether a user should be presented with a passkey component for appending a new passkey, logging in with a passkey, or viewing their list of passkeys.2. How does it work?
Whenever one of the Corbado Web UI Components is about to be displayed to a user, it checks with Corbado’s backend to see if the user is eligible based on the configured rules. Based on the response, the component will either render or stay hidden. These rules can be managed in the Corbado developer panel.3. Configuration Options
You can define rules based on a variety of factors to precisely target user segments:- IP Address: You can restrict access to a certain IP range, which is useful for internal testing.
- Operating System: You can target users on specific operating systems and versions, like showing a component only to iOS users.
- Browser: Similarly, you can target specific browsers, like Chrome, and even specific versions.
- Random Percentage: You can roll out a feature to a random subset of your users, for example, enabling it for just 1% of them initially.
4. Example Scenario
Here’s a possible scenario for a phased rollout during the first week after launching passkeys:- Appending passkeys: Enabled for only 5% of iOS users. This lets a small group of users start creating passkeys.
- Logging in with passkeys: Enabled for 100% of users. This ensures that anyone who has a passkey can use it to log in.
- Managing passkeys: Disabled for everyone initially.
5. Example Ruleset: append-allowed
Here is a comprehensive example of a ruleset for theappend-allowed feature, broken into two phases to show how a rollout can evolve.
5.1 Phase 1: Invitation-Only Rollout
Initially, you can use a very simple ruleset to ensure only internal team members or designated testers can access the new feature in production. This is done using a secret invitation token.- Invitation Token: The WLInvitationTokenrule uses a highsalience(priority) to immediately allow access only to someone with the token. For web, this can be a URL parameter (?invitation-token=secret-token), and for native apps, it can be triggered by a specific gesture.
- Default Deny: The DefaultDenyrule acts as a safety net, blocking everyone else.
5.2 Phase 2: Extended Rollout with Platform and Canary Rules
After initial testing, you can extend the ruleset to roll the feature out to specific platforms, versions, and eventually a random percentage of your users.- Block Unsupported Environments: It blocks automated test frameworks and unsupported browsers.
- Platform & Version Whitelisting: It explicitly allows the feature on specific operating systems and versions that are known to work well. Note that some rules are disabled with when False, allowing you to prepare them for future activation.
- Canary Rollout: The WLCanary5rule introduces a 5% random sampling (as reflected in the rule name). This is a powerful way to ramp up exposure and detect any potential issues with a smaller user group. This percentage can be gradually increased over time (e.g., to 10%, 25%, 50%, and finally 100%) directly in the configuration without requiring any app releases or deployments, allowing for a controlled and safe rollout.
- Default Deny: The final rule continues to act as a safety net.