nativescript-plugin-appsflyer
Version:
Appsflyer SDK for NativeScript applications
204 lines (146 loc) • 7.62 kB
Markdown
# Deeplink
<img src="https://massets.appsflyer.com/wp-content/uploads/2018/06/20092440/static-ziv_1TP.png" width="400" >
## <a id="deeplinking"> Deep Linking
<img src="https://massets.appsflyer.com/wp-content/uploads/2018/03/21101417/app-installed-Recovered.png" width="350">
#### The 3 Deep Linking Types:
Since users may or may not have the mobile app installed, there are 2 types of deep linking:
1. Deferred Deep Linking - Serving personalized content to new or former users, directly after the installation.
2. Direct Deep Linking - Directly serving personalized content to existing users, which already have the mobile app installed.
3. Unified deep linking - Unified deep linking sends new and existing users to a specific in-app activity as soon as the app is opened.
For more info please check out the [OneLink™ Deep Linking Guide](https://support.appsflyer.com/hc/en-us/articles/208874366-OneLink-Deep-Linking-Guide#Intro).
### <a id="deferred-deep-linking"> 1. Deferred Deep Linking (Get Conversion Data)
Handle the Deferred deeplink in the following callback:
```
var options = {
onConversionDataSuccess: function(_res){
console.log("Get conversion data success: " + JSON.stringify(_res));
},
}
```
Check out the deferred deeplinkg guide from the AppFlyer knowledge base [here](https://support.appsflyer.com/hc/en-us/articles/207032096-Accessing-AppsFlyer-Attribution-Conversion-Data-from-the-SDK-Deferred-Deeplinking-#Introduction)
### <a id="handle-deeplinking"> 2. Direct Deeplinking
Handle the Direct deeplink in the 'onAppOpenAttribution' callback:
```
var options = {
devKey: 'devKey',
appId: "appId",
isDebug: true,
onAppOpenAttribution: function(_res){
console.log("onAppOpenAttribution: " + JSON.stringify(_res));
},
onAppOpenAttributionFailure: function(_res){
console.log("onAppOpenAttributionFailure: " + JSON.stringify(_res));
},
};
```
When a deeplink is clicked on the device the AppsFlyer SDK will return the link in the [onAppOpenAttribution](https://support.appsflyer.com/hc/en-us/articles/208874366-OneLink-Deep-Linking-Guide#deep-linking-data-the-onappopenattribution-method-) method.
### <a id="Unified-deep-linking"> 3. Unified deep linking
Handle the Unified deeplink in the 'onDeepLinking' callback (if `onDeepLinking` callback is define, `onAppOpenAttribution` won't be called):
```
var options = {
devKey: 'devKey',
appId: "appId",
isDebug: true,
onDeepLinking: function(_res){
console.log("onDeepLinking: " + _res);
},
};
For more information about this api, please check [OneLink Guide Here](https://dev.appsflyer.com/docs/android-unified-deep-linking)
### <a id="android-deeplink"> Android Deeplink Setup
#### URI Scheme
In your app’s manifest add the following intent-filter to your relevant activity:
```xml
<intent-filter>
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="android.intent.category.BROWSABLE" />
<data android:scheme="your unique scheme" />
</intent-filter>
```
**NOTE:** On Android, AppsFlyer SDK inspects activity intent object during onResume(). Because of that, for each activity that may be configured or launched with any [non-standard launch mode](https://developer.android.com/guide/topics/manifest/activity-element#lmode) the following code was added to `MainActivity.java` in `android/app/src/main/java/com...`
Java:
```java
public void onNewIntent(Intent intent) {
super.onNewIntent(intent);
setIntent(intent);
}
```
Kotlin:
```
override fun onNewIntent(intent : Intent){
super.onNewIntent(intent)
setIntent(intent)
}
```
#### App Links
In your app’s manifest add the following intent-filter to your relevant activity:
```xml
<intent-filter android:autoVerify="true">
<action android:name="android.intent.action.VIEW" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="android.intent.category.BROWSABLE" />
<data android:scheme="your unique scheme" />
<data android:scheme="https"
android:host="yourcompany.onelink.me"
android:pathPrefix="your path prefix" />
</intent-filter>
```
For more on App Links check out the guide [here](https://support.appsflyer.com/hc/en-us/articles/115005314223-Deep-Linking-Users-with-Android-App-Links#what-are-android-app-links).
### <a id="iosdeeplinks"> iOS Deeplink Setup
### URI Scheme
1. Create custom app delegate
2. Add the following iOS method and AppsFlyer API
```
()
export class CustomAppDelegate extends UIResponder, ATTrackingManager implements UIApplicationDelegate{
public static ObjCProtocols = [UIApplicationDelegate];
applicationOpenURLOptions(application: UIApplication, urlOptions: NSURL, options: NSDictionary<string, any>): boolean {
console.log("applicationOpenURLOptions");
AppsFlyerLib.shared().handleOpenUrlOptions(urlOptions, options);
return true;
}
// Open URI-scheme for iOS 8 and below
applicationOpenURLSourceApplicationAnnotation(application: UIApplication, url: NSURL, sourceApplication: string, annotation: any): boolean {
console.log("applicationOpenURLSourceApplicationAnnotation");
AppsFlyerLib.shared().handleOpenURLSourceApplicationWithAnnotation(url, sourceApplication, annotation);
return true;
}
};
```
For more on URI-schemes check out the guide [here](https://support.appsflyer.com/hc/en-us/articles/208874366-OneLink-deep-linking-guide#setups-uri-scheme-for-ios-8-and-below)
### Universal Links
1. Create custom app delegate
2. Add the following iOS method and AppsFlyer API
```
()
export class CustomAppDelegate extends UIResponder, ATTrackingManager implements UIApplicationDelegate{
public static ObjCProtocols = [UIApplicationDelegate];
// Open Universal Links
applicationContinueUserActivityRestorationHandler?(application: UIApplication, userActivity: NSUserActivity, restorationHandler: (p1: NSArray<UIUserActivityRestoring>) => void): boolean{
console.log("applicationContinueUserActivityRestorationHandler");
AppsFlyerLib.shared().continueUserActivityRestorationHandler(userActivity, restorationHandler);
return true;
}
};
```
More on Universal Links:
Essentially, the Universal Links method links between an iOS mobile app and an associate website/domain, such as AppsFlyer’s OneLink domain (xxx.onelink.me). To do so, it is required to:
1. Get your SHA256 fingerprint:
a. Creating A Keystore
b. [Generate Fingerprint](https://developers.google.com/android/guides/client-auth)
2. Configure OneLink sub-domain and link to mobile app in the AppsFlyer onelink setup on your dashboard, add the fingerprint there (AppsFlyer takes care of hosting the ‘apple-app-site-association’ file)
3. Configure the mobile app to register approved domains:
```xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>com.apple.developer.associated-domains</key>
<array>
<string>applinks:test.onelink.me</string>
</array>
</dict>
</plist>
```
For more on Universal Links check out the guide [here](https://support.appsflyer.com/hc/en-us/articles/208874366-OneLink-Deep-Linking-Guide#setups-universal-links).