This commit is contained in:
danilbodry-mac
2026-04-10 19:58:29 +03:00
parent 5821006bf2
commit c5287dc81d
18 changed files with 2495 additions and 161 deletions

View File

@@ -1,12 +1,20 @@
import { createRouter, createWebHistory } from 'vue-router'
import Login from '../views/Login.vue'
import Setup from '../views/Setup.vue'
import Login from '../views/auth/Login.vue'
import Setup from '../views/auth/Setup.vue'
import Dashboard from '../views/Dashboard.vue'
const routes = [
{ path: '/login', component: Login },
{ path: '/setup', component: Setup },
{ path: '/', component: Dashboard, meta: { requiresAuth: true } }
{ path: '/login', component: Login, meta: { title: 'Login' } },
{ path: '/setup', component: Setup, meta: { title: 'Setup' } },
{
path: '/dashboard',
component: Dashboard,
meta: { requiresAuth: true, title: 'Dashboard' }
},
{
path: '/',
redirect: '/dashboard'
}
]
const router = createRouter({
@@ -15,23 +23,39 @@ const router = createRouter({
})
router.beforeEach(async (to, from, next) => {
const requiresAuth = to.matched.some(record => record.meta.requiresAuth)
const loggedIn = await checkAuth() // запрос к /api/admin/users или специальному endpoint
// Update page title
document.title = `${to.meta.title || 'Admin Panel'} | AdminPanel`
if (requiresAuth && !loggedIn) {
next('/login')
// Check if setup is needed
try {
const statusRes = await fetch('/api/status')
const status = await statusRes.json()
if (status.needsSetup && to.path !== '/setup') {
next('/setup')
return
}
} catch (e) {
console.error('Failed to check status', e)
}
// Check authentication
const requiresAuth = to.matched.some(record => record.meta.requiresAuth)
if (requiresAuth) {
try {
const res = await fetch('/api/admin/me')
if (!res.ok) {
next('/login')
} else {
next()
}
} catch {
next('/login')
}
} else {
next()
}
})
async function checkAuth(): Promise<boolean> {
try {
const res = await fetch('/api/admin/users')
return res.ok
} catch {
return false
}
}
export default router