Subversion Repositories SmartDukaan

Rev

Rev 6077 | Rev 7049 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
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
6077 anupam.sin 14
      (gatewayId, userId, merchantTxnId, amount, status, initTimestamp, isDigital) 
1946 chandransh 15
    VALUES
6077 anupam.sin 16
      (#{gatewayId}, #{userId}, #{merchantTxnId}, #{amount}, #{status},  now(), #{isDigital})
1946 chandransh 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>
6503 rajveer 56
    <if test="refundAmount != null">
57
      refundAmount = #{refundAmount},
58
    </if>
1946 chandransh 59
    errorCode = #{errorCode},
60
    successTimestamp = #{successTimestamp},
4422 mandeep.dh 61
    errorTimestamp = #{errorTimestamp},
62
    provisionalCaptureTimestamp = #{provisionalCaptureTimestamp}
1946 chandransh 63
    WHERE id=#{id}
64
  </update>
65
 
66
  <sql id="selectAllPaymentFields">
67
    SELECT * FROM payment
68
  </sql>
69
 
70
  <select id="getPayment" parameterType="int" resultMap="paymentResult">
71
    <include refid="selectAllPaymentFields"/>
72
    WHERE id=#{id}
73
  </select>
74
 
75
  <select id="getPaymentForTxn" parameterType="int" resultMap="paymentResult">
76
    SELECT * FROM payment
77
    WHERE merchantTxnId=#{merchantTxnId}
2388 chandransh 78
    ORDER BY id DESC
79
    LIMIT 1
1946 chandransh 80
  </select>
81
 
2288 chandransh 82
  <sql id="getPaymentsWhereClause">
83
    <if test="fromTime != ''">
84
      initTimestamp &gt;= #{fromTime}
85
    </if>
2289 chandransh 86
    <if test="toTime != '' &amp;&amp; status == 0">
2288 chandransh 87
      AND initTimestamp &lt;= #{toTime}
88
    </if>
2289 chandransh 89
    <if test="toTime != '' &amp;&amp; status != 0">
2288 chandransh 90
      AND (errorTimestamp &lt;= #{toTime} OR successTimestamp &lt;= #{toTime})
91
    </if>
92
    <if test="status != -1">
93
      AND status=#{status}
94
    </if>
95
    <if test="gatewayId != 0">
96
      AND gatewayId = #{gatewayId}
97
    </if>
98
  </sql>
99
 
1946 chandransh 100
  <select id="getPayments" parameterType="map" resultMap="paymentResult">
101
    SELECT * FROM payment
102
    <where>
2288 chandransh 103
      <include refid="getPaymentsWhereClause"/>
1946 chandransh 104
    </where>
105
    ORDER BY id
106
  </select>
107
 
4141 chandransh 108
  <select id="getPaymentsByCapturedDate" parameterType="map" resultMap="paymentResult">
109
    SELECT * FROM payment
110
    <where>
111
      status = #{status}
112
	  <if test="fromTime != ''">
113
	    AND successTimestamp &gt;= #{fromTime}
114
	  </if>
115
	  <if test="toTime != ''">
116
	    AND successTimestamp &lt;= #{toTime}
117
	  </if>
118
	  <if test="gatewayId != 0">
119
        AND gatewayId = #{gatewayId}
120
      </if>
121
    </where>
122
    ORDER BY id
123
  </select>
124
 
1946 chandransh 125
  <select id="getPaymentsForUser" parameterType="map" resultMap="paymentResult">
126
    SELECT * FROM payment
127
    <where>
2288 chandransh 128
      <include refid="getPaymentsWhereClause"/>
129
      AND userId=#{userId}
1946 chandransh 130
    </where>
131
    ORDER BY id
132
  </select>
133
 
134
  <select id="getMinMaxPaymentAmount" resultType="hashmap">
2293 chandransh 135
    SELECT MIN(AMOUNT) MIN, MAX(AMOUNT) MAX from payment WHERE status = 2
1946 chandransh 136
  </select>
137
 
138
  <select id="getAttributesForPayment" parameterType="int" resultType="paymentAttribute">
139
    SELECT * FROM paymentattribute where payment_id = #{id}
140
  </select>
141
</mapper>