Skip to content

Commit

Permalink
fix(medusa-payment-stripe): Missing transactions in Stripe provider (#…
Browse files Browse the repository at this point in the history
  • Loading branch information
adrien2p authored Nov 14, 2022
1 parent d0809bd commit 9e91a50
Show file tree
Hide file tree
Showing 4 changed files with 58 additions and 47 deletions.
6 changes: 6 additions & 0 deletions .changeset/orange-penguins-promise.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
---
"medusa-payment-stripe": patch
"@medusajs/medusa": patch
---

fix(medusa-payment-stripe): missing transaction on create payment
38 changes: 19 additions & 19 deletions packages/medusa-payment-stripe/src/helpers/stripe-base.js
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,7 @@ class StripeBase extends AbstractPaymentService {
regionService,
manager,
},
options,
paymentMethodTypes
options
) {
super(
{
Expand All @@ -25,8 +24,6 @@ class StripeBase extends AbstractPaymentService {
},
options
)
/** @private @const {string[]} */
this.paymentMethodTypes_ = paymentMethodTypes

/**
* Required Stripe options:
Expand Down Expand Up @@ -123,18 +120,19 @@ class StripeBase extends AbstractPaymentService {
* @return {Promise<PaymentSessionData>} Stripe payment intent
*/
async createPayment(cart) {
const intentRequest = this.getPaymentIntentOptions()
const intentRequestData = this.getPaymentIntentOptions()

return await this.stripeProviderService_.createPayment(cart, intentRequest)
return await this.stripeProviderService_
.withTransaction(this.manager_)
.createPayment(cart, intentRequestData)
}

async createPaymentNew(paymentInput) {
const intentRequest = this.getPaymentIntentOptions()
const intentRequestData = this.getPaymentIntentOptions()

return await this.stripeProviderService_.createPaymentNew(
paymentInput,
intentRequest
)
return await this.stripeProviderService_
.withTransaction(this.manager_)
.createPaymentNew(paymentInput, intentRequestData)
}

/**
Expand Down Expand Up @@ -183,17 +181,19 @@ class StripeBase extends AbstractPaymentService {
* @return {Promise<PaymentSessionData>} Stripe payment intent
*/
async updatePayment(paymentSessionData, cart) {
return await this.stripeProviderService_.updatePayment(
paymentSessionData,
cart
)
const intentRequestData = this.getPaymentIntentOptions()

return await this.stripeProviderService_
.withTransaction(this.manager_)
.updatePayment(paymentSessionData, cart, intentRequestData)
}

async updatePaymentNew(paymentSessionData, paymentInput) {
return await this.stripeProviderService_.updatePaymentNew(
paymentSessionData,
paymentInput
)
const intentRequestData = this.getPaymentIntentOptions()

return await this.stripeProviderService_
.withTransaction(this.manager_)
.updatePaymentNew(paymentSessionData, paymentInput, intentRequestData)
}

async deletePayment(paymentSession) {
Expand Down
23 changes: 14 additions & 9 deletions packages/medusa-payment-stripe/src/services/stripe-provider.js
Original file line number Diff line number Diff line change
Expand Up @@ -127,6 +127,7 @@ class StripeProviderService extends AbstractPaymentService {
* Creates a Stripe payment intent.
* If customer is not registered in Stripe, we do so.
* @param {Cart} cart - cart to create a payment for
* @param intentRequestData
* @return {Promise<PaymentSessionData>} Stripe payment intent
*/
async createPayment(cart, intentRequestData = {}) {
Expand Down Expand Up @@ -271,20 +272,24 @@ class StripeProviderService extends AbstractPaymentService {
* Updates Stripe payment intent.
* @param {PaymentSessionData} paymentSessionData - payment session data.
* @param {Cart} cart
* @param intentRequestData
* @return {Promise<PaymentSessionData>} Stripe payment intent
*/
async updatePayment(sessionData, cart) {
async updatePayment(paymentSessionData, cart, intentRequestData) {
try {
const stripeId = cart.customer?.metadata?.stripe_id || undefined

if (stripeId !== sessionData.customer) {
return await this.createPayment(cart)
if (stripeId !== paymentSessionData.customer) {
return await this.createPayment(cart, intentRequestData)
} else {
if (cart.total && sessionData.amount === Math.round(cart.total)) {
return sessionData
if (
cart.total &&
paymentSessionData.amount === Math.round(cart.total)
) {
return paymentSessionData
}

return await this.stripe_.paymentIntents.update(sessionData.id, {
return await this.stripe_.paymentIntents.update(paymentSessionData.id, {
amount: Math.round(cart.total),
})
}
Expand All @@ -293,15 +298,15 @@ class StripeProviderService extends AbstractPaymentService {
}
}

async updatePaymentNew(paymentSessionData, paymentInput) {
async updatePaymentNew(paymentSessionData, paymentInput, intentRequestData) {
try {
const stripeId = paymentInput.customer?.metadata?.stripe_id

if (stripeId !== paymentInput.customer_id) {
return await this.createPaymentNew(paymentInput)
return await this.createPaymentNew(paymentInput, intentRequestData)
} else {
if (paymentSessionData.amount === Math.round(paymentInput.amount)) {
return sessionData
return paymentSessionData
}

return await this.stripe_.paymentIntents.update(paymentSessionData.id, {
Expand Down
38 changes: 19 additions & 19 deletions packages/medusa/src/services/cart.ts
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,12 @@ import {
isCart,
LineItemUpdate,
} from "../types/cart"
import { AddressPayload, FindConfig, TotalField } from "../types/common"
import {
AddressPayload,
FindConfig,
TotalField,
WithRequiredProperty,
} from "../types/common"
import { buildQuery, isDefined, setMetadata } from "../utils"
import { FlagRouter } from "../utils/flag-router"
import { validateEmail } from "../utils/is-email"
Expand Down Expand Up @@ -281,7 +286,7 @@ class CartService extends TransactionBaseService {
cartId: string,
options: FindConfig<Cart> = {},
totalsConfig: TotalsConfig = {}
): Promise<Cart> {
): Promise<WithRequiredProperty<Cart, "total">> {
const relations = this.getTotalsRelations(options)

const cart = await this.retrieve(cartId, {
Expand Down Expand Up @@ -823,15 +828,14 @@ class CartService extends TransactionBaseService {
relations,
})

const originalCartCustomer = { ...(cart.customer ?? {}) }
if (data.customer_id) {
await this.updateCustomerId_(cart, data.customer_id)
} else {
if (isDefined(data.email)) {
const customer = await this.createOrFetchUserFromEmail_(data.email)
cart.customer = customer
cart.customer_id = customer.id
cart.email = customer.email
}
} else if (isDefined(data.email)) {
const customer = await this.createOrFetchUserFromEmail_(data.email)
cart.customer = customer
cart.customer_id = customer.id
cart.email = customer.email
}

if (isDefined(data.customer_id) || isDefined(data.region_id)) {
Expand Down Expand Up @@ -937,7 +941,10 @@ class CartService extends TransactionBaseService {

const updatedCart = await cartRepo.save(cart)

if ("email" in data || "customer_id" in data) {
if (
(data.email && data.email !== originalCartCustomer.email) ||
(data.customer_id && data.customer_id !== originalCartCustomer.id)
) {
await this.eventBus_
.withTransaction(transactionManager)
.emit(CartService.Events.CUSTOMER_UPDATED, updatedCart.id)
Expand Down Expand Up @@ -1486,13 +1493,6 @@ class CartService extends TransactionBaseService {

const { total, region } = cart

if (typeof total === "undefined") {
throw new MedusaError(
MedusaError.Types.UNEXPECTED_STATE,
"cart.total must be defined"
)
}

// If there are existing payment sessions ensure that these are up to date
const seen: string[] = []
if (cart.payment_sessions?.length) {
Expand Down Expand Up @@ -2104,7 +2104,7 @@ class CartService extends TransactionBaseService {
async decorateTotals(
cart: Cart,
totalsConfig: TotalsConfig = {}
): Promise<Cart> {
): Promise<WithRequiredProperty<Cart, "total">> {
const manager = this.transactionManager_ ?? this.manager_
const newTotalsServiceTx = this.newTotalsService_.withTransaction(manager)

Expand Down Expand Up @@ -2192,7 +2192,7 @@ class CartService extends TransactionBaseService {
cart.tax_total -
(cart.gift_card_total + cart.discount_total + cart.gift_card_tax_total)

return cart
return cart as Cart & { total: number }
}

protected async refreshAdjustments_(cart: Cart): Promise<void> {
Expand Down

0 comments on commit 9e91a50

Please sign in to comment.