61 lines
1.5 KiB
Plaintext
61 lines
1.5 KiB
Plaintext
function get_token(user as String, password as String)
|
|
url = "Users/AuthenticateByName?format=json"
|
|
req = APIRequest(url)
|
|
|
|
encPass = CreateObject("roUrlTransfer")
|
|
json = postJson(req, "Username=" + user + "&Pw=" + encPass.Escape(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 = get_setting("active_user")
|
|
url = Substitute("Users/{0}", id)
|
|
resp = APIRequest(url)
|
|
return getJson(resp)
|
|
end function
|
|
|
|
function SignOut()
|
|
if get_setting("active_user") <> invalid
|
|
unset_user_setting("token")
|
|
end if
|
|
unset_setting("active_user")
|
|
m.overhang.currentUser = ""
|
|
end function
|
|
|
|
function AvailableUsers()
|
|
users = parseJson(get_setting("available_users", "[]"))
|
|
return users
|
|
end function
|
|
|
|
function PickUser(id as string)
|
|
this_user = invalid
|
|
for each user in AvailableUsers()
|
|
if user.id = id then this_user = user
|
|
end for
|
|
if this_user = invalid then return invalid
|
|
set_setting("active_user", this_user.id)
|
|
set_setting("server", this_user.server)
|
|
end function
|
|
|
|
function RemoveUser(id as string)
|
|
user = CreateObject("roSGNode", "UserData")
|
|
user.id = id
|
|
user.callFunc("removeFromRegistry")
|
|
|
|
if get_setting("active_user") = id then SignOut()
|
|
end function
|
|
|
|
function ServerInfo()
|
|
url = "System/Info/Public"
|
|
resp = APIRequest(url)
|
|
return getJson(resp)
|
|
end function
|