adjust-icon

React Native SDK 연동 가이드

Adjust React Native SDK를 통해 React Native 앱의 어트리뷰션, 이벤트 등을 측정할 수 있습니다. 본 가이드의 단계를 수행하여 Adjust SDK와 연동되도록 앱을 설정하시기 바랍니다. 이에 대한 예시는 GitHub에서 확인하실 수 있습니다.

1. 프로젝트에 SDK 추가

React Native 앱에서 Adjust SDK를 시작하려면 우선 프로젝트에 Adjust SDK를 추가해야 합니다. Adjust SDK를 추가를 위해 다음 단계를 따르시기 바랍니다.

  1. 다음 방법 중 한 가지를 사용하여 React Native 라이브러리를 다운로드합니다.
  1. 터미널에서 다음 명령어를 실행하여 iOS 앱용 CocoaPods 디펜던시를 설치합니다.
Terminal window
$ cd ios && pod install

2. SDK 연동

SDK를 프로젝트에 연동하려면 Adjust의 SDK 구성을 메인 앱 Javascript 파일로 가져와야 합니다.

앱의 .js 파일 시작 부분에 다음 라인을 추가합니다.

import { Adjust, AdjustEvent, AdjustConfig } from "react-native-adjust";

3. Adjust SDK 초기화

React Native 앱에서 최대한 빨리 Adjust SDK를 초기화하시기 바랍니다. 이를 위해 앱 토큰 및 앱을 실행하고자 하는 환경과 함께 config 객체를 초기화하시기 바랍니다. 앱의 .js 파일 시작 부분에 다음 코드 라인을 추가합니다.

constructor(props) {
super(props);
const adjustConfig = new AdjustConfig("{YourAppToken}", AdjustConfig.EnvironmentSandbox);
Adjust.create(adjustConfig);
}
componentWillUnmount() {
Adjust.componentWillUnmount();
}

다음 AdjustConfig 인수를 전달합니다.

  • {YourAppToken}을 귀하의 토큰으로 교체합니다. 앱 토큰 확인 방법은 앱 설정 페이지를 참조하시기 바랍니다.
  • 앱 환경 을 선택합니다.
    • 앱을 테스트하며 테스트 데이터를 전송하려는 경우 AdjustConfig.EnvironmentSandbox를 사용합니다. 테스트 데이터를 보려면 대시보드에서 샌드박스 모드를 활성화해야 합니다.
    • 테스트를 끝내고 앱 출시가 준비되면 AdjustConfig.EnvironmentProduction을 사용하십시오.

4. Android 기기 설정

권한 추가

Adjust SDK는 정보 액세스를 위한 특정 권한이 필요합니다. AndroidManifest.xml 파일이 아직 존재하지 않는다면 추가하시기 바랍니다.

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

Adjust SDK 4.32.0 및 이상 버전에는 com.google.android.gms.AD_ID 권한이 기본값으로 포함됩니다. 앱이 COPPA 준수 대상이거나 Google 플레이 스토어를 타겟으로 하지 않는 경우, remove를 추가하여 이 권한을 제거할 수 있습니다.

AndroidManifest.xml
<uses-permission android:name="com.google.android.gms.permission.AD_ID"/>

Google Play Services 추가

Google Play Store를 타겟팅하는 앱은 기기를 식별하기 위해 반드시 Google Advertising ID (gps_adid)를 사용해야 합니다. 이를 위해 build.gradle 파일의 dependencies 섹션에 다음의 디펜던시를 추가합니다.

build.gradle
implementation 'com.google.android.gms:play-services-ads-identifier:18.0.1'

Proguard 설정

Proguard를 사용하는 경우, 다음의 규칙을 Proguard 파일에 추가하시기 바랍니다.

Proguard.pro
-keep class com.adjust.sdk.** { *; }
-keep class com.google.android.gms.common.ConnectionResult {
int SUCCESS;
}
-keep class com.google.android.gms.ads.identifier.AdvertisingIdClient {
com.google.android.gms.ads.identifier.AdvertisingIdClient$Info getAdvertisingIdInfo(android.content.Context);
}
-keep class com.google.android.gms.ads.identifier.AdvertisingIdClient$Info {
java.lang.String getId();
boolean isLimitAdTrackingEnabled();
}
-keep public class com.android.installreferrer.** { *; }

설치 리퍼러 설정

설치 리퍼러는 앱 설치를 소스에 어트리뷰션하는 데 사용할 수 있는 어트리뷰션 메커니즘입니다. 이는 두 개의 부분으로 구성됩니다.

  • 개발자가 앱에서 추천 콘텐츠를 검색할 수 있도록 하는 앱 스토어의 API 집합체입니다.
  • Google Play 및 Huawei App Gallery와 같은 앱 스토어가 스토어 웹사이트의 앱 페이지 URL에서 허용하는 referrer 파라미터입니다. 리퍼러 파라미터가 생성되는 방법은 다음과 같습니다.
    • 사용자가 Adjust 링크를 클릭하면 Adjust 서버는 reftag라는 고유 식별자를 전달합니다. 이 식별자는 클릭과 리퍼러 파라미터에 할당됩니다. reftag에 관한 자세한 정보는 Reftag를 참고하시기 바랍니다.
    • Google Ads 캠페인을 실행할 때 Google은 gclid로 불리는 고유 식별자를 리퍼러 파라미터에 전달합니다. Google Ads 계정에서 Auto-tagging 이 활성화되어 있어야 합니다.

