Merge pull request #28 from Herrie82/herrie/config

examples: Externalize configuration values and allow for multiple env…
This commit is contained in:
Dimitar Nanov 2019-12-18 10:37:02 +02:00 committed by GitHub
commit fcbf4ca165
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
13 changed files with 90 additions and 82 deletions

View File

@ -6,18 +6,12 @@ const ebics = require('../index');
const path = require('path'); const path = require('path');
const fs = require('fs'); const fs = require('fs');
const os = require('os'); const os = require('os');
const configjs = require('./config.js');
const client = new ebics.Client({ const client = gClient;
url: 'https://ebics.server',
partnerId: '',
userId: '',
hostId: '',
passphrase: 'test', // keys-test will be decrypted with this passphrase
keyStorage: ebics.fsKeysStorage('./keys-test'),
});
const bankName = 'Bank name'; // Change this to the bank name you're going to send the letter to. const bankName = gConfig.bankName;
const languageCode = 'en'; // Currently 'de' and 'en' are valid values. const languageCode = gConfig.languageCode;
const template = fs.readFileSync('../templates/ini_'+languageCode+'.hbs').toString(); const template = fs.readFileSync('../templates/ini_'+languageCode+'.hbs').toString();
const letter = new ebics.BankLetter({ client, bankName, template }); const letter = new ebics.BankLetter({ client, bankName, template });
const bankLetterFile = path.join(os.homedir(), 'bankLetter_'+languageCode+'.html'); const bankLetterFile = path.join(os.homedir(), 'bankLetter_'+languageCode+'.html');

25
examples/config.js Normal file
View File

@ -0,0 +1,25 @@
const _ = require('lodash');
const ebics = require('../index');
const config = require('./config.json');
var myArgs = process.argv.slice(2);
//We can run this script with an argument. I.e. "testing" or "production" and it will load the corresponding configuration values for the corresponding environment from config.json
const whichEnvironment = myArgs[0].trim().toLowerCase();
const defaultConfig = config.testing;
//We default back to test in case whichEnvironment argument is not passed while running the script, so we don't accidentally end up making changes in production.
const environment = whichEnvironment || 'testing';
const environmentConfig = config[environment];
if (!environmentConfig) {
console.log("ERROR! Could not find configuration for \""+whichEnvironment+"\" using configuration for \"testing\" instead");
}
global.gFinalConfig = _.merge(defaultConfig, environmentConfig);
global.gClient = new ebics.Client({
url: gFinalConfig.serverAddress,
partnerId: gFinalConfig.partnerId,
userId: gFinalConfig.userId,
hostId: gFinalConfig.hostId,
passphrase: gFinalConfig.passphrase, // keys-test will be encrypted with this passphrase
keyStorage: ebics.fsKeysStorage(gFinalConfig.keyStorage),
});

42
examples/config.json Normal file
View File

@ -0,0 +1,42 @@
{
"testing": {
"serverAddress": "https://ebics-test.server",
"partnerId": "EBICS ParnerID Test",
"userId": "MyUserIdTest",
"hostId": "MyHostIdTest",
"passphrase": "MyPasswordTest",
"keyStorage": "./keys-test",
"bankName":"Test Bank",
"languageCode":"en"
},
"development": {
"serverAddress": "https://ebics-development.server",
"partnerId": "EBICS ParnerID Development",
"userId": "MyUserIdDevelopment",
"hostId": "MyHostIdDevelopment",
"passphrase": "MyPasswordDevelopment",
"keyStorage": "./keys-development",
"bankName":"Development Bank",
"languageCode":"en"
},
"staging": {
"serverAddress": "https://ebics-staging.server",
"partnerId": "EBICS ParnerID Staging",
"userId": "MyUserIdStaging",
"hostId": "MyHostIdStaging",
"passphrase": "MyPasswordStaging",
"keyStorage": "./keys-staging",
"bankName":"Staging Bank",
"languageCode":"en"
},
"production": {
"serverAddress": "https://ebics.server",
"partnerId": "EBICS ParnerID Production",
"userId": "MyUserIdProduction",
"hostId": "MyHostIdProduction",
"passphrase": "MyPasswordProduction",
"keyStorage": "./keys-prod",
"bankName":"Production Bank",
"languageCode":"en"
}
}

View File

@ -3,15 +3,9 @@
'use strict'; 'use strict';
const ebics = require('../index'); const ebics = require('../index');
const configjs = require('./config.js');
const client = new ebics.Client({ const client = gClient;
url: 'https://ebics.server',
partnerId: 'PARTNER',
userId: 'USER',
hostId: 'HOST',
passphrase: 'test', // keys-test will be encrypted with this passphrase
keyStorage: ebics.fsKeysStorage('./keys-test'),
});
// New keys will be generated and saved in ./keys-test // New keys will be generated and saved in ./keys-test
client.send(ebics.Orders.INI) client.send(ebics.Orders.INI)

View File

@ -3,15 +3,9 @@
'use strict'; 'use strict';
const ebics = require('../index'); const ebics = require('../index');
const configjs = require('./config.js');
const client = new ebics.Client({ const client = gClient;
url: 'https://ebics.server',
partnerId: '',
userId: '',
hostId: '',
passphrase: 'test', // keys-test will be decrypted with this passphrase
keyStorage: ebics.fsKeysStorage('./keys-test'),
});
// Client keys must be already generated and send by letter. // Client keys must be already generated and send by letter.
// The bank should have enabled the user // The bank should have enabled the user

View File

