diff --git a/src/env.js b/src/env.js
index 8d208def5..1d3bd7bfd 100644
--- a/src/env.js
+++ b/src/env.js
@@ -34,6 +34,7 @@ const env = createEnv({
NEXT_PUBLIC_DEFAULT_COLOR_SCHEME: z.enum(['light', 'dark']).optional().default('light'),
NEXT_PUBLIC_PORT: portSchema,
NEXT_PUBLIC_NODE_ENV: envSchema,
+ NEXT_PUBLIC_DOCKER_ENABLED: z.boolean().optional().default(false),
},
/**
@@ -50,6 +51,7 @@ const env = createEnv({
NEXT_PUBLIC_DEFAULT_COLOR_SCHEME: process.env.DEFAULT_COLOR_SCHEME,
NEXT_PUBLIC_PORT: process.env.PORT,
NEXT_PUBLIC_NODE_ENV: process.env.NODE_ENV,
+ NEXT_PUBLIC_DOCKER_ENABLED: !!process.env.DOCKER_HOST,
},
});
diff --git a/src/pages/board/index.tsx b/src/pages/board/index.tsx
index 680a2a606..c3f4ca312 100644
--- a/src/pages/board/index.tsx
+++ b/src/pages/board/index.tsx
@@ -22,6 +22,7 @@ import { MainLayout } from '~/components/layout/main';
import { useCardStyles } from '~/components/layout/useCardStyles';
import { useInitConfig } from '~/config/init';
import { useConfigContext } from '~/config/provider';
+import { env } from '~/env';
import { getServerAuthSession } from '~/server/auth';
import { prisma } from '~/server/db';
import { getFrontendConfig } from '~/tools/config/getFrontendConfig';
@@ -79,7 +80,7 @@ export const HeaderActions = () => {
return (
<>
-
+ {env.NEXT_PUBLIC_DOCKER_ENABLED && }
>
diff --git a/src/pages/docker.tsx b/src/pages/docker.tsx
index b269e8c3a..840487c1e 100644
--- a/src/pages/docker.tsx
+++ b/src/pages/docker.tsx
@@ -1,20 +1,19 @@
import { Stack } from '@mantine/core';
-import { useDebouncedValue } from '@mantine/hooks';
import { ContainerInfo } from 'dockerode';
import { GetServerSideProps } from 'next';
-import { useTranslation } from 'next-i18next';
import { useState } from 'react';
import { MainLayout } from '~/components/layout/main';
+import { env } from '~/env';
import ContainerActionBar from '~/modules/Docker/ContainerActionBar';
import DockerTable from '~/modules/Docker/DockerTable';
+import { getServerAuthSession } from '~/server/auth';
import { getServerSideTranslations } from '~/tools/server/getServerSideTranslations';
import { dashboardNamespaces } from '~/tools/server/translation-namespaces';
import { api } from '~/utils/api';
export default function DockerPage() {
const [selection, setSelection] = useState([]);
- // TODO: read that from somewhere else?
- const dockerEnabled = true;
+ const dockerEnabled = env.NEXT_PUBLIC_DOCKER_ENABLED;
const { data, refetch, isRefetching } = api.docker.containers.useQuery(undefined, {
enabled: dockerEnabled,
});
@@ -35,6 +34,14 @@ export default function DockerPage() {
}
export const getServerSideProps: GetServerSideProps = async ({ locale, req, res }) => {
+ if (!env.NEXT_PUBLIC_DOCKER_ENABLED) return { notFound: true };
+ const session = await getServerAuthSession({ req, res });
+ if (!session?.user.isAdmin) {
+ return {
+ notFound: true,
+ };
+ }
+
const translations = await getServerSideTranslations(dashboardNamespaces, locale, req, res);
return {
props: {