mirror of
https://github.com/toeverything/AFFiNE.git
synced 2026-02-13 04:48:53 +00:00
106 lines
2.9 KiB
TypeScript
106 lines
2.9 KiB
TypeScript
import { Button } from '@affine/component';
|
|
import { currentAffineUserAtom } from '@affine/workspace/affine/atom';
|
|
import {
|
|
clearLoginStorage,
|
|
createAffineAuth,
|
|
getLoginStorage,
|
|
isExpired,
|
|
parseIdToken,
|
|
setLoginStorage,
|
|
SignMethod,
|
|
} from '@affine/workspace/affine/login';
|
|
import { useAtom } from 'jotai';
|
|
import type { NextPage } from 'next';
|
|
import dynamic from 'next/dynamic';
|
|
import { useMemo } from 'react';
|
|
|
|
import { toast } from '../../utils';
|
|
|
|
const Viewer = dynamic(
|
|
() => import('@rich-data/viewer').then(m => ({ default: m.JsonViewer })),
|
|
{ ssr: false }
|
|
);
|
|
|
|
import { useTheme } from 'next-themes';
|
|
|
|
import { StyledPage, StyledWrapper } from '../../layouts/styles';
|
|
|
|
const LoginDevPage: NextPage = () => {
|
|
const [user, setUser] = useAtom(currentAffineUserAtom);
|
|
const auth = useMemo(() => createAffineAuth(), []);
|
|
return (
|
|
<StyledPage>
|
|
<StyledWrapper>
|
|
<h1>LoginDevPage</h1>
|
|
<Button
|
|
onClick={async () => {
|
|
const storage = getLoginStorage();
|
|
if (storage) {
|
|
const user = parseIdToken(storage.token);
|
|
if (isExpired(user)) {
|
|
await auth.refreshToken(storage);
|
|
}
|
|
}
|
|
const response = await auth.generateToken(SignMethod.Google);
|
|
if (response) {
|
|
setLoginStorage(response);
|
|
const user = parseIdToken(response.token);
|
|
setUser(user);
|
|
} else {
|
|
toast('Login failed');
|
|
}
|
|
}}
|
|
>
|
|
Login
|
|
</Button>
|
|
<Button
|
|
onClick={async () => {
|
|
const storage = getLoginStorage();
|
|
if (!storage) {
|
|
throw new Error('No storage');
|
|
}
|
|
const response = await auth.refreshToken(storage);
|
|
if (response) {
|
|
setLoginStorage(response);
|
|
const user = parseIdToken(response.token);
|
|
setUser(user);
|
|
} else {
|
|
toast('Login failed');
|
|
}
|
|
}}
|
|
>
|
|
Refresh Token
|
|
</Button>
|
|
<Button
|
|
onClick={() => {
|
|
clearLoginStorage();
|
|
setUser(null);
|
|
}}
|
|
>
|
|
Reset Storage
|
|
</Button>
|
|
<Button
|
|
onClick={async () => {
|
|
const status = await fetch('/api/workspace', {
|
|
method: 'GET',
|
|
headers: {
|
|
'Cache-Control': 'no-cache',
|
|
Authorization: getLoginStorage()?.token ?? '',
|
|
},
|
|
}).then(r => r.status);
|
|
toast(`Response Status: ${status}`);
|
|
}}
|
|
>
|
|
Check Permission
|
|
</Button>
|
|
<Viewer
|
|
theme={useTheme().resolvedTheme === 'light' ? 'light' : 'dark'}
|
|
value={user}
|
|
/>
|
|
</StyledWrapper>
|
|
</StyledPage>
|
|
);
|
|
};
|
|
|
|
export default LoginDevPage;
|