Skip to content

Commit

Permalink
Merge branch 'master' into feat/customer-service-api-versioning+ewall…
Browse files Browse the repository at this point in the history
…et-tokenization-flow
  • Loading branch information
mesmur authored Jan 12, 2022
2 parents cfd880d + 83b75fc commit 26fd647
Show file tree
Hide file tree
Showing 12 changed files with 252 additions and 3 deletions.
1 change: 1 addition & 0 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -26,3 +26,4 @@ jobs:
- run: npm run test:integration
env:
SECRET_KEY: xnd_development_chBDpzjQZEI8nncBLrWtwau5r7rgiuunCJ4JCqsd68rXemDd74BnRpdO0bIZAMK
SECRET_KEY_PH: xnd_development_Va7pPIfYxIo7letKqhZCkwniwggDGyjB0sAzmOUe1mMkED4k0nLh1TvtVi0raNne
36 changes: 36 additions & 0 deletions examples/with_async/regional_retail_outlet.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
const x = require('../xendit');

const RegionalRetailOutlet = x.RegionalRetailOutlet;
const ro = new RegionalRetailOutlet({});

(async function() {
try {
const pmCode = await ro.createPaymentCode({
referenceId: 'test_dharma_61',
channelCode: 'CEBUANA',
customerName: 'Dharma',
amount: 50,
currency: 'PHP',
market: 'PH'
});
// eslint-disable-next-line no-console
console.log('fixed payment code created:', pmCode);

const { id } = pmCode;
const retrievedPmCode = await ro.getPaymentCode({ id });
// eslint-disable-next-line no-console
console.log('fixed payment code details:', retrievedPmCode);

const updatedPmCode = await ro.updatePaymentCode({
id,
customerName: "DharmaLain",
});
// eslint-disable-next-line no-console
console.log('updated payment code details:', updatedPmCode);

process.exit(0);
} catch (e) {
console.error(e); // eslint-disable-line no-console
process.exit(1);
}
})();
39 changes: 39 additions & 0 deletions examples/with_promises/regional_retail_outlet.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
const x = require('../xendit');

const RegionalRetailOutlet = x.RegionalRetailOutlet;
const ro = new RegionalRetailOutlet();

