Commit 6cca233033614aa635d64629719600c2362f1cc3

Authored by Adhidarma Hadiwinoto
1 parent 3899d98168
Exists in master

kembali lengkap dengan port

Showing 1 changed file with 1 additions and 1 deletions Inline Diff

partner-kospinjasa.js
1 var winston = require('winston'); 1 var winston = require('winston');
2 var soap = require('soap'); 2 var soap = require('soap');
3 var crypto = require('crypto'); 3 var crypto = require('crypto');
4 var strftime = require('strftime'); 4 var strftime = require('strftime');
5 5
6 var max_retry = 10; 6 var max_retry = 10;
7 var sleep_before_retry = 5000; 7 var sleep_before_retry = 5000;
8 8
9 var config; 9 var config;
10 var callbackReport; 10 var callbackReport;
11 var aaa; 11 var aaa;
12 var logger; 12 var logger;
13 var options; 13 var options;
14 14
15 function start(_config, _callbackReport, options) { 15 function start(_config, _callbackReport, options) {
16 config = _config; 16 config = _config;
17 callbackReport = _callbackReport 17 callbackReport = _callbackReport
18 18
19 if (options && options.aaa) { 19 if (options && options.aaa) {
20 aaa = options.aaa; 20 aaa = options.aaa;
21 } 21 }
22 22
23 if (options && options.logger) { 23 if (options && options.logger) {
24 logger = options.logger; 24 logger = options.logger;
25 } else { 25 } else {
26 logger = new winston.Logger({ 26 logger = new winston.Logger({
27 transports: [ 27 transports: [
28 new (winston.transports.Console)() 28 new (winston.transports.Console)()
29 ] 29 ]
30 }); 30 });
31 } 31 }
32 } 32 }
33 33
34 function topupRequest(task, retry) { 34 function topupRequest(task, retry) {
35 if (retry === undefined) { 35 if (retry === undefined) {
36 retry = max_retry; 36 retry = max_retry;
37 } 37 }
38 38
39 var remoteProduct = task.remoteProduct.split(','); 39 var remoteProduct = task.remoteProduct.split(',');
40 var params = { 40 var params = {
41 userName: config.h2h_out.userid, 41 userName: config.h2h_out.userid,
42 productCode: remoteProduct[0] , 42 productCode: remoteProduct[0] ,
43 terminal: 'terminal0', 43 terminal: 'terminal0',
44 transactionType: '50', 44 transactionType: '50',
45 billNumber: createBillNumber(task.destination), 45 billNumber: createBillNumber(task.destination),
46 amount: remoteProduct[1], 46 amount: remoteProduct[1],
47 bit61: createBillNumber(task.destination), 47 bit61: createBillNumber(task.destination),
48 reff: task.requestId, 48 reff: task.requestId,
49 timeStamp: strftime('%d-%m-%Y %H:%M:%S', new Date()) 49 timeStamp: strftime('%d-%m-%Y %H:%M:%S', new Date())
50 } 50 }
51 51
52 var signature = createSignature(params, config.h2h_out.password); 52 var signature = createSignature(params, config.h2h_out.password);
53 params.signature = signature; 53 params.signature = signature;
54 54
55 topupRequestSoap(task, params, retry); 55 topupRequestSoap(task, params, retry);
56 } 56 }
57 57
58 function topupRequestSoap(task, params, retry) { 58 function topupRequestSoap(task, params, retry) {
59 59
60 soap.createClient(config.h2h_out.partner, function(err, soapClient) { 60 soap.createClient(config.h2h_out.partner, function(err, soapClient) {
61 61
62 logger.info('Requesting to service', {url: config.h2h_out.partner, params: params}); 62 logger.info('Requesting to service', {url: config.h2h_out.partner, params: params});
63 63
64 soapClient.billpayment({ inputCheck: params }, function(err, result) { 64 soapClient.apih2h.apih2hPort.billpayment({ inputCheck: params }, function(err, result) {
65 65
66 logger.info('Got response', {lastRequest: soapClient.lastRequest}); 66 logger.info('Got response', {lastRequest: soapClient.lastRequest});
67 67
68 if (err) { 68 if (err) {
69 logger.warn('Error requesting service', {err: err}); 69 logger.warn('Error requesting service', {err: err});
70 callbackReport(task.requestId, '68', 'something wrong'); 70 callbackReport(task.requestId, '68', 'something wrong');
71 return; 71 return;
72 } 72 }
73 73
74 var responseMessageToST24 = result.outputParameter.resultCode.$value + ' - ' + result.outputParameter.resultDesc.$value; 74 var responseMessageToST24 = result.outputParameter.resultCode.$value + ' - ' + result.outputParameter.resultDesc.$value;
75 75
76 logger.info('Got result: ' + responseMessageToST24, {result: result}); 76 logger.info('Got result: ' + responseMessageToST24, {result: result});
77 77
78 callbackReport(task.requestId, '68', responseMessageToST24); 78 callbackReport(task.requestId, '68', responseMessageToST24);
79 }); 79 });
80 }); 80 });
81 } 81 }
82 82
83 83
84 84
85 function createSignature(params, password) { 85 function createSignature(params, password) {
86 var passwordHash = crypto.createHash('sha256').update(password).digest().toString('hex'); 86 var passwordHash = crypto.createHash('sha256').update(password).digest().toString('hex');
87 87
88 var plain = 88 var plain =
89 params.userName 89 params.userName
90 + passwordHash 90 + passwordHash
91 + params.productCode 91 + params.productCode
92 + params.terminal 92 + params.terminal
93 + params.transactionType 93 + params.transactionType
94 + params.billNumber 94 + params.billNumber
95 + params.amount 95 + params.amount
96 + params.reff 96 + params.reff
97 + params.timeStamp; 97 + params.timeStamp;
98 98
99 var result = crypto.createHash('sha1').update(plain).digest().toString('hex'); 99 var result = crypto.createHash('sha1').update(plain).digest().toString('hex');
100 100
101 if (logger) { 101 if (logger) {
102 logger.verbose('Calculating signature', {plain: plain, result: result, params: params, password: password}); 102 logger.verbose('Calculating signature', {plain: plain, result: result, params: params, password: password});
103 } 103 }
104 104
105 return result; 105 return result;
106 } 106 }
107 107
108 function createBillNumber(destination) { 108 function createBillNumber(destination) {
109 return ("0000000000000" + destination).slice(-13); 109 return ("0000000000000" + destination).slice(-13);
110 } 110 }
111 111
112 exports.start = start; 112 exports.start = start;
113 exports.topupRequest = topupRequest; 113 exports.topupRequest = topupRequest;
114 exports.createSignature = createSignature; 114 exports.createSignature = createSignature;
115 exports.createBillNumber = createBillNumber; 115 exports.createBillNumber = createBillNumber;
116 116