fix(app): skip authorizations in CE [EE-2423] (#6431)

* feat(app): check auth on ee only

* refactor(features): load edition from env var

* fix(containers): show empty message if no containers
pull/6302/head^2
Chaim Lev-Ari 3 years ago committed by GitHub
parent 2c4c638f46
commit b588d901cf
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -0,0 +1 @@
PORTAINER_EDITION=CE

@ -191,19 +191,27 @@ export function ContainersDatatable({
role={tbodyProps.role}
style={tbodyProps.style}
>
{page.map((row) => {
prepareRow(row);
const { key, className, role, style } = row.getRowProps();
return (
<TableRow<DockerContainer>
cells={row.cells}
key={key}
className={className}
role={role}
style={style}
/>
);
})}
{page.length > 0 ? (
page.map((row) => {
prepareRow(row);
const { key, className, role, style } = row.getRowProps();
return (
<TableRow<DockerContainer>
cells={row.cells}
key={key}
className={className}
role={role}
style={style}
/>
);
})
) : (
<tr>
<td colSpan={columns.length} className="text-center text-muted">
No container available.
</td>
</tr>
)}
</tbody>
</Table>

@ -20,7 +20,7 @@ import { configApp } from './config';
import { init as initFeatureService } from './portainer/feature-flags/feature-flags.service';
import { Edition } from './portainer/feature-flags/enums';
initFeatureService(Edition.CE);
initFeatureService(Edition[process.env.PORTAINER_EDITION]);
angular
.module('portainer', [

@ -10,7 +10,7 @@ const state: ServiceState = {
features: <Record<FeatureId, Edition>>{},
};
export async function init(edition: Edition = Edition.CE) {
export async function init(edition: Edition) {
// will be loaded on runtime
const currentEdition = edition;
const features = {

@ -33,13 +33,20 @@ export function useUser() {
return context;
}
export function useAuthorizations(authorizations: string | string[]) {
export function useAuthorizations(
authorizations: string | string[],
adminOnlyCE = false
) {
const authorizationsArray =
typeof authorizations === 'string' ? [authorizations] : authorizations;
const { user } = useUser();
const { params } = useCurrentStateAndParams();
if (process.env.PORTAINER_EDITION === 'CE') {
return !adminOnlyCE || isAdmin(user);
}
const { endpointId } = params;
if (!endpointId) {
return false;
@ -118,6 +125,6 @@ export function UserProvider({ children }: UserProviderProps) {
}
}
function isAdmin(user: UserViewModel): boolean {
return user.Role === 1;
function isAdmin(user?: UserViewModel | null) {
return !!user && user.Role === 1;
}

@ -98,7 +98,7 @@ module.exports = {
},
},
plugins: [
new Dotenv(),
new Dotenv({ defaults: true }),
new ESLintPlugin(),
new HtmlWebpackPlugin({
template: './app/index.html',

Loading…
Cancel
Save