"use strict"; var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; function getDateInSecs(date) { return +new Date(date) / 1000; } function normalizeDate(date) { return isNumber(date) ? date : getDateInSecs(date); } function isNumber(num) { return !isNaN(Number(num)); } function isNonNullObject(input) { return !!input && (typeof input === "undefined" ? "undefined" : _typeof(input)) === "object" && !Array.isArray(input); } function normalizeBoolean(bool) { if (bool === undefined) { return bool; } return bool ? 1 : 0; } function isDefined(value) { return typeof value !== "undefined"; } function normalizeNotes() { var notes = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; var normalizedNotes = {}; for (var key in notes) { normalizedNotes["notes[" + key + "]"] = notes[key]; } return normalizedNotes; } function prettify(val) { /* * given an object , returns prettified string * * @param {Object} val * @return {String} */ return JSON.stringify(val, null, 2); } function getTestError(summary, expectedVal, gotVal) { /* * @param {String} summary * @param {*} expectedVal * @param {*} gotVal * * @return {Error} */ return new Error("\n" + summary + "\n" + ("Expected(" + (typeof expectedVal === "undefined" ? "undefined" : _typeof(expectedVal)) + ")\n" + prettify(expectedVal) + "\n\n") + ("Got(" + (typeof gotVal === "undefined" ? "undefined" : _typeof(gotVal)) + ")\n" + prettify(gotVal))); } function validateWebhookSignature(body, signature, secret) { /* * Verifies webhook signature * * @param {String} summary * @param {String} signature * @param {String} secret * * @return {Boolean} */ var crypto = require("crypto"); if (!isDefined(body) || !isDefined(signature) || !isDefined(secret)) { throw Error("Invalid Parameters: Please give request body," + "signature sent in X-Razorpay-Signature header and " + "webhook secret from dashboard as parameters"); } body = body.toString(); var expectedSignature = crypto.createHmac('sha256', secret).update(body).digest('hex'); return expectedSignature === signature; } function validatePaymentVerification() { var params = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; var signature = arguments[1]; var secret = arguments[2]; /* * Payment verfication * * @param {Object} params * @param {String} signature * @param {String} secret * @return {Boolean} */ var paymentId = params.payment_id; if (!secret) { throw new Error("secret is mandatory"); } if (isDefined(params.order_id) === true) { var orderId = params.order_id; var payload = orderId + '|' + paymentId; } else if (isDefined(params.subscription_id) === true) { var subscriptionId = params.subscription_id; var payload = paymentId + '|' + subscriptionId; } else if (isDefined(params.payment_link_id) === true) { var paymentLinkId = params.payment_link_id; var paymentLinkRefId = params.payment_link_reference_id; var paymentLinkStatus = params.payment_link_status; var payload = paymentLinkId + '|' + paymentLinkRefId + '|' + paymentLinkStatus + '|' + paymentId; } else { throw new Error('Either order_id or subscription_id is mandatory'); } return validateWebhookSignature(payload, signature, secret); }; module.exports = { normalizeNotes: normalizeNotes, normalizeDate: normalizeDate, normalizeBoolean: normalizeBoolean, isNumber: isNumber, getDateInSecs: getDateInSecs, prettify: prettify, isDefined: isDefined, isNonNullObject: isNonNullObject, getTestError: getTestError, validateWebhookSignature: validateWebhookSignature, validatePaymentVerification: validatePaymentVerification };