Subversion Repositories SmartDukaan

Rev

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

Rev Author Line No. Line
121 ashish 1
namespace java in.shop2020.payments
420 ashish 2
namespace py shop2020.thriftpy.payments
121 ashish 3
 
3374 rajveer 4
include "GenericService.thrift"
5
 
121 ashish 6
/**
7
Various structures
8
**/
9
enum PaymentGatewayStatus{
10
	AVAILABLE,
11
	BLOCKED
12
}
13
 
14
enum PaymentStatus{
15
	INIT,
16
	PENDING,
1854 chandransh 17
	SUCCESS,	// HDFC Status: CAPTURED; EBS Status: Captured
18
	FAILED,		// HDFC status: NOT CAPTURED, DENIED BY RISK, HOST TIMEOUT, CANCELLED
3956 chandransh 19
	AUTHORIZED,  // EBS Status: Pending, HDFC Status: APPROVED
4421 mandeep.dh 20
	PARTIALLY_CAPTURED, //In case of COD
21
	CAPTURE_IN_PROCESS, // In case first few attempts to capture failed due to transient connections issues
6482 rajveer 22
	PROVISIONALLY_CAPTURED, // In case payment is not getting
23
	REFUNDED 
121 ashish 24
}
25
 
3270 vikas 26
// If new paymethod is added here, sales database for pentaho must also be updated.
2303 ankur.sing 27
const map<string,string> PAYMENT_METHOD = {
28
	'1001' : 'EBS-TEST Payment'
29
	'1004' : 'EBS-AXIS Bank Account'
30
	'1007' : 'EBS-HDFC Bank Account'
31
	'1008' : 'EBS-VISA'
32
	'1009' : 'EBS-Citi Bank Debit Card'
33
	'1010' : 'EBS-Diners Club'
34
	'1012' : 'EBS-ItzCash'
13441 amit.gupta 35
	'1015' : 'JK Bank Account'
36
	'1016' : 'ICICI Bank Account'
2303 ankur.sing 37
	'1017' : 'EBS-MasterCard'
13441 amit.gupta 38
	'1029' : 'Federal Bank Account'
39
	'1032' : 'State Bank of India Netbanking'
40
	'1033' : 'State Bank of Bikaner and Jaipur Netbanking'
41
	'1034' : 'State Bank of Hyderabad Netbanking'
42
	'1035' : 'State Bank of Patiala Netbanking'
43
	'1036' : 'State Bank of Shaurashtra Netbanking'
44
	'1037' : 'State Bank of Indore Netbanking'
45
	'1038' : 'State Bank of Mysore Netbanking'
46
	'1039' : 'State Bank of Travancore Netbanking'
8274 amit.gupta 47
	'1040' : 'EBS-Citi Bank Reward Point',
13441 amit.gupta 48
	'1154' : 'ORIENTAL BANK OF COMMERCE Netbanking',
8274 amit.gupta 49
	'1210' : 'ING VYSYA BANK Netbanking',
50
	'1224' : 'CANARA BANK Netbanking'
17782 amit.gupta 51
	'1127' : 'Citi Bank NetBanking'
2303 ankur.sing 52
	'1132' : 'EBS-Done Card'
13441 amit.gupta 53
	'1133' : 'Karnataka Bank Account'
2574 chandransh 54
	'1134' : 'EBS-ICash'
13441 amit.gupta 55
	'1135' : 'Corporation Bank Account'
7781 amit.gupta 56
	'1212' : 'United Bank of India'
57
	'1213' : 'Indian Overseas Bank'
58
	'1214' : 'Bank of India'
17782 amit.gupta 59
	'1215' : 'City Union Bank'
7781 amit.gupta 60
	'1216' : 'Union Bank of India'
10040 amit.gupta 61
	'1273' : 'Dhanalaxmi Bank'
13441 amit.gupta 62
	'1601' : 'Catholic Syrian Bank'
63
	'1602' : 'Development Credit Bank'
64
	'1603' : 'Deutsche Bank'
65
	'1604' : 'IDBI Bank'
66
	'1605' : 'IndusInd Bank'
67
	'1606' : 'Karur Vysya - Retail Netbanking'
68
	'1607' : 'Punjab National Bank - Retail Banking'
69
	'1608' : 'South Indian Bank'
70
	'1609' : 'Saraswat Bank'
71
	'1610' : 'Vijaya Bank'
17782 amit.gupta 72
	'1611' : 'DCB Bank - Corporate Netbanking'
73
	'1612' : 'Union Bank - Corporate Netbanking'
74
	'1613' : 'Punjab National Bank-Corporate'
13441 amit.gupta 75
 
2574 chandransh 76
 	'2000' : 'HDFC-VISA/VISA Electron Debit Card'
2461 chandransh 77
	'2008' : 'HDFC-VISA'
5538 anupam.sin 78
	'2017' : 'HDFC-MasterCard Credit Card'
79
	'2018' : 'HDFC-MasterCard Debit Card'
3164 chandransh 80
	'3000' : 'COD'
8907 rajveer 81
	'3001' : 'Coupon'
3270 vikas 82
	'2001' : 'Cheque'
3274 vikas 83
	'1026' : 'EBS-ICICI Bank Debit Card'
84
    '1027' : 'EBS-SBI Debit Card'
3709 chandransh 85
    '2020' : 'HDFC Credit Card 3-month EMI'
6459 rajveer 86
    '5001' : 'HDFC Credit Card 3-month EMI'
87
    '5002' : 'HDFC Credit Card 6-month EMI'
88
    '5003' : 'HDFC Credit Card 9-month EMI'
89
    '5004' : 'HDFC Credit Card 12-month EMI'
7330 amit.gupta 90
    '5005' : 'HDFC Credit Card 18-month EMI'
6978 amit.gupta 91
    '1139' : 'Citi EBS-VISA Credit Card 3-months EMI'
92
    '1140' : 'Citi EBS-MasterCard Credit Card 3-months EMI'
93
    '1141' : 'Citi EBS-VISA Credit Card 6-months EMI'
94
    '1142' : 'Citi EBS-MasterCard Credit Card 6-months EMI'
5102 phani.kuma 95
    '1143' : 'EBS-Indian Bank Netbanking'
96
    '1164' : 'EBS-Maestro Debit Card'
6978 amit.gupta 97
    '4000' : 'BULK',
13421 amit.gupta 98
    '4001' : 'PAYU MONEY',
6978 amit.gupta 99
    '210000':'Axis Bank Innoviti 3 Months EMI',
100
    '220000':'Axis Bank Innoviti 6 Months EMI',
101
    '230000':'Axis Bank Innoviti 9 Months EMI',
102
    '240000':'Axis Bank Innoviti 12 Months EMI',
103
    '250000':'Axis Bank Innoviti 18 Months EMI',
104
    '310000':'ICICI Bank Innoviti 3 Months EMI',
105
    '320000':'ICICI Bank Innoviti 6 Months EMI',
106
    '330000':'ICICI Bank Innoviti 9 Months EMI',
107
    '340000':'ICICI Bank Innoviti 12 Months EMI',
108
    '350000':'ICICI Bank Innoviti 18 Months EMI',
109
    '410000':'InsdusInd Bank Innoviti 3 Months EMI',
110
    '420000':'InsdusInd Bank Innoviti 6 Months EMI',
111
    '430000':'InsdusInd Bank Innoviti 9 Months EMI',
112
    '440000':'InsdusInd Bank Innoviti 12 Months EMI',
9506 amit.gupta 113
    '510000':'Citi Bank Innoviti 3 Months EMI',
114
    '520000':'Citi Bank Innoviti 6 Months EMI',
115
    '530000':'Citi Bank Innoviti 9 Months EMI',
116
    '540000':'Citi Bank Innoviti 12 Months EMI',
6978 amit.gupta 117
    '610000':'Standard Chartered Bank Innoviti 3 Months EMI',
118
    '620000':'Standard Chartered Bank Innoviti 6 Months EMI',
119
    '630000':'Standard Chartered Bank Innoviti 9 Months EMI',
120
    '640000':'Standard Chartered Bank Innoviti 12 Months EMI',
121
    '710000':'HSBC Bank Innoviti 3 Months EMI',
122
    '720000':'HSBC Bank Innoviti 6 Months EMI',
7948 amit.gupta 123
    '730000':'HSBC Bank Innoviti 6 Months EMI',
124
    '740000':'HSBC Bank Innoviti 6 Months EMI',
6978 amit.gupta 125
    '810000':'Kotak Mahindra Bank Innoviti 3 Months EMI',
126
    '820000':'Kotak Mahindra Bank Innoviti 6 Months EMI',
127
    '830000':'Kotak Mahindra Bank Innoviti 9 Months EMI',
128
    '840000':'Kotak Mahindra Bank Innoviti 12 Months EMI',
129
    '910000':'SBI Bank Innoviti 3 Months EMI',
130
    '920000':'SBI Bank Innoviti 6 Months EMI',
131
    '930000':'SBI Bank Innoviti 9 Months EMI',
132
    '940000':'SBI Bank Innoviti 12 Months EMI',
133
    '950000':'SBI Bank Innoviti 18 Months EMI'
3274 vikas 134
}
2303 ankur.sing 135
 
