Search specific term/phrase surrounded by double quotes. e.g. “deep linking”
Exclude records that contain a specific term prefixed with a minus. e.g. Android -Firebase

Flutter SDK Full Reference

All the methods made available by Branch for your Flutter app.

initSession (Deprecated)

MethodDescription
Stream<Map<dynamic, dynamic>> initSession()Initiates a session with the Branch API through a listener.

Example Usage

streamSubscription = FlutterBranchSdk.initSession().listen((data) {
  print('listenDynamicLinks - DeepLink Data: $data');
  controllerData.sink.add((data.toString()));
  if (data.containsKey('+clicked_branch_link') &&
      data['+clicked_branch_link'] == true) {
    print(
      '------------------------------------Link clicked----------------------------------------------');
    print('Custom string: ${data['custom_string']}');
    print('Custom number: ${data['custom_number']}');
    print('Custom bool: ${data['custom_bool']}');
    print('Custom list number: ${data['custom_list_number']}');
    print(
      '------------------------------------------------------------------------------------------------');
    showSnackBar(
      context: context,
      message: 'Link clicked: Custom string - ${data['custom_string']}',
      duration: 10);
  }
}, onError: (error) {
  PlatformException platformException = error as PlatformException;
  print(
    'InitSession error: ${platformException.code} - ${platformException.message}');
  controllerInitSession.add(
    'InitSession error: ${platformException.code} - ${platformException.message}');
});

validateSDKIntegration

MethodDescription

void validateSDKIntegration()

Use the SDK integration validator to check that you've added the Branch SDK and handle deep links correctly when you first integrate Branch into your app. Validates the following:

  • Branch Keys
  • Package Name
  • URI Schemes
  • Android App Link
  • Universal Links
  • Link Domains

Example Usage:

FlutterBranchSdk.validateSDKIntegration();

setRequestMetadata

MethodDescription
void setRequestMetadata(String key, String value)Set specific key/value pairs to all requests. This is required for integrating with specific partners like Adobe Analytics, Amplitude, etc. Partner keys can be found in the partner-specific guides.
ArgumentTypeDescription
keyStringThe partner key. Ex. $marketing_cloud_visitor_id
valueStringThe value of the partner key

Example Usage

FlutterBranchSdk.setRequestMetadata(requestMetadataKey, requestMetadataValue);

setIdentity

MethodDescription
void setIdentity(String userId)Set the identity of a user (ID, UUID, etc) for events, deep links, and referrals. Use this method when the user logs into their account in your app.See PII Best Practices for details.
ArgumentTypeDescription
userIdStringThe unique ID of the user

Example Usage

FlutterBranchSdk.setIdentity('user1234567890');

isUserIdentified

MethodDescription
Future<bool> isUserIdentified()Indicate whether or not this user has a custom identity specified for them. Note that this is independent of installs.If you call the setIdentity method, this device will have that identity associated with this user until the logout method is called.This includes persisting through uninstalls, as device ID is tracked.

Example Usage

bool isUserIdentified = await FlutterBranchSdk.isUserIdentified();

logout

MethodDescription
void logout()Clear the identity set from the setIdentity() method. This method should be called if you know that the user is explicitly logging out or if a different person is about to use the app.

Example Usage

FlutterBranchSdk.logout();

handleDeepLink

MethodDescription
void handleDeepLink(String url)End the current deep link session and starts a new session with the provided URL.

To handle push notifications, call this method inside of the push notification callback.
ArgumentTypeDescription
urlStringThe URL of the deep link for the new session.

Example Usage

FlutterBranchSdk.handleDeepLink('myapp://open?link_click_id=12345');

getLatestReferringParams

MethodDescription
Future<Map<dynamic, dynamic>> getLatestReferringParams()Return the last parameters associated with the link that referred the user to the current app session.

Example Usage

Map<dynamic, dynamic> params = await FlutterBranchSdk.getLatestReferringParams();

getFirstReferringParams

MethodDescription
Future<Map<dynamic, dynamic>> getFirstReferringParams()Return the first parameters associated with the link that referred the user. Consider this as the parameters used to retrieve the details from the user's first app session.

Example Usage

Map<dynamic, dynamic> params = await FlutterBranchSdk.getFirstReferringParams();

disableTracking

