You've already forked AstralRinth
forked from didirus/AstralRinth
* Add auth servers unreachable warning to app * Check auth status every 5 minutes * Use admonition in auth server warning * feat: tanstack * Fix auth server reachability query * Format * intl extract --------- Co-authored-by: Calum H. (IMB11) <contact@cal.engineer>
67 lines
1.9 KiB
JavaScript
67 lines
1.9 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()
|
|
// }
|
|
|
|
/**
|
|
* 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')
|
|
}
|