• Added `.eslintrc.cjs` - Enables `header` + `react-hooks` plugins - Inserts standardized AGPL-3.0 license banner for © 2025 QuantumNous - JS/JSX parsing & JSX support configured • Installed dev-deps: `eslint`, `eslint-plugin-header`, `eslint-plugin-react-hooks` • Updated `web/package.json` scripts - `eslint` → lint with cache - `eslint:fix` → auto-insert/repair license headers • Executed `eslint --fix` to prepend license banner to all JS/JSX files • Ignored runtime cache - Added `.eslintcache` to `.gitignore` & `.dockerignore` Result: consistent AGPL-3.0 license headers, reproducible linting across local dev & CI.
53 lines
1.4 KiB
JavaScript
53 lines
1.4 KiB
JavaScript
/*
|
|
Copyright (C) 2025 QuantumNous
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU Affero General Public License as
|
|
published by the Free Software Foundation, either version 3 of the
|
|
License, or (at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU Affero General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Affero General Public License
|
|
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
For commercial licensing, please contact support@quantumnous.com
|
|
*/
|
|
|
|
import React from 'react';
|
|
import { Navigate } from 'react-router-dom';
|
|
import { history } from './history';
|
|
|
|
export function authHeader() {
|
|
// return authorization header with jwt token
|
|
let user = JSON.parse(localStorage.getItem('user'));
|
|
|
|
if (user && user.token) {
|
|
return { Authorization: 'Bearer ' + user.token };
|
|
} else {
|
|
return {};
|
|
}
|
|
}
|
|
|
|
export const AuthRedirect = ({ children }) => {
|
|
const user = localStorage.getItem('user');
|
|
|
|
if (user) {
|
|
return <Navigate to="/console" replace />;
|
|
}
|
|
|
|
return children;
|
|
};
|
|
|
|
function PrivateRoute({ children }) {
|
|
if (!localStorage.getItem('user')) {
|
|
return <Navigate to='/login' state={{ from: history.location }} />;
|
|
}
|
|
return children;
|
|
}
|
|
|
|
export { PrivateRoute };
|