adbe229fcb
NetBSD can run Docker CLI and then use Docker on some remote machine via DOCKER_HOST. (This can be probably extended to all other Unix-es capable of running just Docker CLI.) Co-authored-by: ChristopherHX <christopher.homberger@web.de>
79 lines
1.8 KiB
Go
79 lines
1.8 KiB
Go
//go:build !(WITHOUT_DOCKER || !(linux || darwin || windows || netbsd))
|
|
|
|
package container
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/docker/docker/api/types"
|
|
"github.com/nektos/act/pkg/common"
|
|
)
|
|
|
|
func NewDockerNetworkCreateExecutor(name string) common.Executor {
|
|
return func(ctx context.Context) error {
|
|
cli, err := GetDockerClient(ctx)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
defer cli.Close()
|
|
|
|
// Only create the network if it doesn't exist
|
|
networks, err := cli.NetworkList(ctx, types.NetworkListOptions{})
|
|
if err != nil {
|
|
return err
|
|
}
|
|
common.Logger(ctx).Debugf("%v", networks)
|
|
for _, network := range networks {
|
|
if network.Name == name {
|
|
common.Logger(ctx).Debugf("Network %v exists", name)
|
|
return nil
|
|
}
|
|
}
|
|
|
|
_, err = cli.NetworkCreate(ctx, name, types.NetworkCreate{
|
|
Driver: "bridge",
|
|
Scope: "local",
|
|
})
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return nil
|
|
}
|
|
}
|
|
|
|
func NewDockerNetworkRemoveExecutor(name string) common.Executor {
|
|
return func(ctx context.Context) error {
|
|
cli, err := GetDockerClient(ctx)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
defer cli.Close()
|
|
|
|
// Make shure that all network of the specified name are removed
|
|
// cli.NetworkRemove refuses to remove a network if there are duplicates
|
|
networks, err := cli.NetworkList(ctx, types.NetworkListOptions{})
|
|
if err != nil {
|
|
return err
|
|
}
|
|
common.Logger(ctx).Debugf("%v", networks)
|
|
for _, network := range networks {
|
|
if network.Name == name {
|
|
result, err := cli.NetworkInspect(ctx, network.ID, types.NetworkInspectOptions{})
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if len(result.Containers) == 0 {
|
|
if err = cli.NetworkRemove(ctx, network.ID); err != nil {
|
|
common.Logger(ctx).Debugf("%v", err)
|
|
}
|
|
} else {
|
|
common.Logger(ctx).Debugf("Refusing to remove network %v because it still has active endpoints", name)
|
|
}
|
|
}
|
|
}
|
|
|
|
return err
|
|
}
|
|
}
|