@mathrunet/masamune
Version:
Manages packages for the server portion (NodeJS) of the Masamune framework.
172 lines • 8.2 kB
JavaScript
;
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || (function () {
var ownKeys = function(o) {
ownKeys = Object.getOwnPropertyNames || function (o) {
var ar = [];
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
return ar;
};
return ownKeys(o);
};
return function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
__setModuleDefault(result, mod);
return result;
};
})();
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
return new (P || (P = Promise))(function (resolve, reject) {
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
};
Object.defineProperty(exports, "__esModule", { value: true });
const functions = __importStar(require("firebase-functions/v2"));
const verifier = __importStar(require("../lib/functions/verify_android"));
const updater = __importStar(require("../lib/functions/update_wallet"));
const firebase_loader_1 = require("../lib/src/firebase_loader");
/**
* Performs a consumption-type in-app purchase. The value of the field in the document specified in [path] is added to [value].
*
* 消費型のアプリ内課金を行います。[path]に指定したドキュメント内のフィールドの値を[value]に加算します。
*
* @param process.env.PURCHASE_ANDROID_SERVICEACCOUNT_EMAIL
* The email address of your Google service account.
* Create an OAuth consent screen from the URL below.
* https://console.cloud.google.com/apis/credentials/consent
* It is then created from the service account.
* https://console.cloud.google.com/iam-admin/serviceaccounts
*
* Googleのサービスアカウントのメールアドレス。
* 下記のURLからOAuthの同意画面を作成します。
* https://console.cloud.google.com/apis/credentials/consent
* その後、サービスアカウントから作成します。
* https://console.cloud.google.com/iam-admin/serviceaccounts
*
* @param process.env.PURCHASE_ANDROID_SERVICEACCOUNT_PRIVATE_KEY
* A private key for your Google service account.
* Create an OAuth consent screen from the URL below.
* https://console.cloud.google.com/apis/credentials/consent
* It is then created from the service account.
* https://console.cloud.google.com/iam-admin/serviceaccounts
* After creating a service account, create a key in Json format from the Key tab.
* The private key is described there.
*
* Googleのサービスアカウントのプライベートキー。
* 下記のURLからOAuthの同意画面を作成します。
* https://console.cloud.google.com/apis/credentials/consent
* その後、サービスアカウントから作成します。
* https://console.cloud.google.com/iam-admin/serviceaccounts
* サービスアカウント作成後、キーのタブからJson形式でキーを作成します。
* プライベートキーはそこに記述されています。
*
* @param path
* The path, including the key, of the field in the document that stores the in-app wallet information.
*
* アプリ内ウォレット情報を保存するドキュメント内のフィールドのキーを含めたパス。
*
* @param value
* Value of the amount to be added.
*
* 加算する金額の値。
*
* @param packageName
* Application package name.
*
* アプリケーションのパッケージ名。
*
* @param productId
* Item ID issued by Google Play.
*
* GooglePlayで発行されたアイテムID。
*
* @param purchaseToken
* The purchase token issued at the time of purchase.
*
* 購入したときに発行された購入トークン。
*/
module.exports = (regions, options, data) => {
var _a, _b, _c, _d;
return functions.https.onCall({
region: (_a = options.region) !== null && _a !== void 0 ? _a : regions,
timeoutSeconds: options.timeoutSeconds,
memory: options.memory,
minInstances: options.minInstances,
concurrency: options.concurrency,
maxInstances: options.maxInstances,
serviceAccount: (_b = options === null || options === void 0 ? void 0 : options.serviceAccount) !== null && _b !== void 0 ? _b : undefined,
enforceAppCheck: (_c = options.enforceAppCheck) !== null && _c !== void 0 ? _c : undefined,
consumeAppCheckToken: (_d = options.consumeAppCheckToken) !== null && _d !== void 0 ? _d : undefined,
}, (query) => __awaiter(void 0, void 0, void 0, function* () {
var _a, _b, _c;
try {
/* ==== Android検証ここから ==== */
const res = yield verifier.verifyAndroid({
type: "products",
serviceAccountEmail: (_a = process.env.PURCHASE_ANDROID_SERVICEACCOUNT_EMAIL) !== null && _a !== void 0 ? _a : "",
serviceAccountPrivateKey: (_b = process.env.PURCHASE_ANDROID_SERVICEACCOUNT_PRIVATE_KEY) !== null && _b !== void 0 ? _b : "",
packageName: query.data.packageName,
productId: query.data.productId,
purchaseToken: query.data.purchaseToken,
});
if (res["purchaseState"] !== 0) {
throw new functions.https.HttpsError("unauthenticated", "Illegal receipt.");
}
/* ==== ここまでAndroid検証 ==== */
if (!query.data.path || !query.data.value) {
throw new functions.https.HttpsError("invalid-argument", `The required parameters are not set. path: ${query.data.path} value: ${query.data.value}`);
return res;
}
/* ==== Firestoreの更新ここから ==== */
let error = null;
const firestoreDatabaseIds = (_c = options.firestoreDatabaseIds) !== null && _c !== void 0 ? _c : [""];
for (const databaseId of firestoreDatabaseIds) {
try {
const firestoreInstance = (0, firebase_loader_1.firestoreLoader)(databaseId);
yield updater.updateWallet({
targetDocumentFieldPath: query.data.path,
value: query.data.value,
transactionId: query.data.purchaseToken,
transactionData: res,
firestoreInstance: firestoreInstance,
});
}
catch (err) {
error = err;
}
}
if (error) {
console.error(error);
throw new functions.https.HttpsError("unknown", "Unknown error.");
}
/* ==== ここまでFirestoreの更新 ==== */
return res;
}
catch (err) {
console.error(err);
throw err;
}
}));
};
//# sourceMappingURL=consumable_verify_android.js.map