--[[ Url Constructor Provides a single location for base urls. ]]-- local ContentProvider = game:GetService("ContentProvider") -- helper functions local function parseBaseUrlInformation() -- get the current base url from the current configuration local baseUrl = ContentProvider.BaseUrl -- keep a copy of the base url (https://www.roblox.com/) -- append a trailing slash if there isn't one if baseUrl:sub(#baseUrl) ~= "/" then baseUrl = baseUrl .. "/" end -- parse out scheme (http, https) local _, schemeEnd = baseUrl:find("://") -- parse out the prefix (www, kyle, ying, etc.) local prefixIndex, prefixEnd = baseUrl:find("%.", schemeEnd + 1) local basePrefix = baseUrl:sub(schemeEnd + 1, prefixIndex - 1) -- parse out the domain (roblox.com/, sitetest1.robloxlabs.com/, etc.) local baseDomain = baseUrl:sub(prefixEnd + 1) return baseUrl, basePrefix, baseDomain end local function preventTableModification(aTable, key, value) error("Attempt to modify read-only table") end local function createReadOnlyTable(aTable) return setmetatable({}, { __index = aTable, __newindex = preventTableModification, __metatable = false }); end -- url construction building blocks local _baseUrl, _basePrefix, _baseDomain = parseBaseUrlInformation() -- construct urls once local _baseApiUrl = string.format("https://api.%s", _baseDomain) local _baseAuthUrl = string.format("https://auth.%s", _baseDomain) local _baseChatUrl = string.format("https://chat.%sv2", _baseDomain) local _baseFriendUrl = string.format("https://friends.%sv1", _baseDomain) local _baseGameAssetUrl = string.format("https://assetgame.%s", _baseDomain) local _baseGamesUrl = string.format("https://games.%s", _baseDomain) local _baseNotificationUrl = string.format("https://notifications.%s", _baseDomain) local _basePresenceUrl = string.format("https://presence.%sv1", _baseDomain) local _baseRealtimeUrl = string.format("https://realtime.%s", _baseDomain) local _baseWebUrl = string.format("https://web.%s", _baseDomain) -- public api local Url = { DOMAIN = _baseDomain, PREFIX = _basePrefix, BASE_URL = _baseUrl, API_URL = _baseApiUrl, AUTH_URL = _baseAuthUrl, GAME_URL = _baseGamesUrl, GAME_ASSET_URL = _baseGameAssetUrl, CHAT_URL = _baseChatUrl, FRIEND_URL = _baseFriendUrl, PRESENCE_URL = _basePresenceUrl, NOTIFICATION_URL = _baseNotificationUrl, REALTIME_URL = _baseRealtimeUrl, WEB_URL = _baseWebUrl } function Url:getUserProfileUrl(userId) return string.format("%susers/%s/profile", self.BASE_URL, userId) end function Url:isVanitySite() return self.PREFIX ~= "www" end -- data - (table) a table of key/value pairs to format function Url:makeQueryString(data) --NOTE - This function can be used to create a query string of parameters -- at the end of url query, or create a application/form-url-encoded post body string local params = {} -- NOTE - Arrays are handled, but generally data is expected to be flat. for key, value in pairs(data) do if value ~= nil then --for optional params if type(value) == "table" then for i = 1, #value do table.insert(params, key .. "=" .. value[i]) end else table.insert(params, key .. "=" .. tostring(value)) end end end return table.concat(params, "&") end -- prevent anyone from modifying this table: Url = createReadOnlyTable(Url) return Url