' needed for SignOut() and ServerInfo() import "pkg:/source/utils/session.bs" import "pkg:/source/utils/misc.brs" function get_token(user as string, password as string) url = "Users/AuthenticateByName?format=json" req = APIRequest(url) json = postJson(req, FormatJson({ "Username": user, "Pw": password })) if json = invalid then return invalid userdata = CreateObject("roSGNode", "UserData") userdata.json = json userdata.callFunc("setActive") userdata.callFunc("saveToRegistry") return userdata end function function AboutMe(id = "" as string) if id = "" if m.global.session.user.id <> invalid id = m.global.session.user.id else return invalid end if end if url = Substitute("Users/{0}", id) resp = APIRequest(url) return getJson(resp) end function sub SignOut(deleteSavedEntry = true as boolean) if deleteSavedEntry unset_user_setting("token") unset_user_setting("username") end if unset_setting("active_user") session.user.Logout() m.global.sceneManager.currentUser = "" group = m.global.sceneManager.callFunc("getActiveScene") group.optionsAvailable = false end sub function AvailableUsers() users = parseJson(get_setting("available_users", "[]")) return users end function function ServerInfo() url = "System/Info/Public" req = APIRequest(url) req.setMessagePort(CreateObject("roMessagePort")) req.AsyncGetToString() ' wait 15 seconds for a server response resp = wait(35000, req.GetMessagePort()) ' handle unknown errors if type(resp) <> "roUrlEvent" return { "Error": true, "ErrorMessage": "Unknown" } end if ' check for a location redirect header in the response headers = resp.GetResponseHeaders() if headers <> invalid and headers.location <> invalid ' only follow redirect if it the API Endpoint path is the same (/System/Info/Public) ' set the server to new location and try again if right(headers.location, 19) = "/System/Info/Public" set_setting("server", left(headers.location, len(headers.location) - 19)) isConnected = session.server.UpdateURL(left(headers.location, len(headers.location) - 19)) if isConnected info = ServerInfo() if info.Error info.UpdatedUrl = left(headers.location, len(headers.location) - 19) info.ErrorMessage = info.ErrorMessage + " (Note: Server redirected us to " + info.UpdatedUrl + ")" end if return info end if end if end if ' handle any non 200 responses, returning the error code and message if resp.GetResponseCode() <> 200 return { "Error": true, "ErrorCode": resp.GetResponseCode(), "ErrorMessage": resp.GetFailureReason() } end if ' return the parsed response string responseString = resp.GetString() if responseString <> invalid and responseString <> "" result = ParseJson(responseString) if result <> invalid result.Error = false return result end if end if ' otherwise return error message return { "Error": true, "ErrorMessage": "Does not appear to be a Jellyfin Server" } end function function GetPublicUsers() url = "Users/Public" resp = APIRequest(url) return getJson(resp) end function sub LoadUserAbilities() if m.global.session.user.Policy.EnableLiveTvManagement = true set_user_setting("livetv.canrecord", "true") else set_user_setting("livetv.canrecord", "false") end if if m.global.session.user.Policy.EnableContentDeletion = true set_user_setting("content.candelete", "true") else set_user_setting("content.candelete", "false") end if end sub function initQuickConnect() resp = APIRequest("QuickConnect/Initiate") jsonResponse = getJson(resp) if jsonResponse = invalid return invalid end if if jsonResponse.Secret = invalid return invalid end if return jsonResponse end function function checkQuickConnect(secret) url = Substitute("QuickConnect/Connect?secret={0}", secret) resp = APIRequest(url) jsonResponse = getJson(resp) if jsonResponse = invalid return false end if if jsonResponse.Authenticated <> invalid and jsonResponse.Authenticated = true return true end if return false end function function AuthenticateViaQuickConnect(secret) params = { secret: secret } req = APIRequest("Users/AuthenticateWithQuickConnect") jsonResponse = postJson(req, FormatJson(params)) if jsonResponse <> invalid and jsonResponse.AccessToken <> invalid and jsonResponse.User <> invalid userdata = CreateObject("roSGNode", "UserData") userdata.json = jsonResponse session.user.Update("id", jsonResponse.User.Id) session.user.Update("authToken", jsonResponse.AccessToken) userdata.callFunc("setActive") userdata.callFunc("saveToRegistry") return true end if return false end function