# Introduction Avoid having multiple `isDefined` definition across our pacakges Also avoid importing `isDefined` from `twenty-ui` which exposes a huge barrel for a such little util function ## In a nutshell Removed own `isDefined.ts` definition from `twenty-ui` `twenty-front` and `twenty-server` to move it to `twenty-shared`. Updated imports for each packages, and added explicit dependencies to `twenty-shared` if not already in place Related PR https://github.com/twentyhq/twenty/pull/9941
37 lines
905 B
TypeScript
37 lines
905 B
TypeScript
import { ApolloClient, InMemoryCache } from '@apollo/client';
|
|
|
|
import { isDefined } from 'twenty-shared';
|
|
import { Tokens } from '~/db/types/auth.types';
|
|
import { RENEW_TOKEN } from '~/graphql/auth/mutations';
|
|
|
|
export const renewToken = async (
|
|
appToken: string,
|
|
): Promise<{ renewToken: { tokens: Tokens } } | null> => {
|
|
const store = await chrome.storage.local.get();
|
|
const serverUrl = `${
|
|
isDefined(store.serverBaseUrl)
|
|
? store.serverBaseUrl
|
|
: import.meta.env.VITE_SERVER_BASE_URL
|
|
}/graphql`;
|
|
|
|
// Create new client to call refresh token graphql mutation
|
|
const client = new ApolloClient({
|
|
uri: serverUrl,
|
|
cache: new InMemoryCache({}),
|
|
});
|
|
|
|
const { data } = await client.mutate({
|
|
mutation: RENEW_TOKEN,
|
|
variables: {
|
|
appToken,
|
|
},
|
|
fetchPolicy: 'network-only',
|
|
});
|
|
|
|
if (isDefined(data)) {
|
|
return data;
|
|
} else {
|
|
return null;
|
|
}
|
|
};
|