You've already forked pages
forked from didirus/AstralRinth
89 lines
2.4 KiB
JavaScript
89 lines
2.4 KiB
JavaScript
/**
|
|
* All theseus API calls return serialized values (both return values and errors);
|
|
* So, for example, addDefaultInstance creates a blank Profile object, where the Rust struct is serialized,
|
|
* and deserialized into a usable JS object.
|
|
*/
|
|
import { invoke } from '@tauri-apps/api/core'
|
|
|
|
// Example function:
|
|
// User goes to auth_url to complete flow, and when completed, authenticate_await_completion() returns the credentials
|
|
// export async function authenticate() {
|
|
// const auth_url = await authenticate_begin_flow()
|
|
// console.log(auth_url)
|
|
// await authenticate_await_completion()
|
|
// }
|
|
|
|
export async function offline_login(name) {
|
|
return await invoke('plugin:auth|offline_login', { name: name })
|
|
}
|
|
|
|
// [AR] • Feature
|
|
export async function elyby_login(uuid, login, accessToken) {
|
|
return await invoke('plugin:auth|elyby_login', {
|
|
uuid,
|
|
login,
|
|
accessToken
|
|
})
|
|
}
|
|
|
|
// [AR] • Feature
|
|
export async function elyby_auth_authenticate(login, password, clientToken) {
|
|
return await invoke('plugin:auth|elyby_auth_authenticate', {
|
|
login,
|
|
password,
|
|
clientToken,
|
|
})
|
|
}
|
|
|
|
/**
|
|
* Check if the authentication servers are reachable, throwing an exception if
|
|
* not reachable.
|
|
*/
|
|
export async function check_reachable() {
|
|
await invoke('plugin:auth|check_reachable')
|
|
}
|
|
|
|
/**
|
|
* Authenticate a user with Hydra - part 1.
|
|
* This begins the authentication flow quasi-synchronously.
|
|
*
|
|
* @returns {Promise<DeviceLoginSuccess>} A DeviceLoginSuccess object with two relevant fields:
|
|
* @property {string} verification_uri - The URL to go to complete the flow.
|
|
* @property {string} user_code - The code to enter on the verification_uri page.
|
|
*/
|
|
export async function login() {
|
|
return await invoke('plugin:auth|login')
|
|
}
|
|
|
|
/**
|
|
* Retrieves the default user
|
|
* @return {Promise<UUID | undefined>}
|
|
*/
|
|
export async function get_default_user() {
|
|
return await invoke('plugin:auth|get_default_user')
|
|
}
|
|
|
|
/**
|
|
* Updates the default user
|
|
* @param {UUID} user
|
|
*/
|
|
export async function set_default_user(user) {
|
|
return await invoke('plugin:auth|set_default_user', { user })
|
|
}
|
|
|
|
/**
|
|
* Remove a user account from the database
|
|
* @param {UUID} user
|
|
*/
|
|
export async function remove_user(user) {
|
|
return await invoke('plugin:auth|remove_user', { user })
|
|
}
|
|
|
|
/**
|
|
* Returns a list of users
|
|
* @returns {Promise<Credential[]>}
|
|
*/
|
|
export async function users() {
|
|
return await invoke('plugin:auth|get_users')
|
|
}
|