Deep Linking
Before starting, you should reference the extensive docs from React Navigation for setting up Deep Linking:
While React Navigation's docs cover the setup for the iOS/Android app, this guide aims to be a complete reference for enabling Universal Linking, including the code needed on the website.
Video​
Overview​
- Set up your React Navigation linking config- Add prefixes correctly
 
- Confirm your app.json/app.config.jshas aschemeproperty inapps/expo
- Configure associatedDomains(iOS) andintentFilters(Android) in yourapp.json/app.config.jsinapps/expo
- Set up apple-app-site-associationon your Next.js app.- This part is unique to this guide.
 
- Test it out
Android instructions for universal linking aren't done yet. I'd accept a PR though.
1. Linking config​
- React Navigation Docs
- Example linking config- Note that this example only has one prefix. If you want Universal Links to work (meaning yourdomain.comshould open your app), be sure to add the correct prefixes.
 
- Note that this example only has one prefix. If you want Universal Links to work (meaning 
For example, if your website is beatgig.com, you might have something like this in your prefixes:
ts
ts
2. Scheme​
Confirm your app.json/app.config.js has a scheme property in apps/expo
js
js
Your app scheme will let you link into your app. For example, if your scheme is solito, then solito:/// will open the app from your iPhone.
3. associatedDomains + intentFilters​
Expo docs:
Your app.json/app.config.js will need to specify the domain you want to receive links from.
For example, imagine you want the app to open from beatgig.com. Then in app.config.js:
js
js
Notice that ios has applinks: prefixing the URL.
4. Apple App Site association​
In order to get Universal Links to work, Apple requires that your website has a file at the path /.well-known/apple-app-site-association on your URL.
1. Create an API route​
Create a file at this exact location in your Solito repo:
apps/next/pages/api/.well-known/apple-app-site-association.ts
Paste the contents from the code block below. Your TEAM_ID is found on AppStore Connect when you click the icon in the top right.
Your bundle ID will look something like com.nandorojo.app. It must exactly match the ios.bundleIdentifier from your app.config.js/app.json in apps/expo.
ts
ts
To see more about how to configure your links, read Apple's docs.
By default, the above code will make any URL clicked from your phone that matches your domain open the app. To change this, you can edit the paths field. For example, you probably don't want someone clicking your marketing page and then deep linking into your app:
ts
ts
2. Add a redirect​
Finally, Apple expects this file to exist at the exact path yourdomain.com/.well-known/apple-app-site-association.
Since the file we created above is an API route, we need to create a redirect in next.config.js:
apps/next/next.config.js
js
js
Your final next.config.js file might look like this:
js
js
5. Test your app​
First, you'll need to make sure you publish your website on the domain you used.
Once it's live, create a new build of your Expo app with expo run:ios -d. Plug your iPhone into your computer to test it out. You can also build it with EAS, Expo's cloud build service.
Next, try texting yourself a URL, and see if it deep links.
It's worth noting that Apple caches your website's apple-app-site-association for a specific install of the iPhone app. As a result, if you update your Next.js site's apple-app-site-association file, it won't be reflected in the iPhone unless you reinstall it.