Advanced features

Associate the device with a user

You can associate your own ID to each device. In this way it will be easier and more intuitive for you to work with our tool. For example:

  • If your users have been identified, you could use your user ID, or email, or any other data that you are used to working with.
  • If your users are anonymous because they have not logged into the app, you may have a Google Analytics or Commscore metric system. You could use the ID provided by these tools.

To make this association between your custom ID (externalId), and the identifier handled by indigitall (deviceId), you have to invoke the setExternalCode method:

IndigitallFlutterPlugin.setExternalCode("YOUR_EXTERNAL_ID", (device) => {
      //DO SOMETHING
  },(error) => {
      //LOG IndigitallErrorModelModel
  });

Do not you worry about anything. Your IDs are irreversibly encrypted on the phone itself and sent securely to our servers. Not even the indigitall team can know this information.

WiFi filter

If it is required to collect the user's WiFi information, in addition to the indigitall panel configuration, you must add the parameter wifiFilterEnabled when the SDK is initialized:

IndigitallFlutterPlugin.init({
  IndigitallParams.PARAM_APP_KEY: "<YOUR_APP_KEY>",
  IndigitallParams.PARAM_SENDER_ID: "<YOUR_SENDER_ID>",
  IndigitallParams.PARAM_WIFI_FILTER_ENABLED: true
});
  • The location permission must be accepted by the user
  • Please note that the WiFi scan time when the app is in the background or closed may be inaccurate.
Android

In order to obtain the Wi-Fi information in android, the following permissions and services declared in the manifest are needed:

<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
  <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
  <uses-permission android:name="android.permission.ACCESS_BACKGROUND_LOCATION"/>

  <uses-permission android:name="android.permission.CHANGE_WIFI_STATE"/>
  <uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/>

  // ANDROID 12 WIFI
  <uses-permission android:name="android.permission.CHANGE_NETWORK_STATE"/>
  <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>

//WiFi service
<service
    android:name="com.indigitall.android.services.WifiStatusService"
    android:permission="android.permission.BIND_JOB_SERVICE" >
</service>

<receiver android:name="com.indigitall.android.receivers.WifiWakeLockReceiver">
    <intent-filter>
        <action android:name="AlarmReceiver.Action.NETWORK_ALARM" />
    </intent-filter>
</receiver>
iOS

Likewise, you must add in the project options in Xcode, in Signing & Capabilities the option Access WiFi Information :

Custom domain

If you are ENTERPRISE CUSTOMER you have to add this parameter in the configuration so that the SDK points to the correct environment

IndigitallFlutterPlugin.init({ 
    IndigitallParams.PARAM_APP_KEY: "YOUR_APPKEY", 
    ...
    IndigitallParams.PARAM_URL_DEVICE_API: "YOUR_DEVICE_API_DOMAIN",
    IndigitallParams.PARAM_URL_INAPP_API: "YOUR_INAPP_API_DOMAIN",
    IndigitallParams.PARAM_URL_INBOX_API: "YOUR_INBOX_API_DOMAIN",
    ...
    }