iOS에서 웹 표준 이니시스(이하 이니시스)
또는 나이스 정보통신(이하 나이스)
실시간 계좌이체
를 연동하는 경우 별도 설정이 요구됩니다.
이니시스는 결제완료 후 콜백이 실행되지 않고, 나이스는 결제인증 후 결제완료 처리가 되지 않기 때문입니다.
이는 이니시스와 나이스 결제모듈 자체 문제입니다.
아임포트 RN 모듈은 이에 대응하기 위한 안내를 제공하고 있습니다.
Expo 프로젝트의 경우 아래의 Linking 작업들을 하지 않으셔도 됩니다.
먼저 뱅크페이 앱에서 귀하의 앱으로 복귀할때를 트리거해야 합니다.
아임포트 RN 모듈은 트리거 된 순간 이니시스의 경우 콜백을 실행시키고, 나이스의 경우 나이스로 결제정보가 담긴 POST 요청을 보냅니다.
Objective C는 들어오는(incoming) 앱 링크를 트리거 하기 위해 openURL
메소드를 제공합니다.
이때 RN Linking
을 활용해 RN단에서 들어오는 앱 링크를 트리거 하게 만들 수 있습니다.
자세한 내용은 RN Linking을 참고하세요.
*AppDelegate.m
파일에 아래 코드를 복사합니다.
// iOS 9.x or newer
#import <React/RCTLinkingManager.h>
- (BOOL)application:(UIApplication *)application
openURL:(NSURL *)url
options:(NSDictionary<UIApplicationOpenURLOptionsKey,id> *)options
{
return [RCTLinkingManager application:application openURL:url options:options];
}
// iOS 8.x or older
#import <React/RCTLinkingManager.h>
- (BOOL)application:(UIApplication *)application openURL:(NSURL *)url
sourceApplication:(NSString *)sourceApplication annotation:(id)annotation
{
return [RCTLinkingManager application:application openURL:url
sourceApplication:sourceApplication annotation:annotation];
}
안드로이드에서는 나이스
실시간 계좌이체
를 연동하는 경우 iOS와 같은 이유로 별도 설정이 요구됩니다.
iOS와 동일하게 뱅크페이 앱에서 귀하의 앱으로 복귀할때를 트리거해야 합니다. 아임포트 RN 모듈은 트리거 된 순간 나이스로 결제정보가 담긴 POST 요청을 보냅니다. 안드로이드에서는 들어오는(incoming) 앱 링크를 트리거하기 위해 deep linking 기능을 제공합니다.
deep linking 기능을 활성화하기 위해 Intent Filter
를 추가하고 MainActivity
의 launchMode
를 아래와 같이 singleTask
로 설정해야 합니다.
자세한 내용은 RN Linking을 참고하세요.
...
<!-- [프로젝트 폴더]/android/app/src/main/AndroidManifest.xml -->.
<!-- MainActivity의 launchMode를 singleTask로 설정 -->
<activity
android:name=".MainActivity"
android:launchMode="singleTask"
>
...
<!-- Intent Filter 추가 -->
<intent-filter>
<action android:name="android.intent.action.VIEW"/>
<category android:name="android.intent.category.DEFAULT"/>
<category android:name="android.intent.category.BROWSABLE"/>
<data android:scheme="앱 스킴 값 EX. example" />
</intent-filter>
...
</activity>
...