Add timeout to fetcher functions

This commit is contained in:
Yarmo Mackenbach 2021-03-25 15:37:30 +01:00
parent 5ea67c1e6f
commit e6e25a65e7
No known key found for this signature in database
GPG key ID: 37367F4AF4087AD1
6 changed files with 82 additions and 22 deletions

View file

@ -16,7 +16,15 @@ limitations under the License.
const dns = require('dns') const dns = require('dns')
module.exports = async (hostname) => { module.exports = async (hostname) => {
return new Promise((resolve, reject) => { let timeoutHandle
const timeoutPromise = new Promise((resolve, reject) => {
timeoutHandle = setTimeout(
() => reject(new Error('Request was timed out')),
5000
)
})
const fetchPromise = new Promise((resolve, reject) => {
dns.resolveTxt(hostname, (err, records) => { dns.resolveTxt(hostname, (err, records) => {
if (err) { if (err) {
reject(err) reject(err)
@ -31,4 +39,9 @@ module.exports = async (hostname) => {
}) })
}) })
}) })
return Promise.race([fetchPromise, timeoutPromise]).then((result) => {
clearTimeout(timeoutHandle)
return result
})
} }

View file

@ -16,7 +16,15 @@ limitations under the License.
const irc = require('irc-upd') const irc = require('irc-upd')
module.exports = async (nickQuery, opts) => { module.exports = async (nickQuery, opts) => {
return new Promise((resolve, reject) => { let timeoutHandle
const timeoutPromise = new Promise((resolve, reject) => {
timeoutHandle = setTimeout(
() => reject(new Error('Request was timed out')),
5000
)
})
const fetchPromise = new Promise((resolve, reject) => {
try { try {
const client = new irc.Client(opts.hostname, opts.nick, { const client = new irc.Client(opts.hostname, opts.nick, {
port: 6697, port: 6697,
@ -44,4 +52,9 @@ module.exports = async (nickQuery, opts) => {
reject(error) reject(error)
} }
}) })
return Promise.race([fetchPromise, timeoutPromise]).then((result) => {
clearTimeout(timeoutHandle)
return result
})
} }

View file

@ -17,9 +17,17 @@ const bent = require('bent')
const bentReq = bent('GET') const bentReq = bent('GET')
module.exports = async (roomId, eventId, opts) => { module.exports = async (roomId, eventId, opts) => {
let timeoutHandle
const timeoutPromise = new Promise((resolve, reject) => {
timeoutHandle = setTimeout(
() => reject(new Error('Request was timed out')),
5000
)
})
const url = `https://${opts.instance}/_matrix/client/r0/rooms/${roomId}/event/${eventId}?access_token=${opts.accessToken}` const url = `https://${opts.instance}/_matrix/client/r0/rooms/${roomId}/event/${eventId}?access_token=${opts.accessToken}`
return bentReq(url, null, { const fetchPromise = bentReq(url, null, {
Accept: 'application/json', Accept: 'application/json',
}) })
.then(async (data) => { .then(async (data) => {
@ -31,4 +39,9 @@ module.exports = async (roomId, eventId, opts) => {
.catch((error) => { .catch((error) => {
return error return error
}) })
return Promise.race([fetchPromise, timeoutPromise]).then((result) => {
clearTimeout(timeoutHandle)
return result
})
} }

View file

@ -17,7 +17,15 @@ const bent = require('bent')
const bentReq = bent('GET') const bentReq = bent('GET')
module.exports = async (tweetId, opts) => { module.exports = async (tweetId, opts) => {
return bentReq( let timeoutHandle
const timeoutPromise = new Promise((resolve, reject) => {
timeoutHandle = setTimeout(
() => reject(new Error('Request was timed out')),
5000
)
})
const fetchPromise = bentReq(
`https://api.twitter.com/1.1/statuses/show.json?id=${tweetId}&tweet_mode=extended`, `https://api.twitter.com/1.1/statuses/show.json?id=${tweetId}&tweet_mode=extended`,
null, null,
{ {
@ -34,4 +42,9 @@ module.exports = async (tweetId, opts) => {
.catch((error) => { .catch((error) => {
return error return error
}) })
return Promise.race([fetchPromise, timeoutPromise]).then((result) => {
clearTimeout(timeoutHandle)
return result
})
} }

View file

@ -43,7 +43,15 @@ const xmppStart = async (service, username, password) => {
} }
module.exports = async (id, data, opts) => { module.exports = async (id, data, opts) => {
return new Promise(async (resolve, reject) => { let timeoutHandle
const timeoutPromise = new Promise((resolve, reject) => {
timeoutHandle = setTimeout(
() => reject(new Error('Request was timed out')),
5000
)
})
const fetchPromise = new Promise(async (resolve, reject) => {
if (!xmpp) { if (!xmpp) {
const xmppStartRes = await xmppStart( const xmppStartRes = await xmppStart(
opts.service, opts.service,
@ -55,11 +63,7 @@ module.exports = async (id, data, opts) => {
} }
const response = await iqCaller.request( const response = await iqCaller.request(
xml( xml('iq', { type: 'get', to: id }, xml('vCard', 'vcard-temp')),
'iq',
{ type: 'get', to: id },
xml('vCard', 'vcard-temp')
),
30 * 1000 30 * 1000
) )
@ -84,8 +88,7 @@ module.exports = async (id, data, opts) => {
break break
default: default:
vcard = dom.window.document.querySelector(data) vcard = dom.window.document.querySelector(data).textContent
.textContent
break break
} }
xmpp.stop() xmpp.stop()
@ -94,4 +97,9 @@ module.exports = async (id, data, opts) => {
reject(error) reject(error)
} }
}) })
return Promise.race([fetchPromise, timeoutPromise]).then((result) => {
clearTimeout(timeoutHandle)
return result
})
} }