{"version":3,"file":"session.1efd4130.js","sources":["../../../../apollo/fragment-masking.ts","../../../../stores/session.ts"],"sourcesContent":["/* eslint-disable */\nimport { ResultOf, DocumentTypeDecoration, TypedDocumentNode } from '@graphql-typed-document-node/core';\nimport { FragmentDefinitionNode } from 'graphql';\nimport { Incremental } from './graphql';\n\n\nexport type FragmentType> = TDocumentType extends DocumentTypeDecoration<\n infer TType,\n any\n>\n ? [TType] extends [{ ' $fragmentName'?: infer TKey }]\n ? TKey extends string\n ? { ' $fragmentRefs'?: { [key in TKey]: TType } }\n : never\n : never\n : never;\n\n// return non-nullable if `fragmentType` is non-nullable\nexport function useFragment(\n _documentNode: DocumentTypeDecoration,\n fragmentType: FragmentType>\n): TType;\n// return nullable if `fragmentType` is undefined\nexport function useFragment(\n _documentNode: DocumentTypeDecoration,\n fragmentType: FragmentType> | undefined\n): TType | undefined;\n// return nullable if `fragmentType` is nullable\nexport function useFragment(\n _documentNode: DocumentTypeDecoration,\n fragmentType: FragmentType> | null\n): TType | null;\n// return nullable if `fragmentType` is nullable or undefined\nexport function useFragment(\n _documentNode: DocumentTypeDecoration,\n fragmentType: FragmentType> | null | undefined\n): TType | null | undefined;\n// return array of non-nullable if `fragmentType` is array of non-nullable\nexport function useFragment(\n _documentNode: DocumentTypeDecoration,\n fragmentType: Array>>\n): Array;\n// return array of nullable if `fragmentType` is array of nullable\nexport function useFragment(\n _documentNode: DocumentTypeDecoration,\n fragmentType: Array>> | null | undefined\n): Array | null | undefined;\n// return readonly array of non-nullable if `fragmentType` is array of non-nullable\nexport function useFragment(\n _documentNode: DocumentTypeDecoration,\n fragmentType: ReadonlyArray>>\n): ReadonlyArray;\n// return readonly array of nullable if `fragmentType` is array of nullable\nexport function useFragment(\n _documentNode: DocumentTypeDecoration,\n fragmentType: ReadonlyArray>> | null | undefined\n): ReadonlyArray | null | undefined;\nexport function useFragment(\n _documentNode: DocumentTypeDecoration,\n fragmentType: FragmentType> | Array>> | ReadonlyArray>> | null | undefined\n): TType | Array | ReadonlyArray | null | undefined {\n return fragmentType as any;\n}\n\n\nexport function makeFragmentData<\n F extends DocumentTypeDecoration,\n FT extends ResultOf\n>(data: FT, _fragment: F): FragmentType {\n return data as FragmentType;\n}\nexport function isFragmentReady(\n queryNode: DocumentTypeDecoration,\n fragmentNode: TypedDocumentNode,\n data: FragmentType, any>> | null | undefined\n): data is FragmentType {\n const deferredFields = (queryNode as { __meta__?: { deferredFields: Record } }).__meta__\n ?.deferredFields;\n\n if (!deferredFields) return true;\n\n const fragDef = fragmentNode.definitions[0] as FragmentDefinitionNode | undefined;\n const fragName = fragDef?.name?.value;\n\n const fields = (fragName && deferredFields[fragName]) || [];\n return fields.length > 0 && fields.every(field => data && field in data);\n}\n","import { gql } from '~/apollo/gql'\nimport { defineStore } from 'pinia'\nimport { useFragment } from '~/apollo/fragment-masking'\nimport type { User as UserType } from 'oidc-client-ts'\n\nexport const useSession = defineStore('session', () => {\n const { $um } = useNuxtApp()\n const route = useRoute()\n\n const impersonating = ref(\n window.localStorage.getItem('sato48:impersonate'),\n )\n\n const sso = ref(null)\n $um.getUser().then(user => {\n sso.value = user\n })\n const roles = computed(\n () => (sso.value?.profile.roles as string[]) || [],\n )\n\n const { result, loading } = useQuery(Whoami, {}, () => ({\n enabled: sso.value != null,\n }))\n const user = computed(() => useFragment(User, result.value?.users[0]))\n const isAuthenticated = computed(() => !!user.value)\n\n const impersonate = async (id?: number) => {\n if (id) {\n window.localStorage.setItem('sato48:impersonate', id.toString())\n $um.signinRedirect({\n scope: `openid offline email impersonate.${id}`,\n })\n } else {\n window.localStorage.clear()\n $um.signinRedirect({\n scope: `openid offline email`,\n })\n }\n }\n\n if (route.hash.startsWith('#impersonate=')) {\n impersonate(parseInt(route.hash.replace('#impersonate=', '')))\n }\n\n return {\n loading,\n sso,\n user,\n roles,\n isAuthenticated,\n impersonate,\n impersonating,\n }\n})\n\nconst User = gql(`fragment User on users {\n id name email sub picture\n}`)\n\nconst Whoami = gql(`query Whoami {\n users {\n ...User\n }\n}`)\n"],"names":["useFragment","_documentNode","fragmentType","useSession","defineStore","$um","useNuxtApp","route","useRoute","impersonating","ref","sso","user","roles","computed","_a","result","loading","useQuery","Whoami","User","isAuthenticated","impersonate","id","gql"],"mappings":"kHAyDgB,SAAAA,EACdC,EACAC,EACgE,CACzD,OAAAA,CACT,CCzDa,MAAAC,EAAaC,EAAY,UAAW,IAAM,CAC/C,KAAA,CAAE,IAAAC,GAAQC,IACVC,EAAQC,IAERC,EAAgBC,EACpB,OAAO,aAAa,QAAQ,oBAAoB,CAAA,EAG5CC,EAAMD,EAAqB,IAAI,EACrCL,EAAI,QAAQ,EAAE,KAAKO,GAAQ,CACzBD,EAAI,MAAQC,CAAA,CACb,EACD,MAAMC,EAAQC,EACZ,IAAA,OAAO,QAAAC,EAAAJ,EAAI,QAAJ,YAAAI,EAAW,QAAQ,QAAsB,CAAC,EAAA,EAG7C,CAAE,OAAAC,EAAQ,QAAAC,CAAQ,EAAIC,EAASC,EAAQ,CAAA,EAAI,KAAO,CACtD,QAASR,EAAI,OAAS,IACtB,EAAA,EACIC,EAAOE,EAAS,IAAM,OAAA,OAAAd,EAAYoB,GAAML,EAAAC,EAAO,QAAP,YAAAD,EAAc,MAAM,EAAE,EAAC,EAC/DM,EAAkBP,EAAS,IAAM,CAAC,CAACF,EAAK,KAAK,EAE7CU,EAAc,MAAOC,GAAgB,CACrCA,GACF,OAAO,aAAa,QAAQ,qBAAsBA,EAAG,UAAU,EAC/DlB,EAAI,eAAe,CACjB,MAAO,oCAAoCkB,CAAE,EAAA,CAC9C,IAED,OAAO,aAAa,QACpBlB,EAAI,eAAe,CACjB,MAAO,sBAAA,CACR,EACH,EAGF,OAAIE,EAAM,KAAK,WAAW,eAAe,GACvCe,EAAY,SAASf,EAAM,KAAK,QAAQ,gBAAiB,EAAE,CAAC,CAAC,EAGxD,CACL,QAAAU,EACA,IAAAN,EACA,KAAAC,EACA,MAAAC,EACA,gBAAAQ,EACA,YAAAC,EACA,cAAAb,CAAA,CAEJ,CAAC,EAEKW,EAAOI,EAAI;AAAA;AAAA,EAEf,EAEIL,EAASK,EAAI;AAAA;AAAA;AAAA;AAAA,EAIjB"}