Commit 371375d72da98f20f0bf6d8849dda3658e486a65

Authored by Adhidarma Hadiwinoto
1 parent 2b3124a967
Exists in master

debug signature

Showing 1 changed file with 4 additions and 0 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 40
41 soap.createClient(config.h2h_out.partner, function(err, client) { 41 soap.createClient(config.h2h_out.partner, function(err, client) {
42 var args = { 42 var args = {
43 userName: config.h2h_out.userid, 43 userName: config.h2h_out.userid,
44 productCode: remoteProduct[0] , 44 productCode: remoteProduct[0] ,
45 terminal: 'terminal0', 45 terminal: 'terminal0',
46 transactionType: '50', 46 transactionType: '50',
47 billNumber: createBillNumber(task.destination), 47 billNumber: createBillNumber(task.destination),
48 amount: remoteProduct[1], 48 amount: remoteProduct[1],
49 bit61: createBillNumber(task.destination), 49 bit61: createBillNumber(task.destination),
50 reff: task.requestId, 50 reff: task.requestId,
51 timeStamp: strftime('%d-%m-%Y %H:%M:%S', new Date()), 51 timeStamp: strftime('%d-%m-%Y %H:%M:%S', new Date()),
52 } 52 }
53 53
54 var signature = createSignature(args, config.h2h_out.password); 54 var signature = createSignature(args, config.h2h_out.password);
55 args.signature = signature; 55 args.signature = signature;
56 56
57 logger.info('Requesting to service', {url: config.h2h_out.partner, args: args}); 57 logger.info('Requesting to service', {url: config.h2h_out.partner, args: args});
58 client.billpayment(args, function(err, result) { 58 client.billpayment(args, function(err, result) {
59 if (err) { 59 if (err) {
60 logger.warn('Error requesting service', {err: err}); 60 logger.warn('Error requesting service', {err: err});
61 callbackReport(task.requestId, '68', 'something wrong'); 61 callbackReport(task.requestId, '68', 'something wrong');
62 return; 62 return;
63 } 63 }
64 64
65 logger.info('Got result', {result: result}); 65 logger.info('Got result', {result: result});
66 callbackReport(task.requestId, '68', 'got result'); 66 callbackReport(task.requestId, '68', 'got result');
67 }); 67 });
68 }); 68 });
69 } 69 }
70 70
71 function createSignature(args, password) { 71 function createSignature(args, password) {
72 var passwordHash = crypto.createHash('sha256').update(password).digest().toString('hex'); 72 var passwordHash = crypto.createHash('sha256').update(password).digest().toString('hex');
73 73
74 var result = crypto.createHash('sha1').update( 74 var result = crypto.createHash('sha1').update(
75 args.userName 75 args.userName
76 + passwordHash 76 + passwordHash
77 + args.productCode 77 + args.productCode
78 + args.terminal 78 + args.terminal
79 + args.transactionType 79 + args.transactionType
80 + args.billNumber 80 + args.billNumber
81 + args.amount 81 + args.amount
82 + args.ref 82 + args.ref
83 + args.timestamp 83 + args.timestamp
84 ).digest().toString('hex'); 84 ).digest().toString('hex');
85 85
86 if (logger) {
87 logger.verbose('Calculating signature', {result: result, args: args});
88 }
89
86 return result; 90 return result;
87 } 91 }
88 92
89 function createBillNumber(destination) { 93 function createBillNumber(destination) {
90 return ("0000000000000" + destination).slice(-13); 94 return ("0000000000000" + destination).slice(-13);
91 } 95 }
92 96
93 exports.start = start; 97 exports.start = start;
94 exports.topupRequest = topupRequest; 98 exports.topupRequest = topupRequest;
95 exports.createSignature = createSignature; 99 exports.createSignature = createSignature;
96 exports.createBillNumber = createBillNumber; 100 exports.createBillNumber = createBillNumber;
97 101