Subversion Repositories SmartDukaan

Rev

Rev 13421 | Rev 17782 | 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'
13441 amit.gupta 51
	'1127' : 'Citi Bank Account'
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'
59
	'1215' : 'Citi Union Bank'
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'
72
 
2574 chandransh 73
 	'2000' : 'HDFC-VISA/VISA Electron Debit Card'
2461 chandransh 74
	'2008' : 'HDFC-VISA'
5538 anupam.sin 75
	'2017' : 'HDFC-MasterCard Credit Card'
76
	'2018' : 'HDFC-MasterCard Debit Card'
3164 chandransh 77
	'3000' : 'COD'
8907 rajveer 78
	'3001' : 'Coupon'
3270 vikas 79
	'2001' : 'Cheque'
3274 vikas 80
	'1026' : 'EBS-ICICI Bank Debit Card'
81
    '1027' : 'EBS-SBI Debit Card'
3709 chandransh 82
    '2020' : 'HDFC Credit Card 3-month EMI'
6459 rajveer 83
    '5001' : 'HDFC Credit Card 3-month EMI'
84
    '5002' : 'HDFC Credit Card 6-month EMI'
85
    '5003' : 'HDFC Credit Card 9-month EMI'
86
    '5004' : 'HDFC Credit Card 12-month EMI'
7330 amit.gupta 87
    '5005' : 'HDFC Credit Card 18-month EMI'
6978 amit.gupta 88
    '1139' : 'Citi EBS-VISA Credit Card 3-months EMI'
89
    '1140' : 'Citi EBS-MasterCard Credit Card 3-months EMI'
90
    '1141' : 'Citi EBS-VISA Credit Card 6-months EMI'
91
    '1142' : 'Citi EBS-MasterCard Credit Card 6-months EMI'
5102 phani.kuma 92
    '1143' : 'EBS-Indian Bank Netbanking'
93
    '1164' : 'EBS-Maestro Debit Card'
6978 amit.gupta 94
    '4000' : 'BULK',
13421 amit.gupta 95
    '4001' : 'PAYU MONEY',
6978 amit.gupta 96
    '210000':'Axis Bank Innoviti 3 Months EMI',
97
    '220000':'Axis Bank Innoviti 6 Months EMI',
98
    '230000':'Axis Bank Innoviti 9 Months EMI',
99
    '240000':'Axis Bank Innoviti 12 Months EMI',
100
    '250000':'Axis Bank Innoviti 18 Months EMI',
101
    '310000':'ICICI Bank Innoviti 3 Months EMI',
102
    '320000':'ICICI Bank Innoviti 6 Months EMI',
103
    '330000':'ICICI Bank Innoviti 9 Months EMI',
104
    '340000':'ICICI Bank Innoviti 12 Months EMI',
105
    '350000':'ICICI Bank Innoviti 18 Months EMI',
106
    '410000':'InsdusInd Bank Innoviti 3 Months EMI',
107
    '420000':'InsdusInd Bank Innoviti 6 Months EMI',
108
    '430000':'InsdusInd Bank Innoviti 9 Months EMI',
109
    '440000':'InsdusInd Bank Innoviti 12 Months EMI',
9506 amit.gupta 110
    '510000':'Citi Bank Innoviti 3 Months EMI',
111
    '520000':'Citi Bank Innoviti 6 Months EMI',
112
    '530000':'Citi Bank Innoviti 9 Months EMI',
113
    '540000':'Citi Bank Innoviti 12 Months EMI',
6978 amit.gupta 114
    '610000':'Standard Chartered Bank Innoviti 3 Months EMI',
115
    '620000':'Standard Chartered Bank Innoviti 6 Months EMI',
116
    '630000':'Standard Chartered Bank Innoviti 9 Months EMI',
117
    '640000':'Standard Chartered Bank Innoviti 12 Months EMI',
118
    '710000':'HSBC Bank Innoviti 3 Months EMI',
