Spaces:
Running
Running
import { WEBUI_API_BASE_URL } from '$lib/constants'; | |
export const getAdminDetails = async (token: string) => { | |
let error = null; | |
const res = await fetch(`${WEBUI_API_BASE_URL}/auths/admin/details`, { | |
method: 'GET', | |
headers: { | |
'Content-Type': 'application/json', | |
Authorization: `Bearer ${token}` | |
} | |
}) | |
.then(async (res) => { | |
if (!res.ok) throw await res.json(); | |
return res.json(); | |
}) | |
.catch((err) => { | |
console.log(err); | |
error = err.detail; | |
return null; | |
}); | |
if (error) { | |
throw error; | |
} | |
return res; | |
}; | |
export const getAdminConfig = async (token: string) => { | |
let error = null; | |
const res = await fetch(`${WEBUI_API_BASE_URL}/auths/admin/config`, { | |
method: 'GET', | |
headers: { | |
'Content-Type': 'application/json', | |
Authorization: `Bearer ${token}` | |
} | |
}) | |
.then(async (res) => { | |
if (!res.ok) throw await res.json(); | |
return res.json(); | |
}) | |
.catch((err) => { | |
console.log(err); | |
error = err.detail; | |
return null; | |
}); | |
if (error) { | |
throw error; | |
} | |
return res; | |
}; | |
export const updateAdminConfig = async (token: string, body: object) => { | |
let error = null; | |
const res = await fetch(`${WEBUI_API_BASE_URL}/auths/admin/config`, { | |
method: 'POST', | |
headers: { | |
'Content-Type': 'application/json', | |
Authorization: `Bearer ${token}` | |
}, | |
body: JSON.stringify(body) | |
}) | |
.then(async (res) => { | |
if (!res.ok) throw await res.json(); | |
return res.json(); | |
}) | |
.catch((err) => { | |
console.log(err); | |
error = err.detail; | |
return null; | |
}); | |
if (error) { | |
throw error; | |
} | |
return res; | |
}; | |
export const getSessionUser = async (token: string) => { | |
let error = null; | |
const res = await fetch(`${WEBUI_API_BASE_URL}/auths/`, { | |
method: 'GET', | |
headers: { | |
'Content-Type': 'application/json', | |
Authorization: `Bearer ${token}` | |
}, | |
credentials: 'include' | |
}) | |
.then(async (res) => { | |
if (!res.ok) throw await res.json(); | |
return res.json(); | |
}) | |
.catch((err) => { | |
console.log(err); | |
error = err.detail; | |
return null; | |
}); | |
if (error) { | |
throw error; | |
} | |
return res; | |
}; | |
export const ldapUserSignIn = async (user: string, password: string) => { | |
let error = null; | |
const res = await fetch(`${WEBUI_API_BASE_URL}/auths/ldap`, { | |
method: 'POST', | |
headers: { | |
'Content-Type': 'application/json' | |
}, | |
credentials: 'include', | |
body: JSON.stringify({ | |
user: user, | |
password: password | |
}) | |
}) | |
.then(async (res) => { | |
if (!res.ok) throw await res.json(); | |
return res.json(); | |
}) | |
.catch((err) => { | |
console.log(err); | |
error = err.detail; | |
return null; | |
}); | |
if (error) { | |
throw error; | |
} | |
return res; | |
}; | |
export const getLdapConfig = async (token: string = '') => { | |
let error = null; | |
const res = await fetch(`${WEBUI_API_BASE_URL}/auths/admin/config/ldap`, { | |
method: 'GET', | |
headers: { | |
'Content-Type': 'application/json', | |
...(token && { authorization: `Bearer ${token}` }) | |
} | |
}) | |
.then(async (res) => { | |
if (!res.ok) throw await res.json(); | |
return res.json(); | |
}) | |
.catch((err) => { | |
console.log(err); | |
error = err.detail; | |
return null; | |
}); | |
if (error) { | |
throw error; | |
} | |
return res; | |
}; | |
export const updateLdapConfig = async (token: string = '', enable_ldap: boolean) => { | |
let error = null; | |
const res = await fetch(`${WEBUI_API_BASE_URL}/auths/admin/config/ldap`, { | |
method: 'POST', | |
headers: { | |
'Content-Type': 'application/json', | |
...(token && { authorization: `Bearer ${token}` }) | |
}, | |
body: JSON.stringify({ | |
enable_ldap: enable_ldap | |
}) | |
}) | |
.then(async (res) => { | |
if (!res.ok) throw await res.json(); | |
return res.json(); | |
}) | |
.catch((err) => { | |
console.log(err); | |
error = err.detail; | |
return null; | |
}); | |
if (error) { | |
throw error; | |
} | |
return res; | |
}; | |
export const getLdapServer = async (token: string = '') => { | |
let error = null; | |
const res = await fetch(`${WEBUI_API_BASE_URL}/auths/admin/config/ldap/server`, { | |
method: 'GET', | |
headers: { | |
'Content-Type': 'application/json', | |
...(token && { authorization: `Bearer ${token}` }) | |
} | |
}) | |
.then(async (res) => { | |
if (!res.ok) throw await res.json(); | |
return res.json(); | |
}) | |
.catch((err) => { | |
console.log(err); | |
error = err.detail; | |
return null; | |
}); | |
if (error) { | |
throw error; | |
} | |
return res; | |
}; | |
export const updateLdapServer = async (token: string = '', body: object) => { | |
let error = null; | |
const res = await fetch(`${WEBUI_API_BASE_URL}/auths/admin/config/ldap/server`, { | |
method: 'POST', | |
headers: { | |
'Content-Type': 'application/json', | |
...(token && { authorization: `Bearer ${token}` }) | |
}, | |
body: JSON.stringify(body) | |
}) | |
.then(async (res) => { | |
if (!res.ok) throw await res.json(); | |
return res.json(); | |
}) | |
.catch((err) => { | |
console.log(err); | |
error = err.detail; | |
return null; | |
}); | |
if (error) { | |
throw error; | |
} | |
return res; | |
}; | |
export const userSignIn = async (email: string, password: string) => { | |
let error = null; | |
const res = await fetch(`${WEBUI_API_BASE_URL}/auths/signin`, { | |
method: 'POST', | |
headers: { | |
'Content-Type': 'application/json' | |
}, | |
credentials: 'include', | |
body: JSON.stringify({ | |
email: email, | |
password: password | |
}) | |
}) | |
.then(async (res) => { | |
if (!res.ok) throw await res.json(); | |
return res.json(); | |
}) | |
.catch((err) => { | |
console.log(err); | |
error = err.detail; | |
return null; | |
}); | |
if (error) { | |
throw error; | |
} | |
return res; | |
}; | |
export const userSignUp = async ( | |
name: string, | |
email: string, | |
password: string, | |
profile_image_url: string | |
) => { | |
let error = null; | |
const res = await fetch(`${WEBUI_API_BASE_URL}/auths/signup`, { | |
method: 'POST', | |
headers: { | |
'Content-Type': 'application/json' | |
}, | |
credentials: 'include', | |
body: JSON.stringify({ | |
name: name, | |
email: email, | |
password: password, | |
profile_image_url: profile_image_url | |
}) | |
}) | |
.then(async (res) => { | |
if (!res.ok) throw await res.json(); | |
return res.json(); | |
}) | |
.catch((err) => { | |
console.log(err); | |
error = err.detail; | |
return null; | |
}); | |
if (error) { | |
throw error; | |
} | |
return res; | |
}; | |
export const userSignOut = async () => { | |
let error = null; | |
const res = await fetch(`${WEBUI_API_BASE_URL}/auths/signout`, { | |
method: 'GET', | |
headers: { | |
'Content-Type': 'application/json' | |
}, | |
credentials: 'include' | |
}) | |
.then(async (res) => { | |
if (!res.ok) throw await res.json(); | |
return res; | |
}) | |
.catch((err) => { | |
console.log(err); | |
error = err.detail; | |
return null; | |
}); | |
if (error) { | |
throw error; | |
} | |
}; | |
export const addUser = async ( | |
token: string, | |
name: string, | |
email: string, | |
password: string, | |
role: string = 'pending' | |
) => { | |
let error = null; | |
const res = await fetch(`${WEBUI_API_BASE_URL}/auths/add`, { | |
method: 'POST', | |
headers: { | |
'Content-Type': 'application/json', | |
...(token && { authorization: `Bearer ${token}` }) | |
}, | |
body: JSON.stringify({ | |
name: name, | |
email: email, | |
password: password, | |
role: role | |
}) | |
}) | |
.then(async (res) => { | |
if (!res.ok) throw await res.json(); | |
return res.json(); | |
}) | |
.catch((err) => { | |
console.log(err); | |
error = err.detail; | |
return null; | |
}); | |
if (error) { | |
throw error; | |
} | |
return res; | |
}; | |
export const updateUserProfile = async (token: string, name: string, profileImageUrl: string) => { | |
let error = null; | |
const res = await fetch(`${WEBUI_API_BASE_URL}/auths/update/profile`, { | |
method: 'POST', | |
headers: { | |
'Content-Type': 'application/json', | |
...(token && { authorization: `Bearer ${token}` }) | |
}, | |
body: JSON.stringify({ | |
name: name, | |
profile_image_url: profileImageUrl | |
}) | |
}) | |
.then(async (res) => { | |
if (!res.ok) throw await res.json(); | |
return res.json(); | |
}) | |
.catch((err) => { | |
console.log(err); | |
error = err.detail; | |
return null; | |
}); | |
if (error) { | |
throw error; | |
} | |
return res; | |
}; | |
export const updateUserPassword = async (token: string, password: string, newPassword: string) => { | |
let error = null; | |
const res = await fetch(`${WEBUI_API_BASE_URL}/auths/update/password`, { | |
method: 'POST', | |
headers: { | |
'Content-Type': 'application/json', | |
...(token && { authorization: `Bearer ${token}` }) | |
}, | |
body: JSON.stringify({ | |
password: password, | |
new_password: newPassword | |
}) | |
}) | |
.then(async (res) => { | |
if (!res.ok) throw await res.json(); | |
return res.json(); | |
}) | |
.catch((err) => { | |
console.log(err); | |
error = err.detail; | |
return null; | |
}); | |
if (error) { | |
throw error; | |
} | |
return res; | |
}; | |
export const getSignUpEnabledStatus = async (token: string) => { | |
let error = null; | |
const res = await fetch(`${WEBUI_API_BASE_URL}/auths/signup/enabled`, { | |
method: 'GET', | |
headers: { | |
'Content-Type': 'application/json', | |
Authorization: `Bearer ${token}` | |
} | |
}) | |
.then(async (res) => { | |
if (!res.ok) throw await res.json(); | |
return res.json(); | |
}) | |
.catch((err) => { | |
console.log(err); | |
error = err.detail; | |
return null; | |
}); | |
if (error) { | |
throw error; | |
} | |
return res; | |
}; | |
export const getDefaultUserRole = async (token: string) => { | |
let error = null; | |
const res = await fetch(`${WEBUI_API_BASE_URL}/auths/signup/user/role`, { | |
method: 'GET', | |
headers: { | |
'Content-Type': 'application/json', | |
Authorization: `Bearer ${token}` | |
} | |
}) | |
.then(async (res) => { | |
if (!res.ok) throw await res.json(); | |
return res.json(); | |
}) | |
.catch((err) => { | |
console.log(err); | |
error = err.detail; | |
return null; | |
}); | |
if (error) { | |
throw error; | |
} | |
return res; | |
}; | |
export const updateDefaultUserRole = async (token: string, role: string) => { | |
let error = null; | |
const res = await fetch(`${WEBUI_API_BASE_URL}/auths/signup/user/role`, { | |
method: 'POST', | |
headers: { | |
'Content-Type': 'application/json', | |
Authorization: `Bearer ${token}` | |
}, | |
body: JSON.stringify({ | |
role: role | |
}) | |
}) | |
.then(async (res) => { | |
if (!res.ok) throw await res.json(); | |
return res.json(); | |
}) | |
.catch((err) => { | |
console.log(err); | |
error = err.detail; | |
return null; | |
}); | |
if (error) { | |
throw error; | |
} | |
return res; | |
}; | |
export const toggleSignUpEnabledStatus = async (token: string) => { | |
let error = null; | |
const res = await fetch(`${WEBUI_API_BASE_URL}/auths/signup/enabled/toggle`, { | |
method: 'GET', | |
headers: { | |
'Content-Type': 'application/json', | |
Authorization: `Bearer ${token}` | |
} | |
}) | |
.then(async (res) => { | |
if (!res.ok) throw await res.json(); | |
return res.json(); | |
}) | |
.catch((err) => { | |
console.log(err); | |
error = err.detail; | |
return null; | |
}); | |
if (error) { | |
throw error; | |
} | |
return res; | |
}; | |
export const getJWTExpiresDuration = async (token: string) => { | |
let error = null; | |
const res = await fetch(`${WEBUI_API_BASE_URL}/auths/token/expires`, { | |
method: 'GET', | |
headers: { | |
'Content-Type': 'application/json', | |
Authorization: `Bearer ${token}` | |
} | |
}) | |
.then(async (res) => { | |
if (!res.ok) throw await res.json(); | |
return res.json(); | |
}) | |
.catch((err) => { | |
console.log(err); | |
error = err.detail; | |
return null; | |
}); | |
if (error) { | |
throw error; | |
} | |
return res; | |
}; | |
export const updateJWTExpiresDuration = async (token: string, duration: string) => { | |
let error = null; | |
const res = await fetch(`${WEBUI_API_BASE_URL}/auths/token/expires/update`, { | |
method: 'POST', | |
headers: { | |
'Content-Type': 'application/json', | |
Authorization: `Bearer ${token}` | |
}, | |
body: JSON.stringify({ | |
duration: duration | |
}) | |
}) | |
.then(async (res) => { | |
if (!res.ok) throw await res.json(); | |
return res.json(); | |
}) | |
.catch((err) => { | |
console.log(err); | |
error = err.detail; | |
return null; | |
}); | |
if (error) { | |
throw error; | |
} | |
return res; | |
}; | |
export const createAPIKey = async (token: string) => { | |
let error = null; | |
const res = await fetch(`${WEBUI_API_BASE_URL}/auths/api_key`, { | |
method: 'POST', | |
headers: { | |
'Content-Type': 'application/json', | |
Authorization: `Bearer ${token}` | |
} | |
}) | |
.then(async (res) => { | |
if (!res.ok) throw await res.json(); | |
return res.json(); | |
}) | |
.catch((err) => { | |
console.log(err); | |
error = err.detail; | |
return null; | |
}); | |
if (error) { | |
throw error; | |
} | |
return res.api_key; | |
}; | |
export const getAPIKey = async (token: string) => { | |
let error = null; | |
const res = await fetch(`${WEBUI_API_BASE_URL}/auths/api_key`, { | |
method: 'GET', | |
headers: { | |
'Content-Type': 'application/json', | |
Authorization: `Bearer ${token}` | |
} | |
}) | |
.then(async (res) => { | |
if (!res.ok) throw await res.json(); | |
return res.json(); | |
}) | |
.catch((err) => { | |
console.log(err); | |
error = err.detail; | |
return null; | |
}); | |
if (error) { | |
throw error; | |
} | |
return res.api_key; | |
}; | |
export const deleteAPIKey = async (token: string) => { | |
let error = null; | |
const res = await fetch(`${WEBUI_API_BASE_URL}/auths/api_key`, { | |
method: 'DELETE', | |
headers: { | |
'Content-Type': 'application/json', | |
Authorization: `Bearer ${token}` | |
} | |
}) | |
.then(async (res) => { | |
if (!res.ok) throw await res.json(); | |
return res.json(); | |
}) | |
.catch((err) => { | |
console.log(err); | |
error = err.detail; | |
return null; | |
}); | |
if (error) { | |
throw error; | |
} | |
return res; | |
}; | |