2016-02-07 10:23:23 +00:00
|
|
|
'use strict'
|
2016-02-05 17:03:20 +00:00
|
|
|
|
2016-03-16 21:29:27 +00:00
|
|
|
const replay = require('request-replay')
|
2016-06-18 14:13:54 +00:00
|
|
|
const request = require('request')
|
2016-02-05 17:03:20 +00:00
|
|
|
|
2016-03-16 21:29:27 +00:00
|
|
|
const constants = require('../initializers/constants')
|
2016-07-01 14:22:36 +00:00
|
|
|
const peertubeCrypto = require('./peertube-crypto')
|
2016-02-05 17:03:20 +00:00
|
|
|
|
2016-03-16 21:29:27 +00:00
|
|
|
const requests = {
|
2016-10-02 10:19:02 +00:00
|
|
|
makeRetryRequest,
|
|
|
|
makeSecureRequest
|
2016-02-07 10:23:23 +00:00
|
|
|
}
|
2016-02-05 17:03:20 +00:00
|
|
|
|
2016-06-18 14:13:54 +00:00
|
|
|
function makeRetryRequest (params, callback) {
|
|
|
|
replay(
|
|
|
|
request(params, callback),
|
|
|
|
{
|
|
|
|
retries: constants.RETRY_REQUESTS,
|
|
|
|
factor: 3,
|
|
|
|
maxTimeout: Infinity,
|
|
|
|
errorCodes: [ 'EADDRINFO', 'ETIMEDOUT', 'ECONNRESET', 'ESOCKETTIMEDOUT', 'ENOTFOUND', 'ECONNREFUSED' ]
|
|
|
|
}
|
|
|
|
)
|
|
|
|
}
|
2016-02-05 17:03:20 +00:00
|
|
|
|
2016-06-18 14:13:54 +00:00
|
|
|
function makeSecureRequest (params, callback) {
|
|
|
|
const requestParams = {
|
2016-11-14 19:03:04 +00:00
|
|
|
url: constants.REMOTE_SCHEME.HTTP + '://' + params.toPod.host + params.path
|
2016-02-07 10:23:23 +00:00
|
|
|
}
|
2016-02-05 17:03:20 +00:00
|
|
|
|
2017-01-04 21:23:07 +00:00
|
|
|
if (params.method !== 'POST') {
|
|
|
|
return callback(new Error('Cannot make a secure request with a non POST method.'))
|
|
|
|
}
|
|
|
|
|
|
|
|
requestParams.json = {}
|
2016-02-05 17:03:20 +00:00
|
|
|
|
2017-01-04 21:23:07 +00:00
|
|
|
// Add signature if it is specified in the params
|
|
|
|
if (params.sign === true) {
|
|
|
|
const host = constants.CONFIG.WEBSERVER.HOST
|
|
|
|
|
|
|
|
let dataToSign
|
2016-06-18 14:13:54 +00:00
|
|
|
if (params.data) {
|
2017-01-04 21:23:07 +00:00
|
|
|
dataToSign = dataToSign = params.data
|
2016-02-07 10:23:23 +00:00
|
|
|
} else {
|
2017-01-04 21:23:07 +00:00
|
|
|
// We do not have data to sign so we just take our host
|
|
|
|
// It is not ideal but the connection should be in HTTPS
|
|
|
|
dataToSign = host
|
2016-02-07 10:23:23 +00:00
|
|
|
}
|
2017-01-04 21:23:07 +00:00
|
|
|
|
|
|
|
requestParams.json.signature = {
|
|
|
|
host, // Which host we pretend to be
|
|
|
|
signature: peertubeCrypto.sign(dataToSign)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// If there are data informations
|
|
|
|
if (params.data) {
|
|
|
|
requestParams.json.data = params.data
|
2016-06-18 14:13:54 +00:00
|
|
|
}
|
2017-01-04 21:23:07 +00:00
|
|
|
|
|
|
|
request.post(requestParams, callback)
|
2016-02-07 10:23:23 +00:00
|
|
|
}
|
2016-02-05 17:03:20 +00:00
|
|
|
|
2016-02-07 10:23:23 +00:00
|
|
|
// ---------------------------------------------------------------------------
|
2016-02-05 17:03:20 +00:00
|
|
|
|
2016-02-07 10:23:23 +00:00
|
|
|
module.exports = requests
|