680 rajveer 136
struct Attribute{
137
	1:string name,
138
	2:string value
121 ashish 139
}
140
 
420 ashish 141
struct PaymentGateway{
121 ashish 142
	1:i64 id,
680 rajveer 143
	2:string name,
144
	3:string url,
145
	4:i64 addedOn,
146
	5:string aliasName,
147
	6:string responseUrl,
148
	7:string errorUrl,
149
	8:PaymentGatewayStatus status
150
	9:list<Attribute> attributes  // list of all attributes for PG
121 ashish 151
}
152
 
153
struct Payment{
680 rajveer 154
	1:i64 paymentId,  				// trackId for bank, paymentid for us and id for table.
155
	2:i64 gatewayId, 				//payment gateway used
156
	3:string gatewayPaymentId
704 chandransh 157
	4:i64 merchantTxnId,			//merchant transaction id. This will be propagated further to order processing
680 rajveer 158
	5:string gatewayTxnId,			//bank trnasaction id
159
	6:double amount,
160
	7:string gatewayTxnStatus,  	// bank status will be stored here
161
	8:PaymentStatus status,
162
	9:i64 userId,					//The user for which payment has to be processed.This is here to speed up querying.
163
	10:string errorCode,
164
	11:string description,
165
	12:string authCode,
166
	13:string referenceCode,		// given by gateway
167
	14:string sessionId, 			// received from PG 
168
	15:string gatewayTxnDate,
169
	16:list<Attribute> attributes,  	// list of all attributes received from PG
170
	17:i64 initTimestamp,			//statring the payment processing timestamp
171
	18:i64 successTimestamp,		//timestamp when payment is captured
172
	19:i64 errorTimestamp,			// in case, error is received from PG
6050 anupam.sin 173
	20:i64 provisionalCaptureTimestamp, // in case, error is received from PG
6503 rajveer 174
	21:bool isDigital,
175
	22:double refundAmount
121 ashish 176
}
177
 
