The frontend for the project formerly known as signet, now known as beignet.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

83 lines
1.9 KiB

  1. import {
  2. createRouter,
  3. createWebHistory,
  4. RouteRecordRaw,
  5. } from 'vue-router';
  6. import RegisterView from '@/views/RegisterView.vue';
  7. import LoginView from '@/views/LoginView.vue';
  8. import {
  9. Privileges,
  10. SuccessResponse,
  11. } from '@/api/types';
  12. import HomeView from '@/views/HomeView.vue';
  13. import FundView from '@/views/FundView.vue';
  14. import AddFundView from '@/views/AddFundView.vue';
  15. import hasPermission from '@/lib/auth';
  16. import SignetRequestController from '@/api/requests';
  17. const routes: Array<RouteRecordRaw> = [
  18. {
  19. path: '/',
  20. name: 'home',
  21. component: HomeView,
  22. meta: { title: 'Home' },
  23. },
  24. {
  25. path: '/fund/:id',
  26. name: 'fund',
  27. component: FundView,
  28. meta: { title: undefined },
  29. },
  30. {
  31. path: '/login',
  32. name: 'login',
  33. component: LoginView,
  34. meta: { title: 'Login' },
  35. },
  36. {
  37. path: '/register',
  38. name: 'register',
  39. component: RegisterView,
  40. meta: {
  41. requiredRights: Privileges.AdminPlus,
  42. accessible: async () => {
  43. const controller = new SignetRequestController();
  44. const canProceed = await controller.post<SuccessResponse, null>('/UsersExist', null);
  45. return canProceed?.success;
  46. },
  47. title: 'Register',
  48. },
  49. },
  50. {
  51. path: '/addfund',
  52. name: 'addfund',
  53. component: AddFundView,
  54. meta: {
  55. requiredRights: Privileges.Admin,
  56. title: 'Add Group Fund',
  57. },
  58. },
  59. ];
  60. const router = createRouter({
  61. history: createWebHistory(process.env.BASE_URL),
  62. routes,
  63. });
  64. router.beforeEach(async (to, from, next) => {
  65. document.title = `Beignet - ${to.meta.title}`;
  66. const requiredRights = to.meta.requiredRights as number | undefined;
  67. const accessible = to.meta.accessible as (() => SuccessResponse) | undefined;
  68. const allowed = requiredRights ? hasPermission(requiredRights)
  69. || (accessible && !accessible().success) : true;
  70. if (allowed) {
  71. next();
  72. } else {
  73. next('/');
  74. }
  75. });
  76. export default router;