mirror of
https://codeberg.org/keyoxide/doipjs.git
synced 2025-01-10 14:39:28 -07:00
WIP Handling of fetched data
This commit is contained in:
parent
55ee948111
commit
1b1d11c802
1 changed files with 28 additions and 1 deletions
29
src/index.js
29
src/index.js
|
@ -14,6 +14,8 @@ See the License for the specific language governing permissions and
|
||||||
limitations under the License.
|
limitations under the License.
|
||||||
*/
|
*/
|
||||||
const validUrl = require('valid-url')
|
const validUrl = require('valid-url')
|
||||||
|
const bent = require('bent')
|
||||||
|
const req = bent('GET')
|
||||||
const { serviceprovidersList, serviceproviders } = require('./serviceproviders')
|
const { serviceprovidersList, serviceproviders } = require('./serviceproviders')
|
||||||
|
|
||||||
const matchServiceproviders = (uri) => {
|
const matchServiceproviders = (uri) => {
|
||||||
|
@ -29,7 +31,7 @@ const matchServiceproviders = (uri) => {
|
||||||
return matches
|
return matches
|
||||||
}
|
}
|
||||||
|
|
||||||
const verify = (uri, fingerprint, opts) => {
|
const verify = async (uri, fingerprint, opts) => {
|
||||||
if (!opts) { opts = {} }
|
if (!opts) { opts = {} }
|
||||||
|
|
||||||
if (!validUrl.isUri(uri)) {
|
if (!validUrl.isUri(uri)) {
|
||||||
|
@ -41,6 +43,31 @@ const verify = (uri, fingerprint, opts) => {
|
||||||
if ('returnMatchesOnly' in opts && opts.returnMatchesOnly) {
|
if ('returnMatchesOnly' in opts && opts.returnMatchesOnly) {
|
||||||
return spMatches
|
return spMatches
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let claimHasBeenVerified = false, sp, iSp = 0, res, proofData
|
||||||
|
while (!claimHasBeenVerified && iSp < spMatches.length) {
|
||||||
|
sp = spMatches[iSp]
|
||||||
|
|
||||||
|
res = null
|
||||||
|
|
||||||
|
if (!sp.proof.useProxy || 'forceDirectRequest' in opts && opts.forceDirectRequest) {
|
||||||
|
res = await req(sp.proof.fetch ? sp.proof.fetch : sp.proof.uri)
|
||||||
|
|
||||||
|
switch (sp.proof.format) {
|
||||||
|
case 'json':
|
||||||
|
proofData = await res.json()
|
||||||
|
break
|
||||||
|
case 'text':
|
||||||
|
proofData = await res.text()
|
||||||
|
break
|
||||||
|
default:
|
||||||
|
throw new Error('No specified proof data format')
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
iSp++
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
exports.verify = verify
|
exports.verify = verify
|
||||||
|
|
Loading…
Reference in a new issue