Players:GetFriendsAsync() / FriendPages APIs consistently return HTTP 500, 502, and 401 errors

I fetch a user’s friends along with relevant data to be displayed in an in-game social tab, but lately this method has started consistently failing which unfortunately results in my game losing important social functionality.

Relevant methods:

  • Players:GetFriendsAsync()
  • FriendPages:GetCurrentPage()
  • FriendPages:AdvanceToNextPageAsync()


Here’s a relevant snippet from my code:

type OnlineFriends = {
	[number]: {
		UserId: number; -- The friend's UserId
		Username:	string; -- The friend's username
		DisplayName: string; -- The display name of the friend
		PlaceId: number?;
	}
}

local onlineFriends: OnlineFriends = {}

local success, err = pcall(function()
	local friendPages = game.Players:GetFriendsAsync(player.UserId)
	
	local function iterPageItems(pages)
		return coroutine.wrap(function()
			local pagenum = 1
			while true do
				for _, item in ipairs(pages:GetCurrentPage()) do
					coroutine.yield(item, pagenum)
				end
				if pages.IsFinished then
					break
				end
				pages:AdvanceToNextPageAsync()
				pagenum = pagenum + 1
			end
		end)
	end
	
	for item, _pageNo in iterPageItems(friendPages) do
		if not item.IsOnline then continue end
		
		local data = {
			UserId = item.Id;
			Username = item.Username;
			DisplayName = item.DisplayName;
			PlaceId = 0; -- fetched with TeleportService
		}
		
		table.insert(onlineFriends, data)
	end
end)

if (not success) then
	warn(("[Friends] Couldn't fetch friends: %s"):format(err))
	return
end
5 Likes

Not related to this particular issue, but it is worth noting that this code isn’t going to function anyway since IsOnline is in the process of being sunset.

1 Like

Thanks for the report! Just to confirm, we have a ticket for this in our internal database.

Hi! Thank you for reporting this. We wanted to check if this is still reproducible since it’s been a few months since it was noticed? Will circle back to team if so