Google Play Referrer API

v4.12.0에서 추가됨

Google Play Referrer API 지원 방법:

  1. 최상위 build.gradle 파일의 디펜던시 블록 에 다음의 라인을 추가합니다.
build.gradle
dependencies {
//...
implementation 'com.android.installreferrer:installreferrer:2.2'
//...
}
  1. installreferrer 라이브러리는 Google Maven 리포지토리의 일부입니다. 앱을 빌드하려면 앱의 최상위 build.gradle 파일에 Google Maven 리포지토리를 추가해야 합니다.
build.gradle
allprojects {
repositories {
maven {
url "https://maven.google.com"
}
}
}
  1. Proguard를 사용하는 경우, Proguard 파일에 다음의 세팅을 추가합니다:
Proguard.pro
-keep public class com.android.installreferrer.** { *; }

Huawei 리퍼러 API

Adjust SDK는 v4.22.0부터 Huawei App Gallery v10.4 이상을 사용하는 Huawei 기기에서의 설치 측정을 지원합니다. Huawei Referrer API를 사용하기 위해 추가적인 변경을 수행하지 않아도 됩니다.

Meta 리퍼러 연동

v4.37.0에서 추가됨

Adjust SDK는 v4.37.0 이상 버전에서 Meta 설치 리퍼러를 지원합니다. 이 기능을 활성화하려면 다음을 수행하시기 바랍니다.

  1. 앱 대시보드에서 Meta 앱 ID를 확인합니다. 자세한 내용은 Meta의 앱 대시보드 문서를 참조하시기 바랍니다.

  2. 앱 ID를 string 인수로 AdjustConfig.setFbAppId 메서드에 전달합니다.

    const adjustConfig = new AdjustConfig(
    "{YourAppToken}",
    AdjustConfig.EnvironmentSandbox,
    );
    //...
    adjustConfig.setFbAppId("<fb_app_id_string>");
    //...
    Adjust.create(adjustConfig);

5. iOS 프레임워크 추가

Adjust SDK는 특정 iOS 프레임워크가 앱에 포함된 경우 추가적인 정보를 얻을 수 있습니다. 이러한 프레임워크는 특정 SDK 기능을 활성화하지만, SDK가 일반적으로 작동하기 위해 반드시 필요한 것은 아닙니다. Project Settings —> Build Phases —> Link Binary With Libraries 에서 프레임워크를 추가한 뒤 이를 ‘optional’로 지정할 수 있습니다.

프레임워크설명참고 사항
AdSupport.frameworkSDK가 IDFA 값과 (iOS 14 이전의 경우) AT 정보에 액세스하기 위해 필요.앱이 “아동” 카테고리를 타겟팅하는 경우에는 이 프레임워크를 실행할 필요 없음.
AdServices.framework본 프레임워크는 Apple Search Ads 어트리뷰션을 위해 필요합니다.
StoreKit.frameworkSKAdNetwork 프레임워크에 액세스하고, Adjust SDK가 iOS 14 및 이후 버전에서 통신을 자동으로 처리하기 위해 필요.
AppTrackingTransparency.frameworkiOS 14 및 이후 버전에서 SDK가 사용자의 ATT 동의를 래핑하고 사용자의 동의 응답에 액세스하기 위해 필요.앱이 “아동” 카테고리를 타겟팅하는 경우에는 이 프레임워크를 실행할 필요 없음.

6. Adjust SDK 서명 추가

Adjust SDK 서명을 사용해 Adjust SDK가 전송한 모든 커뮤니케이션에 서명을 추가할 수 있습니다. Adjust 서버는 이를 기반으로 유효하지 않은 설치 활동을 감지 및 차단할 수 있습니다.

Adjust SDK 서명을 사용하려면 담당 테크니컬 어카운트 매니저 또는 support@adjust.com에 문의하시기 바랍니다.

7. 연동 테스트

Adjust SDK는 연동 테스트와 문제 해결 툴을 제공합니다. 다음과 같이 설정을 테스트하시기 바랍니다.

  • 환경을 AdjustConfig.EnvironmentSandbox로 설정합니다.
  • Adjust 대시보드 결과에 샌드박스 필터를 추가합니다.
  • 로그 수준을 AdjustConfig.LogLevelVerbose로 설정합니다.

Google Play Services 연동 테스트

Adjust SDK가 기기의 Google 광고 ID를 수신할 수 있는지 테스트하려면 로그 수준을 AdjustConfig.LogLevelVerbose로 설정하고, 환경을 AdjustConfig.EnvironmentSandbox로 설정합니다. 앱을 시작하고 세션이나 이벤트를 기록합니다. SDK가 광고 ID를 읽으면 gps_adid 파라미터를 로그합니다.

Google광고 ID를 읽을 수 없다면 SDK Github repository에 이슈를 제기하거나 support@adjust.com으로 메일로 문의해 주시기 바랍니다.