1
0
Fork 0
mirror of https://github.com/portainer/portainer.git synced 2025-07-24 15:59:41 +02:00

fix(docker/container): use nodeName to build links to networks used by containers (#12002)
Some checks failed
/ triage (push) Has been cancelled
ci / build_images (map[arch:amd64 platform:linux version:]) (push) Has been cancelled
ci / build_images (map[arch:amd64 platform:windows version:1809]) (push) Has been cancelled
ci / build_images (map[arch:amd64 platform:windows version:ltsc2022]) (push) Has been cancelled
ci / build_images (map[arch:arm platform:linux version:]) (push) Has been cancelled
ci / build_images (map[arch:arm64 platform:linux version:]) (push) Has been cancelled
ci / build_images (map[arch:ppc64le platform:linux version:]) (push) Has been cancelled
ci / build_images (map[arch:s390x platform:linux version:]) (push) Has been cancelled
Lint / Run linters (push) Has been cancelled
Test / test-client (push) Has been cancelled
Test / test-server (map[arch:amd64 platform:linux]) (push) Has been cancelled
Test / test-server (map[arch:amd64 platform:windows version:1809]) (push) Has been cancelled
Test / test-server (map[arch:amd64 platform:windows version:ltsc2022]) (push) Has been cancelled
Test / test-server (map[arch:arm64 platform:linux]) (push) Has been cancelled
ci / build_manifests (push) Has been cancelled

This commit is contained in:
LP B 2024-07-17 14:40:05 +02:00 committed by GitHub
parent a62aac296b
commit 1900fb695d
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
10 changed files with 134 additions and 141 deletions

View file

@ -1,3 +1,4 @@
import { useMemo } from 'react';
import { Network } from 'lucide-react';
import { EndpointSettings, NetworkSettings } from 'docker-types/generated/1.41';
@ -9,7 +10,7 @@ import { withMeta } from '@@/datatables/extend-options/withMeta';
import { ContainerListViewModel } from '../../types';
import { TableNetwork } from './types';
import { columns } from './columns';
import { buildColumns } from './columns';
import { ConnectNetworkForm } from './ConnectNetworkForm';
const storageKey = 'container-networks';
@ -25,6 +26,7 @@ export function ContainerNetworksDatatable({
nodeName?: string;
}) {
const tableState = useTableState(store, storageKey);
const columns = useMemo(() => buildColumns({ nodeName }), [nodeName]);
const networks: Array<TableNetwork> = Object.entries(dataset || {})
.filter(isNetworkDefined)

View file

@ -11,56 +11,59 @@ import { LoadingButton } from '@@/buttons';
import { TableNetwork, isContainerNetworkTableMeta } from './types';
import { columnHelper } from './helper';
export const actions = columnHelper.display({
header: 'Actions',
cell: Cell,
});
function Cell({
row: {
original: { id: networkId },
},
table: {
options: { meta },
},
}: CellContext<TableNetwork, unknown>) {
const router = useRouter();
const environmentId = useEnvironmentId();
const disconnectMutation = useDisconnectContainer({
environmentId,
networkId,
export function buildActions({ nodeName }: { nodeName?: string } = {}) {
return columnHelper.display({
header: 'Actions',
cell: Cell,
});
return (
<Authorized authorizations="DockerNetworkDisconnect">
<LoadingButton
color="dangerlight"
data-cy="disconnect-network-button"
isLoading={disconnectMutation.isLoading}
loadingText="Leaving network..."
type="button"
onClick={handleSubmit}
>
Leave network
</LoadingButton>
</Authorized>
);
function Cell({
row: {
original: { id: networkId },
},
table: {
options: { meta },
},
}: CellContext<TableNetwork, unknown>) {
const router = useRouter();
const environmentId = useEnvironmentId();
const disconnectMutation = useDisconnectContainer({
environmentId,
networkId,
});
function handleSubmit() {
if (!isContainerNetworkTableMeta(meta)) {
throw new Error('Invalid row meta');
}
disconnectMutation.mutate(
{
containerId: meta.containerId,
},
{
onSuccess() {
notifySuccess('Container successfully disconnected', networkId);
router.stateService.reload();
},
}
return (
<Authorized authorizations="DockerNetworkDisconnect">
<LoadingButton
color="dangerlight"
data-cy="disconnect-network-button"
isLoading={disconnectMutation.isLoading}
loadingText="Leaving network..."
type="button"
onClick={handleSubmit}
>
Leave network
</LoadingButton>
</Authorized>
);
function handleSubmit() {
if (!isContainerNetworkTableMeta(meta)) {
throw new Error('Invalid row meta');
}
disconnectMutation.mutate(
{
containerId: meta.containerId,
nodeName,
},
{
onSuccess() {
notifySuccess('Container successfully disconnected', networkId);
router.stateService.reload();
},
}
);
}
}
}

View file

@ -1,34 +1,37 @@
import { buildExpandColumn } from '@@/datatables/expand-column';
import { buildNameColumn } from '@@/datatables/buildNameColumn';
import { buildNameColumnFromObject } from '@@/datatables/buildNameColumn';
import { TableNetwork } from './types';
import { columnHelper } from './helper';
import { actions } from './actions';
import { buildActions } from './actions';
export const columns = [
buildExpandColumn<TableNetwork>(),
{
...buildNameColumn<TableNetwork>(
'name',
'docker.networks.network',
'docker-networks-name'
),
header: 'Network',
},
columnHelper.accessor((item) => item.IPAddress || '-', {
header: 'IP Address',
id: 'ip',
enableSorting: false,
}),
columnHelper.accessor((item) => item.Gateway || '-', {
header: 'Gateway',
id: 'gateway',
enableSorting: false,
}),
columnHelper.accessor((item) => item.MacAddress || '-', {
header: 'MAC Address',
id: 'macAddress',
enableSorting: false,
}),
actions,
];
export function buildColumns({ nodeName }: { nodeName?: string } = {}) {
return [
buildExpandColumn<TableNetwork>(),
{
...buildNameColumnFromObject<TableNetwork>({
nameKey: 'name',
path: 'docker.networks.network',
dataCy: 'docker-networks-name',
linkParamsBuilder: () => ({ nodeName }),
}),
header: 'Network',
},
columnHelper.accessor((item) => item.IPAddress || '-', {
header: 'IP Address',
id: 'ip',
enableSorting: false,
}),
columnHelper.accessor((item) => item.Gateway || '-', {
header: 'Gateway',
id: 'gateway',
enableSorting: false,
}),
columnHelper.accessor((item) => item.MacAddress || '-', {
header: 'MAC Address',
id: 'macAddress',
enableSorting: false,
}),
buildActions({ nodeName }),
];
}