mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-16 22:27:26 +01:00
* content: add gems blocks * gemsBlocks: include ios and android identifiers * wip: promo code * split common constants into multiple files * add second promo part * geCurrentEvent, refactor promo * fix lint * fix exports, use world state api * start adding world state tests * remove console.log * use gems block for purchases * remove comments * fix most unit tests * restore comment * fix lint * prevent apple/google gift tests from breaking other tests when stub is not reset * fix unit tests, clarify tests names * iap: use gift object when gifting gems * allow gift object with less data * fix iap tests, remove findById stubs * iap: require less data from the mobile apps * apply discounts * add missing worldState file * fix lint * add test event * start removing 20 gems option for web * start adding support for all gems packages on web * fix unit tests for apple, stripe and google * amazon: support all gems blocks * paypal: support all gems blocks * fix payments unit tests, add tests for getGemsBlock * web: add gems plans with discounts, update stripe * fix amazon and paypal clients, payments success modals * amazon pay: disabled state * update icons, start abstracting payments buttons * begin redesign * redesign gems modal * fix buttons * fix hover color for gems modal close icon * add key to world state current event * extend test event length * implement gems modals designs * early test fall2020 * fix header banner position * add missing files * use iso 8601 for dates, minor ui fixes * fix time zones * events: fix ISO8601 format * fix css indentation * start abstracting banners * refactor payments buttons * test spooky, fix group plans box * implement gems promo banners, refactor banners, fixes * fix lint * fix dates * remove unused i18n strings * fix stripe integration test * fix world state integration tests * the current active event * add missing unit tests * add storybook story for payments buttons component * fix typo * fix(stripe): correct label when gifting subscriptions
149 lines
3.7 KiB
JavaScript
149 lines
3.7 KiB
JavaScript
import {
|
|
BadRequest,
|
|
} from '../../../libs/errors';
|
|
import amzLib from '../../../libs/payments/amazon';
|
|
import {
|
|
authWithHeaders,
|
|
} from '../../../middlewares/auth';
|
|
import shared from '../../../../common';
|
|
|
|
const api = {};
|
|
|
|
/**
|
|
* @apiIgnore Payments are considered part of the private API
|
|
* @api {post} /amazon/verifyAccessToken Amazon Payments: verify access token
|
|
* @apiName AmazonVerifyAccessToken
|
|
* @apiGroup Payments
|
|
*
|
|
* @apiSuccess {Object} data Empty object
|
|
* */
|
|
api.verifyAccessToken = {
|
|
method: 'POST',
|
|
url: '/amazon/verifyAccessToken',
|
|
middlewares: [authWithHeaders()],
|
|
async handler (req, res) {
|
|
const accessToken = req.body.access_token;
|
|
|
|
if (!accessToken) throw new BadRequest('Missing req.body.access_token');
|
|
|
|
await amzLib.getTokenInfo(accessToken);
|
|
|
|
res.respond(200, {});
|
|
},
|
|
};
|
|
|
|
/**
|
|
* @apiIgnore Payments are considered part of the private API
|
|
* @api {post} /amazon/createOrderReferenceId Amazon Payments: create order reference id
|
|
* @apiName AmazonCreateOrderReferenceId
|
|
* @apiGroup Payments
|
|
*
|
|
* @apiSuccess {String} data.orderReferenceId The order reference id.
|
|
* */
|
|
api.createOrderReferenceId = {
|
|
method: 'POST',
|
|
url: '/amazon/createOrderReferenceId',
|
|
middlewares: [authWithHeaders()],
|
|
async handler (req, res) {
|
|
const { billingAgreementId } = req.body;
|
|
|
|
if (!billingAgreementId) throw new BadRequest('Missing req.body.billingAgreementId');
|
|
|
|
const response = await amzLib.createOrderReferenceId({
|
|
Id: billingAgreementId,
|
|
IdType: 'BillingAgreement',
|
|
ConfirmNow: false,
|
|
});
|
|
|
|
res.respond(200, {
|
|
orderReferenceId: response.OrderReferenceDetails.AmazonOrderReferenceId,
|
|
});
|
|
},
|
|
};
|
|
|
|
/**
|
|
* @apiIgnore Payments are considered part of the private API
|
|
* @api {post} /amazon/checkout Amazon Payments: checkout
|
|
* @apiName AmazonCheckout
|
|
* @apiGroup Payments
|
|
*
|
|
* @apiSuccess {Object} data Empty object
|
|
* */
|
|
api.checkout = {
|
|
method: 'POST',
|
|
url: '/amazon/checkout',
|
|
middlewares: [authWithHeaders()],
|
|
async handler (req, res) {
|
|
const { user } = res.locals;
|
|
const { orderReferenceId, gift, gemsBlock } = req.body;
|
|
|
|
if (!orderReferenceId) throw new BadRequest('Missing req.body.orderReferenceId');
|
|
|
|
await amzLib.checkout({
|
|
gemsBlock, gift, user, orderReferenceId, headers: req.headers,
|
|
});
|
|
|
|
res.respond(200);
|
|
},
|
|
};
|
|
|
|
/**
|
|
* @apiIgnore Payments are considered part of the private API
|
|
* @api {post} /amazon/subscribe Amazon Payments: subscribe
|
|
* @apiName AmazonSubscribe
|
|
* @apiGroup Payments
|
|
*
|
|
* @apiSuccess {Object} data Empty object
|
|
* */
|
|
api.subscribe = {
|
|
method: 'POST',
|
|
url: '/amazon/subscribe',
|
|
middlewares: [authWithHeaders()],
|
|
async handler (req, res) {
|
|
const { billingAgreementId } = req.body;
|
|
const sub = req.body.subscription
|
|
? shared.content.subscriptionBlocks[req.body.subscription]
|
|
: false;
|
|
const { coupon } = req.body;
|
|
const { user } = res.locals;
|
|
const { groupId } = req.body;
|
|
|
|
await amzLib.subscribe({
|
|
billingAgreementId,
|
|
sub,
|
|
coupon,
|
|
user,
|
|
groupId,
|
|
headers: req.headers,
|
|
});
|
|
|
|
res.respond(200);
|
|
},
|
|
};
|
|
|
|
/**
|
|
* @apiIgnore Payments are considered part of the private API
|
|
* @api {get} /amazon/subscribe/cancel Amazon Payments: subscribe cancel
|
|
* @apiName AmazonSubscribe
|
|
* @apiGroup Payments
|
|
* */
|
|
api.subscribeCancel = {
|
|
method: 'GET',
|
|
url: '/amazon/subscribe/cancel',
|
|
middlewares: [authWithHeaders()],
|
|
async handler (req, res) {
|
|
const { user } = res.locals;
|
|
const { groupId } = req.query;
|
|
|
|
await amzLib.cancelSubscription({ user, groupId, headers: req.headers });
|
|
|
|
if (req.query.noRedirect) {
|
|
res.respond(200);
|
|
} else {
|
|
res.redirect('/');
|
|
}
|
|
},
|
|
};
|
|
|
|
export default api;
|