The first condition in the route guards is to check what the current path is. Since routes are defined by path, the path check is somewhat redundant.
One conventional approach is to use the route meta field to define a property requiresAuth, as follows. Notice the use of a Vuex store for an authentication token.
const router = new VueRouter({
routes: [
{
path: '/foo',
component: Foo,
children: [
{
path: 'bar',
component: Bar,
// a meta field
meta: { requiresAuth: true }
}
]
}
]
})
We currently have the following route guards defined on the main Router instance:
https://github.com/GeriLife/wellbeing-client/blob/09207281346eee3f1eb01db5fb06f286f40cfd40/src/router/index.js#L30-L51
There seem to be three main guards:
The first condition in the route guards is to check what the current path is. Since routes are defined by path, the path check is somewhat redundant.
One conventional approach is to use the route
meta
field to define a propertyrequiresAuth,
as follows. Notice the use of a Vuex store for an authentication token.Refactor the route guards into re-usable functions and apply
requresAuth
meta attribute directly in the relevant route definitions.Resources