/** * 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} 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} */ 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} */ export async function users() { return await invoke('plugin:auth|get_users') }