/* Copyright 2021 Yarmo Mackenbach Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, 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') /** * @module utils */ /** * Generate an URL to request data from a proxy server * @param {string} type - The name of the fetcher the proxy must use * @param {object} data - The data the proxy must provide to the fetcher * @param {object} opts - Options to enable the request * @param {object} opts.proxy.hostname - The hostname of the proxy server * @returns {string} */ const generateProxyURL = (type, data, opts) => { try { validator.isFQDN(opts.proxy.hostname) } catch (err) { throw new Error(`Invalid proxy hostname`) } let queryStrings = [] Object.keys(data).forEach((key) => { queryStrings.push(`${key}=${encodeURIComponent(data[key])}`) }) return `http://${opts.proxy.hostname}/api/2/get/${type}?${queryStrings.join( '&' )}` } /** * Generate the string that must be found in the proof to verify a claim * @param {string} fingerprint - The fingerprint of the claim * @param {number} format - The claim's format (see {@link module:enums~ClaimFormat|enums.ClaimFormat}) * @returns {string} */ const generateClaim = (fingerprint, format) => { switch (format) { case E.ClaimFormat.URI: return `openpgp4fpr:${fingerprint}` break case E.ClaimFormat.MESSAGE: return `[Verifying my OpenPGP key: openpgp4fpr:${fingerprint}]` break case E.ClaimFormat.FINGERPRINT: return fingerprint break default: throw new Error('No valid claim format') } } exports.generateProxyURL = generateProxyURL exports.generateClaim = generateClaim