Store PayU payment metadata and attempts
All checks were successful
build-and-deploy / build-deploy (push) Successful in 37s
All checks were successful
build-and-deploy / build-deploy (push) Successful in 37s
This commit is contained in:
@@ -32,6 +32,30 @@ class Payment(
|
||||
@Column(name = "method", nullable = false)
|
||||
var method: PaymentMethod,
|
||||
|
||||
@Column(name = "gateway_payment_id")
|
||||
var gatewayPaymentId: String? = null,
|
||||
|
||||
@Column(name = "gateway_txn_id")
|
||||
var gatewayTxnId: String? = null,
|
||||
|
||||
@Column(name = "bank_ref_num")
|
||||
var bankRefNum: String? = null,
|
||||
|
||||
@Column(name = "mode")
|
||||
var mode: String? = null,
|
||||
|
||||
@Column(name = "pg_type")
|
||||
var pgType: String? = null,
|
||||
|
||||
@Column(name = "payer_vpa")
|
||||
var payerVpa: String? = null,
|
||||
|
||||
@Column(name = "payer_name")
|
||||
var payerName: String? = null,
|
||||
|
||||
@Column(name = "payment_source")
|
||||
var paymentSource: String? = null,
|
||||
|
||||
@Column(name = "reference")
|
||||
var reference: String? = null,
|
||||
|
||||
|
||||
@@ -0,0 +1,79 @@
|
||||
package com.android.trisolarisserver.models.payment
|
||||
|
||||
import com.android.trisolarisserver.models.booking.Booking
|
||||
import com.android.trisolarisserver.models.property.Property
|
||||
import jakarta.persistence.Column
|
||||
import jakarta.persistence.Entity
|
||||
import jakarta.persistence.FetchType
|
||||
import jakarta.persistence.GeneratedValue
|
||||
import jakarta.persistence.Id
|
||||
import jakarta.persistence.JoinColumn
|
||||
import jakarta.persistence.ManyToOne
|
||||
import jakarta.persistence.Table
|
||||
import java.time.OffsetDateTime
|
||||
import java.util.UUID
|
||||
|
||||
@Entity
|
||||
@Table(name = "payu_payment_attempt")
|
||||
class PayuPaymentAttempt(
|
||||
@Id
|
||||
@GeneratedValue
|
||||
@Column(columnDefinition = "uuid")
|
||||
val id: UUID? = null,
|
||||
|
||||
@ManyToOne(fetch = FetchType.LAZY, optional = false)
|
||||
@JoinColumn(name = "property_id", nullable = false)
|
||||
var property: Property,
|
||||
|
||||
@ManyToOne(fetch = FetchType.LAZY)
|
||||
@JoinColumn(name = "booking_id")
|
||||
var booking: Booking? = null,
|
||||
|
||||
@Column(name = "status")
|
||||
var status: String? = null,
|
||||
|
||||
@Column(name = "unmapped_status")
|
||||
var unmappedStatus: String? = null,
|
||||
|
||||
@Column(name = "amount")
|
||||
var amount: Long? = null,
|
||||
|
||||
@Column(name = "currency")
|
||||
var currency: String? = null,
|
||||
|
||||
@Column(name = "gateway_payment_id")
|
||||
var gatewayPaymentId: String? = null,
|
||||
|
||||
@Column(name = "gateway_txn_id")
|
||||
var gatewayTxnId: String? = null,
|
||||
|
||||
@Column(name = "bank_ref_num")
|
||||
var bankRefNum: String? = null,
|
||||
|
||||
@Column(name = "mode")
|
||||
var mode: String? = null,
|
||||
|
||||
@Column(name = "pg_type")
|
||||
var pgType: String? = null,
|
||||
|
||||
@Column(name = "payer_vpa")
|
||||
var payerVpa: String? = null,
|
||||
|
||||
@Column(name = "payer_name")
|
||||
var payerName: String? = null,
|
||||
|
||||
@Column(name = "payment_source")
|
||||
var paymentSource: String? = null,
|
||||
|
||||
@Column(name = "error_code")
|
||||
var errorCode: String? = null,
|
||||
|
||||
@Column(name = "error_message")
|
||||
var errorMessage: String? = null,
|
||||
|
||||
@Column(name = "payload", columnDefinition = "text")
|
||||
var payload: String? = null,
|
||||
|
||||
@Column(name = "received_at", columnDefinition = "timestamptz")
|
||||
var receivedAt: OffsetDateTime = OffsetDateTime.now()
|
||||
)
|
||||
Reference in New Issue
Block a user