Skip to content

Commit

Permalink
[bug] Fixed the panic for uninitialized docker daemon
Browse files Browse the repository at this point in the history
Signed-off-by: Manik2708 <[email protected]>
  • Loading branch information
Manik2708 committed Feb 1, 2025
1 parent 9656a7f commit fa1bdac
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 5 deletions.
4 changes: 3 additions & 1 deletion KubeArmor/core/dockerHandler.go
Original file line number Diff line number Diff line change
Expand Up @@ -258,13 +258,14 @@ func (dm *KubeArmorDaemon) SetContainerVisibility(containerID string) {
}

// GetAlreadyDeployedDockerContainers Function
func (dm *KubeArmorDaemon) GetAlreadyDeployedDockerContainers() {
func (dm *KubeArmorDaemon) GetAlreadyDeployedDockerContainers() error {
// check if Docker exists else instantiate
if Docker == nil {
var err error
Docker, err = NewDockerHandler()
if err != nil {
dm.Logger.Errf("Failed to create new Docker client: %s", err)
return err
}
}

Expand Down Expand Up @@ -455,6 +456,7 @@ func (dm *KubeArmorDaemon) GetAlreadyDeployedDockerContainers() {
} else {
dm.Logger.Warnf("Error while listing containers: %s", err)
}
return nil
}

// UpdateDockerContainer Function
Expand Down
16 changes: 12 additions & 4 deletions KubeArmor/core/kubeArmor.go
Original file line number Diff line number Diff line change
Expand Up @@ -621,7 +621,10 @@ func KubeArmor() {
// monitor containers
if strings.Contains(cfg.GlobalCfg.CRISocket, "docker") {
// update already deployed containers
dm.GetAlreadyDeployedDockerContainers()
err := dm.GetAlreadyDeployedDockerContainers()
if err != nil {
dm.DestroyKubeArmorDaemon()
}
// monitor docker events
go dm.MonitorDockerEvents()
} else if strings.Contains(cfg.GlobalCfg.CRISocket, "containerd") {
Expand Down Expand Up @@ -663,7 +666,10 @@ func KubeArmor() {
// monitor containers
if strings.Contains(dm.Node.ContainerRuntimeVersion, "docker") || strings.Contains(cfg.GlobalCfg.CRISocket, "docker") {
// update already deployed containers
dm.GetAlreadyDeployedDockerContainers()
err := dm.GetAlreadyDeployedDockerContainers()
if err != nil {
dm.DestroyKubeArmorDaemon()
}
// monitor docker events
go dm.MonitorDockerEvents()
} else if strings.Contains(dm.Node.ContainerRuntimeVersion, "containerd") || strings.Contains(cfg.GlobalCfg.CRISocket, "containerd") {
Expand Down Expand Up @@ -691,8 +697,10 @@ func KubeArmor() {
cfg.GlobalCfg.CRISocket = "unix://" + socketFile

// update already deployed containers
dm.GetAlreadyDeployedDockerContainers()

err := dm.GetAlreadyDeployedDockerContainers()
if err != nil {
dm.DestroyKubeArmorDaemon()
}
// monitor docker events
go dm.MonitorDockerEvents()
} else {
Expand Down

0 comments on commit fa1bdac

Please sign in to comment.