NPM :
https://github.com/voltrue2/in-app-purchasevar iap = require('in-app-purchase');
iap.config({
verbose: true,
//googlePublicKeyStrSandbox: "", //LIVE 먼저 실행하고 에러나면 SandBox 테스트실행함
googlePublicKeyStrLive: "MII...............",
googleAccToken: "6/h...........",
googleRefToken: "9/d...........",
googleClientID: "99.......kv.7dc.ap...ps.g....nt.com",
googleClientSecret: "9.....4Qu"
});
iap.setup(function (error) {
if (error) {
// error hmm
}
var googleReceipt = {
"data":'{"packageName":"kr.co.test","productId":"kr.co.test.is1","purchaseTime":155435321,
"purchaseState":0,"purchaseToken":"oksdf........"}', //{stringified data object}
"signature": "qSVwa8E9z........."
};
iap.validate(iap.GOOGLE, googleReceipt, function (error, response) {
if (error) {
console.log(error);
}
if (iap.isValidated(response)) {
var purchaseDataList = iap.getPurchaseData(response);
console.log(purchaseDataList);
}
});
});
API 통신 로직 : node_modules\in-app-purchase\lib\google.js 참고
/**
* Function to check subscription status in Google Play
* @param {Object} data receipt data
* @param {Function} cb callback function
*/
function checkSubscriptionStatus(data, cb) {
data.service = constants.SERVICES.GOOGLE;
if (!checkSubscriptionState) {
return cb(null, data);
}
var packageName = data.packageName;
var subscriptionID = data.productId;
var purchaseToken = data.purchaseToken;
var url = 'https://www.googleapis.com/androidpublisher/v2/applications/' + packageName +
'/purchases/subscriptions/' + subscriptionID + '/tokens/' + purchaseToken;
var state;
var getSubInfo = function (next) {
verbose.log(NAME, 'Get subscription info from', url);
getSubscriptionInfo(url, function (error, response, body) {
if (error || 'error' in body) {
verbose.log(NAME, 'Failed to get subscription info from', url, error, body);
state = constants.VALIDATION.FAILURE;
// we must move on to validate()
next();
return;
}
1. googleClientID / googleClientSecret 생성하기
1) 설정 => API 액세스 => 기존프로젝트 연결 또는 새프로젝트만들기
data:image/s3,"s3://crabby-images/4c4df/4c4df1b354f579fa9269df736d0b5f499bf3ea0e" alt=""
2) Google 개발자 콘솔 들어가기 ( https://console.developers.google.com/apis/library?project=xxxx )
data:image/s3,"s3://crabby-images/75557/75557a73c178b4ba7804c69c5122f8469ccdccfe" alt=""
3) 사용자 인증 ( 프로젝트 확인 꼭!! ) oauth 생성 > 웹어플리케이션 > 리디렉션 URL ( https://developers.google.com/oauthplayground ) > clientId 및 clientSecret 확인
data:image/s3,"s3://crabby-images/08e33/08e33fbbaf18c56871108b6fcfb5b41329fbfc76" alt=""
data:image/s3,"s3://crabby-images/3ec4f/3ec4ffc86f4f3649f7594f8b418bd5d16670cb7a" alt=""
2. Access 및 Refresh Tokens 얻기
1) https://developers.google.com/oauthplayground 이동 > 우측설정에서 CilentID와 Client secret 입력
data:image/s3,"s3://crabby-images/66bc9/66bc95ded81f91285e042de378a5f77be916cebc" alt=""
2) Google Play Developer API v2 > 개발자 계정 확인 및 관리 허용
data:image/s3,"s3://crabby-images/943f4/943f437084bcdd631a3c255e83d0572fc96dc4ab" alt=""
data:image/s3,"s3://crabby-images/7eadd/7eadd3abdd72e7563b0f44f41e1f9e62bc6fb6c4" alt=""
3) Access Token (googleAccToken) / Refresh Token (googleRefToken)
data:image/s3,"s3://crabby-images/acb20/acb20d4278c6a0e39a49edb6de4cb8bd5c85e0eb" alt=""
※ Access Not Configured. Google Play Developer API has not been used in project
=> Google Play Android Developer API 사용으로 설정
data:image/s3,"s3://crabby-images/2c8bf/2c8bf34c66ff23903a603288ca8f8714213ffe55" alt=""
※ The project id used to call the Google Play Developer API has not been linked in the Google Play Developer Console.
=> 설정 > API 액세스 > 프로젝트가 잘 연결되었는지 OAUTH 클라이언트 ID가 존재하는지 확인 할것
data:image/s3,"s3://crabby-images/f5b62/f5b62bb8cab68dd6c95cd2fba9967a6b3106e9e4" alt=""
※ errors: [ [Object] ], code: 400, message: 'Invalid Value' } }
=> 판매되는 상품에 따라서 lib/google.js 에서 url 정보를 purchases/subscriptions => purchases/products
변경해야되는 이슈 있음 해당 NPM 보니까 구독(subscriptions) 경우만 지원하므로
자세한 내용은 아래 API 레퍼런스 참고 해서 수정 하거나 소스 참고해서 새로 짜는 방안도 있다.
https://developers.google.com/android-publisher/api-ref/purchases/products
https://developers.google.com/android-publisher/api-ref/purchases/subscriptions