Skip to content

Commit

Permalink
Merge pull request #67 from anurag-rajawat/fix-ka-adapter
Browse files Browse the repository at this point in the history
fix(adapters): Update SwDeploymentTools KSP to include apk pkg manager
  • Loading branch information
anurag-rajawat authored Feb 21, 2024
2 parents e4dee8e + 237c9cd commit 3ef1c3b
Showing 1 changed file with 100 additions and 26 deletions.
126 changes: 100 additions & 26 deletions pkg/adapter/nimbus-kubearmor/processor/kspbuilder.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,13 +4,10 @@
package processor

import (
"io"
"net/http"
"strings"

"github.com/go-logr/logr"
kubearmorv1 "github.com/kubearmor/KubeArmor/pkg/KubeArmorController/api/security.kubearmor.com/v1"
"k8s.io/apimachinery/pkg/util/yaml"

v1 "github.com/5GSEC/nimbus/api/v1"
"github.com/5GSEC/nimbus/pkg/adapter/idpool"
Expand Down Expand Up @@ -83,31 +80,108 @@ func unAuthorizedSaTokenAccessKsp() kubearmorv1.KubeArmorPolicy {
}
}

// TODO: Instead of downloading the KSP build it locally
func swDeploymentToolsKsp() kubearmorv1.KubeArmorPolicy {
var ksp kubearmorv1.KubeArmorPolicy
fileUrl := "https://raw.githubusercontent.com/kubearmor/policy-templates/main/nist/system/ksp-nist-si-4-execute-package-management-process-in-container.yaml"
response, err := http.Get(fileUrl)

if err != nil {
return ksp
}
defer func() {
err = response.Body.Close()
if err != nil {
return
}
}()

data, err := io.ReadAll(response.Body)
if err != nil {
return ksp
return kubearmorv1.KubeArmorPolicy{
Spec: kubearmorv1.KubeArmorPolicySpec{
Process: kubearmorv1.ProcessType{
MatchPaths: []kubearmorv1.ProcessPathType{
{
Path: "/usr/bin/apt",
},
{
Path: "/usr/bin/apt-get",
},
{
Path: "/sbin/apk",
},
{
Path: "/bin/apt-get",
},
{
Path: "/bin/apt",
},
{
Path: "/usr/bin/dpkg",
},
{
Path: "/bin/dpkg",
},
{
Path: "/usr/bin/gdebi",
},
{
Path: "/bin/gdebi",
},
{
Path: "/usr/bin/make",
},
{
Path: "/bin/make",
},
{
Path: "/usr/bin/yum",
},
{
Path: "/bin/yum",
},
{
Path: "/usr/bin/rpm",
},
{
Path: "/bin/rpm",
},
{
Path: "/usr/bin/dnf",
},
{
Path: "/bin/dnf",
},
{
Path: "/usr/bin/pacman",
},
{
Path: "/usr/sbin/pacman",
},
{
Path: "/bin/pacman",
},
{
Path: "/sbin/pacman",
},
{
Path: "/usr/bin/makepkg",
},
{
Path: "/usr/sbin/makepkg",
},
{
Path: "/bin/makepkg",
},
{
Path: "/sbin/makepkg",
},
{
Path: "/usr/bin/yaourt",
},
{
Path: "/usr/sbin/yaourt",
},
{
Path: "/bin/yaourt",
},
{
Path: "/sbin/yaourt",
},
{
Path: "/usr/bin/zypper",
},
{
Path: "/bin/zypper",
},
},
},
},
}
_ = yaml.Unmarshal(data, &ksp)

// remove explicit action
ksp.Spec.Process.Action = ""
return ksp
}

func addManagedByAnnotation(ksp *kubearmorv1.KubeArmorPolicy) {
Expand Down

0 comments on commit 3ef1c3b

Please sign in to comment.