mirror of
https://github.com/kubescape/kubescape.git
synced 2026-04-15 06:58:11 +00:00
* Fix issue for scanning list obj * Fix go mod in httphandler pkg * Broken links fix in roadmap.md Planning, backlog, and wishlist links were not taking to the required section. * override infoMap only if it's not nil * improved icon of kubescape in readme * Support scanning several files * gramatical improvements * docs(readme): Star → star * Fix issues according to review * Handle with issues caused by updating opa-utils * Fix scanning ListObj following reviews * Update core/pkg/resourcehandler/filesloader.go Co-authored-by: Vlad Klokun <vladklokun@users.noreply.github.com> * Update completion.go * Added fixed control input * update go.mod * Print chart name log when fail to generate * Change formatting to %s * Added resource prioritization information, raw resource will be sent on the result object * Merging typo fixes from master (#772) * greetings * Update aws.sh simplified the comment * typo: In the title and h1 element Their was a typo in index.html file. * punctuation changes * docs : added gitpod badge in readme.md * fixed typos * some grammar mistake is corrected inPULL_REQUEST_TEMPLATE.md file * Updated README.md file Added link to CONTRIBUTING.md file in a line in README. * Added link to code of conduct file I have added link to the code of conduct file and fixed some problems in the Readme file. * Fixed readme * Added alpine tag Adding alpine tag instead of latest and removing repeating commands * roadmap.md file is modified * Automatically Close "Typo" labelled Issue * build.py is modified * modified PR template * Fixed some typos in feature_request.md "." at the end of the headings were missing and all the text were in same line. Now this gives a clear and concise view of the texts. * fixed the typo in docs/index.html Found and fixed typo in the 'alt' attribute of img tag * Update PULL_REQUEST_TEMPLATE.md Co-authored-by: Krishna Agarwal <dmkrishna.agarwal@gmail.com> Co-authored-by: Saswata Senapati <74651639+saswat16@users.noreply.github.com> Co-authored-by: Rahul Singh <110548934+rahuldhirendersingh@users.noreply.github.com> Co-authored-by: deepuyadav004 <deepuyadavze@gmail.com> Co-authored-by: kartik <97971066+kartikgajjar7@users.noreply.github.com> Co-authored-by: Rounak-28 <95576871+Rounak-28@users.noreply.github.com> Co-authored-by: pwnb0y <vickykr07@yahoo.com> Co-authored-by: Ben Hirschberg <59160382+slashben@users.noreply.github.com> Co-authored-by: Saptarshi Sarkar <saptarshi.programmer@gmail.com> Co-authored-by: Rahul Surwade <93492791+RahulSurwade08@users.noreply.github.com> Co-authored-by: Suhas Gumma <43647369+suhasgumma@users.noreply.github.com> Co-authored-by: Kamal Nayan <95926324+legendarykamal@users.noreply.github.com> Co-authored-by: TarangVerma <90996971+TarangVerma@users.noreply.github.com> Co-authored-by: avikittu <65793296+avikittu@users.noreply.github.com> * update logger version * update logger version (#773) * Fixed: Kubescape fails to authenticate remote private Github repo (#721) * grammar error fixer in CONTRIBUTING.md * scanning private git repository is available * giturl to gitapi * NO TOKEN error functionality added * Used GetToken method of giturl.IGitAPPI for auth Co-authored-by: satyam kale <satyamkale271@gmail.com> Co-authored-by: Ben Hirschberg <59160382+slashben@users.noreply.github.com> * bump opa-utils to 181 * Option to force enable color output (closes #560) (#767) * Option to force enable color output (closes #560) (cherry picked from commit 4f951781ee8dd6bb451ac7d159787f47e4b07379) * Update go.mod * update scanner image * Update host scanner image (#774) * update logger version * update scanner image * remove windows exe extension * Remove windows extension build (#775) * update logger version * update scanner image * remove windows exe extension * commened out prioritization logic * Edit Junit output (#802) * Edit Junit output * Update go sum * Following review * update AdoptClusterName * Print line separator only if some controls failed (#813) * removed the extra 'download' word from the example (#810) it was confusing to understand the download command because there was an extra 'download' mentioned * Prioritization (#815) * removed commented out code * Added attack tracks information to prioritization algorithm * bump opa-utils * go mod tidy * go mod tidy * CR changes * Issue 613 cluster name (#783) * added --clusterName flag (#613) Signed-off-by: Anubhav Gupta <mail.anubhav06@gmail.com> * update flag name to --cluster-name Signed-off-by: Anubhav Gupta <mail.anubhav06@gmail.com> Signed-off-by: Anubhav Gupta <mail.anubhav06@gmail.com> * Per 307 fail on severity counters (#831) * feat: fail on exceeding severity thresholds (#830) - Add support for severity counters - Add support for CLI flags that set severity thresholds - Terminate Kubescape with an exit code 1 if scan results exceed the severity thresholds * Update opa-utils pkg version Co-authored-by: Vlad Klokun <vladklokun@users.noreply.github.com> * Fix merge conflict * typo in .gitignore file (#833) * remove unsupported installation method * fixed welcome message * fixed merge * fixed attack tracks loading logic Signed-off-by: Anubhav Gupta <mail.anubhav06@gmail.com> Co-authored-by: Moshe-Rappaport-CA <moshep@armosec.io> Co-authored-by: Moshe Rappaport <89577611+Moshe-Rappaport-CA@users.noreply.github.com> Co-authored-by: Om Raut <33827410+om2137@users.noreply.github.com> Co-authored-by: Kamal Nayan <95926324+legendarykamal@users.noreply.github.com> Co-authored-by: Vlad Klokun <vladklokun@users.noreply.github.com> Co-authored-by: Chirag Arora <84070677+Chirag8023@users.noreply.github.com> Co-authored-by: shm12 <shmuelb@armosec.io> Co-authored-by: Amir Malka <amirm@armosec.io> Co-authored-by: Krishna Agarwal <dmkrishna.agarwal@gmail.com> Co-authored-by: Saswata Senapati <74651639+saswat16@users.noreply.github.com> Co-authored-by: Rahul Singh <110548934+rahuldhirendersingh@users.noreply.github.com> Co-authored-by: deepuyadav004 <deepuyadavze@gmail.com> Co-authored-by: kartik <97971066+kartikgajjar7@users.noreply.github.com> Co-authored-by: Rounak-28 <95576871+Rounak-28@users.noreply.github.com> Co-authored-by: pwnb0y <vickykr07@yahoo.com> Co-authored-by: Ben Hirschberg <59160382+slashben@users.noreply.github.com> Co-authored-by: Saptarshi Sarkar <saptarshi.programmer@gmail.com> Co-authored-by: Rahul Surwade <93492791+RahulSurwade08@users.noreply.github.com> Co-authored-by: Suhas Gumma <43647369+suhasgumma@users.noreply.github.com> Co-authored-by: TarangVerma <90996971+TarangVerma@users.noreply.github.com> Co-authored-by: avikittu <65793296+avikittu@users.noreply.github.com> Co-authored-by: satyam kale <satyamkale271@gmail.com> Co-authored-by: Aditya Pratap Singh <adityapratapsingh51@gmail.com> Co-authored-by: Ashray Shetty <ashrayshetty1999@gmail.com> Co-authored-by: Anubhav Gupta <mail.anubhav06@gmail.com> Co-authored-by: Meyazhagan <meyazhagan.ofcl@gmail.com>
140 lines
4.3 KiB
Go
140 lines
4.3 KiB
Go
package resourcesprioritization
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/kubescape/k8s-interface/workloadinterface"
|
|
"github.com/kubescape/kubescape/v2/core/cautils"
|
|
"github.com/kubescape/kubescape/v2/core/cautils/getter"
|
|
"github.com/kubescape/opa-utils/reporthandling/attacktrack/v1alpha1"
|
|
"github.com/kubescape/opa-utils/reporthandling/results/v1/prioritization"
|
|
)
|
|
|
|
type ResourcesPrioritizationHandler struct {
|
|
attackTracks []v1alpha1.IAttackTrack
|
|
}
|
|
|
|
func NewResourcesPrioritizationHandler(attackTracksGetter getter.IAttackTracksGetter) (*ResourcesPrioritizationHandler, error) {
|
|
handler := &ResourcesPrioritizationHandler{
|
|
attackTracks: make([]v1alpha1.IAttackTrack, 0),
|
|
}
|
|
|
|
if tracks, err := attackTracksGetter.GetAttackTracks(); err != nil {
|
|
return nil, err
|
|
} else {
|
|
for _, attackTrack := range tracks {
|
|
if !attackTrack.IsValid() {
|
|
return nil, fmt.Errorf("invalid attack track: %s", attackTrack.GetName())
|
|
}
|
|
|
|
t := attackTrack
|
|
handler.attackTracks = append(handler.attackTracks, &t)
|
|
}
|
|
}
|
|
|
|
if len(handler.attackTracks) == 0 {
|
|
return nil, fmt.Errorf("expected to find at least one attack track")
|
|
}
|
|
|
|
return handler, nil
|
|
}
|
|
|
|
func (handler *ResourcesPrioritizationHandler) PrioritizeResources(sessionObj *cautils.OPASessionObj) error {
|
|
if sessionObj.AllPolicies == nil {
|
|
return fmt.Errorf("expected to find policies map")
|
|
} else if len(sessionObj.AllPolicies.Controls) == 0 {
|
|
return fmt.Errorf("expected to find controls in policies map")
|
|
}
|
|
allControls := make(map[string]v1alpha1.IAttackTrackControl, len(sessionObj.AllPolicies.Controls))
|
|
for id := range sessionObj.AllPolicies.Controls {
|
|
ctrl := sessionObj.AllPolicies.Controls[id]
|
|
allControls[id] = &ctrl
|
|
}
|
|
|
|
for resourceId, result := range sessionObj.ResourcesResult {
|
|
resourcePriorityVector := []prioritization.ControlsVector{}
|
|
resource, exist := sessionObj.AllResources[resourceId]
|
|
if !exist {
|
|
return fmt.Errorf("expected to find resource id '%s' in scanned resources map", resourceId)
|
|
}
|
|
|
|
workload := workloadinterface.NewWorkloadObj(resource.GetObject())
|
|
|
|
if workload != nil && handler.isSupportedKind(workload) {
|
|
// build a map of attack track categories to a list of failed controls for the specific resource
|
|
failedControls := result.ListControlsIDs(nil).Failed()
|
|
if len(failedControls) > 0 {
|
|
|
|
controlsLookup := v1alpha1.NewAttackTrackControlsLookup(handler.attackTracks, failedControls, allControls)
|
|
replicaCount := workload.GetReplicas()
|
|
|
|
for _, attackTrack := range handler.attackTracks {
|
|
if !controlsLookup.HasAssociatedControls(attackTrack.GetName()) {
|
|
continue
|
|
}
|
|
|
|
// Load the failed controls into the attack track
|
|
allPathsHandler := v1alpha1.NewAttackTrackAllPathsHandler(attackTrack, &controlsLookup)
|
|
|
|
// Calculate all the paths for the attack track
|
|
allAttackPaths := allPathsHandler.CalculateAllPaths()
|
|
|
|
// Create priority vectors from every attack path
|
|
controlsVectors := prioritization.ControlsVectorFromAttackTrackPaths(attackTrack, allAttackPaths)
|
|
|
|
// Calculate the score and severity for every priority vector, and add it to the resource priority vector
|
|
for _, controlsVector := range controlsVectors {
|
|
if score, err := controlsVector.CalculateScore(allControls, replicaCount); err == nil {
|
|
controlsVector.SetScore(score)
|
|
} else {
|
|
return err
|
|
}
|
|
|
|
if severity, err := controlsVector.CalculateSeverity(allControls); err == nil {
|
|
controlsVector.SetSeverity(severity)
|
|
} else {
|
|
return err
|
|
}
|
|
|
|
resourcePriorityVector = append(resourcePriorityVector, controlsVector)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
// Resource priority vector is ready, add it to the session object
|
|
prioritizedResource := prioritization.PrioritizedResource{
|
|
ResourceID: resourceId,
|
|
PriorityVector: resourcePriorityVector,
|
|
}
|
|
|
|
prioritizedResource.SetSeverity(prioritizedResource.CalculateSeverity())
|
|
prioritizedResource.SetScore(prioritizedResource.CalculateScore())
|
|
|
|
if prioritizedResource.GetScore() == 0 {
|
|
continue
|
|
}
|
|
|
|
sessionObj.ResourcesPrioritized[resourceId] = prioritizedResource
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (handler *ResourcesPrioritizationHandler) isSupportedKind(obj workloadinterface.IMetadata) bool {
|
|
if obj != nil {
|
|
switch obj.GetKind() {
|
|
case "Deployment",
|
|
"Pod",
|
|
"ReplicaSet",
|
|
"Node",
|
|
"DaemonSet",
|
|
"StatefulSet",
|
|
"Job",
|
|
"CronJob":
|
|
return true
|
|
}
|
|
}
|
|
return false
|
|
}
|