Subversion Repositories SmartDukaan

Rev

Rev 4422 | Rev 6503 | 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>
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 &gt;= #{fromTime}
82
    </if>
2289 chandransh 83
    <if test="toTime != '' &amp;&amp; status == 0">
2288 chandransh 84
      AND initTimestamp &lt;= #{toTime}
85
    </if>
2289 chandransh 86
    <if test="toTime != '' &amp;&amp; status != 0">
2288 chandransh 87
      AND (errorTimestamp &lt;= #{toTime} OR successTimestamp &lt;= #{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 &gt;= #{fromTime}
111
	  </if>
112
	  <if test="toTime != ''">
113
	    AND successTimestamp &lt;= #{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>