def create_object(self, data, view_kwargs):
        """
        create_object method for the Charges layer
        charge the user using paypal or stripe
        :param data:
        :param view_kwargs:
        :return:
        """

        if view_kwargs.get('order_identifier').isdigit():
            # when id is passed
            order = Order.query.filter_by(id=view_kwargs['order_identifier']).first()
        else:
            # when identifier is passed
            order = Order.query.filter_by(identifier=view_kwargs['order_identifier']).first()

        if not order:
            raise ObjectNotFound({'parameter': 'order_identifier'},
                                 "Order with identifier: {} not found".format(view_kwargs['order_identifier']))
        elif order.status == 'cancelled' or order.status == 'expired' or order.status == 'completed':
            raise ConflictException({'parameter': 'id'},
                                    "You cannot charge payments on a cancelled, expired or completed order")
        elif (not order.amount) or order.amount == 0:
            raise ConflictException({'parameter': 'id'},
                                    "You cannot charge payments on a free order")

        data['id'] = order.id

        # charge through stripe
        if order.payment_mode == 'stripe':
            if not data.get('stripe'):
                raise UnprocessableEntity({'source': ''}, "stripe token is missing")
            if not order.event.can_pay_by_stripe:
                raise ConflictException({'': ''}, "This event doesn't accept payments by Stripe")

            success, response = TicketingManager.charge_stripe_order_payment(order, data['stripe'])
            data['status'] = success
            data['message'] = response

        # charge through paypal
        elif order.payment_mode == 'paypal':
            if (not data.get('paypal_payer_id')) or (not data.get('paypal_payment_id')):
                raise UnprocessableEntity({'source': ''}, "paypal_payer_id or paypal_payment_id or both missing")
            if not order.event.can_pay_by_paypal:
                raise ConflictException({'': ''}, "This event doesn't accept payments by Paypal")

            success, response = TicketingManager.charge_paypal_order_payment(order, data['paypal_payer_id'],
                                                                             data['paypal_payment_id'])
            data['status'] = success
            data['message'] = response

        return data
Пример #2
0
    def create_object(self, data, view_kwargs):
        order = Order.query.filter_by(id=view_kwargs['id']).first()
        if order.payment_mode == 'stripe':
            if data.get('stripe') is None:
                raise UnprocessableEntity({'source': ''}, "stripe token is missing")
            success, response = TicketingManager.charge_stripe_order_payment(order, data['stripe'])
            if not success:
                raise UnprocessableEntity({'source': 'stripe_token_id'}, response)

        elif order.payment_mode == 'paypal':
            success, response = TicketingManager.charge_paypal_order_payment(order)
            if not success:
                raise UnprocessableEntity({'source': ''}, response)
        return order
Пример #3
0
    def create_object(self, data, view_kwargs):
        """
        create_object method for the Charges layer
        charge the user using paypal or stripe
        :param data:
        :param view_kwargs:
        :return:
        """

        if view_kwargs.get('order_identifier').isdigit():
            # when id is passed
            order = Order.query.filter_by(
                id=view_kwargs['order_identifier']).first()
        else:
            # when identifier is passed
            order = Order.query.filter_by(
                identifier=view_kwargs['order_identifier']).first()

        if not order:
            raise ObjectNotFound(
                {'parameter': 'order_identifier'},
                "Order with identifier: {} not found".format(
                    view_kwargs['order_identifier']),
            )
        if (order.status == 'cancelled' or order.status == 'expired'
                or order.status == 'completed'):
            raise ConflictError(
                {'parameter': 'id'},
                "You cannot charge payments on a cancelled, expired or completed order",
            )
        if (not order.amount) or order.amount == 0:
            raise ConflictError({'parameter': 'id'},
                                "You cannot charge payments on a free order")

        data['id'] = order.id

        # charge through stripe
        if order.payment_mode == 'stripe':
            if not order.event.can_pay_by_stripe:
                raise ConflictError(
                    {'': ''}, "This event doesn't accept payments by Stripe")

            success, response = TicketingManager.charge_stripe_order_payment(
                order)
            data['status'] = success
            data['message'] = response

        # charge through paypal
        elif order.payment_mode == 'paypal':
            if (not data.get('paypal_payer_id')) or (
                    not data.get('paypal_payment_id')):
                raise UnprocessableEntityError(
                    {'source': ''},
                    "paypal_payer_id or paypal_payment_id or both missing")
            if not order.event.can_pay_by_paypal:
                raise ConflictError(
                    {'': ''}, "This event doesn't accept payments by Paypal")

            success, response = TicketingManager.charge_paypal_order_payment(
                order, data['paypal_payer_id'], data['paypal_payment_id'])
            data['status'] = success
            data['message'] = response

        return data