| 1946 |
chandransh |
1 |
<?xml version="1.0" encoding="UTF-8"?>
|
|
|
2 |
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
|
|
3 |
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
|
|
4 |
|
|
|
5 |
<mapper namespace="in.shop2020.payment.persistence.PaymentMapper">
|
|
|
6 |
|
|
|
7 |
<resultMap type="payment" id="paymentResult">
|
|
|
8 |
<id property="id" column="id"/>
|
|
|
9 |
<collection property="attributes" javaType="ArrayList" column="id" ofType="paymentAttribute" select="getAttributesForPayment"/>
|
|
|
10 |
</resultMap>
|
|
|
11 |
|
|
|
12 |
<insert id="insertPayment" parameterType="payment" useGeneratedKeys="true" keyProperty="id">
|
|
|
13 |
INSERT INTO payment
|
|
|
14 |
(gatewayId, userId, merchantTxnId, amount, status, initTimestamp)
|
|
|
15 |
VALUES
|
|
|
16 |
(#{gatewayId}, #{userId}, #{merchantTxnId}, #{amount}, #{status}, now())
|
|
|
17 |
</insert>
|
|
|
18 |
|
|
|
19 |
<insert id="insertPaymentAttribute" parameterType="map">
|
|
|
20 |
INSERT INTO paymentattribute
|
|
|
21 |
(payment_id, name, value)
|
|
|
22 |
VALUES(#{paymentId}, #{name}, #{value})
|
|
|
23 |
ON DUPLICATE KEY UPDATE value=values(value);
|
|
|
24 |
</insert>
|
|
|
25 |
|
|
|
26 |
<update id="updatePayment" parameterType="payment">
|
|
|
27 |
UPDATE payment
|
| 2388 |
chandransh |
28 |
SET
|
|
|
29 |
<if test="gatewayPaymentId != null">
|
|
|
30 |
gatewayPaymentId = #{gatewayPaymentId},
|
|
|
31 |
</if>
|
|
|
32 |
<if test="sessionId != null">
|
|
|
33 |
sessionId = #{sessionId},
|
|
|
34 |
</if>
|
|
|
35 |
<if test="gatewayTxnStatus != null">
|
|
|
36 |
gatewayTxnStatus = #{gatewayTxnStatus},
|
|
|
37 |
</if>
|
|
|
38 |
<if test="description != null">
|
|
|
39 |
description = #{description},
|
|
|
40 |
</if>
|
|
|
41 |
<if test="gatewayTxnId != null">
|
|
|
42 |
gatewayTxnId = #{gatewayTxnId},
|
|
|
43 |
</if>
|
|
|
44 |
<if test="authCode != null">
|
|
|
45 |
authCode = #{authCode},
|
|
|
46 |
</if>
|
|
|
47 |
<if test="referenceCode != null">
|
|
|
48 |
referenceCode = #{referenceCode},
|
|
|
49 |
</if>
|
|
|
50 |
<if test="gatewayTxnDate != null">
|
|
|
51 |
gatewayTxnDate = #{gatewayTxnDate},
|
|
|
52 |
</if>
|
|
|
53 |
<if test="status != null">
|
|
|
54 |
status = #{status},
|
|
|
55 |
</if>
|
| 1946 |
chandransh |
56 |
errorCode = #{errorCode},
|
|
|
57 |
successTimestamp = #{successTimestamp},
|
| 4422 |
mandeep.dh |
58 |
errorTimestamp = #{errorTimestamp},
|
|
|
59 |
provisionalCaptureTimestamp = #{provisionalCaptureTimestamp}
|
| 1946 |
chandransh |
60 |
WHERE id=#{id}
|
|
|
61 |
</update>
|
|
|
62 |
|
|
|
63 |
<sql id="selectAllPaymentFields">
|
|
|
64 |
SELECT * FROM payment
|
|
|
65 |
</sql>
|
|
|
66 |
|
|
|
67 |
<select id="getPayment" parameterType="int" resultMap="paymentResult">
|
|
|
68 |
<include refid="selectAllPaymentFields"/>
|
|
|
69 |
WHERE id=#{id}
|
|
|
70 |
</select>
|
|
|
71 |
|
|
|
72 |
<select id="getPaymentForTxn" parameterType="int" resultMap="paymentResult">
|
|
|
73 |
SELECT * FROM payment
|
|
|
74 |
WHERE merchantTxnId=#{merchantTxnId}
|
| 2388 |
chandransh |
75 |
ORDER BY id DESC
|
|
|
76 |
LIMIT 1
|
| 1946 |
chandransh |
77 |
</select>
|
|
|
78 |
|
| 2288 |
chandransh |
79 |
<sql id="getPaymentsWhereClause">
|
|
|
80 |
<if test="fromTime != ''">
|
|
|
81 |
initTimestamp >= #{fromTime}
|
|
|
82 |
</if>
|
| 2289 |
chandransh |
83 |
<if test="toTime != '' && status == 0">
|
| 2288 |
chandransh |
84 |
AND initTimestamp <= #{toTime}
|
|
|
85 |
</if>
|
| 2289 |
chandransh |
86 |
<if test="toTime != '' && status != 0">
|
| 2288 |
chandransh |
87 |
AND (errorTimestamp <= #{toTime} OR successTimestamp <= #{toTime})
|
|
|
88 |
</if>
|
|
|
89 |
<if test="status != -1">
|
|
|
90 |
AND status=#{status}
|
|
|
91 |
</if>
|
|
|
92 |
<if test="gatewayId != 0">
|
|
|
93 |
AND gatewayId = #{gatewayId}
|
|
|
94 |
</if>
|
|
|
95 |
</sql>
|
|
|
96 |
|
| 1946 |
chandransh |
97 |
<select id="getPayments" parameterType="map" resultMap="paymentResult">
|
|
|
98 |
SELECT * FROM payment
|
|
|
99 |
<where>
|
| 2288 |
chandransh |
100 |
<include refid="getPaymentsWhereClause"/>
|
| 1946 |
chandransh |
101 |
</where>
|
|
|
102 |
ORDER BY id
|
|
|
103 |
</select>
|
|
|
104 |
|
| 4141 |
chandransh |
105 |
<select id="getPaymentsByCapturedDate" parameterType="map" resultMap="paymentResult">
|
|
|
106 |
SELECT * FROM payment
|
|
|
107 |
<where>
|
|
|
108 |
status = #{status}
|
|
|
109 |
<if test="fromTime != ''">
|
|
|
110 |
AND successTimestamp >= #{fromTime}
|
|
|
111 |
</if>
|
|
|
112 |
<if test="toTime != ''">
|
|
|
113 |
AND successTimestamp <= #{toTime}
|
|
|
114 |
</if>
|
|
|
115 |
<if test="gatewayId != 0">
|
|
|
116 |
AND gatewayId = #{gatewayId}
|
|
|
117 |
</if>
|
|
|
118 |
</where>
|
|
|
119 |
ORDER BY id
|
|
|
120 |
</select>
|
|
|
121 |
|
| 1946 |
chandransh |
122 |
<select id="getPaymentsForUser" parameterType="map" resultMap="paymentResult">
|
|
|
123 |
SELECT * FROM payment
|
|
|
124 |
<where>
|
| 2288 |
chandransh |
125 |
<include refid="getPaymentsWhereClause"/>
|
|
|
126 |
AND userId=#{userId}
|
| 1946 |
chandransh |
127 |
</where>
|
|
|
128 |
ORDER BY id
|
|
|
129 |
</select>
|
|
|
130 |
|
|
|
131 |
<select id="getMinMaxPaymentAmount" resultType="hashmap">
|
| 2293 |
chandransh |
132 |
SELECT MIN(AMOUNT) MIN, MAX(AMOUNT) MAX from payment WHERE status = 2
|
| 1946 |
chandransh |
133 |
</select>
|
|
|
134 |
|
|
|
135 |
<select id="getAttributesForPayment" parameterType="int" resultType="paymentAttribute">
|
|
|
136 |
SELECT * FROM paymentattribute where payment_id = #{id}
|
|
|
137 |
</select>
|
|
|
138 |
</mapper>
|