ro.createPaymentCode({
referenceId: 'test_dharma_4',
channelCode: 'CEBUANA',
customerName: 'Dharma',
amount: 50,
currency: 'PHP',
market: 'PH'
})
.then(r => {
// eslint-disable-next-line no-console
console.log('fixed payment code created:', r);
return r;
})
.then(({ id }) => ro.getPaymentCode({ id }))
.then(r => {
// eslint-disable-next-line no-console
console.log('fixed payment code details:', r);
return r;
})
.then(({ id }) => {
return ro.updatePaymentCode({
id,
customerName: "DharmaLain",
});
})
.then(r => {
// eslint-disable-next-line no-console
console.log('updated payment code details:', r);
return r;
})
.catch(e => {
console.error(e); // eslint-disable-line no-console
process.exit(1);
});
1 change: 1 addition & 0 deletions integration_test/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ Promise.all([
require('./platform.test')(),
require('./customer.test')(),
require('./direct_debit.test')(),
require('./regional_retail_outlet.test')(),
])
.then(() => {
// eslint-disable-next-line no-console
Expand Down
27 changes: 27 additions & 0 deletions integration_test/regional_retail_outlet.test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
const x = require('./xendit_ph.test');

const RegionalRetailOutlet = x.RegionalRetailOutlet;
const ro = new RegionalRetailOutlet({});

const dynamicReferenceId = Math.floor((Math.random() * 9999) + 1)

module.exports = function() {
return ro
.createPaymentCode({
referenceId: `test_dharma_${dynamicReferenceId}`,
channelCode: 'CEBUANA',
customerName: 'Dharma',
amount: 50,
currency: 'PHP',
market: 'PH'
})
.then(({ id }) => ro.getPaymentCode({ id }))
.then(({ id }) => ro.updatePaymentCode({ id: id, customerName: "DharmaLain" }))
.then(() => {
// eslint-disable-next-line no-console
console.log('Regional Retail outlet integration test done...');
})
.catch(e => {
throw new Error(`Regional RO integration tests failed with error: ${e.message}`);
});
};
6 changes: 3 additions & 3 deletions integration_test/va.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ module.exports = function() {
.getVABanks()
.then(banks => {
return va.createFixedVA({
externalID: 'VA-' + new Date().toLocaleString(),
externalID: 'VA-xendit-node-js998877',
bankCode: banks[0].code,
name: 'Stanley Nguyen',
isClosed: true,
Expand All @@ -25,10 +25,10 @@ module.exports = function() {
return va.getFixedVA({ id });
})
.then(({ id }) => {
sleepFor(5000);
return va.updateFixedVA({
id,
suggestedAmt: 10000,
expectedAmt: 10000,
expectedAmt: 12000,
});
})
.then(() => {
Expand Down
12 changes: 12 additions & 0 deletions integration_test/xendit_ph.test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
// For actual usage, this should be require('xendit-node')
const Xendit = require('../src/xendit');
const dotenv = require('dotenv');

dotenv.config();

const xph = new Xendit({
secretKey: process.env.SECRET_KEY_PH,
xenditURL: process.env.XENDIT_URL,
});

module.exports = xph;
3 changes: 3 additions & 0 deletions src/regional_retail_outlet/index.d.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
import RegionalRetailOutletService from './regional_retail_outlet';

export { RegionalRetailOutletService };
3 changes: 3 additions & 0 deletions src/regional_retail_outlet/index.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
const RegionalRetailOutletService = require('./regional_retail_outlet');

module.exports = { RegionalRetailOutletService };
28 changes: 28 additions & 0 deletions src/regional_retail_outlet/regional_retail_outlet.d.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
import { XenditOptions } from '../xendit_opts';

export = class RegionalRetailOutlet {
constructor({});
static _constructorWithInjectedXenditOpts: (
opts: XenditOptions,
) => typeof RetailOutlet;
createPaymentCode(data: {
reference_id: string;
channel_code: string;
amount: number;
currency: number;
customer_name: string;
market: string;
payment_code?: string;
expires_at?: Date;
is_single_use?: boolean;
desciption?: string;
metadata?: object[];
}): Promise<object>;
updateFixedPaymentCode(data: {
id: string;
name?: string;
expectedAmt?: number;
expirationDate?: Date;
}): Promise<object>;
getFixedPaymentCode(data: { id: string }): Promise<object>;
};
95 changes: 95 additions & 0 deletions src/regional_retail_outlet/regional_retail_outlet.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,95 @@
const { promWithJsErr, Validate, fetchWithHTTPErr, Auth } = require('../utils');

const REGIONAL_RETAIL_OUTLET_PATH = '/payment_codes';

function RegionalRetailOutlet(options) {
let aggOpts = options;
if (
RegionalRetailOutlet._injectedOpts &&
Object.keys(RegionalRetailOutlet._injectedOpts).length > 0
) {
aggOpts = Object.assign({}, options, RegionalRetailOutlet._injectedOpts);
}

this.opts = aggOpts;
this.API_ENDPOINT = this.opts.xenditURL + REGIONAL_RETAIL_OUTLET_PATH;
}

RegionalRetailOutlet._injectedOpts = {};
RegionalRetailOutlet._constructorWithInjectedXenditOpts = function(options) {
RegionalRetailOutlet._injectedOpts = options;
return RegionalRetailOutlet;
};

RegionalRetailOutlet.prototype.createPaymentCode = function(data) {
return promWithJsErr((resolve, reject) => {
Validate.rejectOnMissingFields(
['referenceId', 'channelCode', 'amount', 'currency', 'customerName', 'market'],
data,
reject,
);

fetchWithHTTPErr(`${this.API_ENDPOINT}`, {
method: 'POST',
headers: {
Authorization: Auth.basicAuthHeader(this.opts.secretKey),
'Content-Type': 'application/json',
},
body: JSON.stringify({
reference_id: data.referenceId,
channel_code: data.channelCode,
amount: data.amount,
currency: data.currency,
customer_name: data.customerName,
market: data.market,
payment_code: data.paymentCode,
description: data.description,
metadata: data.metadata,
expires_at: data.expiresAt
? data.expiresAt.toISOString()
: undefined,
is_single_use: data.isSingleUse,
}),
})
.then(resolve)
.catch(reject);
});
};

RegionalRetailOutlet.prototype.updatePaymentCode = function(data) {
return promWithJsErr((resolve, reject) => {
Validate.rejectOnMissingFields(['id'], data, reject);

fetchWithHTTPErr(`${this.API_ENDPOINT}/${data.id}`, {
method: 'PATCH',
headers: {
Authorization: Auth.basicAuthHeader(this.opts.secretKey),
'Content-Type': 'application/json',
},
body: JSON.stringify({
amount: data.amount,
currency: data.amount,
customer_name: data.customerName
}),
})
.then(resolve)
.catch(reject);
});
};

RegionalRetailOutlet.prototype.getPaymentCode = function(data) {
return promWithJsErr((resolve, reject) => {
Validate.rejectOnMissingFields(['id'], data, reject);

fetchWithHTTPErr(`${this.API_ENDPOINT}/${data.id}`, {
method: 'GET',
headers: {
Authorization: Auth.basicAuthHeader(this.opts.secretKey),
},
})
.then(resolve)
.catch(reject);
});
};

module.exports = RegionalRetailOutlet;
4 changes: 4 additions & 0 deletions src/xendit.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ const { QrCode } = require('./qr_code');
const { PlatformService } = require('./platform');
const { CustomerService } = require('./customer');
const { DirectDebitService } = require('./direct_debit');
const { RegionalRetailOutletService } = require('./regional_retail_outlet');
const Errors = require('./errors');

function Xendit(options) {
Expand Down Expand Up @@ -38,6 +39,9 @@ function Xendit(options) {
this.RetailOutlet = RetailOutletService._constructorWithInjectedXenditOpts(
this.opts,
);
this.RegionalRetailOutlet = RegionalRetailOutletService._constructorWithInjectedXenditOpts(
this.opts,
);
this.QrCode = QrCode._constructorWithInjectedXenditOpts(this.opts);
this.Platform = PlatformService._constructorWithInjectedXenditOpts(this.opts);
this.Customer = CustomerService._constructorWithInjectedXenditOpts(this.opts);
Expand Down

0 comments on commit 26fd647

Please sign in to comment.