From f5964ed305cc6b7f0a3dd05cd2dd8ab058ee9a69 Mon Sep 17 00:00:00 2001 From: Yarmo Mackenbach Date: Fri, 16 Apr 2021 11:36:59 +0200 Subject: [PATCH] Adapt proxy URL generator to v2 API --- src/utils.js | 27 ++++++++++++--------------- 1 file changed, 12 insertions(+), 15 deletions(-) diff --git a/src/utils.js b/src/utils.js index 9e656cb..b1ae21e 100644 --- a/src/utils.js +++ b/src/utils.js @@ -13,28 +13,25 @@ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. */ +const validator = require('validator') const E = require('./enums') -const generateProxyURL = (type, urlElements, opts) => { - if (!opts || !opts.doipProxyHostname) { - return null - } - let addParam = '' - if (type == 'xmpp') { - addParam += '/DESC' +const generateProxyURL = (type, data, opts) => { + try { + validator.isFQDN(opts.proxy.hostname) + } catch (err) { + throw new Error(`Invalid proxy hostname`) } - if (!Array.isArray(urlElements)) { - urlElements = [urlElements] - } + let queryStrings = [] - urlElements = urlElements.map((x) => { - return encodeURIComponent(x) + Object.keys(data).forEach(key => { + queryStrings.push(`${key}=${encodeURIComponent(data[key])}`) }) - return `https://${ - opts.doipProxyHostname - }/api/1/get/${type}/${urlElements.join('/')}${addParam}` + return `http://${ + opts.proxy.hostname + }/api/2/get/${type}?${queryStrings.join('&')}` } const generateClaim = (fingerprint, format) => {