mirror of
https://github.com/public-transport/db-vendo-client.git
synced 2025-02-23 07:09:35 +02:00
configure iface address used via LOCAL_ADDRESS env var
This commit is contained in:
parent
2afe4154f8
commit
cb8d92befb
2 changed files with 26 additions and 3 deletions
|
@ -3,18 +3,40 @@
|
||||||
const DEV = process.env.NODE_ENV === 'dev'
|
const DEV = process.env.NODE_ENV === 'dev'
|
||||||
const DEBUG = /\bhafas-client\b/.test(process.env.DEBUG || '')
|
const DEBUG = /\bhafas-client\b/.test(process.env.DEBUG || '')
|
||||||
|
|
||||||
|
const ProxyAgent = require('https-proxy-agent')
|
||||||
|
const {isIP} = require('net')
|
||||||
|
const {Agent: HttpsAgent} = require('https')
|
||||||
|
const roundRobin = require('@derhuerst/round-robin-scheduler')
|
||||||
const {randomBytes} = require('crypto')
|
const {randomBytes} = require('crypto')
|
||||||
const createHash = require('create-hash')
|
const createHash = require('create-hash')
|
||||||
const pick = require('lodash/pick')
|
const pick = require('lodash/pick')
|
||||||
const captureStackTrace = DEV ? require('capture-stack-trace') : () => {}
|
const captureStackTrace = DEV ? require('capture-stack-trace') : () => {}
|
||||||
const {stringify} = require('qs')
|
const {stringify} = require('qs')
|
||||||
const ProxyAgent = require('https-proxy-agent')
|
|
||||||
const Promise = require('pinkie-promise')
|
const Promise = require('pinkie-promise')
|
||||||
const {fetch} = require('fetch-ponyfill')({Promise})
|
const {fetch} = require('fetch-ponyfill')({Promise})
|
||||||
const {addErrorInfo} = require('./errors')
|
const {addErrorInfo} = require('./errors')
|
||||||
|
|
||||||
const proxyAddress = process.env.HTTPS_PROXY || process.env.HTTP_PROXY || null
|
const proxyAddress = process.env.HTTPS_PROXY || process.env.HTTP_PROXY || null
|
||||||
const proxyAgent = proxyAddress ? new ProxyAgent(proxyAddress) : null
|
const localAddresses = process.env.LOCAL_ADDRESS || null
|
||||||
|
|
||||||
|
if (proxyAddress && localAddresses) {
|
||||||
|
console.error('Both env vars HTTPS_PROXY/HTTP_PROXY and LOCAL_ADDRESS are not supported.')
|
||||||
|
process.exit(1)
|
||||||
|
}
|
||||||
|
let getAgent = () => null
|
||||||
|
if (proxyAddress) {
|
||||||
|
const agent = new ProxyAgent(proxyAddress)
|
||||||
|
getAgent = () => agent
|
||||||
|
} else if (localAddresses) {
|
||||||
|
const agents = process.env.LOCAL_ADDRESS.split(',')
|
||||||
|
.map((addr) => {
|
||||||
|
const family = isIP(addr)
|
||||||
|
if (family === 0) throw new Error('invalid local address:' + addr)
|
||||||
|
return new HttpsAgent({addr, family})
|
||||||
|
})
|
||||||
|
const pool = roundRobin(agents)
|
||||||
|
getAgent = () => pool.get()
|
||||||
|
}
|
||||||
|
|
||||||
const id = randomBytes(6).toString('hex')
|
const id = randomBytes(6).toString('hex')
|
||||||
const randomizeUserAgent = (userAgent) => {
|
const randomizeUserAgent = (userAgent) => {
|
||||||
|
@ -42,7 +64,7 @@ const request = (ctx, userAgent, reqData) => {
|
||||||
if (DEBUG) console.error(JSON.stringify(body))
|
if (DEBUG) console.error(JSON.stringify(body))
|
||||||
|
|
||||||
const req = profile.transformReq(ctx, {
|
const req = profile.transformReq(ctx, {
|
||||||
agent: proxyAgent,
|
agent: getAgent(),
|
||||||
method: 'post',
|
method: 'post',
|
||||||
// todo: CORS? referrer policy?
|
// todo: CORS? referrer policy?
|
||||||
body: JSON.stringify(body),
|
body: JSON.stringify(body),
|
||||||
|
|
|
@ -40,6 +40,7 @@
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@derhuerst/br2nl": "^1.0.0",
|
"@derhuerst/br2nl": "^1.0.0",
|
||||||
|
"@derhuerst/round-robin-scheduler": "^1.0.4",
|
||||||
"capture-stack-trace": "^1.0.0",
|
"capture-stack-trace": "^1.0.0",
|
||||||
"create-hash": "^1.2.0",
|
"create-hash": "^1.2.0",
|
||||||
"fetch-ponyfill": "^7.0.0",
|
"fetch-ponyfill": "^7.0.0",
|
||||||
|
|
Loading…
Add table
Reference in a new issue