119
    '720000':'HSBC Bank Innoviti 6 Months EMI',
7948 amit.gupta 120
    '730000':'HSBC Bank Innoviti 6 Months EMI',
121
    '740000':'HSBC Bank Innoviti 6 Months EMI',
6978 amit.gupta 122
    '810000':'Kotak Mahindra Bank Innoviti 3 Months EMI',
123
    '820000':'Kotak Mahindra Bank Innoviti 6 Months EMI',
124
    '830000':'Kotak Mahindra Bank Innoviti 9 Months EMI',
125
    '840000':'Kotak Mahindra Bank Innoviti 12 Months EMI',
126
    '910000':'SBI Bank Innoviti 3 Months EMI',
127
    '920000':'SBI Bank Innoviti 6 Months EMI',
128
    '930000':'SBI Bank Innoviti 9 Months EMI',
129
    '940000':'SBI Bank Innoviti 12 Months EMI',
130
    '950000':'SBI Bank Innoviti 18 Months EMI'
3274 vikas 131
}
2303 ankur.sing 132
 
680 rajveer 133
struct Attribute{
134
	1:string name,
135
	2:string value
121 ashish 136
}
137
 
420 ashish 138
struct PaymentGateway{
121 ashish 139
	1:i64 id,
680 rajveer 140
	2:string name,
141
	3:string url,
142
	4:i64 addedOn,
143
	5:string aliasName,
144
	6:string responseUrl,
145
	7:string errorUrl,
146
	8:PaymentGatewayStatus status
147
	9:list<Attribute> attributes  // list of all attributes for PG
121 ashish 148
}
149
 
150
struct Payment{
680 rajveer 151
	1:i64 paymentId,  				// trackId for bank, paymentid for us and id for table.
152
	2:i64 gatewayId, 				//payment gateway used
153
	3:string gatewayPaymentId
704 chandransh 154
	4:i64 merchantTxnId,			//merchant transaction id. This will be propagated further to order processing
680 rajveer 155
	5:string gatewayTxnId,			//bank trnasaction id
156
	6:double amount,
157
	7:string gatewayTxnStatus,  	// bank status will be stored here
158
	8:PaymentStatus status,
159
	9:i64 userId,					//The user for which payment has to be processed.This is here to speed up querying.
160
	10:string errorCode,
161
	11:string description,
162
	12:string authCode,
163
	13:string referenceCode,		// given by gateway
164
	14:string sessionId, 			// received from PG 
165
	15:string gatewayTxnDate,
166
	16:list<Attribute> attributes,  	// list of all attributes received from PG
167
	17:i64 initTimestamp,			//statring the payment processing timestamp
168
	18:i64 successTimestamp,		//timestamp when payment is captured
169
	19:i64 errorTimestamp,			// in case, error is received from PG
6050 anupam.sin 170
	20:i64 provisionalCaptureTimestamp, // in case, error is received from PG
6503 rajveer 171
	21:bool isDigital,
172
	22:double refundAmount
121 ashish 173
}
174
 
2747 chandransh 175
struct Refund{
176
	1:i64 id,
177
	2:i64 paymentId,
178
    3:i64 gatewayId,
179
    4:i64 orderId,
180
    5:double amount,
181
    6:string gatewayTxnId,
182
    7:i32 attempts,
183
    8:i64 createdAt,
184
    9:i64 processedAt,
185
    10:list<Attribute> attributes
186
}
121 ashish 187
 
188
exception PaymentException{
189
	1:i64 error_code,
190
	2:string message
191
}
192
 
4008 mandeep.dh 193
enum ExtraPaymentProcessingType {
4421 mandeep.dh 194
    FAILED_PAYMENTS,
195
    PENDING_CAPTURE
4008 mandeep.dh 196
}
197
 