MethodDescription
void disableTracking(bool value)void disableTracking(bool value)If you need to comply with a user's request to not be tracked for GDPR purposes, or otherwise determine that a user should not be tracked, utilize this method to prevent Branch from sending network requests. This setting can also be enabled across all users for a particular link or across your Branch Links.
ArgumentTypeDescription
valueBooleanIf set to true, disableTracking is enabled.
If set to false, disableTracking is disabled.

Example Usage

FlutterBranchSdk.disableTracking(true);

getShortUrl

ArgumentTypeDescription
buoBranchUniversalObjectThe Universal Object used to define content within your app.BUO Best Practices
linkPropertiesBranchLinkPropertiesThe analytics properties associated with the link you are about to generate.

Example Usage

BranchUniversalObject buo = BranchUniversalObject(
  canonicalIdentifier: 'flutter/branch',
  //canonicalUrl: '',
  title: 'Flutter Branch Plugin',
  imageUrl: 'https://flutter.dev/assets/flutter-lockup-4cb0ee072ab312e59784d9fbf4fb7ad42688a7fdaea1270ccf6bbf4f34b7e03f.svg',
  contentDescription: 'Flutter Branch Description',
  keywords: ['Plugin', 'Branch', 'Flutter'],
  publiclyIndex: true,
  locallyIndex: true,
  contentMetadata: BranchContentMetaData()..addCustomMetadata('custom_string', 'abc')
  ..addCustomMetadata('custom_number', 12345)
  ..addCustomMetadata('custom_bool', true)
  ..addCustomMetadata('custom_list_number', [1,2,3,4,5 ])
  ..addCustomMetadata('custom_list_string', ['a', 'b', 'c']),
);

BranchLinkProperties lp = BranchLinkProperties(
  //alias: 'flutterplugin', //define link url,
  channel: 'facebook',
  feature: 'sharing',
  stage: 'new share',
  tags: ['one', 'two', 'three']
);
lp.addControlParam('url', 'http://www.google.com');
lp.addControlParam('url2', 'http://flutter.dev');

BranchResponse response =
  await FlutterBranchSdk.getShortUrl(buo: buo, linkProperties: lp);
if (response.success) {
  print('Link generated: ${response.result}');
} else {
  print('Error : ${response.errorCode} - ${response.errorMessage}');
}

showShareSheet

ArgumentTypeDescription
buoBranchUniversalObjectThe Universal Object used to define content within your app. BUO Best Practices
linkPropertiesBranchLinkPropertiesThe analytics properties associated with the link you are about to generate.
messageTextStringThe body of the message in your share sheet.
androidMessageTitleStringThe message title of the share sheet.
androidSharingTitleStringThe sharing title of the share sheet.

Example Usage

BranchResponse response = await FlutterBranchSdk.showShareSheet(
  buo: buo,
  linkProperties: lp,
  messageText: 'My Share text',
  androidMessageTitle: 'My Message Title',
  androidSharingTitle: 'My Share with');

if (response.success) {
  print('showShareSheet Sucess');
} else {
  print('Error : ${response.errorCode} - ${response.errorMessage}');
}

getQRCode

ArgumentTypeDescription
primaryColor ColorColor name or Hex color value
backgroundColor ColorColor name or Hex color value of the background of the QR code itself.
margin Integer (Pixels)The number of pixels you want for the margin. Min 1px. Max 20px.
width Integer (Pixels)Output size of QR Code image. Min 300px. Max 2000px. (Only applicable to JPEG/PNG)
imageFormat BranchImageFormatJPEG, PNG
centerLogoUrlString (HTTP URL)URL to the image you want as a center logo e.g. https://raw.githubusercontent.com/RodrigoSMarques/flutter_branch_sdk/master/assets/branch_logo_qrcode.jpeg

Example Usage

