Panduan Integrasi Channel Engagelab

Mendapatkan Informasi Aplikasi

Buat aplikasi di konsol. Setelah aplikasi dibuat, AppKey akan otomatis dihasilkan untuk identifikasi aplikasi. Untuk detail lebih lanjut, lihat Pengaturan Aplikasi.

Mengimpor Library

  • Metode Manual
Impor mt-sdk-x.x.x.aar dari folder libs ke direktori libs. Impor th-xxx-x.x.x.aar yang ada di dalam paket libs ke direktori libs.
              
              Impor mt-sdk-x.x.x.aar dari folder libs ke direktori libs.
Impor th-xxx-x.x.x.aar yang ada di dalam paket libs ke direktori libs.

            
Tampilkan blok kode ini di jendela mengambang
  • Metode Otomatis
dependencies { // Wajib: Paket utama implementation 'com.engagelab:engagelab:4.3.9' // Contoh versi 4.3.9 // Opsional: Google implementation 'com.engagelab.plugin:google:4.3.9' // Opsional: Honor implementation 'com.engagelab.plugin:honor:4.3.9' implementation 'com.engagelab.plugin:honor_th_push:4.3.9' // Opsional: Huawei implementation 'com.engagelab.plugin:huawei:4.3.9' // Opsional: Xiaomi (China) implementation 'com.engagelab.plugin:mi:4.3.9' // Opsional: Meizu implementation 'com.engagelab.plugin:meizu:4.3.9' // Opsional: Oppo implementation 'com.engagelab.plugin:oppo:4.3.9' implementation 'com.engagelab.plugin:oppo_th_push:4.3.9' // Opsional: Vivo implementation 'com.engagelab.plugin:vivo:4.3.9' // Opsional: Fungsi siaran suara implementation 'com.engagelab.plugin:oth_sound:4.3.9' }
              
              dependencies {
  // Wajib: Paket utama
  implementation 'com.engagelab:engagelab:4.3.9' // Contoh versi 4.3.9
  // Opsional: Google
  implementation 'com.engagelab.plugin:google:4.3.9'
  // Opsional: Honor
  implementation 'com.engagelab.plugin:honor:4.3.9'
  implementation 'com.engagelab.plugin:honor_th_push:4.3.9'
  // Opsional: Huawei
  implementation 'com.engagelab.plugin:huawei:4.3.9'
  // Opsional: Xiaomi (China)
  implementation 'com.engagelab.plugin:mi:4.3.9'
  // Opsional: Meizu
  implementation 'com.engagelab.plugin:meizu:4.3.9'
  // Opsional: Oppo
  implementation 'com.engagelab.plugin:oppo:4.3.9'
  implementation 'com.engagelab.plugin:oppo_th_push:4.3.9'
  // Opsional: Vivo
  implementation 'com.engagelab.plugin:vivo:4.3.9'
  // Opsional: Fungsi siaran suara
  implementation 'com.engagelab.plugin:oth_sound:4.3.9'
}

            
Tampilkan blok kode ini di jendela mengambang

2. Konfigurasi build.gradle

plugins { id 'com.android.application' } android { ... defaultConfig { // Nama paket aplikasi, harus sama dengan yang ada di konsol applicationId "com.engagelab.app" ... manifestPlaceholders = [ // AppKey, harus sama dengan di konsol; satu-satu dengan packageName ENGAGELAB_PRIVATES_APPKEY : "YourAppKey", // appChannel Engagelab, untuk statistik channel ENGAGELAB_PRIVATES_CHANNEL: "developer", // Proses Engagelab, proses tempat SDK berjalan; diawali dengan : ENGAGELAB_PRIVATES_PROCESS: ":remote", ] } } dependencies { implementation fileTree(include: ['*.jar', '*.aar'], dir: 'libs') }
              
              plugins {
    id 'com.android.application'
}

android {
    ...

    defaultConfig {
        // Nama paket aplikasi, harus sama dengan yang ada di konsol
        applicationId "com.engagelab.app"
        ...
        manifestPlaceholders = [
            // AppKey, harus sama dengan di konsol; satu-satu dengan packageName
            ENGAGELAB_PRIVATES_APPKEY : "YourAppKey",
            // appChannel Engagelab, untuk statistik channel
            ENGAGELAB_PRIVATES_CHANNEL: "developer",
            // Proses Engagelab, proses tempat SDK berjalan; diawali dengan :
            ENGAGELAB_PRIVATES_PROCESS: ":remote",
        ]
    }
}

dependencies {
    implementation fileTree(include: ['*.jar', '*.aar'], dir: 'libs')
}

            
Tampilkan blok kode ini di jendela mengambang

Membuat Komponen yang Dibutuhkan

UserService

package com.engagelab.app.component; import com.engagelab.privates.common.component.MTCommonService; /** * Pengembang dapat mewarisi MTCommonService untuk memperpanjang masa hidup koneksi panjang. * Implementasi kosong sudah cukup. */ public class UserService extends MTCommonService {}
              
              package com.engagelab.app.component;

import com.engagelab.privates.common.component.MTCommonService;

/**
 * Pengembang dapat mewarisi MTCommonService untuk memperpanjang masa hidup koneksi panjang.
 * Implementasi kosong sudah cukup.
 */
public class UserService extends MTCommonService {}

            
Tampilkan blok kode ini di jendela mengambang

UserReceiver

package com.engagelab.app.component; import android.content.Context; import android.widget.Toast; import com.engagelab.app.common.ExampleGlobal; import com.engagelab.app.listener.StatusObserver; import com.engagelab.app.log.ExampleLogger; import com.engagelab.privates.common.component.MTCommonReceiver; import com.engagelab.privates.core.api.MTCorePrivatesApi; import com.engagelab.privates.push.api.CustomMessage; import com.engagelab.privates.push.api.NotificationMessage; import com.engagelab.privates.push.api.PlatformTokenMessage; public class UserReceiver extends MTCommonReceiver { private static final String TAG = "UserReceiver"; @Override public void onNotificationStatus(Context context, boolean enable) { ExampleLogger.i(TAG, "onNotificationStatus:" + enable); Toast.makeText(context.getApplicationContext(), "onNotificationStatus " + enable, Toast.LENGTH_SHORT).show(); ExampleGlobal.isNotificationEnable = enable; if (StatusObserver.getInstance().getListener() != null) { StatusObserver.getInstance().getListener().onNotificationStatus(enable); } } @Override public void onConnectStatus(Context context, boolean enable) { ExampleLogger.i(TAG, "onConnectState:" + enable); Toast.makeText(context.getApplicationContext(), "onConnectStatus " + enable, Toast.LENGTH_SHORT).show(); ExampleGlobal.isConnectEnable = enable; if (StatusObserver.getInstance().getListener() != null) { StatusObserver.getInstance().getListener().onConnectStatus(enable); } if (enable) { String registrationId = MTCorePrivatesApi.getRegistrationId(context); ExampleLogger.i(TAG, "registrationId:" + registrationId); } } @Override public void onNotificationArrived(Context context, NotificationMessage notificationMessage) { ExampleLogger.i(TAG, "onNotificationArrived:" + notificationMessage.toString()); } @Override public void onNotificationUnShow(Context context, NotificationMessage notificationMessage) { ExampleLogger.i(TAG, "onNotificationUnShow:" + notificationMessage.toString()); } @Override public void onNotificationClicked(Context context, NotificationMessage notificationMessage) { ExampleLogger.i(TAG, "onNotificationClicked:" + notificationMessage.toString()); } @Override public void onNotificationDeleted(Context context, NotificationMessage notificationMessage) { ExampleLogger.i(TAG, "onNotificationDeleted:" + notificationMessage.toString()); } @Override public void onCustomMessage(Context context, CustomMessage customMessage) { ExampleLogger.i(TAG, "onCustomMessage:" + customMessage.toString()); } @Override public void onPlatformToken(Context context, PlatformTokenMessage platformTokenMessage) { ExampleLogger.i(TAG, "onPlatformToken:" + platformTokenMessage.toString()); } }
              
              package com.engagelab.app.component;

import android.content.Context;
import android.widget.Toast;

import com.engagelab.app.common.ExampleGlobal;
import com.engagelab.app.listener.StatusObserver;
import com.engagelab.app.log.ExampleLogger;
import com.engagelab.privates.common.component.MTCommonReceiver;
import com.engagelab.privates.core.api.MTCorePrivatesApi;
import com.engagelab.privates.push.api.CustomMessage;
import com.engagelab.privates.push.api.NotificationMessage;
import com.engagelab.privates.push.api.PlatformTokenMessage;

public class UserReceiver extends MTCommonReceiver {
    private static final String TAG = "UserReceiver";

    @Override
    public void onNotificationStatus(Context context, boolean enable) {
        ExampleLogger.i(TAG, "onNotificationStatus:" + enable);
        Toast.makeText(context.getApplicationContext(), "onNotificationStatus " + enable, Toast.LENGTH_SHORT).show();
        ExampleGlobal.isNotificationEnable = enable;
        if (StatusObserver.getInstance().getListener() != null) {
            StatusObserver.getInstance().getListener().onNotificationStatus(enable);
        }
    }

    @Override
    public void onConnectStatus(Context context, boolean enable) {
        ExampleLogger.i(TAG, "onConnectState:" + enable);
        Toast.makeText(context.getApplicationContext(), "onConnectStatus " + enable, Toast.LENGTH_SHORT).show();
        ExampleGlobal.isConnectEnable = enable;
        if (StatusObserver.getInstance().getListener() != null) {
            StatusObserver.getInstance().getListener().onConnectStatus(enable);
        }
        if (enable) {
            String registrationId = MTCorePrivatesApi.getRegistrationId(context);
            ExampleLogger.i(TAG, "registrationId:" + registrationId);
        }
    }

    @Override
    public void onNotificationArrived(Context context, NotificationMessage notificationMessage) {
        ExampleLogger.i(TAG, "onNotificationArrived:" + notificationMessage.toString());
    }

    @Override
    public void onNotificationUnShow(Context context, NotificationMessage notificationMessage) {
        ExampleLogger.i(TAG, "onNotificationUnShow:" + notificationMessage.toString());
    }

    @Override
    public void onNotificationClicked(Context context, NotificationMessage notificationMessage) {
        ExampleLogger.i(TAG, "onNotificationClicked:" + notificationMessage.toString());
    }

    @Override
    public void onNotificationDeleted(Context context, NotificationMessage notificationMessage) {
        ExampleLogger.i(TAG, "onNotificationDeleted:" + notificationMessage.toString());
    }

    @Override
    public void onCustomMessage(Context context, CustomMessage customMessage) {
        ExampleLogger.i(TAG, "onCustomMessage:" + customMessage.toString());
    }

    @Override
    public void onPlatformToken(Context context, PlatformTokenMessage platformTokenMessage) {
        ExampleLogger.i(TAG, "onPlatformToken:" + platformTokenMessage.toString());
    }
}

            
Tampilkan blok kode ini di jendela mengambang

4. Konfigurasi AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" package="com.engagelab.app"> <!-- Wajib: Izin internet --> <uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> <!-- Opsional: Getar untuk notifikasi --> <uses-permission android:name="android.permission.VIBRATE" /> <application android:name="com.engagelab.app.MainApplication" android:allowBackup="false" android:icon="@drawable/ic_launcher" android:label="@string/app_name" android:supportsRtl="true" android:theme="@style/Theme.MT" android:usesCleartextTraffic="true" tools:targetApi="m"> <!-- Service untuk koneksi panjang --> <service android:name="com.engagelab.app.component.UserService" android:exported="false" android:process="${ENGAGELAB_PRIVATES_PROCESS}"> <intent-filter> <action android:name="com.engagelab.privates.intent.USER_SERVICE" /> </intent-filter> </service> <!-- Receiver untuk callback bisnis Engagelab --> <receiver android:name="com.engagelab.app.component.UserReceiver" android:exported="false"> <intent-filter> <action android:name="com.engagelab.privates.intent.USER_RECEIVER" /> </intent-filter> </receiver> </application> </manifest>
              
              <?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    package="com.engagelab.app">
        
    <!-- Wajib: Izin internet -->
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <!-- Opsional: Getar untuk notifikasi -->
    <uses-permission android:name="android.permission.VIBRATE" /> 
        
    <application
        android:name="com.engagelab.app.MainApplication"
        android:allowBackup="false"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:supportsRtl="true"
        android:theme="@style/Theme.MT"
        android:usesCleartextTraffic="true"
        tools:targetApi="m">

        <!-- Service untuk koneksi panjang -->
        <service
            android:name="com.engagelab.app.component.UserService"
            android:exported="false"
            android:process="${ENGAGELAB_PRIVATES_PROCESS}">
            <intent-filter>
                <action android:name="com.engagelab.privates.intent.USER_SERVICE" />
            </intent-filter>
        </service>

        <!-- Receiver untuk callback bisnis Engagelab -->
        <receiver
            android:name="com.engagelab.app.component.UserReceiver"
            android:exported="false">
            <intent-filter>
                <action android:name="com.engagelab.privates.intent.USER_RECEIVER" />
            </intent-filter>
        </receiver>

    </application>
</manifest>

            
Tampilkan blok kode ini di jendela mengambang

5. Konfigurasi Lingkungan

package com.engagelab.app; import android.app.Application; import com.engagelab.privates.core.api.MTCorePrivatesApi; public class MainApplication extends Application { private static final String TAG = "MainApplication"; @Override public void onCreate() { super.onCreate(); // Konfigurasi di application.onCreate, tidak perlu cek proses, SDK sudah otomatis. MTCorePrivatesApi.configDebugMode(this, true); // Untuk versi lama, panggil jika dibutuhkan: // MTPushPrivatesApi.configOldPushVersion(context.getApplicationContext()); // Inisialisasi push: // MTPushPrivatesApi.init(this); } }
              
              package com.engagelab.app;

import android.app.Application;
import com.engagelab.privates.core.api.MTCorePrivatesApi;

public class MainApplication extends Application {
    private static final String TAG = "MainApplication";

    @Override
    public void onCreate() {
        super.onCreate();
        // Konfigurasi di application.onCreate, tidak perlu cek proses, SDK sudah otomatis.
        MTCorePrivatesApi.configDebugMode(this, true);
        // Untuk versi lama, panggil jika dibutuhkan:
        // MTPushPrivatesApi.configOldPushVersion(context.getApplicationContext());
        // Inisialisasi push:
        // MTPushPrivatesApi.init(this);
    }
}

            
Tampilkan blok kode ini di jendela mengambang

6. Membuat Komponen Loncatan Klik Notifikasi

package com.engagelab.app.component; import android.app.Activity; import android.content.Intent; import android.os.Bundle; import android.widget.TextView; import android.widget.Toast; import com.engagelab.app.R; import com.engagelab.app.log.ExampleLogger; public class UserActivity400 extends Activity { private static final String TAG = "UserActivity400"; private TextView tvMessage; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_intent); tvMessage = findViewById(R.id.tv_message); onIntent(getIntent()); } @Override protected void onNewIntent(Intent intent) { super.onNewIntent(intent); onIntent(intent); } private void onIntent(Intent intent) { try { Toast.makeText(this, TAG, Toast.LENGTH_SHORT).show(); if (intent == null) return; String notificationMessage = intent.getStringExtra("message_json"); if (notificationMessage == null) return; ExampleLogger.d(TAG, "notificationMessage:" + notificationMessage); tvMessage.setText(notificationMessage); } catch (Throwable throwable) { throwable.printStackTrace(); } } }
              
              package com.engagelab.app.component;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.widget.TextView;
import android.widget.Toast;
import com.engagelab.app.R;
import com.engagelab.app.log.ExampleLogger;

public class UserActivity400 extends Activity {
    private static final String TAG = "UserActivity400";
    private TextView tvMessage;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_intent);
        tvMessage = findViewById(R.id.tv_message);
        onIntent(getIntent());
    }

    @Override
    protected void onNewIntent(Intent intent) {
        super.onNewIntent(intent);
        onIntent(intent);
    }

    private void onIntent(Intent intent) {
        try {
            Toast.makeText(this, TAG, Toast.LENGTH_SHORT).show();
            if (intent == null) return;
            String notificationMessage = intent.getStringExtra("message_json");
            if (notificationMessage == null) return;
            ExampleLogger.d(TAG, "notificationMessage:" + notificationMessage);
            tvMessage.setText(notificationMessage);
        } catch (Throwable throwable) {
            throwable.printStackTrace();
        }
    }
}

            
Tampilkan blok kode ini di jendela mengambang

7. Konfigurasi AndroidManifest.xml untuk Loncatan Klik

<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" package="com.engagelab.app"> <uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> <uses-permission android:name="android.permission.VIBRATE" /> <application android:name="com.engagelab.app.MainApplication" android:allowBackup="false" android:icon="@drawable/ic_launcher" android:label="@string/app_name" android:supportsRtl="true" android:theme="@style/Theme.MT" android:usesCleartextTraffic="true" tools:targetApi="m"> <!-- Activity untuk loncatan klik notifikasi --> <activity android:name="com.engagelab.app.component.UserActivity400" android:exported="false" android:launchMode="singleTask" /> <!-- Contoh intent-filter untuk deep link (opsional) --> <!-- <activity android:name="com.engagelab.app.component.UserActivity400" android:exported="false" > <intent-filter> <data android:scheme="YourScheme"/> <data android:host="YourHost"/> <action android:name="android.intent.action.VIEW" /> <category android:name="android.intent.category.DEFAULT" /> <category android:name="android.intent.category.BROWSABLE" /> </intent-filter> </activity> --> <!-- Whitelist transfer lokal --> <meta-data android:name="ENGAGELAB_PRIVATES_TRANSFER" android:value="com.engagelab.app.component.UserActivity400" /> <!-- Diperlukan untuk push Google --> <meta-data android:name="com.google.firebase.messaging.default_notification_icon" android:resource="@drawable/mtpush_notification_icon" /> <!-- Diperlukan untuk push Huawei --> <meta-data android:name="com.huawei.messaging.default_notification_icon" android:resource="@drawable/mtpush_notification_icon" /> </application> </manifest>
              
              <?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    package="com.engagelab.app">

    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.VIBRATE" />

    <application
        android:name="com.engagelab.app.MainApplication"
        android:allowBackup="false"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:supportsRtl="true"
        android:theme="@style/Theme.MT"
        android:usesCleartextTraffic="true"
        tools:targetApi="m">

        <!-- Activity untuk loncatan klik notifikasi -->
        <activity
            android:name="com.engagelab.app.component.UserActivity400"
            android:exported="false"
            android:launchMode="singleTask" />

        <!-- Contoh intent-filter untuk deep link (opsional) -->
        <!--
        <activity
            android:name="com.engagelab.app.component.UserActivity400"
            android:exported="false" >
            <intent-filter>
                <data android:scheme="YourScheme"/>
                <data android:host="YourHost"/>
                <action android:name="android.intent.action.VIEW" />
                <category android:name="android.intent.category.DEFAULT" />
                <category android:name="android.intent.category.BROWSABLE" />
            </intent-filter>
        </activity>
        -->

        <!-- Whitelist transfer lokal -->
        <meta-data
            android:name="ENGAGELAB_PRIVATES_TRANSFER"
            android:value="com.engagelab.app.component.UserActivity400" />
                
        <!-- Diperlukan untuk push Google -->
        <meta-data
            android:name="com.google.firebase.messaging.default_notification_icon"
            android:resource="@drawable/mtpush_notification_icon" />

        <!-- Diperlukan untuk push Huawei -->
        <meta-data
            android:name="com.huawei.messaging.default_notification_icon"
            android:resource="@drawable/mtpush_notification_icon" />

    </application>
</manifest>

            
Tampilkan blok kode ini di jendela mengambang
Icon Solid Transparent White Qiyu
Hubungi Sales