2747 chandransh 178
struct Refund{
179
	1:i64 id,
180
	2:i64 paymentId,
181
    3:i64 gatewayId,
182
    4:i64 orderId,
183
    5:double amount,
184
    6:string gatewayTxnId,
185
    7:i32 attempts,
186
    8:i64 createdAt,
187
    9:i64 processedAt,
188
    10:list<Attribute> attributes
189
}
121 ashish 190
 
191
exception PaymentException{
192
	1:i64 error_code,
193
	2:string message
194
}
195
 
4008 mandeep.dh 196
enum ExtraPaymentProcessingType {
4421 mandeep.dh 197
    FAILED_PAYMENTS,
198
    PENDING_CAPTURE
4008 mandeep.dh 199
}
200
 
3374 rajveer 201
service PaymentService extends GenericService.GenericService{
680 rajveer 202
	/**
4141 chandransh 203
	create a new payment and return payment id, throws an exception if gateway is not active
204
	*/
6050 anupam.sin 205
	i64 createPayment(1:i64 userId, 2:double amount, 3:i64 gatewayId, 4:i64 txnId, 5:bool isDigital) throws (1:PaymentException pe),
121 ashish 206
 
680 rajveer 207
	/**
4141 chandransh 208
	Get all payments for user. If status and gateway are null, they are ignored. Same for times as well.
209
	*/ 
680 rajveer 210
	list<Payment> getPaymentsForUser(1:i64 userId, 2:i64 fromTime, 3:i64 toTime, 4:PaymentStatus status, 5:i64 gatewayId) throws (1:PaymentException pe),
121 ashish 211
 
680 rajveer 212
	/**
4141 chandransh 213
	Get all payments in the given status for the given gateway. If gatewayId is 0, then it is ignored.
214
	*/ 
680 rajveer 215
	list<Payment> getPayments(1:i64 fromTime, 2:i64 toTime, 3:PaymentStatus status, 4:i64 gatewayId) throws (1:PaymentException pe),
121 ashish 216
 
4141 chandransh 217
	/**
218
	Get all payments for the given gateway which were captured between the given dates. If the gatewayId is 0, it's ignored.
219
	*/
220
	list<Payment> getPaymentsByCapturedDate(1:i64 fromTime, 2:i64 toTime, 3:i64 gatewayId) throws (1:PaymentException pe),	
121 ashish 221
 
680 rajveer 222
	/** 
4141 chandransh 223
	Get the gateway for the given id. 
224
	*/
680 rajveer 225
	PaymentGateway getPaymentGateway(1:i64 id) throws (1:PaymentException pe),
4600 varun.gupt 226
 
227
	/**
228
	 *Get all active Payment Gateways
229
	 **/
230
	list<PaymentGateway> getActivePaymentGateways() throws (1:PaymentException pe),
231
 
680 rajveer 232
	/** 
233
	* Get a particular payment info
234
	**/
420 ashish 235
	Payment getPayment(1:i64 id) throws (1:PaymentException pe),
680 rajveer 236
 
237
 
238
	/** 
4600 varun.gupt 239
	* Get payments for a transaction. Will raise exception.
680 rajveer 240
	**/
241
	list<Payment> getPaymentForTxnId(1:i64 txnId) throws (1:PaymentException pe),
121 ashish 242
 
4600 varun.gupt 243
	/** 
7049 anupam.sin 244
	* Get payments for a recharge transaction id. Will raise exception.
245
	**/
246
	list<Payment> getPaymentForRechargeTxnId(1:i64 txnId) throws (1:PaymentException pe),
247
 
248
	/** 
4600 varun.gupt 249
	* Get successful payment for a transaction. Will raise exception.
250
	**/
251
	Payment getSuccessfulPaymentForTxnId(1:i64 txnId) throws (1:PaymentException pe),
252
 
680 rajveer 253
	/**
254
	* mark payment successful and store parameters
255
	**/
1118 rajveer 256
	bool updatePaymentDetails(1:i64 id, 2:string gatewayPaymentId, 3:string sessionId, 4:string gatewayTxnStatus, 5:string  description, 6:string gatewayTxnId, 7:string authCode, 8:string referenceCode, 9:string errorCode, 10:PaymentStatus  status, 11:string gatewayTxnDate, 12:list<Attribute> attributes) throws (1:PaymentException pe),
420 ashish 257
 
680 rajveer 258
	/**
259
	* mark payment failed and store parameters
694 rajveer 260
 
680 rajveer 261
	bool markPaymentFailed(1:i64 id, 2:string gatewayPaymentId, 3:string sessionId, 4:string gatewayTxnStatus, 5:string description, 6:string errorCode, 7:list<Attribute> attributes )  throws (1:PaymentException pe)
694 rajveer 262
	*/
1731 ankur.sing 263
 
1628 ankur.sing 264
	/**
1731 ankur.sing 265
	Returns the minimum and maximum amounts among successful payments.
266
	List contains two double values, first minimum and second maximum amount.
1628 ankur.sing 267
	*/
2461 chandransh 268
	list<double> getSuccessfulPaymentsAmountRange(),
269
 
270
	/**
271
	Initialize the payment pipe for a HDFC payment. The URL the user should be redirected to is returned.
3010 chandransh 272
	In case of any processing error, an exception is raised.
2461 chandransh 273
	*/
10269 amit.gupta 274
	string initializeHdfcPayment(1:i64 merchantPaymentId, 2:bool isMobile) throws (1:PaymentException pe),
2689 chandransh 275
 
276
	/**
6050 anupam.sin 277
	Initialize the payment pipe for a HDFC payment in case of a digital order. The URL the user should be redirected to is returned.
6228 anupam.sin 278
	In case of any processing error, an exception is raised. The phone is a madatory field and is required in case of dth payments.
6050 anupam.sin 279
	*/
10269 amit.gupta 280
	string doHdfcPaymentForDigitalOrder(1:i64 merchantPaymentId, 2:i64 rechargeOrderId, 3:string phone, 4:bool isMobile) throws (1:PaymentException pe),
6050 anupam.sin 281
 
282
	/**
3616 chandransh 283
	Initialize the payment pipe for a HDFC EMI payment. The URL the user should be redirected to is returned.
284
	In case of any processing error, an exception is raised.
285
	*/
10269 amit.gupta 286
	string initializeHdfcEmiPayment(1:i64 merchantPaymentId, 2:bool isMobile) throws (1:PaymentException pe),
3616 chandransh 287
 
288
	/**
2689 chandransh 289
	Create a refund of the given amount corresponding to the given order to be processed through the same
290
	payment gateway which processed the payment for the corresponding transaction.
291
	Returns the id of the newly created Refund.
292
	*/	
3010 chandransh 293
	i64 createRefund(1:i64 orderId, 2:i64 merchantTxnId, 3:double amount) throws (1:PaymentException pe),
294
 
295
	/**
296
	Capture the payment for the given merchant transaction id. It processes the last payment for the given
4421 mandeep.dh 297
	transaction. If the capture attempt failed, the payment is marked as failed. PaymentException with error 
6486 rajveer 298
	code 104 is	thrown in case no payments are found for the transaction id passed. PaymentException is also
299
	thrown with error code 106 in case capture was not possible due to connection
300
	issue. 
301
	*/
8907 rajveer 302
	bool capturePayment(1:i64 merchantTxnId, 2:bool isDigital) throws (1:PaymentException pe),
6486 rajveer 303
 
304
	/**
305
	Refund the payment for the given merchant transaction id. It processes the last payment for the given
6503 rajveer 306
	transaction. If refund will be failed nothing will be updated in database.
3010 chandransh 307
	*/
6486 rajveer 308
	bool refundPayment(1:i64 merchantTxnId, 2:double amount, 3:bool isDigital) throws (1:PaymentException pe),
3956 chandransh 309
 
6486 rajveer 310
 
3956 chandransh 311
	/**
312
	Adds the given amount to the captured amount of a COD payment.
313
	Updates the captured amount for the corresponding payment and marks it as PARTIALLY CAPTURED.
314
	If the captured amount becomes equal to total amount, then the payment status is set as SUCCESS.
315
	Also sets the name of the entity which transferred the money, the date on which it was transferred
316
	and the corresponding transaction id.
317
 
318
	Returns false if the payment couldn't be captured.
319
	Throws exception if no such payment could be found or if the captured amount will exceed the total amount after capturing.
320
	*/
4008 mandeep.dh 321
	bool partiallyCapturePayment(1:i64 merchantTxnId, 2:double amount, 3:string xferBy, 4:string xferTxnId, 5:i64 xferDate) throws (1:PaymentException pe),
322
 
323
    /**
324
     * Returns the list of payments that require some extra processing and
325
     * which belong to a particular category. This is currently used by CRM
326
     * application.
327
     */
328
    list<i64> getPaymentsRequiringExtraProcessing(1:ExtraPaymentProcessingType category),
329
 
330
    /**
331
     * Marks a particular payment as processed for a particular cateogory.
332
     * It essentially deletes the payment if it is processed for a particular
333
     * category. This is currently used by CRM application.
334
     */
8907 rajveer 335
    void markPaymentAsProcessed(1:i64 paymentId, 2:ExtraPaymentProcessingType category),
336
 
8914 rajveer 337
    PaymentStatus getPaymentStatusAtGateway(1:i64 merchantTxnId, 2:double amount, 3:bool isDigital) throws (1:PaymentException pe)
121 ashish 338
}