Overview
World ID 4.0 unlocks powerful new capabilities for your app:- New credential types: More flexibility in requesting proofs with new credential options and third party issuance
- World ID proofs without World App: You can generate World ID proofs directly in your own native app without needing the World App.
- Account Recovery: Recovery flows and other improvements to prevent users from losing their World IDs.
To migrate:
- Register in the Developer Portal and generate new keys
- Upgrade IDKit/MiniKit to 4.0. This is non breaking and supports v3 and v4 proofs.
- Follow the respective migration plan below
- On chain applications will require new World ID 4.0 contract addresses to verify proofs
Migrating your app in the Developer Portal is not a breaking change. You can
do this before migrating your app logic to World ID 4.0. Authenticators will
support 3.0 proofs at least until the end of the year for existing users. New
users will stop being registered with legacy 3.0 from May 1, 2026.
Definitions:
- Relying Party (RP): An application that uses World ID to verify users.
- Session Proofs: A new proof type in World ID 4.0 that lets an RP verify a returning user is the same World ID holder they interacted with previously. Session Proofs last the lifetime of a user’s World ID
Migration Timeline (Phase Dates)
Use these dates as the default migration timeline referenced throughout this guide, some dates may shift later:- Phase 1 (Migration): through May 1, 2026
- Upgrade SDKs/contracts, register your RP, and create v4 actions.
- New World App users will have v3 and v4 credentials
- Phase 2 (Transition): May 1, 2026 to March 31, 2027
- New users from this date will only be able to create 4.0 proofs.
- All users migrated to 4.0
- Phase 3 (v3 Cut-off): from April 1, 2027 onward
- v3 Proofs will no longer be generated by World App
If your rollout needs more time, extend Phase 2 and move
CD later. Keep
Phase 2 long enough to avoid excluding users with older credentials.New API Design
Backend Setup (Node.js)
Backend Signing
Frontend Implementation
Compatibility flow for 3.0
Migration Path
Below we outline migration paths based on how you previously used World ID in your application.One time actions
These apps have a single long running action. Examples: A stamp for every verified human in the world. A token given to every human in the world once.Important:
genesis_issued_at is when the user originally got their
credential (for example, went to an Orb), not when they upgraded their
authenticator to v4. A user who was Orb-verified in 2023 and upgrades to v4
in 2025 still has genesis_issued_at from 2023.Migration Flow Diagram
This diagram shows the three-phase migration process: preparation, gradual transition, and v3 cut-off. Summary: During Phase 2, both v3 and v4 proofs are accepted. Phase 3 enforces v4-only.Step-by-step Migration Details
- Update SDKs and Contracts: RPs upgrade SDKs, contracts, and API calls to enable baseline support for the upgraded protocol. This is backwards compatible.
- Register in Developer Portal: RPs generate their new RP registration and relevant actions for the v4 protocol in the Developer Portal.
- For long-running actions:
- RP decides a transition date (
TD) to start accepting v4 proofs. They specify a minimumgenesis_issued_at = TDtimestamp in the IDKit request withallow_legacy_proofs: true. This means only users who get their Orb credential (or document credentials) from this point forward can generate v4 proofs. Users who have not upgraded their World App can still issue v3 proofs. RPs should keep track of both nullifiers. The nullifiers can be kept together as collision risk is very low. - At a future cut-off date (
CD > TD), the RP should switch their IDKit request toallow_legacy_proofs: falseto stop accepting v3 proofs and only accept v4 proofs.
- RP decides a transition date (
- For limited-time actions (for example, recurring grant drops): The transition can be made at the action level. Short-running actions have a simpler migration path.
Example Code
Old Contract - Disable minting here:Mint.sol
Mintv4.sol
Short Term Recurring Actions
These apps create multiple one-time actions. These actions are short lived. Example: A daily voting app where each vote requires a fresh proof of human. Migration approach: Simply migrate your SDK and Developer Portal account. Pick a new action in the future to start only accepting v4 proofs.Migration Flow Diagram
This diagram shows a simpler two-phase migration with a hard cutover. Summary: During Phase 2, only accept v4 proofs for new actions.Recurring Verifications and New Credential Checks
For apps that rely on unlimited verifications of the same action. Examples: Partners that check for users who’ve added new credentials. Apps that allow users to verify before each claim using the same action (note this is an anti-pattern of World ID). Migration approach: Migrate to using Session Proofs, which allow developers to verify credentials over a period of time while ensuring it’s the same user. The session ID returned in the proof will be the long-lived stable identifier instead.Migration Flow Diagram
This diagram shows how Session Proofs provide a stable identifier across multiple verifications. Summary: Session IDs provide continuity across verifications, replacing nullifiers as the stable identifier.Creating a session
Proving a session
New Apps
Apps launched after v4 is fully released will not need to migrate.Deprecating Verification Level
With the introduction of credentials, a minimum verification level no longer makes sense. Credentials can now be requested arbitrarily viaall, any, and enumerate.
For convenience, we have introduced legacy presets that mirror the respective verification levels from the 3.0 protocol:
OrbLegacyPresetSecureDocumentLegacyPresetDocumentLegacyPreset
Example: Using Legacy Presets
Recovery
Context: The Recovery feature will optionally let users who lose access
to all authenticators recover their existing World ID account. This only
works for users in the new v4 protocol - users in the legacy v3 protocol will
not be able to directly recover their existing World ID.
- Users who verified (obtained their Orb credential) prior to the introduction of World ID 4.0 will be able to get a new credential in a new World ID in the new protocol once, essentially looking new. This is an issuer decision, and it has been called Reset in the past.
- Importantly,
genesis_issued_atstill defers to the original credential issuance date, allowing you to prevent double claims.
- Importantly,
Disclosures
- Nullifiers are now one-time use. Applications that need a stable identifier across verifications should use session proofs. After creation, sessions require an RP to pass the same session ID in future session verifications.
- New users after the migration to 4.0 will not have a legacy (3.0) World ID.
- Estimate: May 1, 2026