payment.js 3.19 KB
/**
 * 各种支付的入口
 *
 * @author: jiangfeng<jeff.jiang@yoho.cn>
 * @date: 16/7/22
 */

'use strict';

const PayData = require('../models/pay');
const OrderData = require('../models/order');
const Alipay = require('./pay/alipay');
const Promise = require('bluebird');
const co = Promise.coroutine;
const logger = global.yoho.logger;

const Payment = {
    pay(user, order, method) {
        return co(function*() {
            let payInfo = yield PayData.getPaymentInfo(method);
            let result = {
                code: 400,
                message: '获取支付方式信息失败'
            };

            if (payInfo && payInfo.id === method) {
                if (method === 2) {
                    result = Alipay.pay(user, order, payInfo);
                }
            }

            if (result.code === 200) {
                let updateInfo = yield Payment.beforePay(user, order, method);

                if (updateInfo && updateInfo.code !== 200) {
                    return updateInfo;
                }
            }

            return result;
        })();
    },

    beforePay(user, order, method) {
        return Promise.all([
            OrderData.updateOrderPayment(order.orderCode, method, user.uid),
            PayData.getBankByOrder(order.orderCode)
        ]).then(result => {
            let paymentRecord = result[0];
            let bankRecord = result[1];
            let bankCode = '';  // 暂时写成'', 参考php代码 Payment.php:564

            if (!paymentRecord || paymentRecord.code !== 200) {
                let message = paymentRecord && paymentRecord.message ? paymentRecord.message : '系统繁忙,请稍后再试';

                return {code: 400, message: message};
            }

            if (bankRecord && bankRecord.bankCode) {
                return PayData.updateOrderPayBank(order.orderCode, method, bankCode);
            } else {
                return PayData.setOrderPayBank(order.orderCode, method, bankCode);
            }

        }).catch(e => {
            logger.error('update order pay info error.', e);

            return Promise.resolve({
                code: 400,
                message: '更新订单支付信息失败'
            });
        });
    },

    afterPay(query, payId, user) {
        return co(function*() {
            let payInfo = yield PayData.getPaymentInfo(payId);
            let payResult = {};

            if (payId === 2) {
                payResult = Alipay.notify(query, payInfo);

                payResult.bankName = payResult.bankName || payInfo.payName || '';
                payResult.bankCode = payResult.bankCode || payInfo.pay_code || '';
            }

            console.log(payResult);

            if (payResult && payResult.payResult === 200) {
                if (payResult.orderCode) {
                    logger.info('pay back confirm');
                    yield PayData.sendPayConfirm(payResult.orderCode, payId, user.uid);
                }

                return yield PayData.procOrderData(payResult, user.uid);
            } else {
                return {
                    code: 500,
                    message: '支付失败'
                };
            }
        })();
    }
};

module.exports = Payment;