👽 Update to latest Passport version

This commit is contained in:
2024-09-16 11:21:53 +08:00
parent 010f8a065b
commit 7375c6a774
7 changed files with 50 additions and 38 deletions

View File

@ -1,11 +1,15 @@
<template>
<div class="flex items-center">
<v-form class="flex-grow-1" @submit.prevent="submit">
<v-text-field :label="t('username')" variant="solo" density="comfortable" class="mb-3" :hide-details="true"
:disabled="props.loading" v-model="probe" />
<v-text-field :label="t('password')" variant="solo" density="comfortable" type="password"
:disabled="props.loading"
v-model="password" />
<v-text-field
:label="t('username')"
variant="solo"
density="comfortable"
class="mb-3"
:hide-details="true"
:disabled="props.loading"
v-model="probe"
/>
<v-expand-transition>
<v-alert v-show="error" variant="tonal" type="error" class="text-xs mb-3">
@ -36,7 +40,6 @@ const { t } = useI18n()
const config = useRuntimeConfig()
const probe = ref("")
const password = ref("")
const error = ref<string | null>(null)
@ -44,13 +47,13 @@ const props = defineProps<{ loading?: boolean }>()
const emits = defineEmits(["swap", "update:loading", "update:ticket"])
async function submit() {
if (!probe.value || !password.value) return
if (!probe.value) return
emits("update:loading", true)
const res = await fetch(`${config.public.solarNetworkApi}/cgi/id/auth`, {
method: "POST",
headers: { "Content-Type": "application/json" },
body: JSON.stringify({ username: probe.value, password: password.value }),
body: JSON.stringify({ username: probe.value }),
})
if (res.status !== 200) {
error.value = await res.text()

View File

@ -58,8 +58,8 @@ const emits = defineEmits(["swap", "update:ticket", "update:loading"])
async function submit() {
emits("update:loading", true)
const res = await fetch(`${config.public.solarNetworkApi}/cgi/id/auth/mfa`, {
method: "POST",
const res = await fetch(`${config.public.solarNetworkApi}/cgi/id/auth`, {
method: "PATCH",
headers: { "Content-Type": "application/json" },
body: JSON.stringify({
ticket_id: props.ticket?.id,

View File

@ -48,7 +48,7 @@ async function load() {
if (res.status !== 200) {
error.value = await res.text()
} else {
factors.value = (await res.json()).filter((e: any) => e.type != 0)
factors.value = await res.json()
}
emits("update:loading", false)
}
@ -76,13 +76,15 @@ async function submit() {
function getFactorType(item: any) {
switch (item.type) {
case 0:
return { icon: "mdi-form-textbox-password", label: t("multiFactorTypePassword") }
case 1:
return { icon: "mdi-email-fast", label: t('multiFactorTypeEmail') }
return { icon: "mdi-email-fast", label: t("multiFactorTypeEmail") }
}
}
function getFactorAvailable(factor: any) {
const blacklist: number[] = props.ticket?.blacklist_factors ?? []
const blacklist: number[] = props.ticket?.factor_trail ?? []
return blacklist.includes(factor.id)
}
</script>