Digital Measurement Android Artifactory Guide
From Engineering Client Portal
    
The Nielsen AppSDK can either be downloaded directly from the Engineering Portal, or can be integrated directly within an application through the use of a CocoaPod or Gradle.
How to install the Nielsen AppSDK using Gradle for Android
Below are the steps which need to be performed by app developers to integrate the Nielsen App SDK within an Android application.
Update grade.properties
The first step is to add the credentials received from Nielsen into your gradle.properties file, typically near the end of the file. We recommend using the version in your home folder (Global Properties). Gradle looks for gradle.properties files in this sequence:
- gradle.propertiesin project root directory.
- gradle.propertiesin GRADLE_USER_HOME directory.
- system properties, e.g. when -Dgradle.user.homeis set on the command line.
Properties from one file will override the properties from the previous ones (so file in gradle user home has precedence over the others, and file in sub-project has precedence over the one in project root).
Reference: https://gradle.org/docs/current/userguide/build_environment.html
machine raw.githubusercontent.com
nielsen_user=<Nielsen App SDK client>
nielsen_authCode=<Auth token>
Please do not upload any file to github or bitbucket containing the credentials above.
This will automatically lock your access.
Credentials
Obtain credentials → here ←
Add Nielsen Maven Repository
Please add the Nielsen maven repository inside the repositories section of your app's module build.gradle file like below:
android{ 
repositories {
   //Copy below code inside repository section of app’s build.gradle file
maven { url 'https://raw.githubusercontent.com/NielsenDigitalSDK/nielsenappsdk-android/master/'
   credentials {
      //Make sure you add nielsen_user and nielsen_passwd with respective nielsen provided
     // values to global gradle.properties file
       username = project.property("nielsen_user")
       password = project.property("nielsen_authCode")
   }
   authentication {
       basic(BasicAuthentication)
   }
}
}
}
Add gradle dependency
Please add Nielsen app SDK as compile time dependency inside build.gradle file as below
grade 4.x and above
For gradle version starting with 4.x add the following line inside dependencies section of build.gradle file.
implementation 'com.nielsenappsdk:${flavour}:${version}'
grade prior to 4.x
For gradle version previous to 4.x add below line inside dependencies section of build.gradle file.
compile 'com.nielsenappsdk:${flavour}:${version}'
Version Control
It is recommended to use  +  to ensure you receive the most recent version of the NielsenSDK.
compile 'com.nielsenappsdk:${flavour}:${version}'
and a sample is:
dependencies { ....
implementation 'com.nielsenappsdk:globalx:+'
}
However a specific version can also be requested.  To specify a version, please replace ${version} with required Nielsen App SDK release.
dependencies { ....
implementation 'com.nielsenappsdk:globalx:7.1.0.0'
}
If using version control, a warning message will be displayed within the console trace during the build of your app, and it will show all sdk versions released to-date, allowing a developer to select a more recent build if desired.
Flavor Control
To specify a specific flavor of the Nielsen SDK, please replace ${flavor} with one of below flavor types: 
| App Flavor Name | Description | |
|---|---|---|
| com.nielsenappsdk:globalx | GLOBAL flavor of appsdk for androidx apps | Recommended | 
| com.nielsenappsdk:global | GLOBAL flavor of appsdk for non androidx apps | |
| com.nielsenappsdk:agfx | AGF flavor of appsdk for androidx apps | Recommended | 
| com.nielsenappsdk:agf | AGF flavor of appsdk for non androidx apps | 
Starting with Version 8.x, the Nielsen SDK will only support Androidx. If
com.nielsenappsdk:globalis requested, you will be provided withcom.nielsenappsdk:globalx. It is recommended to use Androidx version whenever possible.
Below is an example for dependency
dependencies { ....
implementation 'com.nielsenappsdk:globalx:+'
}
Ensuring you have the latest release information
It is recommended to use the most recent version of the NielsenSDK by using the following:
dependencies { ....
implementation 'com.nielsenappsdk:globalx:+'
}
In addition, please add below gradle task inside your  build.gradle (Module:app) or build.gradle(Project:My-app) file to fetch latest release details of nielsen app sdk as below:
Please note: The
build.gradle (Module:app)can overwrite thebuild.gradle(Project:My-app).
task NielsenSdkReleaseCheck {
   def login_details = project.property("nielsen_user")+":"+project.property("nielsen_authCode")
   def p = ['curl', '-u',login_details ,"https://raw.githubusercontent.com/NielsenDigitalSDK/nielsenappsdk-android/master/com/nielsenappsdk/global/NielsenAppSdk-ReadMe.md"].execute().text
   project.logger.log(LogLevel.ERROR,p)
}
preBuild.dependsOn('NielsenSdkReleaseCheck')
= App Suffix Reference
The Nielsen AppSDK has various configurations per market and distribution type, which can be determined by reviewing the sdk suffix.  The first part will be the SDK version: 3 digits for the major SDK version and 1 digit for the minor SDK version. EG: aa.8.1.0.0_abc
Sync
If you are finished with all previous steps then you can sync your build.gradle and after successful build you are ready to use Nielsen App SDK library in your code.
Sample file
The below is an example of a very basic app build.gradle file
apply plugin: 'com.android.application'
android {
    compileSdkVersion 29
    defaultConfig {
        applicationId "com.nielsen.android_bsdk_app"
        minSdkVersion 23
        targetSdkVersion 29
        versionCode 1
        versionName "1.0"
        testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
        }
    }
    repositories {
        //Copy below code inside repository section of app’s build.gradle file
        maven { url 'https://raw.githubusercontent.com/NielsenDigitalSDK/nielsenappsdk-android/master/'
            credentials {
                //Make sure you add nielsen_user and nielsen_passwd with respective nielsen provided
                // values to global gradle.properties file
                username = project.property("nielsen_user")
                password = project.property("nielsen_authCode")
            }
            authentication {
                basic(BasicAuthentication)
            }
        }
    }
}
task NielsenSdkReleaseCheck {
    def login_details = project.property("nielsen_user")+":"+project.property("nielsen_authCode")
    def p = ['curl', '-u',login_details ,"https://raw.githubusercontent.com/NielsenDigitalSDK/nielsenappsdk-
android/master/com/nielsenappsdk/global/NielsenAppSdk-ReadMe.md"].execute().text
    project.logger.log(LogLevel.ERROR,p)
}
preBuild.dependsOn('NielsenSdkReleaseCheck')
dependencies {
    implementation fileTree(include: ['*.jar'], dir: 'libs')
    implementation 'com.nielsenappsdk:globalx:7.2.0.0'
    implementation 'androidx.appcompat:appcompat:1.1.0'
    implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'androidx.test.ext:junit:1.1.1'
    implementation 'com.google.android.gms:play-services:+'
    implementation 'androidx.lifecycle:lifecycle-extensions:2.0.0'
    implementation 'com.android.support:multidex:1.0.3'
    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'com.android.support.test:runner:1.0.2'
    androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'
}
