Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix: avoid login or logged in issues #1037

Merged
merged 2 commits into from
Oct 15, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 5 additions & 5 deletions .vscode/extensions.json
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
{
"recommendations": [
"dbaeumer.vscode-eslint",
"esbenp.prettier-vscode",
"firsttris.vscode-jest-runner"
]
"recommendations": [
"dbaeumer.vscode-eslint",
"esbenp.prettier-vscode",
"firsttris.vscode-jest-runner"
]
}
34 changes: 17 additions & 17 deletions .vscode/settings.json
Original file line number Diff line number Diff line change
@@ -1,18 +1,18 @@
{
"workbench.colorCustomizations": {
"activityBar.background": "#65c89b",
"activityBar.activeBorder": "#945bc4",
"activityBar.foreground": "#15202b",
"activityBar.inactiveForeground": "#15202b99",
"activityBarBadge.background": "#945bc4",
"activityBarBadge.foreground": "#e7e7e7",
"titleBar.activeBackground": "#42b883",
"titleBar.inactiveBackground": "#42b88399",
"titleBar.activeForeground": "#15202b",
"titleBar.inactiveForeground": "#15202b99",
"statusBar.background": "#42b883",
"statusBarItem.hoverBackground": "#359268",
"statusBar.foreground": "#15202b"
},
"peacock.color": "#42b883"
}
"workbench.colorCustomizations": {
"activityBar.background": "#65c89b",
"activityBar.activeBorder": "#945bc4",
"activityBar.foreground": "#15202b",
"activityBar.inactiveForeground": "#15202b99",
"activityBarBadge.background": "#945bc4",
"activityBarBadge.foreground": "#e7e7e7",
"titleBar.activeBackground": "#42b883",
"titleBar.inactiveBackground": "#42b88399",
"titleBar.activeForeground": "#15202b",
"titleBar.inactiveForeground": "#15202b99",
"statusBar.background": "#42b883",
"statusBarItem.hoverBackground": "#359268",
"statusBar.foreground": "#15202b"
},
"peacock.color": "#42b883"
}
4 changes: 2 additions & 2 deletions Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -22,13 +22,13 @@ ENV NGINX_GROUP=nginx

USER $NGINX_USER_ID

# Add build to nginx root file
# Add build to nginx root webapp
COPY --from=builder --chown=$NGINX_USER:$NGINX_GROUP /bauhaus/build /usr/share/nginx/html

# Copy nginx configuration
RUN rm /etc/nginx/conf.d/default.conf
COPY --from=builder --chown=$NGINX_USER:$NGINX_GROUP /bauhaus/nginx.conf /etc/nginx/conf.d/nginx.conf

# Add entrypoint
# Add entrypoint and start nginx server
RUN chmod 755 /usr/share/nginx/html/vite-envs.sh
ENTRYPOINT sh -c "/usr/share/nginx/html/vite-envs.sh && nginx -g 'daemon off;'"
11 changes: 8 additions & 3 deletions src/packages/auth/hoc.tsx
Original file line number Diff line number Diff line change
@@ -1,9 +1,10 @@
import { connect } from 'react-redux';
import LoginNoAuth from './no-auth/login';
import LoginOidcComponent from './open-id-connect-auth/use-oidc';
import LoggedWrapper, { LoginWrapper } from './open-id-connect-auth/use-oidc';
import { NO_AUTH, OPEN_ID_CONNECT_AUTH } from './constants';
import { getPermission } from '../redux/selectors';
import { ReduxModel } from '../redux/model';
import { useOidc } from './create-oidc';

const auth = (WrappedComponent: any) => {
const AuthComponent = ({
Expand All @@ -13,8 +14,12 @@ const auth = (WrappedComponent: any) => {
authType: string;
roles: string[] | null;
}) => {
if (authType === OPEN_ID_CONNECT_AUTH)
return <LoginOidcComponent WrappedComponent={WrappedComponent} />;
if (authType === OPEN_ID_CONNECT_AUTH) {
const { isUserLoggedIn } = useOidc();
PierreVasseur marked this conversation as resolved.
Show resolved Hide resolved
if (!isUserLoggedIn)
return <LoginWrapper WrappedComponent={WrappedComponent} />;
PierreVasseur marked this conversation as resolved.
Show resolved Hide resolved
else return <LoggedWrapper WrappedComponent={WrappedComponent} />;
}

if (roles) return <WrappedComponent />;

Expand Down
46 changes: 26 additions & 20 deletions src/packages/auth/open-id-connect-auth/use-oidc.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,40 +5,46 @@ import { storeToken } from './token-utils';
import { useEffect, useState } from 'react';
import { UsersApi } from '../../sdk/users-api';

type LoginOidcComponentTypes = {
type OidcWrapperTypes = {
WrappedComponent: any;
saveUserProps: ({ roles, stamp }: { roles: string[]; stamp: string }) => void;
};

const LoginOidcComponent = ({
export const LoginWrapper = ({
WrappedComponent,
saveUserProps,
}: LoginOidcComponentTypes) => {
const { isUserLoggedIn, login, oidcTokens } = useOidc({
}: Omit<OidcWrapperTypes, 'saveUserProps'>) => {
const { isUserLoggedIn, login } = useOidc({
assertUserLoggedIn: false,
});
const { renewTokens } = useOidc({ assertUserLoggedIn: true });
const [userInformationLoaded, setUserInformationLoaded] = useState(false);

if (!isUserLoggedIn) {
login({
doesCurrentHrefRequiresAuth: true,
});
return null;
}

return <WrappedComponent />;
PierreVasseur marked this conversation as resolved.
Show resolved Hide resolved
};

const LoggedWrapper = ({
WrappedComponent,
saveUserProps,
}: OidcWrapperTypes) => {
const { oidcTokens, renewTokens } = useOidc({
assertUserLoggedIn: true,
});
const [userInformationLoaded, setUserInformationLoaded] = useState(false);

useEffect(() => {
if (isUserLoggedIn) {
storeToken(oidcTokens?.accessToken);
UsersApi.getStamp().then(({ stamp }: { stamp: string }) => {
const roles = (oidcTokens?.decodedIdToken.realm_access as any).roles;
saveUserProps({ roles, stamp });
setUserInformationLoaded(true);
});
setInterval(() => {
renewTokens();
}, 120000);
}
storeToken(oidcTokens?.accessToken);
UsersApi.getStamp().then(({ stamp }: { stamp: string }) => {
const roles = (oidcTokens?.decodedIdToken.realm_access as any).roles;
saveUserProps({ roles, stamp });
setUserInformationLoaded(true);
});
setInterval(() => {
renewTokens();
}, 120000);
}, []);

useEffect(() => {
Expand All @@ -56,4 +62,4 @@ const mapDispatchToProps = {
saveUserProps,
};

export default connect(undefined, mapDispatchToProps)(LoginOidcComponent);
export default connect(undefined, mapDispatchToProps)(LoggedWrapper);
1 change: 0 additions & 1 deletion src/vite-env.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,6 @@ type ImportMetaEnv = {
VITE_CONCEPTS_DOCUMENTATION: string
VITE_OPERATIONS_DOCUMENTATION: string
VITE_DEV_TOOLS_ENABLED: string
VITE_INSEE: string
VITE_NAME: string
VITE_VERSION: string
BASE_URL: string
Expand Down