Use redux auth for now
This commit is contained in:
parent
7ac18c0951
commit
15f536e949
5 changed files with 22 additions and 100 deletions
|
@ -202,7 +202,9 @@ export const rememberAuthAccount = (accountUrl: string) =>
|
||||||
|
|
||||||
export const loadCredentials = (token: string, accountUrl: string) =>
|
export const loadCredentials = (token: string, accountUrl: string) =>
|
||||||
(dispatch: AppDispatch) => dispatch(rememberAuthAccount(accountUrl))
|
(dispatch: AppDispatch) => dispatch(rememberAuthAccount(accountUrl))
|
||||||
.then(() => dispatch(verifyCredentials(token, accountUrl)))
|
.then(() => {
|
||||||
|
dispatch(verifyCredentials(token, accountUrl));
|
||||||
|
})
|
||||||
.catch(() => dispatch(verifyCredentials(token, accountUrl)));
|
.catch(() => dispatch(verifyCredentials(token, accountUrl)));
|
||||||
|
|
||||||
/** Trim the username and strip the leading @. */
|
/** Trim the username and strip the leading @. */
|
||||||
|
|
|
@ -41,7 +41,7 @@ const maybeParseJSON = (data: string) => {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
const getAuthBaseURL = createSelector([
|
export const getAuthBaseURL = createSelector([
|
||||||
(state: RootState, me: string | false | null) => state.accounts.getIn([me, 'url']),
|
(state: RootState, me: string | false | null) => state.accounts.getIn([me, 'url']),
|
||||||
(state: RootState, _me: string | false | null) => state.auth.get('me'),
|
(state: RootState, _me: string | false | null) => state.auth.get('me'),
|
||||||
], (accountUrl, authUserUrl) => {
|
], (accountUrl, authUserUrl) => {
|
||||||
|
|
|
@ -13,11 +13,11 @@ import { loadInstance } from 'soapbox/actions/instance';
|
||||||
import { fetchMe } from 'soapbox/actions/me';
|
import { fetchMe } from 'soapbox/actions/me';
|
||||||
import { loadSoapboxConfig, getSoapboxConfig } from 'soapbox/actions/soapbox';
|
import { loadSoapboxConfig, getSoapboxConfig } from 'soapbox/actions/soapbox';
|
||||||
import { fetchVerificationConfig } from 'soapbox/actions/verification';
|
import { fetchVerificationConfig } from 'soapbox/actions/verification';
|
||||||
|
import { getAuthBaseURL } from 'soapbox/api';
|
||||||
import * as BuildConfig from 'soapbox/build_config';
|
import * as BuildConfig from 'soapbox/build_config';
|
||||||
import GdprBanner from 'soapbox/components/gdpr-banner';
|
import GdprBanner from 'soapbox/components/gdpr-banner';
|
||||||
import Helmet from 'soapbox/components/helmet';
|
import Helmet from 'soapbox/components/helmet';
|
||||||
import LoadingScreen from 'soapbox/components/loading-screen';
|
import LoadingScreen from 'soapbox/components/loading-screen';
|
||||||
import { AuthProvider, useAuth } from 'soapbox/contexts/auth-context';
|
|
||||||
import AuthLayout from 'soapbox/features/auth_layout';
|
import AuthLayout from 'soapbox/features/auth_layout';
|
||||||
import PublicLayout from 'soapbox/features/public_layout';
|
import PublicLayout from 'soapbox/features/public_layout';
|
||||||
import BundleContainer from 'soapbox/features/ui/containers/bundle_container';
|
import BundleContainer from 'soapbox/features/ui/containers/bundle_container';
|
||||||
|
@ -40,6 +40,7 @@ import {
|
||||||
} from 'soapbox/hooks';
|
} from 'soapbox/hooks';
|
||||||
import MESSAGES from 'soapbox/locales/messages';
|
import MESSAGES from 'soapbox/locales/messages';
|
||||||
import { queryClient, useAxiosInterceptors } from 'soapbox/queries/client';
|
import { queryClient, useAxiosInterceptors } from 'soapbox/queries/client';
|
||||||
|
import { getAccessToken } from 'soapbox/utils/auth';
|
||||||
import { useCachedLocationHandler } from 'soapbox/utils/redirect';
|
import { useCachedLocationHandler } from 'soapbox/utils/redirect';
|
||||||
import { generateThemeCss } from 'soapbox/utils/theme';
|
import { generateThemeCss } from 'soapbox/utils/theme';
|
||||||
|
|
||||||
|
@ -63,7 +64,7 @@ const loadInitial = () => {
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
return async(dispatch, getState) => {
|
return async(dispatch, getState) => {
|
||||||
// Await for authenticated fetch
|
// Await for authenticated fetch
|
||||||
const account = await dispatch(fetchMe());
|
await dispatch(fetchMe());
|
||||||
// Await for feature detection
|
// Await for feature detection
|
||||||
await dispatch(loadInstance());
|
await dispatch(loadInstance());
|
||||||
// Await for configuration
|
// Await for configuration
|
||||||
|
@ -76,8 +77,6 @@ const loadInitial = () => {
|
||||||
if (pepeEnabled && !state.me) {
|
if (pepeEnabled && !state.me) {
|
||||||
await dispatch(fetchVerificationConfig());
|
await dispatch(fetchVerificationConfig());
|
||||||
}
|
}
|
||||||
|
|
||||||
return account;
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -199,15 +198,16 @@ interface ISoapboxLoad {
|
||||||
/** Initial data loader. */
|
/** Initial data loader. */
|
||||||
const SoapboxLoad: React.FC<ISoapboxLoad> = ({ children }) => {
|
const SoapboxLoad: React.FC<ISoapboxLoad> = ({ children }) => {
|
||||||
const dispatch = useAppDispatch();
|
const dispatch = useAppDispatch();
|
||||||
const { setAccount, token, baseApiUri } = useAuth();
|
|
||||||
|
|
||||||
useAxiosInterceptors(token, baseApiUri);
|
|
||||||
|
|
||||||
const me = useAppSelector(state => state.me);
|
const me = useAppSelector(state => state.me);
|
||||||
const account = useOwnAccount();
|
const account = useOwnAccount();
|
||||||
const swUpdating = useAppSelector(state => state.meta.swUpdating);
|
const swUpdating = useAppSelector(state => state.meta.swUpdating);
|
||||||
|
const accessToken = useAppSelector((state) => getAccessToken(state));
|
||||||
|
const baseURL = useAppSelector((state) => me ? getAuthBaseURL(state, me) : '');
|
||||||
const locale = useLocale();
|
const locale = useLocale();
|
||||||
|
|
||||||
|
useAxiosInterceptors(accessToken, baseURL);
|
||||||
|
|
||||||
const [messages, setMessages] = useState<Record<string, string>>({});
|
const [messages, setMessages] = useState<Record<string, string>>({});
|
||||||
const [localeLoading, setLocaleLoading] = useState(true);
|
const [localeLoading, setLocaleLoading] = useState(true);
|
||||||
const [isLoaded, setIsLoaded] = useState(false);
|
const [isLoaded, setIsLoaded] = useState(false);
|
||||||
|
@ -231,8 +231,7 @@ const SoapboxLoad: React.FC<ISoapboxLoad> = ({ children }) => {
|
||||||
|
|
||||||
// Load initial data from the API
|
// Load initial data from the API
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
dispatch(loadInitial()).then((account) => {
|
dispatch(loadInitial()).then(() => {
|
||||||
setAccount(account);
|
|
||||||
setIsLoaded(true);
|
setIsLoaded(true);
|
||||||
}).catch(() => {
|
}).catch(() => {
|
||||||
setIsLoaded(true);
|
setIsLoaded(true);
|
||||||
|
@ -290,7 +289,6 @@ const SoapboxHead: React.FC<ISoapboxHead> = ({ children }) => {
|
||||||
/** The root React node of the application. */
|
/** The root React node of the application. */
|
||||||
const Soapbox: React.FC = () => {
|
const Soapbox: React.FC = () => {
|
||||||
return (
|
return (
|
||||||
<AuthProvider>
|
|
||||||
<QueryClientProvider client={queryClient}>
|
<QueryClientProvider client={queryClient}>
|
||||||
<Provider store={store}>
|
<Provider store={store}>
|
||||||
<SoapboxHead>
|
<SoapboxHead>
|
||||||
|
@ -300,7 +298,6 @@ const Soapbox: React.FC = () => {
|
||||||
</SoapboxHead>
|
</SoapboxHead>
|
||||||
</Provider>
|
</Provider>
|
||||||
</QueryClientProvider>
|
</QueryClientProvider>
|
||||||
</AuthProvider>
|
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -1,77 +0,0 @@
|
||||||
|
|
||||||
import React, {
|
|
||||||
createContext,
|
|
||||||
useContext,
|
|
||||||
useEffect,
|
|
||||||
useMemo,
|
|
||||||
useState,
|
|
||||||
} from 'react';
|
|
||||||
|
|
||||||
import { localState } from 'soapbox/reducers/auth';
|
|
||||||
import { parseBaseURL } from 'soapbox/utils/auth';
|
|
||||||
|
|
||||||
const AuthContext = createContext(null as any);
|
|
||||||
|
|
||||||
interface IAccount {
|
|
||||||
acct: string
|
|
||||||
avatar: string
|
|
||||||
avatar_static: string
|
|
||||||
bot: boolean
|
|
||||||
created_at: string
|
|
||||||
discoverable: boolean
|
|
||||||
display_name: string
|
|
||||||
emojis: string[]
|
|
||||||
fields: any // not sure
|
|
||||||
followers_count: number
|
|
||||||
following_count: number
|
|
||||||
group: boolean
|
|
||||||
header: string
|
|
||||||
header_static: string
|
|
||||||
id: string
|
|
||||||
last_status_at: string
|
|
||||||
location: string
|
|
||||||
locked: boolean
|
|
||||||
note: string
|
|
||||||
statuses_count: number
|
|
||||||
url: string
|
|
||||||
username: string
|
|
||||||
verified: boolean
|
|
||||||
website: string
|
|
||||||
}
|
|
||||||
|
|
||||||
export const AuthProvider: React.FC<any> = ({ children }: { children: React.ReactNode }) => {
|
|
||||||
const [account, setAccount] = useState<IAccount>();
|
|
||||||
const [token, setToken] = useState<string>();
|
|
||||||
const [baseApiUri, setBaseApiUri] = useState<string>();
|
|
||||||
|
|
||||||
const value = useMemo(() => ({
|
|
||||||
account,
|
|
||||||
baseApiUri,
|
|
||||||
setAccount,
|
|
||||||
token,
|
|
||||||
}), [account]);
|
|
||||||
|
|
||||||
useEffect(() => {
|
|
||||||
const cachedAuth: any = localState?.toJS();
|
|
||||||
|
|
||||||
if (cachedAuth?.me) {
|
|
||||||
setToken(cachedAuth.users[cachedAuth.me].access_token);
|
|
||||||
setBaseApiUri(parseBaseURL(cachedAuth.users[cachedAuth.me].url));
|
|
||||||
}
|
|
||||||
}, []);
|
|
||||||
|
|
||||||
return (
|
|
||||||
<AuthContext.Provider value={value}>
|
|
||||||
{children}
|
|
||||||
</AuthContext.Provider>
|
|
||||||
);
|
|
||||||
};
|
|
||||||
|
|
||||||
interface IAuth {
|
|
||||||
account: IAccount
|
|
||||||
baseApiUri: string
|
|
||||||
setAccount(account: IAccount): void
|
|
||||||
token: string
|
|
||||||
}
|
|
||||||
|
|
||||||
export const useAuth = (): IAuth => useContext(AuthContext);
|
|
|
@ -38,7 +38,7 @@ const getSessionUser = () => {
|
||||||
};
|
};
|
||||||
|
|
||||||
const sessionUser = getSessionUser();
|
const sessionUser = getSessionUser();
|
||||||
export const localState = fromJS(JSON.parse(localStorage.getItem(STORAGE_KEY)));
|
const localState = fromJS(JSON.parse(localStorage.getItem(STORAGE_KEY)));
|
||||||
|
|
||||||
// Checks if the user has an ID and access token
|
// Checks if the user has an ID and access token
|
||||||
const validUser = user => {
|
const validUser = user => {
|
||||||
|
|
Loading…
Reference in a new issue