init.server.ts 1018 B

1234567891011121314151617181920212223242526272829303132333435
  1. import {defineNuxtPlugin, useCookie} from "nuxt/app";
  2. import {useAccessProfileStore} from "~/stores/accessProfile";
  3. import {useEntityManager} from "~/composables/data/useEntityManager";
  4. import UnauthorizedError from "~/services/error/UnauthorizedError";
  5. import {useRedirectToLogout} from "~/composables/utils/useRedirectToLogout";
  6. export default defineNuxtPlugin(async ({ssrContext}) => {
  7. const redirectToLogout = useRedirectToLogout()
  8. const bearer = useCookie('BEARER')
  9. const accessId = useCookie('AccessId')
  10. const accessProfile = useAccessProfileStore()
  11. if (accessId.value !== null) {
  12. accessProfile.$patch({
  13. bearer: bearer.value,
  14. id: parseInt(accessId.value)
  15. })
  16. } else {
  17. redirectToLogout()
  18. }
  19. const {em} = useEntityManager()
  20. try {
  21. await em.refreshProfile()
  22. } catch (error) {
  23. if (error instanceof UnauthorizedError) {
  24. redirectToLogout()
  25. } else {
  26. throw error
  27. }
  28. }
  29. })