BranchResponse responseQrCodeImage = await FlutterBranchSdk.getQRCodeAsImage(
  buo: buo!,
  linkProperties: lp,
  qrCode: BranchQrCode(primaryColor: Colors.black, 
                       //primaryColor: const Color(0xff443a49), //Hex colors
                       centerLogoUrl: imageURL,
                       backgroundColor: Colors.white,
                       imageFormat: BranchImageFormat.PNG));

  if (response.success) {
      print('QrCode Success');
      showQrCode(this.context, responseQrCodeImage.result);
      /*
       Image(image: responseQrCodeImage.result,
             height: 250,
             width: 250,),
      */
  } else {
     print('Error : ${response.errorCode} - ${response.errorMessage}');

trackContent

By default, the Branch SDK tracks clicks, opens, installs, reinstalls and impressions automatically (out-of-the-box).

General Event Tracking

Please refer to our Event Tracking Docs for more information and examples:

Tracking In-App Web View Events

With the Branch Flutter SDK, it is possible to inject JavaScript into an in-app web view with event listeners to make calls to one of our mobile SDKs.

In this scenario, the website’s JavaScript posts a message when a button or element on the page is clicked. The app then uses a JavaScript channel to listen for that message. Inside of the callback, a switch statement is used to check the message and trigger a Branch Event.

To implement this approach:

  1. Add JavaScript code to the website to add a listener to the button’s selector and call the postMessage() function:

    var _selector = document.querySelector('button[id=BUTTON_ID]');
    _selector.addEventListener('click', function(event) {
      var message = "LOGIN";
    
      if (messageHandler) {
        messageHandler.postMessage(message);
      }
    });
    
  2. Add a JavaScript channel to the WebViewController to handle the onMessageRecieved callback and trigger the corresponding Branch Event:

    class _MyWebViewState extends State<MyWebView> {
      late final WebViewController controller;
      @override
      void initState() {
        super.initState();
        controller = WebViewController()
          ..loadRequest(
            Uri.parse('https://YOUR_WEBSITE.com'),
          );
        controller.setJavaScriptMode(JavaScriptMode.unrestricted);
        controller.addJavaScriptChannel('messageHandler',
            onMessageReceived: (message) {
          switch (message.message) {
            case "LOGIN":
              BranchEvent event =   
              BranchEvent.standardEvent(BranchStandardEvent.LOGIN);
              FlutterBranchSdk.trackContentWithoutBuo(branchEvent: event);
              break;
            case "PURCHASE":
              BranchEvent event = 
              BranchEvent.standardEvent(BranchStandardEvent.PURCHASE);
              FlutterBranchSdk.trackContentWithoutBuo(branchEvent: event);
              break;
          }
        });
      }
    }
    

registerView

MethodDescription
void registerView({required BranchUniversalObject buo})Mark the content referred to by this object as viewed. This will increment the view count of the contents referred by this object.
ArgumentTypeDescription
buoBranchUniversalObjectThe Universal Object used to define content within your app.BUO Best Practices

Example Usage

FlutterBranchSdk.registerView(buo: buo);

listOnSearch

ArgumentTypeDescription
buoBranchUniversalObjectThe Universal Object used to define content within your app. BUO Best Practices
linkPropertiesBranchLinkPropertiesThe analytics properties associated with the link you are about to generate.

Example Usage

bool success = await FlutterBranchSdk.listOnSearch(buo: buo);
print(success);

removeFromSearch

MethodDescription
Future<bool> removeFromSearch( {required BranchUniversalObject buo, BranchLinkProperties? linkProperties})On iOS, remove the BUO from Spotlight if privately indexed.
ArgumentTypeDescription
buoBranchUniversalObjectThe Universal Object used to define content within your app.BUO Best Practices
linkPropertiesBranchLinkPropertiesThe analytics properties associated with the link you are about to generate.

Example Usage

bool success = await FlutterBranchSdk.removeFromSearch(buo: buo);
print('Remove sucess: $success');

setIOSSKAdNetworkMaxTime

MethodDescription
void setIOSSKAdNetworkMaxTime(int hours)Set the time window for SKAdNetwork callout in hours on iOS only.

By default, Branch limits calls to SKAdNetwork to within 72 hours after first install.
ArgumentTypeDescription
hoursintTime window in hours.

Example Usage

FlutterBranchSdk.setIOSSKAdNetworkMaxTime(24);


requestTrackingAuthorization

MethodDescription
Future<AppTrackingStatus> requestTrackingAuthorization()Request AppTracking Authorization and returns AppTrackingStatus on iOS only.

Example Usage

AppTrackingStatus status = await FlutterBranchSdk.requestTrackingAuthorization();
print(status);

getTrackingAuthorizationStatus

MethodDescription
Future<AppTrackingStatus> getTrackingAuthorizationStatus()Return AppTrackingStatus on iOS only.

Example Usage

AppTrackingStatus status = await FlutterBranchSdk.getTrackingAuthorizationStatus();
print(status);

getAdvertisingIdentifier

MethodDescription
Future<String> getAdvertisingIdentifier()Return the advertising identifier on iOS only.

Example Usage

String status = await FlutterBranchSdk.getAdvertisingIdentifier();
print(status);