init.server.ts 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839
  1. import UnauthorizedError from "~/services/error/UnauthorizedError";
  2. import {useRedirect} from "~/composables/utils/useRedirect";
  3. import {useRefreshProfile} from "~/composables/data/useRefreshProfile";
  4. import type {CookieRef} from "#app";
  5. export default defineNuxtPlugin(async () => {
  6. const { redirectToLogout } = useRedirect()
  7. const bearer: CookieRef<string | null> = useCookie('BEARER') ?? null
  8. let accessCookieId: CookieRef<string | null> = useCookie('AccessId') ?? null
  9. const switchId: CookieRef<string | null> = useCookie('SwitchAccessId') ?? null
  10. if (accessCookieId.value === null || Number.isNaN(accessCookieId.value)) {
  11. redirectToLogout()
  12. return
  13. }
  14. const accessId: number = parseInt(accessCookieId.value)
  15. if (isNaN(accessId)) {
  16. throw new Error('Invalid access id')
  17. }
  18. const { initiateProfile } = useRefreshProfile()
  19. try {
  20. await initiateProfile(
  21. accessId,
  22. bearer.value ?? '',
  23. switchId.value !== null ? parseInt(switchId.value) : null
  24. )
  25. } catch (error) {
  26. if (error instanceof UnauthorizedError) {
  27. redirectToLogout()
  28. } else {
  29. throw error
  30. }
  31. }
  32. })