// Includes
const http = require('../util/http.js').func
const getGeneralToken = require('../util/getGeneralToken.js').func
const RobloxAPIError = require('../util/apiError.js')
// Args
exports.required = ['tradeId']
exports.optional = ['jar']
// Docs
/**
* 🔐 Accept an active trade.
* @category Trade
* @alias acceptTrade
* @param {number} tradeId - The tradeId to accept.
* @returns {Promise<void>}
* @example const noblox = require("noblox.js")
* // Login using your cookie
* noblox.acceptTrade(1234)
**/
// Define
function acceptTrade (tradeId, jar, xcsrf) {
return new Promise((resolve, reject) => {
http({
url: '//trades.roblox.com/v1/trades/' + tradeId + '/accept',
options: {
method: 'POST',
resolveWithFullResponse: true,
jar,
headers: {
'X-CSRF-TOKEN': xcsrf,
'Content-Type': 'application/json'
}
}
}).then((res) => {
if (res.statusCode === 200) {
resolve()
} else {
reject(new RobloxAPIError(res))
}
}).catch(error => reject(error))
})
}
exports.func = function (args) {
const jar = args.jar
return getGeneralToken({ jar })
.then(function (xcsrf) {
return acceptTrade(args.tradeId, jar, xcsrf)
})
}
Source