2022-07-12 10:55:28 +02:00
|
|
|
import { AUTH_USER_ACTOR_ID } from "@/constants";
|
|
|
|
import { UPDATE_CURRENT_ACTOR_CLIENT, IDENTITIES } from "@/graphql/actor";
|
|
|
|
import { IPerson } from "@/types/actor";
|
|
|
|
import { apolloClient } from "@/vue-apollo";
|
|
|
|
import {
|
|
|
|
provideApolloClient,
|
|
|
|
useMutation,
|
|
|
|
useQuery,
|
|
|
|
} from "@vue/apollo-composable";
|
|
|
|
import { computed, watch } from "vue";
|
|
|
|
|
|
|
|
export class NoIdentitiesException extends Error {}
|
|
|
|
|
2022-09-27 10:50:14 +02:00
|
|
|
function saveActorData(obj: IPerson): void {
|
2022-07-12 10:55:28 +02:00
|
|
|
localStorage.setItem(AUTH_USER_ACTOR_ID, `${obj.id}`);
|
|
|
|
}
|
|
|
|
|
|
|
|
export async function changeIdentity(identity: IPerson): Promise<void> {
|
|
|
|
if (!identity.id) return;
|
|
|
|
const { mutate: updateCurrentActorClient } = provideApolloClient(
|
|
|
|
apolloClient
|
|
|
|
)(() => useMutation(UPDATE_CURRENT_ACTOR_CLIENT));
|
|
|
|
|
|
|
|
updateCurrentActorClient(identity);
|
|
|
|
if (identity.id) {
|
|
|
|
saveActorData(identity);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* We fetch from localStorage the latest actor ID used,
|
|
|
|
* then fetch the current identities to set in cache
|
|
|
|
* the current identity used
|
|
|
|
*/
|
|
|
|
export async function initializeCurrentActor(): Promise<void> {
|
|
|
|
const actorId = localStorage.getItem(AUTH_USER_ACTOR_ID);
|
|
|
|
|
|
|
|
const { result: identitiesResult } = provideApolloClient(apolloClient)(() =>
|
|
|
|
useQuery<{ identities: IPerson[] }>(IDENTITIES)
|
|
|
|
);
|
|
|
|
|
|
|
|
const identities = computed(() => identitiesResult.value?.identities);
|
|
|
|
|
|
|
|
watch(identities, async () => {
|
|
|
|
if (identities.value && identities.value.length < 1) {
|
|
|
|
console.warn("Logged user has no identities!");
|
|
|
|
throw new NoIdentitiesException();
|
|
|
|
}
|
|
|
|
const activeIdentity =
|
|
|
|
(identities.value || []).find(
|
|
|
|
(identity: IPerson | undefined) => identity?.id === actorId
|
|
|
|
) || ((identities.value || [])[0] as IPerson);
|
|
|
|
|
|
|
|
if (activeIdentity) {
|
|
|
|
await changeIdentity(activeIdentity);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|