3374 rajveer 198
service PaymentService extends GenericService.GenericService{
680 rajveer 199
	/**
4141 chandransh 200
	create a new payment and return payment id, throws an exception if gateway is not active
201
	*/
6050 anupam.sin 202
	i64 createPayment(1:i64 userId, 2:double amount, 3:i64 gatewayId, 4:i64 txnId, 5:bool isDigital) throws (1:PaymentException pe),
121 ashish 203
 
680 rajveer 204
	/**
4141 chandransh 205
	Get all payments for user. If status and gateway are null, they are ignored. Same for times as well.
206
	*/ 
680 rajveer 207
	list<Payment> getPaymentsForUser(1:i64 userId, 2:i64 fromTime, 3:i64 toTime, 4:PaymentStatus status, 5:i64 gatewayId) throws (1:PaymentException pe),
121 ashish 208
 
680 rajveer 209
	/**
4141 chandransh 210
	Get all payments in the given status for the given gateway. If gatewayId is 0, then it is ignored.
211
	*/ 
680 rajveer 212
	list<Payment> getPayments(1:i64 fromTime, 2:i64 toTime, 3:PaymentStatus status, 4:i64 gatewayId) throws (1:PaymentException pe),
121 ashish 213
 
4141 chandransh 214
	/**
215
	Get all payments for the given gateway which were captured between the given dates. If the gatewayId is 0, it's ignored.
216
	*/
217
	list<Payment> getPaymentsByCapturedDate(1:i64 fromTime, 2:i64 toTime, 3:i64 gatewayId) throws (1:PaymentException pe),	
121 ashish 218
 
680 rajveer 219
	/** 
4141 chandransh 220
	Get the gateway for the given id. 
221
	*/
680 rajveer 222
	PaymentGateway getPaymentGateway(1:i64 id) throws (1:PaymentException pe),
4600 varun.gupt 223
 
224
	/**
225
	 *Get all active Payment Gateways
226
	 **/
227
	list<PaymentGateway> getActivePaymentGateways() throws (1:PaymentException pe),
228
 
680 rajveer 229
	/** 
230
	* Get a particular payment info
231
	**/
420 ashish 232
	Payment getPayment(1:i64 id) throws (1:PaymentException pe),
680 rajveer 233
 
234
 
235
	/** 
4600 varun.gupt 236
	* Get payments for a transaction. Will raise exception.
680 rajveer 237
	**/
238
	list<Payment> getPaymentForTxnId(1:i64 txnId) throws (1:PaymentException pe),
121 ashish 239
 
4600 varun.gupt 240
	/** 
7049 anupam.sin 241
	* Get payments for a recharge transaction id. Will raise exception.
242
	**/
243
	list<Payment> getPaymentForRechargeTxnId(1:i64 txnId) throws (1:PaymentException pe),
244
 
245
	/** 
4600 varun.gupt 246
	* Get successful payment for a transaction. Will raise exception.
247
	**/
248
	Payment getSuccessfulPaymentForTxnId(1:i64 txnId) throws (1:PaymentException pe),
249
 
680 rajveer 250
	/**
251
	* mark payment successful and store parameters
252
	**/
1118 rajveer 253
	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 254
 
680 rajveer 255
	/**
256
	* mark payment failed and store parameters
694 rajveer 257
 
680 rajveer 258
	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 259
	*/
1731 ankur.sing 260
 
1628 ankur.sing 261
	/**
1731 ankur.sing 262
	Returns the minimum and maximum amounts among successful payments.
263
	List contains two double values, first minimum and second maximum amount.
1628 ankur.sing 264
	*/
2461 chandransh 265
	list<double> getSuccessfulPaymentsAmountRange(),
266
 
267
	/**
268
	Initialize the payment pipe for a HDFC payment. The URL the user should be redirected to is returned.
3010 chandransh 269
	In case of any processing error, an exception is raised.
2461 chandransh 270
	*/
10269 amit.gupta 271
	string initializeHdfcPayment(1:i64 merchantPaymentId, 2:bool isMobile) throws (1:PaymentException pe),
2689 chandransh 272
 
273
	/**
6050 anupam.sin 274
	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 275
	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 276
	*/
10269 amit.gupta 277
	string doHdfcPaymentForDigitalOrder(1:i64 merchantPaymentId, 2:i64 rechargeOrderId, 3:string phone, 4:bool isMobile) throws (1:PaymentException pe),
6050 anupam.sin 278
 
279
	/**
3616 chandransh 280
	Initialize the payment pipe for a HDFC EMI payment. The URL the user should be redirected to is returned.
281
	In case of any processing error, an exception is raised.
282
	*/
10269 amit.gupta 283
	string initializeHdfcEmiPayment(1:i64 merchantPaymentId, 2:bool isMobile) throws (1:PaymentException pe),
3616 chandransh 284
 
285
	/**
2689 chandransh 286
	Create a refund of the given amount corresponding to the given order to be processed through the same
287
	payment gateway which processed the payment for the corresponding transaction.
288
	Returns the id of the newly created Refund.
289
	*/	
3010 chandransh 290
	i64 createRefund(1:i64 orderId, 2:i64 merchantTxnId, 3:double amount) throws (1:PaymentException pe),
291
 
292
	/**
293
	Capture the payment for the given merchant transaction id. It processes the last payment for the given
4421 mandeep.dh 294
	transaction. If the capture attempt failed, the payment is marked as failed. PaymentException with error 
6486 rajveer 295
	code 104 is	thrown in case no payments are found for the transaction id passed. PaymentException is also
296
	thrown with error code 106 in case capture was not possible due to connection
297
	issue. 
298
	*/
8907 rajveer 299
	bool capturePayment(1:i64 merchantTxnId, 2:bool isDigital) throws (1:PaymentException pe),
6486 rajveer 300
 
301
	/**
302
	Refund the payment for the given merchant transaction id. It processes the last payment for the given
6503 rajveer 303
	transaction. If refund will be failed nothing will be updated in database.
3010 chandransh 304
	*/
6486 rajveer 305
	bool refundPayment(1:i64 merchantTxnId, 2:double amount, 3:bool isDigital) throws (1:PaymentException pe),
3956 chandransh 306
 
6486 rajveer 307
 
3956 chandransh 308
	/**
309
	Adds the given amount to the captured amount of a COD payment.
310
	Updates the captured amount for the corresponding payment and marks it as PARTIALLY CAPTURED.
311
	If the captured amount becomes equal to total amount, then the payment status is set as SUCCESS.
312
	Also sets the name of the entity which transferred the money, the date on which it was transferred
313
	and the corresponding transaction id.
314
 
315
	Returns false if the payment couldn't be captured.
316
	Throws exception if no such payment could be found or if the captured amount will exceed the total amount after capturing.
317
	*/
4008 mandeep.dh 318
	bool partiallyCapturePayment(1:i64 merchantTxnId, 2:double amount, 3:string xferBy, 4:string xferTxnId, 5:i64 xferDate) throws (1:PaymentException pe),
319
 
320
    /**
321
     * Returns the list of payments that require some extra processing and
322
     * which belong to a particular category. This is currently used by CRM
323
     * application.
324
     */
325
    list<i64> getPaymentsRequiringExtraProcessing(1:ExtraPaymentProcessingType category),
326
 
327
    /**
328
     * Marks a particular payment as processed for a particular cateogory.
329
     * It essentially deletes the payment if it is processed for a particular
330
     * category. This is currently used by CRM application.
331
     */
8907 rajveer 332
    void markPaymentAsProcessed(1:i64 paymentId, 2:ExtraPaymentProcessingType category),
333
 
8914 rajveer 334
    PaymentStatus getPaymentStatusAtGateway(1:i64 merchantTxnId, 2:double amount, 3:bool isDigital) throws (1:PaymentException pe)
121 ashish 335
}