Source

lib/user/getFriendRequests.js

// Includes
const http = require('../util/http.js').func

// Args
exports.required = []
exports.optional = ['sortOrder', 'limit', 'cursor', 'jar']

// Docs
/**
 * 🔐 Get the friend requests of the authenticated user.
 * @category User
 * @alias getFriendRequests
 * @param {SortOrder=} [sortOrder=Asc] - The order of the returned data (Asc or Desc)
 * @param {Limit=} [limit=10] - The number of users returned by each request.
 * @param {string=} cursor - The previous or next page's cursor.
 * @returns {Promise<FriendRequestsPage>}
 * @example const noblox = require("noblox.js")
 * // Login using your cookie
 * let friendRequests = await noblox.getFriendRequests({sortOrder: "Desc", limit: 100})
**/

// Define
function getFriendsRequests (args) {
  return new Promise((resolve, reject) => {
    const jar = args.jar
    const httpOpt = {
      url: '//friends.roblox.com/v1/my/friends/requests',
      options: {
        method: 'GET',
        jar: jar,
        resolveWithFullResponse: true
      }
    }
    return http(httpOpt)
      .then(function (res) {
        if (res.statusCode === 200) {
          resolve(JSON.parse(res.body))
        } else {
          const body = JSON.parse(res.body) || {}
          if (body.errors && body.errors.length > 0) {
            const errors = body.errors.map((e) => {
              return e.message
            })
            reject(new Error(`${res.statusCode} ${errors.join(', ')}`))
          }
        }
      })
  })
}

exports.func = getFriendsRequests