@ -3,15 +3,9 @@
'use strict'; 'use strict';
const ebics = require('../index'); const ebics = require('../index');
const configjs = require('./config.js');
const client = new ebics.Client({ const client = gClient;
url: 'https://ebics.server',
partnerId: '',
userId: '',
hostId: '',
passphrase: 'test', // keys-test will be decrypted with this passphrase
keyStorage: ebics.fsKeysStorage('./keys-test'),
});
// The bank keys must have been already saved // The bank keys must have been already saved
client.send(ebics.Orders.C52(null, null)) // startDate 'YYYY-MM-DD', endDate 'YYYY-MM-DD' client.send(ebics.Orders.C52(null, null)) // startDate 'YYYY-MM-DD', endDate 'YYYY-MM-DD'

View File

@ -3,15 +3,9 @@
'use strict'; 'use strict';
const ebics = require('../index'); const ebics = require('../index');
const configjs = require('./config.js');
const client = new ebics.Client({ const client = gClient;
url: 'https://ebics.server',
partnerId: '',
userId: '',
hostId: '',
passphrase: 'test', // keys-test will be decrypted with this passphrase
keyStorage: ebics.fsKeysStorage('./keys-test'),
});
// The bank keys must have been already saved // The bank keys must have been already saved
client.send(ebics.Orders.C53(null, null)) // startDate 'YYYY-MM-DD', endDate 'YYYY-MM-DD' client.send(ebics.Orders.C53(null, null)) // startDate 'YYYY-MM-DD', endDate 'YYYY-MM-DD'

View File

@ -3,15 +3,9 @@
'use strict'; 'use strict';
const ebics = require('../index'); const ebics = require('../index');
const configjs = require('./config.js');
const client = new ebics.Client({ const client = gClient;
url: 'https://ebics.server',
partnerId: '',
userId: '',
hostId: '',
passphrase: 'test', // keys-test will be decrypted with this passphrase
keyStorage: ebics.fsKeysStorage('./keys-test'),
});
// The bank keys must have been already saved // The bank keys must have been already saved
client.send(ebics.Orders.DKI(null, null)) // startDate 'YYYY-MM-DD', endDate 'YYYY-MM-DD' client.send(ebics.Orders.DKI(null, null)) // startDate 'YYYY-MM-DD', endDate 'YYYY-MM-DD'

View File

@ -3,15 +3,9 @@
'use strict'; 'use strict';
const ebics = require('../index'); const ebics = require('../index');
const configjs = require('./config.js');
const client = new ebics.Client({ const client = gClient;
url: 'https://ebics.server',
partnerId: '',
userId: '',
hostId: '',
passphrase: 'test', // keys-test will be decrypted with this passphrase
keyStorage: ebics.fsKeysStorage('./keys-test'),
});
// The bank keys must have been already saved // The bank keys must have been already saved
client.send(ebics.Orders.HKD) client.send(ebics.Orders.HKD)

View File

@ -3,15 +3,9 @@
'use strict'; 'use strict';
const ebics = require('../index'); const ebics = require('../index');
const configjs = require('./config.js');
const client = new ebics.Client({ const client = gClient;
url: 'https://ebics.server',
partnerId: '',
userId: '',
hostId: '',
passphrase: 'test', // keys-test will be decrypted with this passphrase
keyStorage: ebics.fsKeysStorage('./keys-test'),
});
// The bank keys must have been already saved // The bank keys must have been already saved
client.send(ebics.Orders.HTD) client.send(ebics.Orders.HTD)

View File

@ -3,15 +3,9 @@
'use strict'; 'use strict';
const ebics = require('../index'); const ebics = require('../index');
const configjs = require('./config.js');
const client = new ebics.Client({ const client = gClient;
url: 'https://ebics.server',
partnerId: '',
userId: '',
hostId: '',
passphrase: 'test', // keys-test will be decrypted with this passphrase
keyStorage: ebics.fsKeysStorage('./keys-test'),
});
// The bank keys must have been already saved // The bank keys must have been already saved
client.send(ebics.Orders.STA(null, null)) // startDate 'YYYY-MM-DD', endDate 'YYYY-MM-DD' client.send(ebics.Orders.STA(null, null)) // startDate 'YYYY-MM-DD', endDate 'YYYY-MM-DD'

View File

@ -3,15 +3,9 @@
'use strict'; 'use strict';
const ebics = require('../index'); const ebics = require('../index');
const configjs = require('./config.js');
const client = new ebics.Client({ const client = gClient;
url: 'https://ebics.server',
partnerId: '',
userId: '',
hostId: '',
passphrase: 'test', // keys-test will be decrypted with this passphrase
keyStorage: ebics.fsKeysStorage('./keys-test'),
});
// The bank keys must have been already saved // The bank keys must have been already saved
client.send(ebics.Orders.VMK(null, null)) // startDate 'YYYY-MM-DD', endDate 'YYYY-MM-DD' client.send(ebics.Orders.VMK(null, null)) // startDate 'YYYY-MM-DD', endDate 'YYYY-MM-DD'

View File

@ -54,6 +54,7 @@
"auto-changelog": "^1.16.2", "auto-changelog": "^1.16.2",
"handlebars": "^4.5.3", "handlebars": "^4.5.3",
"js2xmlparser": "^4.0.0", "js2xmlparser": "^4.0.0",
"lodash":"^4.17.15",
"node-forge": "^0.9.1", "node-forge": "^0.9.1",
"request": "^2.88.0", "request": "^2.88.0",
"uuid": "^3.3.3", "uuid": "^3.3.3",