mirror of
https://github.com/komodorio/helm-dashboard.git
synced 2026-03-24 11:48:04 +00:00
* Object model with self-sufficient binary (#131) * Code cosmetics * Experimenting with object model and direct HELM usage * Experiment with object model * replacing the kubectl * Progressing * Save the progress * Able to start with migration in mind * Migrated two pieces * List releases via Helm * Forgotten field * Cristallized the problem of ctx switcher * Reworked to multi-context * Rollback is also new style * More migration * Refactoring * Describe via code * Bye-bye kubectl binary * Eliminate more old code * Refactor a bit * Merges * No binaries in dockerfile * Commit * Progress with getting the data * Learned the thing about get * One field less * Sstart with repos * Repo add * repo remove * Repos! Icons! * Simplified access to data * Ver listing works * Ver check works * Caching and values * fixup * Done with repos * Working on install * Install work-ish * Fix UI failing on install * Upgrade flow works * Fix image building * Remove outdated test file * Move files around * REfactorings * Cosmetics * Test for cache control (#151) * Files import formatted * Added go-test tools * Added test for no-cache header * added changes * test for cache behaviour of app * test for static route (#153) * Tests: route configuration & context setter (#154) * Test for route configuration * Test for context setter middleware * implemented changes * Restore coverage profile Fixes #156 * Cosmetics * Test for `NewRouter` function (#157) * Test for `configureScanners` (#158) * Test for `configureKubectls` (#163) * Test for repository loading (#169) - Created `repos_test.go` - Test: `Load()` of Repositories * Build all PRs * Fixes failing test (#171) * Fixes failing test - Fixes failing test of repo loading * handles error for * Did some changes * Test for listing of repos (#173) - and did some code formatting Signed-off-by: OmAxiani0 <aximaniom@gmail.com> Signed-off-by: OmAxiani0 <aximaniom@gmail.com> * Test for adding repo (#175) - Modified the `repositories.yml` file Signed-off-by: OmAxiani0 <aximaniom@gmail.com> Signed-off-by: OmAxiani0 <aximaniom@gmail.com> * Test for deleting the repository (#176) * Test for deleting the repository - Also added cleanup function for `TestAdd` * Fixes failing test * Add auto labeler for PR's (#174) * Add auto labeler for PR's * Add all file under .github/workflow to 'ci' label Co-authored-by: Harshit Mehta <harshitm@nvidia.com> * Test for getting repository (#177) * Add github workflow for auto PR labeling (#181) Co-authored-by: Harshit Mehta <harshitm@nvidia.com> * Stub compilation * Fixes around installing * More complex test * Using object model to execute helm test (#191) * Expand test * More test * Coverage * Add mutex for operations * Rectore cluster detection code * Change receiver to pointer * Support multiple namespaces * Cosmetics * Update repos periodically * fix tests * Fix error display * Allow reconfiguring chart without repo * mute linter * Cosmetics * Failing approach to parse manifests Relates to #30 * Report the error properly * ✅ Add test for dashboard/objects/data.go NewDataLayer (#199) * Fix problem of wrong namespace * Added unit tests for releases (#204) * Rework API routes (#197) * Bootstrap OpenAPI doc * Renaming some routes * Listing namespaces * k8s part of things * Repositories section * Document scanners API * One more API call * Progress * Reworked install flow * History endpoint * Textual info section * Resources endpoint * Rollback endpoint * Rollback endpoint * Unit tests * Cleanup * Forgotten tags * Fix tests * TODOs * Rework manifest scanning * add hasTests flag * Adding more information on UI for helm test API response (#195) * Hide test button when no tests Fixes #115 Improves #195 --------- Signed-off-by: OmAxiani0 <aximaniom@gmail.com> Co-authored-by: Om Aximani <75031769+OmAximani0@users.noreply.github.com> Co-authored-by: Harshit Mehta <hdm23061993@gmail.com> Co-authored-by: Harshit Mehta <harshitm@nvidia.com> Co-authored-by: Todd Turner <todd@toddtee.sh> Co-authored-by: arvindsundararajan98 <109727359+arvindsundararajan98@users.noreply.github.com>
172 lines
4.0 KiB
Go
172 lines
4.0 KiB
Go
package scanners
|
|
|
|
import (
|
|
"encoding/json"
|
|
"github.com/joomcode/errorx"
|
|
"github.com/komodorio/helm-dashboard/pkg/dashboard/objects"
|
|
"github.com/komodorio/helm-dashboard/pkg/dashboard/subproc"
|
|
"github.com/komodorio/helm-dashboard/pkg/dashboard/utils"
|
|
"github.com/olekukonko/tablewriter"
|
|
log "github.com/sirupsen/logrus"
|
|
v1 "k8s.io/apimachinery/pkg/apis/testapigroup/v1"
|
|
"strings"
|
|
)
|
|
|
|
type Checkov struct {
|
|
Data *objects.DataLayer
|
|
}
|
|
|
|
func (c *Checkov) ManifestIsScannable() bool {
|
|
return true
|
|
}
|
|
|
|
func (c *Checkov) SupportedResourceKinds() []string {
|
|
// from https://github.com/bridgecrewio/checkov//blob/master/docs/5.Policy%20Index/kubernetes.md
|
|
return []string{
|
|
"AdmissionConfiguration",
|
|
"ClusterRole",
|
|
"ClusterRoleBinding",
|
|
"ConfigMap",
|
|
"CronJob",
|
|
"DaemonSet",
|
|
"Deployment",
|
|
"DeploymentConfig",
|
|
"Ingress",
|
|
"Job",
|
|
"Pod",
|
|
"PodSecurityPolicy",
|
|
"PodTemplate",
|
|
"Policy",
|
|
"ReplicaSet",
|
|
"ReplicationController",
|
|
"Role",
|
|
"RoleBinding",
|
|
"Secret",
|
|
"Service",
|
|
"ServiceAccount",
|
|
"StatefulSet",
|
|
}
|
|
}
|
|
|
|
func (c *Checkov) Name() string {
|
|
return "Checkov"
|
|
}
|
|
|
|
func (c *Checkov) Test() bool {
|
|
utils.FailLogLevel = log.DebugLevel
|
|
defer func() { utils.FailLogLevel = log.WarnLevel }()
|
|
|
|
res, err := utils.RunCommand([]string{"checkov", "--version"}, nil)
|
|
if err != nil {
|
|
return false
|
|
}
|
|
log.Infof("Discovered Checkov version: %s", strings.TrimSpace(res))
|
|
return true
|
|
}
|
|
|
|
func (c *Checkov) ScanManifests(mnf string) (*subproc.ScanResults, error) {
|
|
fname, fclose, err := utils.TempFile(mnf)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
defer fclose()
|
|
|
|
cmd := []string{"checkov", "--quiet", "--soft-fail", "--framework", "kubernetes", "--output", "json", "--file", fname}
|
|
out, err := utils.RunCommand(cmd, nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
res := &subproc.ScanResults{}
|
|
|
|
err = json.Unmarshal([]byte(out), &res.OrigReport)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return res, nil
|
|
}
|
|
|
|
func (c *Checkov) ScanResource(ns string, kind string, name string) (*subproc.ScanResults, error) {
|
|
carp := v1.Carp{}
|
|
carp.Kind = kind
|
|
carp.Name = name
|
|
app, err := c.Data.AppForCtx(c.Data.KubeContext)
|
|
if err != nil {
|
|
return nil, errorx.Decorate(err, "failed to get app for context")
|
|
}
|
|
|
|
mnf, err := app.K8s.GetResourceYAML(kind, ns, name)
|
|
if err != nil {
|
|
return nil, errorx.Decorate(err, "failed to get YAML for resource")
|
|
}
|
|
|
|
fname, fclose, err := utils.TempFile(mnf)
|
|
if err != nil {
|
|
return nil, errorx.Decorate(err, "failed to create temporary file")
|
|
}
|
|
defer fclose()
|
|
|
|
cmd := []string{"checkov", "--quiet", "--soft-fail", "--framework", "kubernetes", "--output", "json", "--file", fname}
|
|
out, err := utils.RunCommand(cmd, nil)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
cr := CheckovReport{}
|
|
err = json.Unmarshal([]byte(out), &cr)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
res := &subproc.ScanResults{
|
|
PassedCount: cr.Summary.Passed,
|
|
FailedCount: cr.Summary.Failed,
|
|
OrigReport: checkovReportTable(&cr),
|
|
}
|
|
|
|
return res, nil
|
|
}
|
|
|
|
func checkovReportTable(c *CheckovReport) string {
|
|
data := [][]string{}
|
|
for _, item := range c.Results.FailedChecks {
|
|
data = append(data, []string{item.Id, item.Name + "\n", item.Guideline})
|
|
}
|
|
|
|
tableString := &strings.Builder{}
|
|
table := tablewriter.NewWriter(tableString)
|
|
table.SetHeader([]string{"ID", "Name", "Guideline"})
|
|
table.SetBorder(false)
|
|
table.SetColWidth(64)
|
|
table.AppendBulk(data)
|
|
table.Render()
|
|
return tableString.String()
|
|
}
|
|
|
|
type CheckovReport struct {
|
|
Summary CheckovSummary `json:"summary"`
|
|
Results CheckovResults `json:"results"`
|
|
}
|
|
|
|
type CheckovSummary struct {
|
|
Failed int `json:"failed"`
|
|
Passed int `json:"passed"`
|
|
ResourceCount int `json:"resource_count"`
|
|
// parsing errors?
|
|
// skipped ?
|
|
}
|
|
|
|
type CheckovResults struct {
|
|
FailedChecks []CheckovCheck `json:"failed_checks"`
|
|
}
|
|
|
|
type CheckovCheck struct {
|
|
Id string `json:"check_id"`
|
|
BcId string `json:"bc_check_id"`
|
|
Name string `json:"check_name"`
|
|
Resource string `json:"resource"`
|
|
Guideline string `json:"guideline"`
|
|
FileLineRange []int `json:"file_line_range"`
|
|
}
|