You've already forked AstralRinth
* feat(theseus): Initial migration to Tauri v2 * feat(theseus): Added a way to zoom / scale UI * chore(theseus): Started cleaning up some plugins * fix(theseus): Github Actions * refactor(theseus): Reduced boilerplate & more work * feat(theseus): Allow multiple app instances to be open at once (#995) * fix(theseus): Lint & more * fix(theseus): App Release github action * fix(theseus): Open links in browser & macos builds * fix(theseus): Rebase fixes * fix(theseus): Updater & app release action * fix(theseus): Fixed definitions in `build.rs` * Fix MacOS deep linking, window decorations * fix(theseus): Closing & maximizing app * Fix macos build * add back release conf * acc fix build * make updater for release builds only * focus window on startup --------- Co-authored-by: Jai A <jaiagr+gpg@pm.me> Co-authored-by: Geometrically <18202329+Geometrically@users.noreply.github.com>
59 lines
1.7 KiB
JavaScript
59 lines
1.7 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()
|
|
// }
|
|
|
|
/**
|
|
* 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')
|
|
}
|