From b98364d3e47a41b8258608e54642b6e50ad904e7 Mon Sep 17 00:00:00 2001 From: chenk Date: Wed, 27 Sep 2023 16:18:16 +0300 Subject: [PATCH] feat: add k8s cve collector (#239) --- .github/workflows/k8s.yml | 41 ++ .gitignore | 1 + create_pr.sh | 46 ++ go.mod | 4 + go.sum | 12 + k8s/k8s.go | 280 ++++++++++ k8s/k8s_test.go | 62 +++ k8s/mitre.go | 286 ++++++++++ k8s/mitre_test.go | 75 +++ k8s/parser.go | 140 +++++ k8s/parser_test.go | 47 ++ k8s/testdata/expected-vulndb.json | 1 + k8s/testdata/happy/upstream/CVE-2018-1002102 | 91 ++++ k8s/testdata/k8s-db.json | 535 +++++++++++++++++++ main.go | 7 +- osv/types.go | 17 +- 16 files changed, 1639 insertions(+), 6 deletions(-) create mode 100644 .github/workflows/k8s.yml create mode 100755 create_pr.sh create mode 100644 k8s/k8s.go create mode 100644 k8s/k8s_test.go create mode 100644 k8s/mitre.go create mode 100644 k8s/mitre_test.go create mode 100644 k8s/parser.go create mode 100644 k8s/parser_test.go create mode 100644 k8s/testdata/expected-vulndb.json create mode 100644 k8s/testdata/happy/upstream/CVE-2018-1002102 create mode 100644 k8s/testdata/k8s-db.json diff --git a/.github/workflows/k8s.yml b/.github/workflows/k8s.yml new file mode 100644 index 0000000..f0c65a8 --- /dev/null +++ b/.github/workflows/k8s.yml @@ -0,0 +1,41 @@ +name: Update vuln-list-k8s repo +on: + schedule: + - cron: "0 */6 * * *" + workflow_dispatch: + +jobs: + update: + name: Update vuln-list-k8s + runs-on: ubuntu-latest + env: + GITHUB_TOKEN: ${{ secrets.ACCESS_TOKEN }} + VULN_LIST_DIR: "vuln-list-k8s" + REPOSITORY_OWNER: ${{ github.repository_owner }} + steps: + - name: Check out code + uses: actions/checkout@v4 + + - name: Set up Go + uses: actions/setup-go@v4 + with: + go-version-file: go.mod + + - name: Check out vuln-list-k8s repo + uses: actions/checkout@v4 + with: + repository: ${{ env.REPOSITORY_OWNER }}/${{ env.VULN_LIST_DIR }} + token: ${{ secrets.ACCESS_TOKEN }} + path: ${{ env.VULN_LIST_DIR }} + + - name: Setup github user email and name + run: | + git config --global user.email "action@github.com" + git config --global user.name "GitHub Action" + + - name: Compile vuln-list-update + run: go build -o vuln-list-update . + + - if: always() + name: K8s official vulnerability advisory + run: ./create_pr.sh k8s \ No newline at end of file diff --git a/.gitignore b/.gitignore index fc99f47..59bf60f 100644 --- a/.gitignore +++ b/.gitignore @@ -16,3 +16,4 @@ vuln-list-update # MacOs .DS_Store +.vscode diff --git a/create_pr.sh b/create_pr.sh new file mode 100755 index 0000000..a7f0836 --- /dev/null +++ b/create_pr.sh @@ -0,0 +1,46 @@ +#!/bin/bash + +TARGET=$1 + +if [ -z "$TARGET" ]; then + echo "target required" + exit 1 +fi + +./vuln-list-update -vuln-list-dir "$VULN_LIST_DIR" -target "$TARGET" + +cd "$VULN_LIST_DIR" || exit 1 + +if [[ -n $(git status --porcelain) ]]; then + # List changed files + CHANGED_FILES=$(git ls-files . --exclude-standard --others | grep "CVE") + REPO="$REPOSITORY_OWNER/$VULN_LIST_DIR" + BASE_BRANCH="main" + # Loop through changed files and create PRs + for FILE in $CHANGED_FILES; do + + BRANCH_NAME=$(echo "$FILE" | tr / -) + PR_TITLE="Update $FILE" + PR_BODY="This PR updates $FILE" + + # Check if a PR with the same branch name already exists + OPEN_PR_COUNT=$(gh pr list --state open --base $BASE_BRANCH --repo "$REPO" | grep "$FILE" | wc -l) + + if [ "$OPEN_PR_COUNT" != 0 ]; then + echo "PR for $FILE already exists, skipping." + continue + fi + + # Create a new branch and push it + git checkout -b "$BRANCH_NAME" + echo "$FILE" + git add "$FILE" + git commit -m "Update $FILE" + + git push origin "$BRANCH_NAME" --force + # Create a new pull request using gh + gh pr create --base "$BASE_BRANCH" --head "$BRANCH_NAME" --title "$PR_TITLE" --body "$PR_BODY" --repo "$REPO" + + git checkout $BASE_BRANCH + done +fi diff --git a/go.mod b/go.mod index 550d938..d4695ad 100644 --- a/go.mod +++ b/go.mod @@ -4,9 +4,12 @@ go 1.20 require ( github.com/PuerkitoBio/goquery v1.8.0 + github.com/aquasecurity/go-pep440-version v0.0.0-20210121094942-22b2f8951d46 + github.com/aquasecurity/go-version v0.0.0-20210121072130-637058cfe492 github.com/araddon/dateparse v0.0.0-20190426192744-0d74ffceef83 github.com/cheggaaa/pb v2.0.7+incompatible github.com/cheggaaa/pb/v3 v3.1.4 + github.com/goark/go-cvss v1.6.6 github.com/hashicorp/go-getter v1.7.2 github.com/kylelemons/godebug v1.1.0 github.com/mattn/go-jsonpointer v0.0.1 @@ -35,6 +38,7 @@ require ( github.com/davecgh/go-spew v1.1.1 // indirect github.com/elazarl/goproxy v0.0.0-20190421051319-9d40249d3c2f // indirect github.com/fatih/color v1.15.0 // indirect + github.com/goark/errs v1.1.0 // indirect github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da // indirect github.com/golang/protobuf v1.5.3 // indirect github.com/google/go-cmp v0.5.9 // indirect diff --git a/go.sum b/go.sum index 9840317..6ffaec4 100644 --- a/go.sum +++ b/go.sum @@ -198,6 +198,10 @@ github.com/VividCortex/ewma v1.2.0/go.mod h1:nz4BbCtbLyFDeC9SUHbtcT5644juEuWfUAU github.com/andybalholm/cascadia v1.3.1 h1:nhxRkql1kdYCc8Snf7D5/D3spOX+dBgjA6u8x004T2c= github.com/andybalholm/cascadia v1.3.1/go.mod h1:R4bJ1UQfqADjvDa4P6HZHLh/3OxWWEqc0Sk8XGwHqvA= github.com/antihax/optional v1.0.0/go.mod h1:uupD/76wgC+ih3iEmQUL+0Ugr19nfwCT1kdvxnR2qWY= +github.com/aquasecurity/go-pep440-version v0.0.0-20210121094942-22b2f8951d46 h1:vmXNl+HDfqqXgr0uY1UgK1GAhps8nbAAtqHNBcgyf+4= +github.com/aquasecurity/go-pep440-version v0.0.0-20210121094942-22b2f8951d46/go.mod h1:olhPNdiiAAMiSujemd1O/sc6GcyePr23f/6uGKtthNg= +github.com/aquasecurity/go-version v0.0.0-20210121072130-637058cfe492 h1:rcEG5HI490FF0a7zuvxOxen52ddygCfNVjP0XOCMl+M= +github.com/aquasecurity/go-version v0.0.0-20210121072130-637058cfe492/go.mod h1:9Beu8XsUNNfzml7WBf3QmyPToP1wm1Gj/Vc5UJKqTzU= github.com/araddon/dateparse v0.0.0-20190426192744-0d74ffceef83 h1:ukTLOeMC0aVxbJWVg6hOsVJ0VPIo8w++PbNsze/pqF8= github.com/araddon/dateparse v0.0.0-20190426192744-0d74ffceef83/go.mod h1:SLqhdZcd+dF3TEVL2RMoob5bBP5R1P1qkox+HtCBgGI= github.com/aws/aws-sdk-go v1.44.122 h1:p6mw01WBaNpbdP2xrisz5tIkcNwzj/HysobNoaAHjgo= @@ -225,6 +229,7 @@ github.com/cncf/xds/go v0.0.0-20210805033703-aa0b78936158/go.mod h1:eXthEFrGJvWH github.com/cncf/xds/go v0.0.0-20210922020428-25de7278fc84/go.mod h1:eXthEFrGJvWHgFFCl3hGmgk+/aYT6PnTQLykKQRLhEs= github.com/cncf/xds/go v0.0.0-20211001041855-01bcc9b48dfe/go.mod h1:eXthEFrGJvWHgFFCl3hGmgk+/aYT6PnTQLykKQRLhEs= github.com/cncf/xds/go v0.0.0-20211011173535-cb28da3451f1/go.mod h1:eXthEFrGJvWHgFFCl3hGmgk+/aYT6PnTQLykKQRLhEs= +github.com/cpuguy83/go-md2man/v2 v2.0.0-20190314233015-f79a8a8ca69d/go.mod h1:maD7wRr/U5Z6m/iR4s+kqSMx2CaBsrgA7czyZG/E6dU= github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c= github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= @@ -247,6 +252,10 @@ github.com/ghodss/yaml v1.0.0/go.mod h1:4dBDuWmgqj2HViK6kFavaiC9ZROes6MMH2rRYeME github.com/go-gl/glfw v0.0.0-20190409004039-e6da0acd62b1/go.mod h1:vR7hzQXu2zJy9AVAgeJqvqgH9Q5CA+iKCZ2gyEVpxRU= github.com/go-gl/glfw/v3.3/glfw v0.0.0-20191125211704-12ad95a8df72/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8= github.com/go-gl/glfw/v3.3/glfw v0.0.0-20200222043503-6f7a984d4dc4/go.mod h1:tQ2UAYgL5IevRw8kRxooKSPJfGvJ9fJQFa0TUsXzTg8= +github.com/goark/errs v1.1.0 h1:FKnyw4LVyRADIjM8Nj0Up6r0/y5cfADvZAd1E+tthXE= +github.com/goark/errs v1.1.0/go.mod h1:TtaPEoadm2mzqzfXdkkfpN2xuniCFm2q4JH+c1qzaqw= +github.com/goark/go-cvss v1.6.6 h1:WJFuIWqmAw1Ilb9USv0vuX+nYzOWJp8lIujseJ/y3sU= +github.com/goark/go-cvss v1.6.6/go.mod h1:H3qbfUSUlV7XtA3EwWNunvXz6OySwWHOuO+R6ZPMQPI= github.com/golang/glog v0.0.0-20160126235308-23def4e6c14b/go.mod h1:SBH7ygxi8pfUlaOkMMuAQtPIUF8ecWP5IEl/CR7VP2Q= github.com/golang/groupcache v0.0.0-20190702054246-869f871628b6/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= github.com/golang/groupcache v0.0.0-20191227052852-215e87163ea7/go.mod h1:cIg4eruTrX1D+g88fzRXU5OdNfaM+9IcxsU14FzY7Hc= @@ -407,10 +416,12 @@ github.com/rivo/uniseg v0.2.0 h1:S1pD9weZBuJdFmowNwbpi7BJ8TNftyUImj/0WQi72jY= github.com/rivo/uniseg v0.2.0/go.mod h1:J6wj4VEh+S6ZtnVlnTBMWIodfgj8LQOQFoIToxlJtxc= github.com/rogpeppe/fastuuid v1.2.0/go.mod h1:jVj6XXZzXRy/MSR5jhDC/2q6DgLz+nrA6LYCDYWNEvQ= github.com/rogpeppe/go-internal v1.3.0/go.mod h1:M8bDsm7K2OlrFYOpmOWEs/qY81heoFRclV5y23lUDJ4= +github.com/russross/blackfriday/v2 v2.0.1/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM= github.com/shurcooL/githubv4 v0.0.0-20191127044304-8f68eb5628d0 h1:T9uus1QvcPgeLShS30YOnnzk3r9Vvygp45muhlrufgY= github.com/shurcooL/githubv4 v0.0.0-20191127044304-8f68eb5628d0/go.mod h1:hAF0iLZy4td2EX+/8Tw+4nodhlMrwN3HupfaXj3zkGo= github.com/shurcooL/graphql v0.0.0-20181231061246-d48a9a75455f h1:tygelZueB1EtXkPI6mQ4o9DQ0+FKW41hTbunoXZCTqk= github.com/shurcooL/graphql v0.0.0-20181231061246-d48a9a75455f/go.mod h1:AuYgA5Kyo4c7HfUmvRGs/6rGlMMV/6B1bVnB9JxJEEg= +github.com/shurcooL/sanitized_anchor_name v1.0.0/go.mod h1:1NzhyTcUVG4SuEtjjoZeVRXNmyL/1OwPU0+IJeTBvfc= github.com/simplereach/timeutils v1.2.0 h1:btgOAlu9RW6de2r2qQiONhjgxdAG7BL6je0G6J/yPnA= github.com/simplereach/timeutils v1.2.0/go.mod h1:VVbQDfN/FHRZa1LSqcwo4kNZ62OOyqLLGQKYB3pB0Q8= github.com/smartystreets/assertions v1.2.0 h1:42S6lae5dvLc7BrLu/0ugRtcFVjoJNMC/N3yZFZkDFs= @@ -434,6 +445,7 @@ github.com/stretchr/testify v1.8.4 h1:CcVxjf3Q8PM0mHUKJCdn+eZZtm5yQwehR5yeSVQQcU github.com/stretchr/testify v1.8.4/go.mod h1:sz/lmYIOXD/1dqDmKjjqLyZ2RngseejIcXlSw2iwfAo= github.com/ulikunitz/xz v0.5.10 h1:t92gobL9l3HE202wg3rlk19F6X+JOxl9BBrCCMYEYd8= github.com/ulikunitz/xz v0.5.10/go.mod h1:nbz6k7qbPmH4IRqmfOplQw/tblSgqTqBwxkY0oWt/14= +github.com/urfave/cli/v2 v2.3.0/go.mod h1:LJmUH05zAU44vOAcrfzZQKsZbVcdbOG8rtL3/XcUArI= github.com/yuin/goldmark v1.1.25/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= github.com/yuin/goldmark v1.1.32/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74= diff --git a/k8s/k8s.go b/k8s/k8s.go new file mode 100644 index 0000000..9cdff6a --- /dev/null +++ b/k8s/k8s.go @@ -0,0 +1,280 @@ +package k8s + +import ( + "encoding/json" + "errors" + "fmt" + "log" + "net/http" + "os" + "path/filepath" + "strings" + "time" + + "golang.org/x/xerrors" + + "github.com/aquasecurity/vuln-list-update/osv" + "github.com/aquasecurity/vuln-list-update/utils" + uu "github.com/aquasecurity/vuln-list-update/utils" +) + +const ( + k8svulnDBURL = "https://kubernetes.io/docs/reference/issues-security/official-cve-feed/index.json" + vulnListRepoTarBall = "https://api.github.com/repos/aquasecurity/vuln-list-k8s/tarball" + mitreURL = "https://cveawg.mitre.org/api/cve" + cveList = "https://www.cve.org/" +) + +type VulnDB struct { + Cves []*osv.OSV +} + +type CVE struct { + Items []Item `json:"items,omitempty"` +} + +type Item struct { + ID string `json:"id,omitempty"` + Summary string `json:"summary,omitempty"` + ContentText string `json:"content_text,omitempty"` + DatePublished string `json:"date_published,omitempty"` + ExternalURL string `json:"external_url,omitempty"` + URL string `json:"url,omitempty"` +} + +func Collect() (*VulnDB, error) { + response, err := http.Get(k8svulnDBURL) + if err != nil { + return nil, err + } + defer response.Body.Close() + var db CVE + if err = json.NewDecoder(response.Body).Decode(&db); err != nil { + return nil, err + } + cvesMap, err := getExitingCvesToModifiedMap() + if err != nil { + return nil, err + } + return ParseVulnDBData(db, cvesMap) +} + +const ( + // excludeNonCoreComponentsCves exclude cves with missing data or non k8s core components + excludeNonCoreComponentsCves = "CVE-2019-11255,CVE-2020-10749,CVE-2020-8554" +) + +func Update() error { + if err := update(); err != nil { + return xerrors.Errorf("error in k8s update: %w", err) + } + return nil +} + +func update() error { + log.Printf("Fetching k8s cves") + + k8sdb, err := Collect() + if err != nil { + return err + } + for _, cve := range k8sdb.Cves { + if err = uu.Write(filepath.Join(uu.VulnListDir(), "upstream", fmt.Sprintf("%s.json", cve.ID)), cve); err != nil { + return xerrors.Errorf("failed to save k8s CVE detail: %w", err) + } + } + + return nil +} + +func ParseVulnDBData(db CVE, cvesMap map[string]string) (*VulnDB, error) { + var fullVulnerabilities []*osv.OSV + for _, item := range db.Items { + for _, cveID := range getMultiIDs(item.ID) { + // check if the current cve is older than the existing one on the vuln-list-k8s repo + if strings.Contains(excludeNonCoreComponentsCves, item.ID) || olderCve(cveID, item.DatePublished, cvesMap) { + continue + } + vulnerability, err := parseMitreCve(item.ExternalURL, cveID) + if err != nil { + return nil, err + } + if cveMissingImportantData(vulnerability) { + continue + } + descComponent := getComponentFromDescription(item.ContentText, vulnerability.Package) + fullVulnerabilities = append(fullVulnerabilities, &osv.OSV{ + ID: cveID, + Modified: item.DatePublished, + Published: item.DatePublished, + Summary: item.Summary, + Details: vulnerability.Description, + Affected: getAffectedEvents(vulnerability.versions, getComponentName(descComponent, vulnerability.Package), vulnerability.CvssV3), + References: []osv.Reference{{Url: item.URL}, {Url: item.ExternalURL}}, + }) + } + } + err := validateCvesData(fullVulnerabilities) + if err != nil { + return nil, err + } + return &VulnDB{fullVulnerabilities}, nil +} + +func getAffectedEvents(v []*Version, p string, cvss Cvssv3) []osv.Affected { + affected := make([]osv.Affected, 0) + for _, av := range v { + if len(av.Introduced) == 0 { + continue + } + if av.Introduced == "0.0.0" { + av.Introduced = "0" + } + events := make([]osv.Event, 0) + ranges := make([]osv.Range, 0) + if len(av.Introduced) > 0 { + events = append(events, osv.Event{Introduced: av.Introduced}) + } + if len(av.Fixed) > 0 { + events = append(events, osv.Event{Fixed: av.Fixed}) + } else if len(av.LastAffected) > 0 { + events = append(events, osv.Event{LastAffected: av.LastAffected}) + } else if len(av.Introduced) > 0 && len(av.LastAffected) == 0 && len(av.Fixed) == 0 { + events = append(events, osv.Event{LastAffected: av.Introduced}) + } + ranges = append(ranges, osv.Range{ + Events: events, + }) + affected = append(affected, osv.Affected{Ranges: ranges, Package: osv.Package{Name: p, Ecosystem: "kubernetes"}, Severities: []osv.Severity{{Type: cvss.Type, Score: cvss.Vector}}}) + } + return affected +} + +func getComponentName(k8sComponent string, mitreComponent string) string { + if len(k8sComponent) == 0 { + k8sComponent = mitreComponent + } + if strings.ToLower(mitreComponent) != "kubernetes" { + k8sComponent = mitreComponent + } + return strings.ToLower(fmt.Sprintf("%s/%s", upstreamOrgByName(k8sComponent), upstreamRepoByName(k8sComponent))) +} + +func validateCvesData(cves []*osv.OSV) error { + var result error + for _, cve := range cves { + if len(cve.ID) == 0 { + result = errors.Join(result, fmt.Errorf("\nid is mssing on cve #%s", cve.ID)) + } + if len(cve.Published) == 0 { + result = errors.Join(result, fmt.Errorf("\nCreatedAt is mssing on cve #%s", cve.ID)) + } + if len(cve.Summary) == 0 { + result = errors.Join(result, fmt.Errorf("\nSummary is mssing on cve #%s", cve.ID)) + } + for _, af := range cve.Affected { + if len(strings.TrimPrefix(af.Package.Name, upstreamOrgByName(af.Package.Name))) == 0 { + result = errors.Join(result, fmt.Errorf("\nComponent is mssing on cve #%s", cve.ID)) + } + } + if len(cve.Details) == 0 { + result = errors.Join(result, fmt.Errorf("\nDescription is mssing on cve #%s", cve.ID)) + } + if len(cve.Affected) == 0 { + result = errors.Join(result, fmt.Errorf("\nAffected Version is missing on cve #%s", cve.ID)) + } + if len(cve.Affected) > 0 { + for _, v := range cve.Affected { + for _, s := range v.Severities { + if len(s.Type) == 0 { + result = errors.Join(result, fmt.Errorf("\nVector is mssing on cve #%s", cve.ID)) + } + } + for _, r := range v.Ranges { + for i := 1; i < len(r.Events); i++ { + if len(r.Events[i-1].Introduced) == 0 { + result = errors.Join(result, fmt.Errorf("\nAffectedVersion Introduced is missing from cve #%s", cve.ID)) + } + if len(r.Events[i].Fixed) == 0 && len(r.Events[i].LastAffected) == 0 { + result = errors.Join(result, fmt.Errorf("\nAffectedVersion Fixed and LastAffected are missing from cve #%s", cve.ID)) + } + } + } + } + } + if len(cve.References) == 0 { + result = errors.Join(result, fmt.Errorf("\nUrls is mssing on cve #%s", cve.ID)) + } + } + return result +} + +func cveMissingImportantData(vulnerability *Cve) bool { + return len(vulnerability.versions) == 0 || + len(vulnerability.Package) == 0 || + len(vulnerability.CvssV3.Vector) == 0 +} + +// getExitingCvesToModifiedMap get the existing cves from vuln-list-k8s repo and map it to cve id and last updated +func getExitingCvesToModifiedMap() (map[string]string, error) { + response, err := http.Get(vulnListRepoTarBall) + if err != nil { + return nil, err + } + defer response.Body.Close() + return cveIDToModifiedMap(utils.VulnListDir()) +} + +// cveIDToModifiedMap read existing cves from vulnList folder and map it to cve id and last updated +func cveIDToModifiedMap(cveFolderPath string) (map[string]string, error) { + mapCveTime := make(map[string]string) + if _, err := os.Stat(cveFolderPath); os.IsNotExist(err) { + return mapCveTime, nil + } + fileInfo, err := os.ReadDir(cveFolderPath) + if err != nil { + return mapCveTime, err + } + for _, file := range fileInfo { + if file.IsDir() { + continue + } + b, err := os.ReadFile(filepath.Join(cveFolderPath, file.Name())) + if err != nil { + return nil, err + } + var cve osv.OSV + err = json.Unmarshal([]byte(strings.ReplaceAll(string(b), "\n", "")), &cve) + if err != nil { + return nil, err + } + mapCveTime[cve.ID] = cve.Modified + } + return mapCveTime, nil +} + +// olderCve check if the current cve is older than the existing one +func olderCve(cveID string, currentCVEUpdated string, existCveLastUpdated map[string]string) bool { + if len(existCveLastUpdated) == 0 { + return false + } + var lastUpdated string + var ok bool + if lastUpdated, ok = existCveLastUpdated[cveID]; !ok { + return false + } + existLastUpdated, err := time.Parse(time.RFC3339, lastUpdated) + if err != nil { + return false + } + currentLastUpdated, err := time.Parse(time.RFC3339, currentCVEUpdated) + if err != nil { + return false + } + // check if the current collcted cve is older or same as the existing one + if currentLastUpdated.Before(existLastUpdated) || currentLastUpdated == existLastUpdated { + return true + } + + return false +} diff --git a/k8s/k8s_test.go b/k8s/k8s_test.go new file mode 100644 index 0000000..888a6c3 --- /dev/null +++ b/k8s/k8s_test.go @@ -0,0 +1,62 @@ +package k8s + +import ( + "encoding/json" + "os" + "testing" + + "github.com/stretchr/testify/assert" +) + +func Test_ParseVulneDB(t *testing.T) { + b, err := os.ReadFile("./testdata/k8s-db.json") + assert.NoError(t, err) + var bi CVE + err = json.Unmarshal(b, &bi) + assert.NoError(t, err) + kvd, err := ParseVulnDBData(bi, map[string]string{}) + assert.NoError(t, err) + err = validateCvesData(kvd.Cves) + assert.NoError(t, err) + gotVulnDB, err := json.Marshal(kvd.Cves) + assert.NoError(t, err) + wantVulnDB, err := os.ReadFile("./testdata/expected-vulndb.json") + assert.NoError(t, err) + assert.Equal(t, string(wantVulnDB), string(gotVulnDB)) +} + +func Test_cveIDToModifiedMap(t *testing.T) { + t.Run("valid folder with cve", func(t *testing.T) { + tm, err := cveIDToModifiedMap("./testdata/happy/upstream") + assert.NoError(t, err) + assert.Equal(t, tm["CVE-2018-1002102"], "2018-11-26T11:07:36Z") + }) + + t.Run("non existing folder", func(t *testing.T) { + tm, err := cveIDToModifiedMap("./test") + assert.NoError(t, err) + assert.True(t, len(tm) == 0) + }) +} + +func Test_OlderCve(t *testing.T) { + tests := []struct { + Name string + currentCveID string + currentModified string + cveModified map[string]string + want bool + }{ + {Name: "match CVE but older Modified", currentCveID: "CVE-2018-1002102", currentModified: "2018-11-25T11:07:36Z", cveModified: map[string]string{"CVE-2018-1002102": "2018-11-26T11:07:36Z"}, want: true}, + {Name: "match CVE but older not Modified", currentCveID: "CVE-2018-1002102", currentModified: "2018-11-27T11:07:36Z", cveModified: map[string]string{"CVE-2018-1002102": "2018-11-26T11:07:36Z"}, want: false}, + {Name: "match CVE same time", currentCveID: "CVE-2018-1002102", currentModified: "2018-11-27T11:07:36Z", cveModified: map[string]string{"CVE-2018-1002102": "2018-11-27T11:07:36Z"}, want: true}, + {Name: "no existing cve", currentCveID: "CVE-2018-1002102", currentModified: "2018-11-27T11:07:36Z", cveModified: map[string]string{}, want: false}, + } + for _, tt := range tests { + t.Run(tt.Name, func(t *testing.T) { + got := olderCve(tt.currentCveID, tt.currentModified, tt.cveModified) + assert.Equal(t, got, tt.want) + + }) + } +} diff --git a/k8s/mitre.go b/k8s/mitre.go new file mode 100644 index 0000000..493c15a --- /dev/null +++ b/k8s/mitre.go @@ -0,0 +1,286 @@ +package k8s + +import ( + "encoding/json" + "fmt" + "net/http" + "sort" + "strconv" + "strings" + + version "github.com/aquasecurity/go-version/pkg/version" +) + +type MitreCVE struct { + CveMetadata CveMetadata + Containers Containers +} + +type Containers struct { + Cna struct { + Affected []struct { + Product string + Vendor string + Versions []*MitreVersion + } + Descriptions []Descriptions + Metrics []struct { + CvssV3_1 struct { + VectorString string + } + CvssV3_0 struct { + VectorString string + } + } + } +} + +type MitreVersion struct { + Status string + Version string + LessThanOrEqual string + LessThan string + VersionType string +} + +type CveMetadata struct { + CveId string +} + +type Descriptions struct { + Lang string + Value string +} + +type Cve struct { + Description string + versions []*Version + CvssV3 Cvssv3 + Package string +} + +type Cvssv3 struct { + Vector string + Type string +} + +type Version struct { + Introduced string `json:"introduced,omitempty"` + Fixed string `json:"fixed,omitempty"` + LastAffected string `json:"last_affected,omitempty"` + FixedIndex int `json:"-"` +} + +func parseMitreCve(externalURL string, cveID string) (*Cve, error) { + if !strings.HasPrefix(externalURL, cveList) { + // if no external url provided, return empty vulnerability to be skipped + return &Cve{}, nil + } + response, err := http.Get(fmt.Sprintf("%s/%s", mitreURL, cveID)) + if err != nil { + return nil, err + } + defer response.Body.Close() + var cve MitreCVE + if err = json.NewDecoder(response.Body).Decode(&cve); err != nil { + return nil, err + } + vulnerableVersions := make([]*Version, 0) + var component string + var requireMerge bool + for _, a := range cve.Containers.Cna.Affected { + if len(component) == 0 { + component = strings.ToLower(a.Product) + } + for _, sv := range a.Versions { + if sv.Status != "affected" { + continue + } + var introduce, lastAffected, fixed string + v, ok := sanitizedVersions(sv) + if !ok { + continue + } + switch { + case len(v.LessThan) > 0: + if strings.HasSuffix(v.LessThan, ".0") { + v.Version = "0" + } + introduce, fixed = updateVersions(v.LessThan, v.Version) + case len(v.LessThanOrEqual) > 0: + introduce, lastAffected = updateVersions(v.LessThanOrEqual, v.Version) + case minorVersion(v.Version): + requireMerge = true + introduce = v.Version + default: + introduce, lastAffected = extractRangeVersions(v.Version) + } + vulnerableVersions = append(vulnerableVersions, &Version{ + Introduced: introduce, + Fixed: fixed, + LastAffected: lastAffected, + }) + } + } + if requireMerge { + vulnerableVersions, err = mergeVersionRange(vulnerableVersions) + if err != nil { + return nil, err + } + } + vector, vectorType := getMetrics(cve) + description := getDescription(cve.Containers.Cna.Descriptions) + return &Cve{ + Description: description, + CvssV3: Cvssv3{ + Vector: vector, + Type: vectorType, + }, + Package: getComponentFromDescription(description, component), + versions: vulnerableVersions, + }, nil +} + +func sanitizedVersions(v *MitreVersion) (*MitreVersion, bool) { + if strings.Contains(v.Version, "n/a") && len(v.LessThan) == 0 && len(v.LessThanOrEqual) == 0 { + return v, false + } + if (v.LessThanOrEqual == "unspecified" || v.LessThan == "unspecified") && len(v.Version) > 0 { + return v, false + } + // example https://cveawg.mitre.org/api/cve/CVE-2023-2727 + if len(v.LessThanOrEqual) > 0 && v.LessThanOrEqual == "<=" { + v.LessThanOrEqual = v.Version + } else if len(v.LessThan) > 0 { + switch { + // example https://cveawg.mitre.org/api/cve/CVE-2019-11244 + case strings.HasSuffix(strings.TrimSpace(v.LessThan), "*"): + v.Version = strings.TrimSpace(strings.ReplaceAll(v.LessThan, "*", "")) + v.LessThan = "" + } + } else if len(v.Version) > 0 { + switch { + // example https://cveawg.mitre.org/api/cve/CVE-2020-8566 + case strings.HasPrefix(v.Version, "< "): + v.LessThan = strings.TrimPrefix(v.Version, "< ") + // example https://cveawg.mitre.org/api/cve/CVE-2020-8565 + case strings.HasPrefix(v.Version, "<= "): + v.LessThanOrEqual = strings.TrimPrefix(v.Version, "<= ") + //example https://cveawg.mitre.org/api/cve/CVE-2019-11247 + case strings.HasPrefix(strings.TrimSpace(v.Version), "prior to"): + priorToVersion := strings.TrimSpace(strings.TrimPrefix(v.Version, "prior to")) + if minorVersion(priorToVersion) { + priorToVersion = priorToVersion + ".0" + v.Version = priorToVersion + } + v.LessThan = priorToVersion + // all version is vulnerable : https://cveawg.mitre.org/api/cve/CVE-2017-1002101 + case strings.HasSuffix(strings.TrimSpace(v.Version), ".x"): + v.Version = strings.TrimSpace(strings.ReplaceAll(v.Version, ".x", "")) + } + } + return &MitreVersion{ + Version: trimString(v.Version, []string{"v", "V"}), + LessThanOrEqual: trimString(v.LessThanOrEqual, []string{"v", "V"}), + LessThan: trimString(v.LessThan, []string{"v", "V"}), + }, true +} + +func getDescription(descriptions []Descriptions) string { + for _, d := range descriptions { + if d.Lang == "en" { + return d.Value + } + } + return "" +} + +type byVersion []*Version + +func (s byVersion) Len() int { + return len(s) +} + +func (s byVersion) Swap(i, j int) { + s[i], s[j] = s[j], s[i] +} + +func (s byVersion) Less(i, j int) bool { + v1, err := version.Parse(s[i].Introduced) + if err != nil { + return false + } + v2, err := version.Parse(s[j].Introduced) + if err != nil { + return false + } + return v1.LessThan(v2) +} + +func mergeVersionRange(affectedVersions []*Version) ([]*Version, error) { + // this special handling is made to handle to case of conceutive vulnable minor versions. + // example: vulnerable 1.3, 1.4, 1.5, 1.6 and prior to versions 1.7.14, 1.8.9 will be form as follow: + // Introduced: 1.3.0 Fixed: 1.7.14 + // Introduced: 1.8.0 Fixed: 1.8.9 + // example: https://cveawg.mitre.org/api/cve/CVE-2019-11249 + sort.Sort(byVersion(affectedVersions)) + newAffectedVesion := make([]*Version, 0) + minorVersions := make([]*Version, 0) + for _, av := range affectedVersions { + if minorVersion(av.Introduced) { + minorVersions = append(minorVersions, av) + } else if strings.Count(av.Introduced, ".") > 1 && len(minorVersions) > 0 { + newAffectedVesion = append(newAffectedVesion, &Version{ + Introduced: fmt.Sprintf("%s.0", minorVersions[0].Introduced), + LastAffected: av.LastAffected, + Fixed: av.Fixed, + }) + minorVersions = minorVersions[:0] + continue + } + if len(minorVersions) == 0 { + newAffectedVesion = append(newAffectedVesion, av) + } + } + + // this special handling is made to handle to case of consecutive vulnable minor versions, wheen there is no fixed version is provided. + // example: vulnerable 1.3, 1.4, 1.5, 1.6 will be form as follow: + // Introduced: 1.3.0 Fixed: 1.7.0 + if len(minorVersions) > 0 { + currentVersion := fmt.Sprintf("%s.0", minorVersions[len(minorVersions)-1].Introduced) + versionParts, err := versionParts(currentVersion) + if err != nil { + return nil, err + } + fixed := fmt.Sprintf("%d.%d.%d", versionParts[0], versionParts[1]+1, versionParts[2]) + newAffectedVesion = append(newAffectedVesion, &Version{Introduced: fmt.Sprintf("%s.0", minorVersions[0].Introduced), Fixed: fixed}) + } + return newAffectedVesion, nil +} + +func getMetrics(cve MitreCVE) (string, string) { + var vectorString string + var vectorType string + for _, metric := range cve.Containers.Cna.Metrics { + vectorString = metric.CvssV3_0.VectorString + vectorType = "CVSS_V3_0" + if len(vectorString) == 0 { + vectorString = metric.CvssV3_1.VectorString + vectorType = "CVSS_V3_1" + } + } + return vectorString, vectorType +} + +func versionParts(version string) ([]int, error) { + parts := strings.Split(version, ".") + intParts := make([]int, 0) + for _, p := range parts { + i, err := strconv.Atoi(p) + if err != nil { + return nil, err + } + intParts = append(intParts, i) + } + return intParts, nil +} diff --git a/k8s/mitre_test.go b/k8s/mitre_test.go new file mode 100644 index 0000000..54534c1 --- /dev/null +++ b/k8s/mitre_test.go @@ -0,0 +1,75 @@ +package k8s + +import ( + "testing" + + "github.com/stretchr/testify/assert" +) + +func TestSanitizedVersion(t *testing.T) { + tests := []struct { + Name string + Version *MitreVersion + Want *MitreVersion + }{ + {Name: "validate n/a version ", Version: &MitreVersion{Version: "n/a"}, Want: &MitreVersion{Version: "n/a"}}, + {Name: "validate unspecified version ", Version: &MitreVersion{Version: "unspecified"}, Want: &MitreVersion{Version: "unspecified"}}, + {Name: "validate less equal sign and version", Version: &MitreVersion{LessThanOrEqual: "<=", Version: "1.3.4"}, Want: &MitreVersion{Version: "1.3.4", LessThanOrEqual: "1.3.4"}}, + {Name: "validate less sign in version", Version: &MitreVersion{Version: "< 1.3.4"}, Want: &MitreVersion{Version: "< 1.3.4", LessThan: "1.3.4"}}, + {Name: "validate prior to then sign in version", Version: &MitreVersion{Version: "prior to 1.3.4"}, Want: &MitreVersion{Version: "prior to 1.3.4", LessThan: "1.3.4"}}, + {Name: "validate prior to with minor in version", Version: &MitreVersion{Version: "prior to 1.3"}, Want: &MitreVersion{Version: "1.3.0", LessThan: "1.3.0"}}, + {Name: "validate less with astrix", Version: &MitreVersion{LessThan: "1.3*"}, Want: &MitreVersion{Version: "1.3"}}, + {Name: "validate less with x", Version: &MitreVersion{Version: "1.3.x"}, Want: &MitreVersion{Version: "1.3"}}, + } + for _, tt := range tests { + t.Run(tt.Name, func(t *testing.T) { + got, _ := sanitizedVersions(tt.Version) + assert.Equal(t, got, tt.Want) + + }) + } +} + +func TestMergedVersion(t *testing.T) { + tests := []struct { + Name string + affectedVersions []*Version + WantAffectedVersions []*Version + }{ + {Name: "merge regular version", affectedVersions: []*Version{ + {Introduced: "1.2"}, + {Introduced: "1.3"}, + {Introduced: "1.4.1", LastAffected: "1.4.6"}, + }, WantAffectedVersions: []*Version{ + {Introduced: "1.2.0", LastAffected: "1.4.6"}}, + }, + {Name: "merge mixed version", affectedVersions: []*Version{ + {Introduced: "1.3"}, + {Introduced: "1.4"}, + {Introduced: "1.5"}, + {Introduced: "1.6"}, + {Introduced: "1.7.0", Fixed: "1.7.14"}, + {Introduced: "1.8.0", Fixed: "1.8.9"}, + }, WantAffectedVersions: []*Version{ + {Introduced: "1.3.0", Fixed: "1.7.14"}, + {Introduced: "1.8.0", Fixed: "1.8.9"}}, + }, + {Name: "merge all minor version", affectedVersions: []*Version{ + {Introduced: "1.3"}, + {Introduced: "1.4"}, + {Introduced: "1.5"}, + {Introduced: "1.6"}, + {Introduced: "1.7"}, + }, WantAffectedVersions: []*Version{ + {Introduced: "1.3.0", Fixed: "1.8.0"}, + }}, + } + for _, tt := range tests { + t.Run(tt.Name, func(t *testing.T) { + gotLastAffected, err := mergeVersionRange(tt.affectedVersions) + assert.NoError(t, err) + assert.Equal(t, gotLastAffected, tt.WantAffectedVersions) + + }) + } +} diff --git a/k8s/parser.go b/k8s/parser.go new file mode 100644 index 0000000..ca979cb --- /dev/null +++ b/k8s/parser.go @@ -0,0 +1,140 @@ +package k8s + +import ( + "fmt" + "strings" + + version "github.com/aquasecurity/go-version/pkg/version" +) + +var ( + UpstreamOrgName = map[string]string{ + "k8s.io": "controller-manager,kubelet,apiserver,kubectl,kubernetes,kube-scheduler,kube-proxy", + "sigs.k8s.io": "secrets-store-csi-driver", + } + + UpstreamRepoName = map[string]string{ + "kube-controller-manager": "controller-manager", + "kubelet": "kubelet", + "kube-apiserver": "apiserver", + "kubectl": "kubectl", + "kubernetes": "kubernetes", + "kube-scheduler": "kube-scheduler", + "kube-proxy": "kube-proxy", + "api server": "apiserver", + "secrets-store-csi-driver": "secrets-store-csi-driver", + } +) + +func trimString(s string, trimValues []string) string { + for _, v := range trimValues { + s = strings.Trim(s, v) + } + return strings.TrimSpace(s) +} + +func updateVersions(to, introduce string) (string, string) { + // Example: https://cveawg.mitre.org/api/cve/CVE-2023-2878 + if introduce == "0" { + return introduce, to + } + // Example: https://cveawg.mitre.org/api/cve/CVE-2019-11243 + if minorVersion(introduce) { + return introduce + ".0", to + } + // Example: https://cveawg.mitre.org/api/cve/CVE-2019-1002100 + if lIndex := strings.LastIndex(to, "."); lIndex != -1 { + return strings.TrimSpace(fmt.Sprintf("%s.%s", to[:lIndex], "0")), to + } + return introduce, to +} + +func extractRangeVersions(introduce string) (string, string) { + // Example https://cveawg.mitre.org/api/cve/CVE-2021-25749 + var lastAffected string + validVersion := make([]string, 0) + // clean unwanted strings from versions + versionRangeParts := strings.Split(introduce, " ") + for _, p := range versionRangeParts { + candidate, err := version.Parse(p) + if err != nil { + continue + } + validVersion = append(validVersion, candidate.String()) + } + if len(validVersion) >= 1 { + introduce = strings.TrimSpace(validVersion[0]) + } + if len(validVersion) == 2 { + lastAffected = strings.TrimSpace(validVersion[1]) + } + return introduce, lastAffected +} + +func getMultiIDs(id string) []string { + var idsList []string + if strings.Contains(id, ",") { + idParts := strings.Split(id, ",") + for _, p := range idParts { + if strings.HasPrefix(strings.TrimSpace(p), "CVE-") { + idsList = append(idsList, strings.TrimSpace(p)) + } + } + return idsList + } + return []string{id} +} + +func upstreamOrgByName(component string) string { + for key, components := range UpstreamOrgName { + for _, c := range strings.Split(components, ",") { + if strings.TrimSpace(c) == strings.ToLower(component) { + return key + } + } + } + return "" +} + +func upstreamRepoByName(component string) string { + if val, ok := UpstreamRepoName[component]; ok { + return val + } + return component +} + +func getComponentFromDescription(descriptions string, currentComponent string) string { + if strings.ToLower(currentComponent) != "kubernetes" { + return currentComponent + } + var compName string + var compCounter int + var kubeCtlVersionFound bool + CoreComponentsNaming := []string{"kube-controller-manager", "kubelet", "kube-apiserver", "kubectl", "kube-scheduler", "kube-proxy", "secrets-store-csi-driver", "api server"} + + for _, key := range CoreComponentsNaming { + if strings.Contains(strings.ToLower(descriptions), key) { + c := strings.Count(strings.ToLower(descriptions), key) + if UpstreamRepoName[key] == compName { + compCounter = compCounter + c + } + if strings.Contains(strings.ToLower(descriptions), "kubectl version") { + kubeCtlVersionFound = true + } + if c > compCounter { + compCounter = c + compName = UpstreamRepoName[key] + } + } + } + // in case found kubectl in env description and only one component found or no component found then fallback to k8s.io/kubernetes component + if len(compName) == 0 || (kubeCtlVersionFound && compName == "kubectl" && compCounter == 1) { + return currentComponent + } + return compName +} + +// MinorVersion returns true if version is minor version 1.1 or 2.2 and etc +func minorVersion(version string) bool { + return strings.Count(version, ".") == 1 +} diff --git a/k8s/parser_test.go b/k8s/parser_test.go new file mode 100644 index 0000000..446003b --- /dev/null +++ b/k8s/parser_test.go @@ -0,0 +1,47 @@ +package k8s + +import ( + "testing" + + "github.com/stretchr/testify/assert" +) + +func Test_ExtractVersions(t *testing.T) { + tests := []struct { + name string + version string + less string + wantIntroduce string + wantLastAffected string + }{ + {name: "range less with minor", version: "1.2", less: "1.2.5", wantIntroduce: "1.2.0", wantLastAffected: "1.2.5"}, + {name: "range less", version: "", less: "1.2.5", wantIntroduce: "1.2.0", wantLastAffected: "1.2.5"}, + {name: "range lessThen", version: "", less: "1.2.5", wantIntroduce: "1.2.0", wantLastAffected: "1.2.5"}, + } + for _, tt := range tests { + t.Run(tt.name, func(t *testing.T) { + gotIntoduce, gotLastAffected := updateVersions(tt.less, tt.version) + assert.Equal(t, gotIntoduce, tt.wantIntroduce) + assert.Equal(t, gotLastAffected, tt.wantLastAffected) + }) + } +} + +func Test_ExtractRangeVersions(t *testing.T) { + tests := []struct { + name string + version string + wantIntroduce string + wantLastAffected string + }{ + {name: "range versions", version: "1.2.3 - 1.2.5", wantIntroduce: "1.2.3", wantLastAffected: "1.2.5"}, + {name: "single versions", version: "1.2.5", wantIntroduce: "1.2.5", wantLastAffected: ""}, + } + for _, tt := range tests { + t.Run(tt.name, func(t *testing.T) { + gotIntoduce, gotLastAffected := extractRangeVersions(tt.version) + assert.Equal(t, gotIntoduce, tt.wantIntroduce) + assert.Equal(t, gotLastAffected, tt.wantLastAffected) + }) + } +} diff --git a/k8s/testdata/expected-vulndb.json b/k8s/testdata/expected-vulndb.json new file mode 100644 index 0000000..bbfd76a --- /dev/null +++ b/k8s/testdata/expected-vulndb.json @@ -0,0 +1 @@ +[{"id":"CVE-2023-2431","modified":"2023-06-15T14:42:32Z","published":"2023-06-15T14:42:32Z","summary":"Bypass of seccomp profile enforcement ","details":"A security issue was discovered in Kubelet that allows pods to bypass the seccomp profile enforcement. Pods that use localhost type for seccomp profile but specify an empty profile field, are affected by this issue. In this scenario, this vulnerability allows the pod to run in unconfined (seccomp disabled) mode. This bug affects Kubelet.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:L/AC:L/PR:H/UI:N/S:U/C:L/I:L/A:N"}],"ranges":[{"events":[{"introduced":"0"},{"fixed":"1.24.14"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:L/AC:L/PR:H/UI:N/S:U/C:L/I:L/A:N"}],"ranges":[{"events":[{"introduced":"1.25.0"},{"fixed":"1.25.9"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:L/AC:L/PR:H/UI:N/S:U/C:L/I:L/A:N"}],"ranges":[{"events":[{"introduced":"1.26.0"},{"fixed":"1.26.4"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:L/AC:L/PR:H/UI:N/S:U/C:L/I:L/A:N"}],"ranges":[{"events":[{"introduced":"1.27.0"},{"fixed":"1.27.1"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/118690"},{"url":"https://www.cve.org/cverecord?id=CVE-2023-2431"}]},{"id":"CVE-2023-2727","modified":"2023-06-13T14:42:06Z","published":"2023-06-13T14:42:06Z","summary":"Bypassing policies imposed by the ImagePolicyWebhook and bypassing mountable secrets policy imposed by the ServiceAccount admission plugin","details":"Users may be able to launch containers using images that are restricted by ImagePolicyWebhook when using ephemeral containers. Kubernetes clusters are only affected if the ImagePolicyWebhook admission plugin is used together with ephemeral containers.\n\n","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:H/I:H/A:N"}],"ranges":[{"events":[{"introduced":"1.24.0"},{"last_affected":"1.24.14"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:H/I:H/A:N"}],"ranges":[{"events":[{"introduced":"1.25.0"},{"last_affected":"1.25.10"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:H/I:H/A:N"}],"ranges":[{"events":[{"introduced":"1.26.0"},{"last_affected":"1.26.5"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:H/I:H/A:N"}],"ranges":[{"events":[{"introduced":"1.27.0"},{"last_affected":"1.27.2"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/118640"},{"url":"https://www.cve.org/cverecord?id=CVE-2023-2727, CVE-2023-2728"}]},{"id":"CVE-2023-2728","modified":"2023-06-13T14:42:06Z","published":"2023-06-13T14:42:06Z","summary":"Bypassing policies imposed by the ImagePolicyWebhook and bypassing mountable secrets policy imposed by the ServiceAccount admission plugin","details":"Users may be able to launch containers that bypass the mountable secrets policy enforced by the ServiceAccount admission plugin when using ephemeral containers. The policy ensures pods running with a service account may only reference secrets specified in the service account’s secrets field. Kubernetes clusters are only affected if the ServiceAccount admission plugin and the `kubernetes.io/enforce-mountable-secrets` annotation are used together with ephemeral containers.\n\n","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:H/I:H/A:N"}],"ranges":[{"events":[{"introduced":"1.24.0"},{"last_affected":"1.24.14"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:H/I:H/A:N"}],"ranges":[{"events":[{"introduced":"1.25.0"},{"last_affected":"1.25.10"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:H/I:H/A:N"}],"ranges":[{"events":[{"introduced":"1.26.0"},{"last_affected":"1.26.5"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:H/I:H/A:N"}],"ranges":[{"events":[{"introduced":"1.27.0"},{"last_affected":"1.27.2"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/118640"},{"url":"https://www.cve.org/cverecord?id=CVE-2023-2727, CVE-2023-2728"}]},{"id":"CVE-2023-2878","modified":"2023-06-02T19:03:54Z","published":"2023-06-02T19:03:54Z","summary":"secrets-store-csi-driver discloses service account tokens in logs","details":"Kubernetes secrets-store-csi-driver in versions before 1.3.3 discloses service account tokens in logs.\n","affected":[{"package":{"ecosystem":"kubernetes","name":"sigs.k8s.io/secrets-store-csi-driver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:C/C:H/I:N/A:N"}],"ranges":[{"events":[{"introduced":"0"},{"fixed":"1.3.3"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/118419"},{"url":"https://www.cve.org/cverecord?id=CVE-2023-2878"}]},{"id":"CVE-2022-3294","modified":"2022-11-08T21:33:26Z","published":"2022-11-08T21:33:26Z","summary":"Node address isn't always verified when proxying","details":"Users may have access to secure endpoints in the control plane network. Kubernetes clusters are only affected if an untrusted user can modify Node objects and send proxy requests to them. Kubernetes supports node proxying, which allows clients of kube-apiserver to access endpoints of a Kubelet to establish connections to Pods, retrieve container logs, and more. While Kubernetes already validates the proxying address for Nodes, a bug in kube-apiserver made it possible to bypass this validation. Bypassing this validation could allow authenticated requests destined for Nodes to to the API server's private network.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:H/PR:H/UI:N/S:U/C:H/I:H/A:H"}],"ranges":[{"events":[{"introduced":"1.25.0"},{"last_affected":"1.25.3"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:H/PR:H/UI:N/S:U/C:H/I:H/A:H"}],"ranges":[{"events":[{"introduced":"1.24.0"},{"last_affected":"1.24.7"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:H/PR:H/UI:N/S:U/C:H/I:H/A:H"}],"ranges":[{"events":[{"introduced":"1.23.0"},{"last_affected":"1.23.13"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:H/PR:H/UI:N/S:U/C:H/I:H/A:H"}],"ranges":[{"events":[{"introduced":"1.22.0"},{"last_affected":"1.22.15"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/113757"},{"url":"https://www.cve.org/cverecord?id=CVE-2022-3294"}]},{"id":"CVE-2022-3162","modified":"2022-11-08T21:33:07Z","published":"2022-11-08T21:33:07Z","summary":"Unauthorized read of Custom Resources","details":"Users authorized to list or watch one type of namespaced custom resource cluster-wide can read custom resources of a different type in the same API group without authorization. Clusters are impacted by this vulnerability if all of the following are true: 1. There are 2+ CustomResourceDefinitions sharing the same API group 2. Users have cluster-wide list or watch authorization on one of those custom resources. 3. The same users are not authorized to read another custom resource in the same API group.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.25.0"},{"last_affected":"1.25.3"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.24.0"},{"last_affected":"1.24.7"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.23.0"},{"last_affected":"1.23.13"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.22.0"},{"last_affected":"1.22.15"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/113756"},{"url":"https://www.cve.org/cverecord?id=CVE-2022-3162"}]},{"id":"CVE-2021-25749","modified":"2022-09-01T21:02:01Z","published":"2022-09-01T21:02:01Z","summary":"`runAsNonRoot` logic bypass for Windows containers","details":"Windows workloads can run as ContainerAdministrator even when those workloads set the runAsNonRoot option to true.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H"}],"ranges":[{"events":[{"introduced":"1.22.0"},{"fixed":"1.22.14"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H"}],"ranges":[{"events":[{"introduced":"1.23.0"},{"fixed":"1.23.11"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H"}],"ranges":[{"events":[{"introduced":"1.24.0"},{"fixed":"1.24.5"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/112192"},{"url":"https://www.cve.org/cverecord?id=CVE-2021-25749"}]},{"id":"CVE-2021-25741","modified":"2021-09-13T20:58:56Z","published":"2021-09-13T20:58:56Z","summary":"Symlink Exchange Can Allow Host Filesystem Access","details":"A security issue was discovered in Kubernetes where a user may be able to create a container with subpath volume mounts to access files \u0026 directories outside of the volume, including on the host filesystem.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H"}],"ranges":[{"events":[{"introduced":"1.19.0"},{"last_affected":"1.19.14"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H"}],"ranges":[{"events":[{"introduced":"1.20.0"},{"last_affected":"1.20.10"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H"}],"ranges":[{"events":[{"introduced":"1.21.0"},{"last_affected":"1.21.4"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H"}],"ranges":[{"events":[{"introduced":"1.22.0"},{"last_affected":"1.22.1"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/104980"},{"url":"https://www.cve.org/cverecord?id=CVE-2021-25741"}]},{"id":"CVE-2021-25737","modified":"2021-05-18T19:14:27Z","published":"2021-05-18T19:14:27Z","summary":"Holes in EndpointSlice Validation Enable Host Network Hijack","details":"A security issue was discovered in Kubernetes where a user may be able to redirect pod traffic to private networks on a Node. Kubernetes already prevents creation of Endpoint IPs in the localhost or link-local range, but the same validation was not performed on EndpointSlice IPs.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:L/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.18.0"},{"last_affected":"1.18.18"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:L/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.19.0"},{"last_affected":"1.19.10"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:L/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.20.0"},{"last_affected":"1.20.6"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:L/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.21.0"},{"last_affected":"1.21.0"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/102106"},{"url":"https://www.cve.org/cverecord?id=CVE-2021-25737"}]},{"id":"CVE-2021-25735","modified":"2021-03-10T18:18:01Z","published":"2021-03-10T18:18:01Z","summary":"Validating Admission Webhook does not observe some previous fields","details":"A security issue was discovered in kube-apiserver that could allow node updates to bypass a Validating Admission Webhook. Clusters are only affected by this vulnerability if they run a Validating Admission Webhook for Nodes that denies admission based at least partially on the old state of the Node object. Validating Admission Webhook does not observe some previous fields.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:N/I:H/A:H"}],"ranges":[{"events":[{"introduced":"1.18.0"},{"last_affected":"1.18.17"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:N/I:H/A:H"}],"ranges":[{"events":[{"introduced":"1.19.0"},{"last_affected":"1.19.9"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:N/I:H/A:H"}],"ranges":[{"events":[{"introduced":"1.20.0"},{"last_affected":"1.20.5"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/100096"},{"url":"https://www.cve.org/cverecord?id=CVE-2021-25735"}]},{"id":"CVE-2020-8566","modified":"2020-10-15T22:07:53Z","published":"2020-10-15T22:07:53Z","summary":"Ceph RBD adminSecrets exposed in logs when loglevel \u003e= 4","details":"In Kubernetes clusters using Ceph RBD as a storage provisioner, with logging level of at least 4, Ceph RBD admin secrets can be written to logs. This occurs in kube-controller-manager's logs during provisioning of Ceph RBD persistent claims. This affects \u003c v1.19.3, \u003c v1.18.10, \u003c v1.17.13.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/controller-manager"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:L/AC:H/PR:L/UI:N/S:U/C:H/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.19.0"},{"fixed":"1.19.3"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/controller-manager"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:L/AC:H/PR:L/UI:N/S:U/C:H/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.18.0"},{"fixed":"1.18.10"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/controller-manager"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:L/AC:H/PR:L/UI:N/S:U/C:H/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.17.0"},{"fixed":"1.17.13"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/95624"},{"url":"https://www.cve.org/cverecord?id=CVE-2020-8566"}]},{"id":"CVE-2020-8565","modified":"2020-10-15T22:05:32Z","published":"2020-10-15T22:05:32Z","summary":"Incomplete fix for CVE-2019-11250 allows for token leak in logs when logLevel \u003e= 9","details":"In Kubernetes, if the logging level is set to at least 9, authorization and bearer tokens will be written to log files. This can occur both in API server logs and client tool output like kubectl. This affects \u003c= v1.19.3, \u003c= v1.18.10, \u003c= v1.17.13, \u003c v1.20.0-alpha2.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubectl"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:L/AC:H/PR:L/UI:N/S:U/C:H/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.19.0"},{"last_affected":"1.19.3"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubectl"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:L/AC:H/PR:L/UI:N/S:U/C:H/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.18.0"},{"last_affected":"1.18.10"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubectl"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:L/AC:H/PR:L/UI:N/S:U/C:H/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.17.0"},{"last_affected":"1.17.13"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubectl"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:L/AC:H/PR:L/UI:N/S:U/C:H/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.20.0"},{"fixed":"1.20.0-alpha2"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/95623"},{"url":"https://www.cve.org/cverecord?id=CVE-2020-8565"}]},{"id":"CVE-2020-8564","modified":"2020-10-15T22:03:19Z","published":"2020-10-15T22:03:19Z","summary":"Docker config secrets leaked when file is malformed and log level \u003e= 4","details":"In Kubernetes clusters using a logging level of at least 4, processing a malformed docker config file will result in the contents of the docker config file being leaked, which can include pull secrets or other registry credentials. This affects \u003c v1.19.3, \u003c v1.18.10, \u003c v1.17.13.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubernetes"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:L/AC:H/PR:L/UI:N/S:U/C:H/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.19.0"},{"fixed":"1.19.3"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubernetes"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:L/AC:H/PR:L/UI:N/S:U/C:H/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.18.0"},{"fixed":"1.18.10"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubernetes"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:L/AC:H/PR:L/UI:N/S:U/C:H/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.17.0"},{"fixed":"1.17.13"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/95622"},{"url":"https://www.cve.org/cverecord?id=CVE-2020-8564"}]},{"id":"CVE-2020-8563","modified":"2020-10-15T22:00:44Z","published":"2020-10-15T22:00:44Z","summary":"Secret leaks in kube-controller-manager when using vSphere provider","details":"In Kubernetes clusters using VSphere as a cloud provider, with a logging level set to 4 or above, VSphere cloud credentials will be leaked in the cloud controller manager's log. This affects \u003c v1.19.3.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/controller-manager"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:L/AC:H/PR:L/UI:N/S:U/C:H/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.19.0"},{"fixed":"1.19.3"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/95621"},{"url":"https://www.cve.org/cverecord?id=CVE-2020-8563"}]},{"id":"CVE-2020-8557","modified":"2020-07-13T18:39:08Z","published":"2020-07-13T18:39:08Z","summary":"Node disk DOS by writing to container /etc/hosts","details":"The Kubernetes kubelet component in versions 1.1-1.16.12, 1.17.0-1.17.8 and 1.18.0-1.18.5 do not account for disk usage by a pod which writes to its own /etc/hosts file. The /etc/hosts file mounted in a pod by kubelet is not included by the kubelet eviction manager when calculating ephemeral storage usage by a pod. If a pod writes a large amount of data to the /etc/hosts file, it could fill the storage space of the node and cause the node to fail.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H"}],"ranges":[{"events":[{"introduced":"1.1.0"},{"fixed":"1.16.13"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H"}],"ranges":[{"events":[{"introduced":"1.17.0"},{"fixed":"1.17.9"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H"}],"ranges":[{"events":[{"introduced":"1.18.0"},{"fixed":"1.18.6"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/93032"},{"url":"https://www.cve.org/cverecord?id=CVE-2020-8557"}]},{"id":"CVE-2020-8559","modified":"2020-07-08T17:03:16Z","published":"2020-07-08T17:03:16Z","summary":"Privilege escalation from compromised node to cluster","details":"The Kubernetes kube-apiserver in versions v1.6-v1.15, and versions prior to v1.16.13, v1.17.9 and v1.18.6 are vulnerable to an unvalidated redirect on proxied upgrade requests that could allow an attacker to escalate privileges from a node compromise to a full cluster compromise.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:H/PR:H/UI:R/S:U/C:H/I:H/A:H"}],"ranges":[{"events":[{"introduced":"1.6.0"},{"last_affected":"1.16.12"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:H/PR:H/UI:R/S:U/C:H/I:H/A:H"}],"ranges":[{"events":[{"introduced":"1.17.0"},{"last_affected":"1.17.8"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:H/PR:H/UI:R/S:U/C:H/I:H/A:H"}],"ranges":[{"events":[{"introduced":"1.18.0"},{"last_affected":"1.18.5"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/92914"},{"url":"https://www.cve.org/cverecord?id=CVE-2020-8559"}]},{"id":"CVE-2020-8558","modified":"2020-06-19T18:38:58Z","published":"2020-06-19T18:38:58Z","summary":"Node setting allows for neighboring hosts to bypass localhost boundary","details":"The Kubelet and kube-proxy components in versions 1.1.0-1.16.10, 1.17.0-1.17.6, and 1.18.0-1.18.3 were found to contain a security issue which allows adjacent hosts to reach TCP and UDP services bound to 127.0.0.1 running on the node or in the node's network namespace. Such a service is generally thought to be reachable only by other processes on the same host, but due to this defeect, could be reachable by other hosts on the same LAN as the node, or by containers running on the same node as the service.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:A/AC:L/PR:N/UI:N/S:U/C:L/I:L/A:N"}],"ranges":[{"events":[{"introduced":"1.1.0"},{"fixed":"1.16.11"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:A/AC:L/PR:N/UI:N/S:U/C:L/I:L/A:N"}],"ranges":[{"events":[{"introduced":"1.17.0"},{"fixed":"1.17.7"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:A/AC:L/PR:N/UI:N/S:U/C:L/I:L/A:N"}],"ranges":[{"events":[{"introduced":"1.18.0"},{"fixed":"1.18.4"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/92315"},{"url":"https://www.cve.org/cverecord?id=CVE-2020-8558"}]},{"id":"CVE-2020-8555","modified":"2020-05-28T16:13:34Z","published":"2020-05-28T16:13:34Z","summary":"Half-Blind SSRF in kube-controller-manager","details":"The Kubernetes kube-controller-manager in versions v1.0-1.14, versions prior to v1.15.12, v1.16.9, v1.17.5, and version v1.18.0 are vulnerable to a Server Side Request Forgery (SSRF) that allows certain authorized users to leak up to 500 bytes of arbitrary information from unprotected endpoints within the master's host network (such as link-local or loopback services).","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/controller-manager"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:C/C:H/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.1.0"},{"fixed":"1.15.12"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/controller-manager"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:C/C:H/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.16.0"},{"fixed":"1.16.9"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/controller-manager"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:C/C:H/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.17.0"},{"fixed":"1.17.5"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/controller-manager"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:C/C:H/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.18.0"},{"last_affected":"1.18.0"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/91542"},{"url":"https://www.cve.org/cverecord?id=CVE-2020-8555"}]},{"id":"CVE-2019-11254","modified":"2020-03-26T18:55:26Z","published":"2020-03-26T18:55:26Z","summary":"kube-apiserver Denial of Service vulnerability from malicious YAML payloads","details":"The Kubernetes API Server component in versions 1.1-1.14, and versions prior to 1.15.10, 1.16.7 and 1.17.3 allows an authorized user who sends malicious YAML payloads to cause the kube-apiserver to consume excessive CPU cycles while parsing YAML.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H"}],"ranges":[{"events":[{"introduced":"1.1.0"},{"fixed":"1.15.10"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H"}],"ranges":[{"events":[{"introduced":"1.16.0"},{"fixed":"1.16.7"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H"}],"ranges":[{"events":[{"introduced":"1.17.0"},{"fixed":"1.17.3"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/89535"},{"url":"https://www.cve.org/cverecord?id=CVE-2019-11254"}]},{"id":"CVE-2020-8552","modified":"2020-03-23T18:35:34Z","published":"2020-03-23T18:35:34Z","summary":"apiserver DoS (oom)","details":"The Kubernetes API server component in versions prior to 1.15.9, 1.16.0-1.16.6, and 1.17.0-1.17.2 has been found to be vulnerable to a denial of service attack via successful API requests.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L"}],"ranges":[{"events":[{"introduced":"1.17.0"},{"fixed":"1.17.3"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L"}],"ranges":[{"events":[{"introduced":"1.16.0"},{"fixed":"1.16.7"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L"}],"ranges":[{"events":[{"introduced":"1.15.0"},{"fixed":"1.15.10"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/89378"},{"url":"https://www.cve.org/cverecord?id=CVE-2020-8552"}]},{"id":"CVE-2020-8551","modified":"2020-03-23T18:34:40Z","published":"2020-03-23T18:34:40Z","summary":"Kubelet DoS via API","details":"The Kubelet component in versions 1.15.0-1.15.9, 1.16.0-1.16.6, and 1.17.0-1.17.2 has been found to be vulnerable to a denial of service attack via the kubelet API, including the unauthenticated HTTP read-only API typically served on port 10255, and the authenticated HTTPS API typically served on port 10250.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:A/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L"}],"ranges":[{"events":[{"introduced":"1.17.0"},{"fixed":"1.17.3"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:A/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L"}],"ranges":[{"events":[{"introduced":"1.16.0"},{"fixed":"1.16.7"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:A/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L"}],"ranges":[{"events":[{"introduced":"1.15.0"},{"fixed":"1.15.10"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/89377"},{"url":"https://www.cve.org/cverecord?id=CVE-2020-8551"}]},{"id":"CVE-2019-11251","modified":"2020-02-03T15:12:22Z","published":"2020-02-03T15:12:22Z","summary":"kubectl cp symlink vulnerability","details":"The Kubernetes kubectl cp command in versions 1.1-1.12, and versions prior to 1.13.11, 1.14.7, and 1.15.4 allows a combination of two symlinks provided by tar output of a malicious container to place a file outside of the destination directory specified in the kubectl cp invocation. This could be used to allow an attacker to place a nefarious file using a symlink, outside of the destination tree.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubectl"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:H/PR:L/UI:R/S:U/C:N/I:H/A:N"}],"ranges":[{"events":[{"introduced":"1.1.0"},{"fixed":"1.13.11"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubectl"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:H/PR:L/UI:R/S:U/C:N/I:H/A:N"}],"ranges":[{"events":[{"introduced":"1.14.0"},{"fixed":"1.14.7"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubectl"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:H/PR:L/UI:R/S:U/C:N/I:H/A:N"}],"ranges":[{"events":[{"introduced":"1.15.0"},{"fixed":"1.15.4"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/87773"},{"url":"https://www.cve.org/cverecord?id=CVE-2019-11251"}]},{"id":"CVE-2018-1002102","modified":"2019-12-03T22:58:37Z","published":"2019-12-03T22:58:37Z","summary":"Unvalidated redirect","details":"Improper validation of URL redirection in the Kubernetes API server in versions prior to v1.14.0 allows an attacker-controlled Kubelet to redirect API server requests from streaming endpoints to arbitrary hosts. Impacted API servers will follow the redirect as a GET request with client-certificate credentials for authenticating to the Kubelet.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:H/PR:H/UI:R/S:C/C:L/I:N/A:N"}],"ranges":[{"events":[{"introduced":"0"},{"fixed":"1.14.0"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/85867"},{"url":"https://www.cve.org/cverecord?id=CVE-2018-1002102"}]},{"id":"CVE-2019-11253","modified":"2019-09-27T16:53:31Z","published":"2019-09-27T16:53:31Z","summary":"Kubernetes API Server JSON/YAML parsing vulnerable to resource exhaustion attack","details":"Improper input validation in the Kubernetes API server in versions v1.0-1.12 and versions prior to v1.13.12, v1.14.8, v1.15.5, and v1.16.2 allows authorized users to send malicious YAML or JSON payloads, causing the API server to consume excessive CPU or memory, potentially crashing and becoming unavailable. Prior to v1.14.0, default RBAC policy authorized anonymous users to submit requests that could trigger this vulnerability. Clusters upgraded from a version prior to v1.14.0 keep the more permissive policy by default for backwards compatibility.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H"}],"ranges":[{"events":[{"introduced":"1.1.0"},{"fixed":"1.13.12"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H"}],"ranges":[{"events":[{"introduced":"1.14.0"},{"fixed":"1.14.8"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H"}],"ranges":[{"events":[{"introduced":"1.15.0"},{"fixed":"1.15.5"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_1","score":"CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H"}],"ranges":[{"events":[{"introduced":"1.16.0"},{"fixed":"1.16.2"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/83253"},{"url":"https://www.cve.org/cverecord?id=CVE-2019-11253"}]},{"id":"CVE-2019-11250","modified":"2019-08-08T02:03:04Z","published":"2019-08-08T02:03:04Z","summary":"Bearer tokens are revealed in logs","details":"The Kubernetes client-go library logs request headers at verbosity levels of 7 or higher. This can disclose credentials to unauthorized users via logs or command output. Kubernetes components (such as kube-apiserver) prior to v1.16.0, which make use of basic or bearer token authentication, and run at high verbosity levels, are affected.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:L/AC:H/PR:L/UI:N/S:U/C:H/I:N/A:N"}],"ranges":[{"events":[{"introduced":"0"},{"fixed":"1.16.0"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/81114"},{"url":"https://www.cve.org/cverecord?id=CVE-2019-11250"}]},{"id":"CVE-2019-11248","modified":"2019-08-06T14:34:33Z","published":"2019-08-06T14:34:33Z","summary":"/debug/pprof exposed on kubelet's healthz port","details":"The debugging endpoint /debug/pprof is exposed over the unauthenticated Kubelet healthz port. The go pprof endpoint is exposed over the Kubelet's healthz port. This debugging endpoint can potentially leak sensitive information such as internal Kubelet memory addresses and configuration, or for limited denial of service. Versions prior to 1.15.0, 1.14.4, 1.13.8, and 1.12.10 are affected. The issue is of medium severity, but not exposed by the default configuration.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:N/A:L"}],"ranges":[{"events":[{"introduced":"1.1.0"},{"fixed":"1.12.10"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:N/A:L"}],"ranges":[{"events":[{"introduced":"1.13.0"},{"fixed":"1.13.8"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:N/A:L"}],"ranges":[{"events":[{"introduced":"1.14.0"},{"fixed":"1.14.4"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/81023"},{"url":"https://www.cve.org/cverecord?id=CVE-2019-11248"}]},{"id":"CVE-2019-11249","modified":"2019-08-05T12:44:23Z","published":"2019-08-05T12:44:23Z","summary":"Incomplete fixes for CVE-2019-1002101 and CVE-2019-11246, kubectl cp potential directory traversal","details":"The kubectl cp command allows copying files between containers and the user machine. To copy files from a container, Kubernetes runs tar inside the container to create a tar archive, copies it over the network, and kubectl unpacks it on the user’s machine. If the tar binary in the container is malicious, it could run any code and output unexpected, malicious results. An attacker could use this to write files to any path on the user’s machine when kubectl cp is called, limited only by the system permissions of the local user. Kubernetes affected versions include versions prior to 1.13.9, versions prior to 1.14.5, versions prior to 1.15.2, and versions 1.1, 1.2, 1.4, 1.4, 1.5, 1.6, 1.7, 1.8, 1.9, 1.10, 1.11, 1.12.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubectl"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:H/PR:L/UI:R/S:U/C:N/I:H/A:N"}],"ranges":[{"events":[{"introduced":"1.1.0"},{"fixed":"1.13.9"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubectl"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:H/PR:L/UI:R/S:U/C:N/I:H/A:N"}],"ranges":[{"events":[{"introduced":"1.14.0"},{"fixed":"1.14.5"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubectl"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:H/PR:L/UI:R/S:U/C:N/I:H/A:N"}],"ranges":[{"events":[{"introduced":"1.15.0"},{"fixed":"1.15.2"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/80984"},{"url":"https://www.cve.org/cverecord?id=CVE-2019-11249"}]},{"id":"CVE-2019-11247","modified":"2019-08-05T12:44:08Z","published":"2019-08-05T12:44:08Z","summary":"API server allows access to custom resources via wrong scope","details":"The Kubernetes kube-apiserver mistakenly allows access to a cluster-scoped custom resource if the request is made as if the resource were namespaced. Authorizations for the resource accessed in this manner are enforced using roles and role bindings within the namespace, meaning that a user with access only to a resource in one namespace could create, view update or delete the cluster-scoped resource (according to their namespace role privileges). Kubernetes affected versions include versions prior to 1.13.9, versions prior to 1.14.5, versions prior to 1.15.2, and versions 1.7, 1.8, 1.9, 1.10, 1.11, 1.12.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:H/PR:L/UI:N/S:U/C:L/I:L/A:L"}],"ranges":[{"events":[{"introduced":"1.7.0"},{"fixed":"1.13.9"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:H/PR:L/UI:N/S:U/C:L/I:L/A:L"}],"ranges":[{"events":[{"introduced":"1.14.0"},{"fixed":"1.14.5"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:H/PR:L/UI:N/S:U/C:L/I:L/A:L"}],"ranges":[{"events":[{"introduced":"1.15.0"},{"fixed":"1.15.2"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/80983"},{"url":"https://www.cve.org/cverecord?id=CVE-2019-11247"}]},{"id":"CVE-2019-11245","modified":"2019-05-24T16:14:49Z","published":"2019-05-24T16:14:49Z","summary":"container uid changes to root after first restart or if image is already pulled to the node","details":"In kubelet v1.13.6 and v1.14.2, containers for pods that do not specify an explicit runAsUser attempt to run as uid 0 (root) on container restart, or if the image was previously pulled to the node. If the pod specified mustRunAsNonRoot: true, the kubelet will refuse to start the container as root. If the pod did not specify mustRunAsNonRoot: true, the kubelet will run the container as uid 0.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:L/AC:H/PR:N/UI:N/S:U/C:L/I:L/A:L"}],"ranges":[{"events":[{"introduced":"1.13.6"},{"last_affected":"1.13.6"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:L/AC:H/PR:N/UI:N/S:U/C:L/I:L/A:L"}],"ranges":[{"events":[{"introduced":"1.14.2"},{"last_affected":"1.14.2"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/78308"},{"url":"https://www.cve.org/cverecord?id=CVE-2019-11245"}]},{"id":"CVE-2019-11243","modified":"2019-04-18T21:31:53Z","published":"2019-04-18T21:31:53Z","summary":"rest.AnonymousClientConfig() does not remove the serviceaccount credentials from config created by rest.InClusterConfig()","details":"In Kubernetes v1.12.0-v1.12.4 and v1.13.0, the rest.AnonymousClientConfig() method returns a copy of the provided config, with credentials removed (bearer token, username/password, and client certificate/key data). In the affected versions, rest.AnonymousClientConfig() did not effectively clear service account credentials loaded using rest.InClusterConfig()","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubernetes"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:H/PR:L/UI:N/S:U/C:L/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.12.0"},{"last_affected":"1.12.4"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubernetes"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:H/PR:L/UI:N/S:U/C:L/I:N/A:N"}],"ranges":[{"events":[{"introduced":"1.13.0"},{"last_affected":"1.13.0"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/76797"},{"url":"https://www.cve.org/cverecord?id=CVE-2019-11243"}]},{"id":"CVE-2019-11244","modified":"2019-04-16T20:14:25Z","published":"2019-04-16T20:14:25Z","summary":"`kubectl:-http-cache=\u003cworld-accessible dir\u003e` creates world-writeable cached schema files","details":"In Kubernetes v1.8.x-v1.14.x, schema info is cached by kubectl in the location specified by --cache-dir (defaulting to $HOME/.kube/http-cache), written with world-writeable permissions (rw-rw-rw-). If --cache-dir is specified and pointed at a different location accessible to other users/groups, the written files may be modified by other users/groups and disrupt the kubectl invocation.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubectl"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:L/AC:H/PR:L/UI:R/S:U/C:L/I:L/A:N"}],"ranges":[{"events":[{"introduced":"1.8.0"},{"fixed":"1.15.0"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/76676"},{"url":"https://www.cve.org/cverecord?id=CVE-2019-11244"}]},{"id":"CVE-2019-1002100","modified":"2019-02-25T19:39:09Z","published":"2019-02-25T19:39:09Z","summary":"json-patch requests can exhaust apiserver resources","details":"In all Kubernetes versions prior to v1.11.8, v1.12.6, and v1.13.4, users that are authorized to make patch requests to the Kubernetes API Server can send a specially crafted patch of type \"json-patch\" (e.g. `kubectl patch --type json` or `\"Content-Type: application/json-patch+json\"`) that consumes excessive resources while processing, causing a Denial of Service on the API Server.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H"}],"ranges":[{"events":[{"introduced":"1.0.0"},{"fixed":"1.11.8"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H"}],"ranges":[{"events":[{"introduced":"1.12.0"},{"fixed":"1.12.6"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H"}],"ranges":[{"events":[{"introduced":"1.13.0"},{"fixed":"1.13.4"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/74534"},{"url":"https://www.cve.org/cverecord?id=CVE-2019-1002100"}]},{"id":"CVE-2018-1002105","modified":"2018-11-26T11:07:36Z","published":"2018-11-26T11:07:36Z","summary":"proxy request handling in kube-apiserver can leave vulnerable TCP connections","details":"In all Kubernetes versions prior to v1.10.11, v1.11.5, and v1.12.3, incorrect handling of error responses to proxied upgrade requests in the kube-apiserver allowed specially crafted requests to establish a connection through the Kubernetes API server to backend servers, then send arbitrary requests over the same connection directly to the backend, authenticated with the Kubernetes API server's TLS credentials used to establish the backend connection.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H"}],"ranges":[{"events":[{"introduced":"1.0.0"},{"fixed":"1.10.11"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H"}],"ranges":[{"events":[{"introduced":"1.11.0"},{"fixed":"1.11.5"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/apiserver"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H"}],"ranges":[{"events":[{"introduced":"1.12.0"},{"fixed":"1.12.3"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/71411"},{"url":"https://www.cve.org/cverecord?id=CVE-2018-1002105"}]},{"id":"CVE-2018-1002101","modified":"2018-07-03T08:06:15Z","published":"2018-07-03T08:06:15Z","summary":"smb mount security issue","details":"In Kubernetes versions 1.9.0-1.9.9, 1.10.0-1.10.5, and 1.11.0-1.11.1, user input was handled insecurely while setting up volume mounts on Windows nodes, which could lead to command line argument injection.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubernetes"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:H/PR:H/UI:N/S:U/C:H/I:H/A:N"}],"ranges":[{"events":[{"introduced":"1.9.0"},{"fixed":"1.9.10"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubernetes"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:H/PR:H/UI:N/S:U/C:H/I:H/A:N"}],"ranges":[{"events":[{"introduced":"1.10.0"},{"fixed":"1.10.6"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubernetes"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:H/PR:H/UI:N/S:U/C:H/I:H/A:N"}],"ranges":[{"events":[{"introduced":"1.11.0"},{"fixed":"1.11.2"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/65750"},{"url":"https://www.cve.org/cverecord?id=CVE-2018-1002101"}]},{"id":"CVE-2018-1002100","modified":"2018-03-16T19:24:46Z","published":"2018-03-16T19:24:46Z","summary":"Kubectl copy doesn't check for paths outside of it's destination directory.","details":"In Kubernetes versions 1.5.x, 1.6.x, 1.7.x, 1.8.x, and prior to version 1.9.6, the kubectl cp command insecurely handles tar data returned from the container, and can be caused to overwrite arbitrary local files.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubectl"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:H/PR:H/UI:R/S:U/C:N/I:H/A:N"}],"ranges":[{"events":[{"introduced":"1.5.0"},{"fixed":"1.9.6"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/61297"},{"url":"https://www.cve.org/cverecord?id=CVE-2018-1002100"}]},{"id":"CVE-2017-1002102","modified":"2018-03-05T20:55:20Z","published":"2018-03-05T20:55:20Z","summary":"atomic writer volume handling allows arbitrary file deletion in host filesystem","details":"In Kubernetes versions 1.3.x, 1.4.x, 1.5.x, 1.6.x and prior to versions 1.7.14, 1.8.9 and 1.9.4 containers using a secret, configMap, projected or downwardAPI volume can trigger deletion of arbitrary files/directories from the nodes where they are running.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:L/PR:L/UI:N/S:U/C:N/I:L/A:H"}],"ranges":[{"events":[{"introduced":"1.3.0"},{"fixed":"1.7.14"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:L/PR:L/UI:N/S:U/C:N/I:L/A:H"}],"ranges":[{"events":[{"introduced":"1.8.0"},{"fixed":"1.8.9"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubelet"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:L/PR:L/UI:N/S:U/C:N/I:L/A:H"}],"ranges":[{"events":[{"introduced":"1.9.0"},{"fixed":"1.9.4"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/60814"},{"url":"https://www.cve.org/cverecord?id=CVE-2017-1002102"}]},{"id":"CVE-2017-1002101","modified":"2018-03-05T20:53:58Z","published":"2018-03-05T20:53:58Z","summary":"subpath volume mount handling allows arbitrary file access in host filesystem","details":"In Kubernetes versions 1.3.x, 1.4.x, 1.5.x, 1.6.x and prior to versions 1.7.14, 1.8.9 and 1.9.4 containers using subpath volume mounts with any volume type (including non-privileged pods, subject to file permissions) can access files/directories outside of the volume, including the host's filesystem.","affected":[{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubernetes"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H"}],"ranges":[{"events":[{"introduced":"1.3.0"},{"fixed":"1.7.14"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubernetes"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H"}],"ranges":[{"events":[{"introduced":"1.8.0"},{"fixed":"1.8.9"}]}]},{"package":{"ecosystem":"kubernetes","name":"k8s.io/kubernetes"},"severity":[{"type":"CVSS_V3_0","score":"CVSS:3.0/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H"}],"ranges":[{"events":[{"introduced":"1.9.0"},{"fixed":"1.9.4"}]}]}],"references":[{"url":"https://github.com/kubernetes/kubernetes/issues/60813"},{"url":"https://www.cve.org/cverecord?id=CVE-2017-1002101"}]}] \ No newline at end of file diff --git a/k8s/testdata/happy/upstream/CVE-2018-1002102 b/k8s/testdata/happy/upstream/CVE-2018-1002102 new file mode 100644 index 0000000..12f2ee2 --- /dev/null +++ b/k8s/testdata/happy/upstream/CVE-2018-1002102 @@ -0,0 +1,91 @@ +{ + "id": "CVE-2018-1002102", + "modified": "2018-11-26T11:07:36Z", + "published": "2018-11-26T11:07:36Z", + "summary": "proxy request handling in kube-apiserver can leave vulnerable TCP connections", + "details": "In all Kubernetes versions prior to v1.10.11, v1.11.5, and v1.12.3, incorrect handling of error responses to proxied upgrade requests in the kube-apiserver +allowed specially crafted requests to establish a connection through the Kubernetes API server to backend servers, then send arbitrary requests over the same connection +directly to the backend, authenticated with the Kubernetes API server's TLS credentials used to establish the backend connection.", + "affected": [ + { + "package": { + "ecosystem": "kubernetes", + "name": "k8s.io/apiserver" + }, + "severity": [ + { + "type": "CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H", + "score": "9.8" + } + ], + "ranges": [ + { + "events": [ + { + "introduced": "1.0.0" + }, + { + "fixed": "1.10.11" + } + ] + } + ] + }, + { + "package": { + "ecosystem": "kubernetes", + "name": "k8s.io/apiserver" + }, + "severity": [ + { + "type": "CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H", + "score": "9.8" + } + ], + "ranges": [ + { + "events": [ + { + "introduced": "1.11.0" + }, + { + "fixed": "1.11.5" + } + ] + } + ] + }, + { + "package": { + "ecosystem": "kubernetes", + "name": "k8s.io/apiserver" + }, + "severity": [ + { + "type": "CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H", + "score": "9.8" + } + ], + "ranges": [ + { + "events": [ + { + "introduced": "1.12.0" + }, + { + "fixed": "1.12.3" + } + ] + } + ] + } + ], + "references": [ + { + "url": "https://github.com/kubernetes/kubernetes/issues/71411" + }, + { + "url": "https://www.cve.org/cverecord?id=CVE-2018-1002105" + } + ] +} diff --git a/k8s/testdata/k8s-db.json b/k8s/testdata/k8s-db.json new file mode 100644 index 0000000..752d45d --- /dev/null +++ b/k8s/testdata/k8s-db.json @@ -0,0 +1,535 @@ +{ + "_kubernetes_io": { + "feed_refresh_job": "https://testgrid.k8s.io/sig-security-cve-feed#auto-refreshing-official-cve-feed", + "updated_at": "2023-07-01T22:37:44Z" + }, + "authors": [ + { + "name": "Kubernetes Community", + "url": "https://www.kubernetes.dev" + } + ], + "description": "Auto-refreshing official CVE feed for Kubernetes repository", + "feed_url": "https://kubernetes.io/docs/reference/issues-security/official-cve-feed/index.json", + "home_page_url": "https://kubernetes.io", + "items": [ + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2023-2431", + "issue_number": 118690 + }, + "content_text": "### What happened?\r\n\r\nA security issue was discovered in Kubelet that allows pods to bypass the seccomp profile enforcement. This issue has been rated LOW ([CVSS:3.1/AV:L/AC:L/PR:H/UI:N/S:U/C:L/I:L/A:N](https://www.first.org/cvss/calculator/3.1#CVSS:3.1/AV:L/AC:L/PR:H/UI:N/S:U/C:L/I:L/A:N)) (score: 3.4).\r\n\r\nIf you have pods in your cluster that use [localhost type](https://kubernetes.io/docs/reference/generated/kubernetes-api/v1.27/#seccompprofile-v1-core) for seccomp profile but specify an empty profile field, then you are affected by this issue. In this scenario, this vulnerability allows the pod to run in “unconfined” (seccomp disabled) mode. This bug affects Kubelet.\r\n\r\n### How can we reproduce it (as minimally and precisely as possible)?\r\n\r\nThis can be reproduced by creating a pod with following sample seccomp Localhost profile - \r\n\r\n```\r\n localhostProfile: \"\"\r\n```\r\n\r\nhttps://kubernetes.io/docs/reference/generated/kubernetes-api/v1.27/#seccompprofile-v1-core\r\n\r\n### Kubernetes version\r\n\r\n**Affected Versions**\r\nv1.27.0 - v1.27.1\r\nv1.26.0 - v1.26.4\r\nv1.25.0 - v1.25.9\r\n\u003c= v1.24.13\r\n\r\n**Fixed Versions**\r\nv1.27.2\r\nv1.26.5\r\nv1.25.10\r\nV1.24.14\r\n\r\n### Anything else we need to know?\r\n\r\nHow do I remediate this vulnerability?\r\nTo remediate this vulnerability you should upgrade your Kubelet to one of the below mentioned versions.\r\n\r\nAcknowledgements\r\nThis vulnerability was reported by Tim Allclair, and fixed by Craig Ingram.", + "date_published": "2023-06-15T14:42:32Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2023-2431", + "id": "CVE-2023-2431", + "summary": "Bypass of seccomp profile enforcement ", + "url": "https://github.com/kubernetes/kubernetes/issues/118690" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2023-2727, CVE-2023-2728", + "issue_number": 118640 + }, + "content_text": "### CVE-2023-2727: Bypassing policies imposed by the ImagePolicyWebhook admission plugin\r\nCVSS Rating: [CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:H/I:H/A:N](https://www.first.org/cvss/calculator/3.1#CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:H/I:H/A:N)\r\n\r\nA security issue was discovered in Kubernetes where users may be able to launch containers using images that are restricted by ImagePolicyWebhook when using ephemeral containers. Kubernetes clusters are only affected if the ImagePolicyWebhook admission plugin is used together with ephemeral containers.\r\n\r\n### Am I vulnerable?\r\nClusters are impacted by this vulnerability if all of the following are true:\r\n\r\n1. The ImagePolicyWebhook admission plugin is used to restrict use of certain images\r\n2. Pods are using ephemeral containers.\r\n\r\n### Affected Versions\r\n\r\n- kube-apiserver v1.27.0 - v1.27.2\r\n- kube-apiserver v1.26.0 - v1.26.5\r\n- kube-apiserver v1.25.0 - v1.25.10\r\n- kube-apiserver \u003c= v1.24.14\r\n\r\n### How do I mitigate this vulnerability?\r\nThis issue can be mitigated by applying the patch provided for the kube-apiserver component. This patch prevents ephemeral containers from using an image that is restricted by ImagePolicyWebhook. \r\n\r\nNote: Validation webhooks (such as [Gatekeeper](https://open-policy-agent.github.io/gatekeeper-library/website/validation/allowedrepos/) and [Kyverno](https://kyverno.io/policies/other/allowed-image-repos/allowed-image-repos/)) can also be used to enforce the same restrictions.\r\n\r\n### Fixed Versions\r\n\r\n- kube-apiserver v1.27.3\r\n- kube-apiserver v1.26.6\r\n- kube-apiserver v1.25.11\r\n- kube-apiserver v1.24.15\r\n\r\n### Detection\r\nPod update requests using an ephemeral container with an image that should have been restricted by an ImagePolicyWebhook will be captured in API audit logs. You can also use `kubectl get pods` to find active pods with ephemeral containers running an image that should have been restricted in your cluster with this issue.\r\n\r\n### Acknowledgements\r\nThis vulnerability was reported by Stanislav Láznička, and fixed by Rita Zhang.\r\n\r\n### CVE-2023-2728: Bypassing enforce mountable secrets policy imposed by the ServiceAccount admission plugin\r\nCVSS Rating: [CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:H/I:H/A:N](https://www.first.org/cvss/calculator/3.1#CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:H/I:H/A:N)\r\n\r\nA security issue was discovered in Kubernetes where users may be able to launch containers that bypass the mountable secrets policy enforced by the ServiceAccount admission plugin when using ephemeral containers. The policy ensures pods running with a service account may only reference secrets specified in the service account’s secrets field. Kubernetes clusters are only affected if the ServiceAccount admission plugin and the `kubernetes.io/enforce-mountable-secrets` annotation are used together with ephemeral containers.\r\n\r\n### Am I vulnerable?\r\nClusters are impacted by this vulnerability if all of the following are true:\r\n\r\n1. The ServiceAccount admission plugin is used. Most cluster should have this on by default as recommended in [https://kubernetes.io/docs/reference/access-authn-authz/admission-controllers/#serviceaccount](https://kubernetes.io/docs/reference/access-authn-authz/admission-controllers/#serviceaccount)\r\n2. The `kubernetes.io/enforce-mountable-secrets` annotation is used by a service account. This annotation is not added by default.\r\n3. Pods are using ephemeral containers.\r\n\r\n### Affected Versions\r\n\r\n- kube-apiserver v1.27.0 - v1.27.2\r\n- kube-apiserver v1.26.0 - v1.26.5\r\n- kube-apiserver v1.25.0 - v1.25.10\r\n- kube-apiserver \u003c= v1.24.14\r\n\r\n### How do I mitigate this vulnerability?\r\nThis issue can be mitigated by applying the patch provided for the kube-apiserver component. The patch prevents ephemeral containers from bypassing the mountable secrets policy enforced by the ServiceAccount admission plugin.\r\n\r\n### Fixed Versions\r\n- kube-apiserver v1.27.3\r\n- kube-apiserver v1.26.6\r\n- kube-apiserver v1.25.11\r\n- kube-apiserver v1.24.15\r\n\r\n### Detection\r\nPod update requests using an ephemeral container that exploits this vulnerability with unintended secret will be captured in API audit logs. You can also use kubectl get pods to find active pods with ephemeral containers running with a secret that is not referenced by the service account in your cluster.\r\n\r\n### Acknowledgements\r\nThis vulnerability was reported by Rita Zhang, and fixed by Rita Zhang.\r\n\r\nIf you find evidence that this vulnerability has been exploited, please contact [security@kubernetes.io](mailto:security@kubernetes.io)\r\n\r\n/area security\r\n/kind bug\r\n/committee security-response\r\n/label official-cve-feed\r\n/sig auth\r\n/area apiserver\r\n", + "date_published": "2023-06-13T14:42:06Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2023-2727, CVE-2023-2728", + "id": "CVE-2023-2727, CVE-2023-2728", + "summary": "Bypassing policies imposed by the ImagePolicyWebhook and bypassing mountable secrets policy imposed by the ServiceAccount admission plugin", + "url": "https://github.com/kubernetes/kubernetes/issues/118640" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2023-2878", + "issue_number": 118419 + }, + "content_text": "A security issue was discovered in [secrets-store-csi-driver](https://github.com/kubernetes-sigs/secrets-store-csi-driver) where an actor with access to the driver logs could observe service account tokens. These tokens could then potentially be exchanged with external cloud providers to access secrets stored in cloud vault solutions. Tokens are only logged when [TokenRequests is configured in the CSIDriver object](https://kubernetes-csi.github.io/docs/token-requests.html) and the driver is set to run at log level 2 or greater via the -v flag.\r\n\r\nThis issue has been rated **MEDIUM** [CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:C/C:H/I:N/A:N](https://www.first.org/cvss/calculator/3.1#CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:C/C:H/I:N/A:N) (6.5), and assigned **CVE-2023-2878**\r\n\r\n**Am I vulnerable?**\r\n\r\nYou may be vulnerable if [TokenRequests is configured in the CSIDriver object](https://kubernetes-csi.github.io/docs/token-requests.html) and the driver is set to run at log level 2 or greater via the -v flag.\r\n\r\nTo check if token requests are configured, run the following command:\r\n\r\n```shell\r\nkubectl get csidriver secrets-store.csi.k8s.io -o jsonpath=\"{.spec.tokenRequests}\"\r\n```\r\n\r\nTo check if tokens are being logged, examine the secrets-store container log:\r\n\r\n```shell\r\nkubectl logs -l app=secrets-store-csi-driver -c secrets-store -f | grep --line-buffered \"csi.storage.k8s.io/serviceAccount.tokens\"\r\n```\r\n\r\n**Affected Versions**\r\n\r\n- secrets-store-csi-driver \u003c 1.3.3\r\n\r\n**How do I mitigate this vulnerability?**\r\n\r\nPrior to upgrading, this vulnerability can be mitigated by running secrets-store-csi-driver at log level 0 or 1 via the -v flag.\r\n\r\n**Fixed Versions**\r\n\r\n- secrets-store-csi-driver \u003e= 1.3.3\r\n\r\nTo upgrade, refer to the documentation: [https://secrets-store-csi-driver.sigs.k8s.io/getting-started/upgrades.html#upgrades](https://secrets-store-csi-driver.sigs.k8s.io/getting-started/upgrades.html#upgrades)\r\n\r\n**Detection**\r\n\r\nExamine cloud provider logs for unexpected token exchanges, as well as unexpected access to cloud vault secrets.\r\n\r\nIf you find evidence that this vulnerability has been exploited, please contact [security@kubernetes.io](mailto:security@kubernetes.io)\r\n\r\n**Acknowledgements**\r\n\r\nThis vulnerability was reported by Tomer Shaiman `@tshaiman` from Microsoft.\r\n\r\n/area security\r\n/kind bug\r\n/committee security-response\r\n/label official-cve-feed\r\n/sig auth", + "date_published": "2023-06-02T19:03:54Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2023-2878", + "id": "CVE-2023-2878", + "summary": "secrets-store-csi-driver discloses service account tokens in logs", + "url": "https://github.com/kubernetes/kubernetes/issues/118419" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2022-3294", + "issue_number": 113757 + }, + "content_text": "CVSS Rating: [CVSS:3.1/AV:N/AC:H/PR:H/UI:N/S:U/C:H/I:H/A:H](https://www.first.org/cvss/calculator/3.1#CVSS:3.1/AV:N/AC:H/PR:H/UI:N/S:U/C:H/I:H/A:H)\r\n\r\nA security issue was discovered in Kubernetes where users may have access to secure endpoints in the control plane network. Kubernetes clusters are only affected if an untrusted user can modify Node objects and send proxy requests to them.\r\n\r\nKubernetes supports node proxying, which allows clients of kube-apiserver to access endpoints of a Kubelet to establish connections to Pods, retrieve container logs, and more. While Kubernetes already validates the proxying address for Nodes, a bug in kube-apiserver made it possible to bypass this validation. Bypassing this validation could allow authenticated requests destined for Nodes to to the API server's private network.\r\n\r\n### Am I vulnerable?\r\n\r\nClusters are affected by this vulnerability if there are endpoints that the kube-apiserver has connectivity to that users should not be able to access. This includes:\r\n\r\n- kube-apiserver is in a separate network from worker nodes\r\n- localhost services\r\n\r\nmTLS services that accept the same client certificate as nodes may be affected. The severity of this issue depends on the privileges \u0026 sensitivity of the exploitable endpoints.\r\n\r\nClusters that configure the egress selector to use a proxy for cluster traffic may not be affected.\r\n\r\n\r\n#### Affected Versions\r\n\r\n- Kubernetes kube-apiserver \u003c= v1.25.3\r\n- Kubernetes kube-apiserver \u003c= v1.24.7\r\n- Kubernetes kube-apiserver \u003c= v1.23.13\r\n- Kubernetes kube-apiserver \u003c= v1.22.15\r\n\r\n### How do I mitigate this vulnerability?\r\n\r\nUpgrading the **kube-apiserver** to a fixed version mitigates this vulnerability.\r\n\r\nAside from upgrading, configuring an [egress proxy for egress to the cluster network](https://kubernetes.io/docs/tasks/extend-kubernetes/setup-konnectivity/) can mitigate this vulnerability.\r\n\r\n#### Fixed Versions\r\n\r\n- Kubernetes kube-apiserver v1.25.4\r\n- Kubernetes kube-apiserver v1.24.8\r\n- Kubernetes kube-apiserver v1.23.14\r\n- Kubernetes kube-apiserver v1.22.16\r\n\r\n**Fix impact:** In some cases, the fix can break clients that depend on the nodes/proxy subresource, specifically if a kubelet advertises a localhost or link-local address to the Kubernetes control plane.\r\n\r\n### Detection\r\n\r\nNode create \u0026 update requests may be included in the Kubernetes audit log, and can be used to identify requests for IP addresses that should not be permitted. Node proxy requests may also be included in audit logs.\r\n\r\nIf you find evidence that this vulnerability has been exploited, please contact security@kubernetes.io\r\n\r\n#### Acknowledgements\r\n\r\nThis vulnerability was reported by Yuval Avrahami of Palo Alto Networks.\r\n\r\n\u003c!-- labels --\u003e\r\n/area security\r\n/kind bug\r\n/committee security-response\r\n/label official-cve-feed\r\n/sig api-machinery\r\n/area apiserver", + "date_published": "2022-11-08T21:33:26Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2022-3294", + "id": "CVE-2022-3294", + "summary": "Node address isn't always verified when proxying", + "url": "https://github.com/kubernetes/kubernetes/issues/113757" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2022-3162", + "issue_number": 113756 + }, + "content_text": "CVSS Rating: [CVSS:3.0/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:N/A:N](https://www.first.org/cvss/calculator/3.0#CVSS:3.0/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:N/A:N)\r\n\r\nA security issue was discovered in Kubernetes where users authorized to list or watch one type of namespaced custom resource cluster-wide can read custom resources of a different type in the same API group without authorization.\r\n\r\n### Am I vulnerable?\r\n\r\nClusters are impacted by this vulnerability if all of the following are true:\r\n- There are 2+ CustomResourceDefinitions sharing the same API group\r\n- Users have cluster-wide list or watch authorization on one of those custom resources.\r\n- The same users are not authorized to read another custom resource in the same API group.\r\n\r\n#### Affected Versions\r\n\r\n- Kubernetes kube-apiserver \u003c= v1.25.3\r\n- Kubernetes kube-apiserver \u003c= v1.24.7\r\n- Kubernetes kube-apiserver \u003c= v1.23.13\r\n- Kubernetes kube-apiserver \u003c= v1.22.15\r\n\r\n### How do I mitigate this vulnerability?\r\n\r\nUpgrading the kube-apiserver to a fixed version mitigates this vulnerability.\r\n\r\nPrior to upgrading, this vulnerability can be mitigated by avoiding granting cluster-wide list and watch permissions.\r\n\r\n#### Fixed Versions\r\n\r\n- Kubernetes kube-apiserver v1.25.4\r\n- Kubernetes kube-apiserver v1.24.8\r\n- Kubernetes kube-apiserver v1.23.14\r\n- Kubernetes kube-apiserver v1.22.16\r\n\r\n### Detection\r\n\r\nRequests containing `..` in the request path are a likely indicator of exploitation. Request paths may be captured in API audit logs, or in kube-apiserver HTTP logs.\r\n\r\nIf you find evidence that this vulnerability has been exploited, please contact security@kubernetes.io\r\n\r\n#### Acknowledgements\r\n\r\nThis vulnerability was reported by Richard Turnbull of NCC Group as part of the Kubernetes Audit.\r\n\r\n\u003c!-- labels --\u003e\r\n/area security\r\n/kind bug\r\n/committee security-response\r\n/label official-cve-feed\r\n/sig api-machinery\r\n/area apiserver\r\n", + "date_published": "2022-11-08T21:33:07Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2022-3162", + "id": "CVE-2022-3162", + "summary": "Unauthorized read of Custom Resources", + "url": "https://github.com/kubernetes/kubernetes/issues/113756" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2022-3172", + "issue_number": 112513 + }, + "content_text": "CVSS Rating: [CVSS:3.1/AV:N/AC:H/PR:H/UI:R/S:C/C:L/I:L/A:L](https://www.first.org/cvss/calculator/3.1#CVSS:3.1/AV:N/AC:H/PR:H/UI:R/S:C/C:L/I:L/A:L) (5.1, medium)\r\n\r\nA security issue was discovered in kube-apiserver that allows an aggregated API server to redirect client traffic to any URL. This could lead to the client performing unexpected actions as well as forwarding the client's API server credentials to third parties.\r\n\r\nThis issue has been rated medium and assigned CVE-2022-3172\r\n\r\n### Am I vulnerable?\r\n\r\nAll Kubernetes clusters with the following versions that are running aggregated API servers are impacted. To identify if you have aggregated API servers configured, run the following command:\r\n\r\n```shell\r\nkubectl get apiservices.apiregistration.k8s.io -o=jsonpath='{range .items[?(@.spec.service)]}{.metadata.name}{\"\\n\"}{end}'\r\n```\r\n\r\n#### Affected Versions\r\n\r\n- kube-apiserver v1.25.0\r\n- kube-apiserver v1.24.0 - v1.24.4\r\n- kube-apiserver v1.23.0 - v1.23.10\r\n- kube-apiserver v1.22.0 - v1.22.13\r\n- kube-apiserver \u003c= v1.21.14\r\n\r\n### How do I mitigate this vulnerability?\r\n\r\nAside from upgrading, no direct mitigation is available.\r\n\r\nAggregated API servers are a trusted part of the Kubernetes control plane, and configuring them is a privileged administrative operation. Ensure that only trusted cluster administrators are allowed to create or modify `APIService` configuration, and follow security best practices with any aggregated API servers that may be in use.\r\n\r\n#### Fixed Versions\r\n\r\n- kube-apiserver v1.25.1 - fixed by #112330\r\n- kube-apiserver v1.24.5 - fixed by #112331\r\n- kube-apiserver v1.23.11 - fixed by #112358\r\n- kube-apiserver v1.22.14 - fixed by #112359\r\n\r\n**Fix impact:** The fix blocks all 3XX responses from aggregated API servers by default. This may disrupt an aggregated API server that relies on redirects as part of its normal function. If all current and future aggregated API servers are considered trustworthy and redirect functionality is required, set the `--aggregator-reject-forwarding-redirect` Kubernetes API server flag to `false` to restore the previous behavior.\r\n\r\nTo upgrade, refer to the documentation: https://kubernetes.io/docs/tasks/administer-cluster/cluster-upgrade\r\n\r\n### Detection\r\n\r\nKubernetes audit log events indicate the HTTP status code sent to the client via the `responseStatus.code` field. This can be used to detect if an aggregated API server is redirecting clients.\r\n\r\nIf you find evidence that this vulnerability has been exploited, please contact security@kubernetes.io\r\n\r\n#### Acknowledgements\r\n\r\nThis vulnerability was reported by Nicolas Joly \u0026 Weinong Wang @weinong from Microsoft.\r\n\r\nThe issue was fixed and coordinated by Di Jin @jindijamie @enj @liggitt @lavalamp @deads2k and @puerco.\r\n\r\n/area security\r\n/kind bug\r\n/committee security-response\r\n/label official-cve-feed\r\n/sig api-machinery\r\n/area apiserver\r\n/triage accepted", + "date_published": "2022-09-16T13:14:50Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2022-3172", + "id": "CVE-2022-3172", + "summary": "Aggregated API server can cause clients to be redirected (SSRF)", + "url": "https://github.com/kubernetes/kubernetes/issues/112513" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2021-25749", + "issue_number": 112192 + }, + "content_text": "A security issue was discovered in Kubernetes that could allow Windows workloads to run as `ContainerAdministrator` even when those workloads set the `runAsNonRoot` option to `true`.\r\n\r\nThis issue has been rated low and assigned CVE-2021-25749\r\n\r\n### Am I vulnerable?\r\n\r\nAll Kubernetes clusters with following versions, running Windows workloads with `runAsNonRoot` are impacted\r\n\r\n#### Affected Versions\r\n\r\n- kubelet v1.20 - v1.21\r\n- kubelet v1.22.0 - v1.22.13\r\n- kubelet v1.23.0 - v1.23.10\r\n- kubelet v1.24.0 - v1.24.4\r\n\r\n### How do I mitigate this vulnerability?\r\n\r\nThere are no known mitigations to this vulnerability.\r\n\r\n#### Fixed Versions\r\n\r\n- kubelet v1.22.14\r\n- kubelet v1.23.11\r\n- kubelet v1.24.5\r\n- kubelet v1.25.0\r\n\r\n\r\nTo upgrade, refer to this documentation _For core Kubernetes:_ https://kubernetes.io/docs/tasks/administer-cluster/cluster-upgrade/\r\n\r\n### Detection\r\n\r\nKubernetes Audit logs may indicate if the user name was misspelled to bypass the restriction placed on which user is a pod allowed to run as.\r\n\r\nIf you find evidence that this vulnerability has been exploited, please contact security@kubernetes.io\r\n\r\n#### Additional Details\r\n\r\nSee the GitHub issue for more details: https://github.com/kubernetes/kubernetes/issues/112192 \r\n\r\n#### Acknowledgements\r\n\r\nThis vulnerability was reported and fixed by Mark Rosetti (@marosset)\r\n", + "date_published": "2022-09-01T21:02:01Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2021-25749", + "id": "CVE-2021-25749", + "summary": "`runAsNonRoot` logic bypass for Windows containers", + "url": "https://github.com/kubernetes/kubernetes/issues/112192" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2021-25741", + "issue_number": 104980 + }, + "content_text": "A security issue was discovered in Kubernetes where a user may be able to create a container with subpath volume mounts to access files \u0026 directories outside of the volume, including on the host filesystem.\r\n\r\nThis issue has been rated **High** ([CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H](https://www.first.org/cvss/calculator/3.1#CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H)), and assigned **CVE-2021-25741**.\r\n\r\n### Affected Components and Configurations\r\nThis bug affects kubelet.\r\n\r\n\r\nEnvironments where cluster administrators have restricted the ability to create hostPath mounts are the most seriously affected. Exploitation allows hostPath-like access without use of the hostPath feature, thus bypassing the restriction. \r\n\r\n\r\nIn a default Kubernetes environment, exploitation could be used to obscure misuse of already-granted privileges.\r\n\r\n#### Affected Versions\r\nv1.22.0 - v1.22.1\r\n\r\nv1.21.0 - v1.21.4\r\n\r\nv1.20.0 - v1.20.10\r\n\r\n\u003c= v1.19.14\r\n\r\n#### Fixed Versions\r\nThis issue is fixed in the following versions:\r\n\r\nv1.22.2\r\n\r\nv1.21.5\r\n\r\nv1.20.11\r\n\r\nv1.19.15\r\n\r\n### Mitigation\r\nTo mitigate this vulnerability without upgrading kubelet, you can disable the VolumeSubpath feature gate on kubelet and kube-apiserver, and remove any existing Pods making use of the feature.\r\n\r\n\r\nYou can also use admission control to prevent less-trusted users from running containers as root to reduce the impact of successful exploitation.\r\n\r\n### Detection\r\nIf you find evidence that this vulnerability has been exploited, please contact security@kubernetes.io\r\n\r\n### Additional Details\r\nSee Kubernetes Issue #104980 for more details.\r\n\r\n### Acknowledgements\r\nThis vulnerability was reported by Fabricio Voznika and Mark Wolters of Google.\r\n\r\n\r\nThanks as well to Ian Coldwater, Duffie Cooley, Brad Geesaman, and Rory McCune for the thorough security research that led to the discovery of this vulnerability.", + "date_published": "2021-09-13T20:58:56Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2021-25741", + "id": "CVE-2021-25741", + "summary": "Symlink Exchange Can Allow Host Filesystem Access", + "url": "https://github.com/kubernetes/kubernetes/issues/104980" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2021-25737", + "issue_number": 102106 + }, + "content_text": "#### Issue Details\r\nA security issue was discovered in Kubernetes where a user may be able to redirect pod traffic to private networks on a Node. Kubernetes already prevents creation of Endpoint IPs in the localhost or link-local range, but the same validation was not performed on EndpointSlice IPs. \r\nThis issue has been rated Low ([CVSS:3.0/AV:N/AC:L/PR:H/UI:N/S:U/C:L/I:N/A:N](https://www.first.org/cvss/calculator/3.0#CVSS:3.0/AV:N/AC:L/PR:H/UI:N/S:U/C:L/I:N/A:N)), and assigned CVE-2021-25737.\r\nAffected Component\r\nkube-apiserver\r\n\r\n#### Affected Versions\r\nv1.21.0\r\nv1.20.0 - v1.20.6\r\nv1.19.0 - v1.19.10\r\nv1.16.0 - v1.18.18 (Note: EndpointSlices were not enabled by default in 1.16-1.18)\r\n#### Fixed Versions\r\nThis issue is fixed in the following versions:\r\nv1.21.1\r\nv1.20.7\r\nv1.19.11\r\nv1.18.19\r\n#### Mitigation\r\nTo mitigate this vulnerability without upgrading kube-apiserver, you can create a validating admission webhook that prevents EndpointSlices with endpoint addresses in the 127.0.0.0/8 and 169.254.0.0/16 ranges. If you have an existing admission policy mechanism (like OPA Gatekeeper) you can create a policy that enforces this restriction.\r\n#### Detection\r\nTo detect whether this vulnerability has been exploited, you can list EndpointSlices and check for endpoint addresses in the 127.0.0.0/8 and 169.254.0.0/16 ranges.\r\n \r\nIf you find evidence that this vulnerability has been exploited, please contact security@kubernetes.io\r\n#### Acknowledgements\r\nThis vulnerability was reported by John Howard of Google.\r\n", + "date_published": "2021-05-18T19:14:27Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2021-25737", + "id": "CVE-2021-25737", + "summary": "Holes in EndpointSlice Validation Enable Host Network Hijack", + "url": "https://github.com/kubernetes/kubernetes/issues/102106" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2021-3121", + "issue_number": 101435 + }, + "content_text": "### Issue Details\r\n\r\nA security issue was discovered in code generated by the gogo protobuf compiler used by Kubernetes. The gogo protobuf compiler issue has been assigned CVE-2021-3121 and is also known as the “skippy peanut butter bug”.\r\n\r\nA program which uses affected code to handle a malicious protobuf message could panic.\r\nThe Kubernetes Product Security Committee has tested the API server using a malicious message, and we believe that **there is no security impact to Kubernetes**. When an authenticated user sent the malicious message to the API server, a panic occurred. However, the panic handler recovered and the API server continued without interruption (except to the malicious requestor, who received no response).\r\n\r\nGenerated protobuf files are part of several Kubernetes repositories, and any downstream projects which vendor in these repos should evaluate whether there is any security impact to their project.\r\n\r\n### Affected Components and Configurations\r\n\r\nAny golang components which use handler code created by the gogo protbuf compiler, which accept protobuf messages and do not gracefully handle panics in the unmarshalling codepath may be affected.\r\n\r\nThe following Linux command can be used to detect affected generated code within a codebase:\r\n\r\n```\r\nfind . -name '*.pb.go' | \\\r\nxargs -r grep -l 'if skippy \u003c 0' | \\\r\nxargs -r awk -e '/if skippy \u003c 0/ {a=4} /if \\(iNdEx \\+ skippy\\) \u003e postIndex/ \u0026\u0026' \\\r\n \t -e 'a\u003e0 {print FILENAME \" \" FNR \": \" $0 \" // vulnerable to CVE-2021-3121\"} {a--}'\r\n```\r\n\r\nAlthough we do not believe there is any security impact to Kubernetes, we have updated all generated protobufs out of an abundance of caution and as a courtesy to any downstream consumers who may be affected. The following PRs addressed this issue in Kubernetes:\r\n\r\nMaster branch: #98477, #101306\r\n1.21 branch: #98477 (in 1.21.0), #101325 (in 1.21.1)\r\n1.20 branch: #100501 (in 1.20.6), #101326 (in 1.20.7)\r\n1.19 branch: #100515 (in 1.19.10), #101327 (in 1.19.11)\r\n1.18 branch: #100514 (in 1.18.18), #101335 (in 1.18.19)\r\n\r\nFor other generated protobuf go handlers, the issue can be remediated by upgrading the gogo protobuf compiler to a fixed version (v1.3.2 or later), then regenerating affected protobuf code with the updated protobuf compiler. \r\n\r\n### Mitigations\r\n\r\nDisabling support for protobuf messages may be one possible mitigation for any affected product.\r\n\r\nAlso, graceful panic handling in message handlers mitigates the bug.\r\n\r\n### Detection\r\n\r\nIf you use generated protobuf code in a product and you observe a process exiting with messages similar to the following, a malicious user may be exploiting this defect:\r\n\r\n```\r\npanic: runtime error: index out of range [-9223372036854775804]\r\n \r\ngoroutine 1 [running]:\r\nv1.(*MessageName).Unmarshal(0xc000057ef8, 0xc0000161a0, 0xa, 0x10, 0xc000057ec8, 0x1)\r\n .../protofile.pb.go:250 +0xb86\r\n```\r\n\r\n### References\r\n- CVE-2021-3121: https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2021-3121\r\n- GoGo Protobuf v1.3.2: https://github.com/gogo/protobuf/releases/tag/v1.3.2\r\n", + "date_published": "2021-04-23T18:07:32Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2021-3121", + "id": "CVE-2021-3121", + "summary": "Processes may panic upon receipt of malicious protobuf messages", + "url": "https://github.com/kubernetes/kubernetes/issues/101435" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2021-25735", + "issue_number": 100096 + }, + "content_text": "A security issue was discovered in kube-apiserver that could allow node updates to bypass a Validating Admission Webhook. You are only affected by this vulnerability if you run a Validating Admission Webhook for Nodes that denies admission based at least partially on the old state of the Node object.\r\n\r\nThis issue has been rated **Medium** ([CVSS:3.0/AV:N/AC:L/PR:H/UI:N/S:U/C:N/I:H/A:H](https://www.first.org/cvss/calculator/3.0#CVSS:3.0/AV:N/AC:L/PR:H/UI:N/S:U/C:N/I:H/A:H)), and assigned **CVE-2021-25735**.\r\n\r\n**Note:** This only impacts validating admission plugins that rely on old values in certain fields, and does not impact calls from kubelets that go through the built-in NodeRestriction admission plugin.\r\n\r\n#### Affected Versions\r\n\r\n- kube-apiserver v1.20.0 - v1.20.5\r\n- kube-apiserver v1.19.0 - v1.19.9\r\n- kube-apiserver \u003c= v1.18.17\r\n\r\n#### Fixed Versions\r\n\r\nThis issue is fixed in the following versions:\r\n- kube-apiserver v1.21.0 - Fixed by https://github.com/kubernetes/kubernetes/pull/99946\r\n- kube-apiserver v1.20.6 - Fixed by https://github.com/kubernetes/kubernetes/pull/100315\r\n- kube-apiserver v1.19.10 - Fixed by https://github.com/kubernetes/kubernetes/pull/100316\r\n- kube-apiserver v1.18.18 - Fixed by https://github.com/kubernetes/kubernetes/pull/100317\r\n\r\n#### Detection\r\n\r\nIf you find evidence that this vulnerability has been exploited, please contact security@kubernetes.io\r\n\r\n#### Acknowledgements\r\n\r\nThis vulnerability was reported by Rogerio Bastos \u0026 Ari Lima from RedHat\r\n", + "date_published": "2021-03-10T18:18:01Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2021-25735", + "id": "CVE-2021-25735", + "summary": "Validating Admission Webhook does not observe some previous fields", + "url": "https://github.com/kubernetes/kubernetes/issues/100096" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2020-8554", + "issue_number": 97076 + }, + "content_text": "CVSS Rating: **Medium** ([CVSS:3.0/AV:N/AC:L/PR:L/UI:N/S:U/C:L/I:L/A:L](https://www.first.org/cvss/calculator/3.0#CVSS:3.0/AV:N/AC:L/PR:L/UI:N/S:U/C:L/I:L/A:L))\r\n \r\nThis issue affects multitenant clusters. If a potential attacker can already create or edit services and pods, then they may be able to intercept traffic from other pods (or nodes) in the cluster.\r\n \r\nAn attacker that is able to create a ClusterIP service and set the spec.externalIPs field can intercept traffic to that IP. An attacker that is able to patch the status (which is considered a privileged operation and should not typically be granted to users) of a LoadBalancer service can set the status.loadBalancer.ingress.ip to similar effect.\r\nThis issue is a design flaw that cannot be mitigated without user-facing changes.\r\n### Affected Components and Configurations\r\n\r\nAll Kubernetes versions are affected. Multi-tenant clusters that grant tenants the ability to create and update services and pods are most vulnerable.\r\n### Mitigations\r\n\r\nThere is no patch for this issue, and it can currently only be mitigated by restricting access to the vulnerable features. Because an in-tree fix would require a breaking change, we will open a conversation about a longer-term fix or built-in mitigation after the embargo is lifted\r\n\r\nTo restrict the use of external IPs we are providing an admission webhook container: k8s.gcr.io/multitenancy/externalip-webhook:v1.0.0. The source code and deployment instructions are published at https://github.com/kubernetes-sigs/externalip-webhook.\r\n\r\nAlternatively, external IPs can be restricted using [OPA Gatekeeper](https://github.com/open-policy-agent/gatekeeper). A sample ConstraintTemplate and Constraint can be found here: https://github.com/open-policy-agent/gatekeeper-library/tree/master/library/general/externalip.\r\n\r\nNo mitigations are provided for LoadBalancer IPs since we do not recommend granting users *patch service/status* permission. If LoadBalancer IP restrictions are required, the approach for the external IP mitigations can be copied.\r\n### Detection\r\n\r\nExternalIP services are not widely used, so we recommend manually auditing any external IP usage. Users should not patch service status, so audit events for patch service status requests authenticated to a user may be suspicious.\r\n \r\nIf you find evidence that this vulnerability has been exploited, please contact security@kubernetes.io\r\n#### Acknowledgements\r\n\r\nThis vulnerability was reported by Etienne Champetier (@champtar) of Anevia.\r\n \r\n/area security\r\n/kind bug\r\n/committee product-security\r\n/sig network\r\n", + "date_published": "2020-12-04T20:02:15Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2020-8554", + "id": "CVE-2020-8554", + "summary": "Man in the middle using LoadBalancer or ExternalIPs", + "url": "https://github.com/kubernetes/kubernetes/issues/97076" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2020-8566", + "issue_number": 95624 + }, + "content_text": "CVSS Rating: 4.7 CVSS:3.0/AV:L/AC:H/PR:L/UI:N/S:U/C:H/I:N/A:N (Medium)\r\n\r\nIn Kubernetes clusters using Ceph RBD as a storage provisioner, with logging level of at least 4, Ceph RBD admin secrets can be written to logs. This occurs in kube-controller-manager's logs during provisioning of Ceph RBD persistent claims.\r\n\r\n### Am I vulnerable?\r\nIf Ceph RBD volumes are in use and kube-controller-manager is using a log level of at least 4.\r\n\r\n#### Affected Versions\r\nkubernetes v1.19.0 - v1.19.2\r\nkubernetes v1.18.0 - v1.18.9\r\nkubernetes v1.17.0 - v1.17.12\r\n\r\n### How do I mitigate this vulnerability?\r\nDo not enable verbose logging in production, limit access to logs.\r\n\r\n#### Fixed Versions\r\nv1.19.3\r\nv1.18.10\r\nv1.17.13\r\n\r\nTo upgrade, refer to the documentation: https://kubernetes.io/docs/tasks/administer-cluster/cluster-management/#upgrading-a-cluster\r\n\r\n### Acknowledgements\r\nThis vulnerability was reported by: Kaizhe Huang (derek0405)\r\n\r\n/area security\r\n/kind bug\r\n/committee product-security\r\n", + "date_published": "2020-10-15T22:07:53Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2020-8566", + "id": "CVE-2020-8566", + "summary": "Ceph RBD adminSecrets exposed in logs when loglevel \u003e= 4", + "url": "https://github.com/kubernetes/kubernetes/issues/95624" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2020-8565", + "issue_number": 95623 + }, + "content_text": "CVSS Rating: 4.7 CVSS:3.0/AV:L/AC:H/PR:L/UI:N/S:U/C:H/I:N/A:N (Medium)\r\n\r\nIn Kubernetes, if the logging level is to at least 9, authorization and bearer tokens will be written to log files. This can occur both in API server logs and client tool output like `kubectl`.\r\n\r\n### Am I vulnerable?\r\nIf kube-apiserver is using a log level of at least 9.\r\n\r\n#### Affected Versions\r\nkubernetes v1.19.0 - v1.19.5\r\nkubernetes v1.18.0 - v1.18.13\r\nkubernetes v1.17.0 - v1.17.15\r\n\r\n### How do I mitigate this vulnerability?\r\nDo not enable verbose logging in production, limit access to logs.\r\n\r\n#### Fixed Versions\r\nkubernetes v1.20.0\r\nkubernetes v1.19.6 \r\nkubernetes v1.18.14 \r\nkubernetes v1.17.16\r\n\r\nTo upgrade, refer to the documentation: https://kubernetes.io/docs/tasks/administer-cluster/cluster-management/#upgrading-a-cluster\r\n\r\n### Acknowledgements\r\nThis vulnerability was reported by: Patrick Rhomberg (purelyapplied)\r\n\r\n/area security\r\n/kind bug\r\n/committee product-security\r\n", + "date_published": "2020-10-15T22:05:32Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2020-8565", + "id": "CVE-2020-8565", + "summary": "Incomplete fix for CVE-2019-11250 allows for token leak in logs when logLevel \u003e= 9", + "url": "https://github.com/kubernetes/kubernetes/issues/95623" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2020-8564", + "issue_number": 95622 + }, + "content_text": "CVSS Rating: 4.7 CVSS:3.0/AV:L/AC:H/PR:L/UI:N/S:U/C:H/I:N/A:N (Medium)\r\n\r\nIn Kubernetes clusters using a logging level of at least 4, processing a malformed docker config file will result in the contents of the docker config file being leaked, which can include pull secrets or other registry credentials.\r\n\r\n### Am I vulnerable?\r\nIf kubernetes.io/dockerconfigjson type secrets are used, and a log level of 4 or higher is used. Third party tools using k8s.io/kubernetes/pkg/credentialprovider to read docker config files may also be vulnerable.\r\n\r\n#### Affected Versions\r\nkubernetes v1.19.0 - v1.19.2\r\nkubernetes v1.18.0 - v1.18.9\r\nkubernetes v1.17.0 - v1.17.12\r\n\r\n### How do I mitigate this vulnerability?\r\nDo not enable verbose logging in production, limit access to logs.\r\n\r\n#### Fixed Versions\r\nv1.19.3\r\nv1.18.10\r\nv1.17.13\r\n\r\n\r\nTo upgrade, refer to the documentation: https://kubernetes.io/docs/tasks/administer-cluster/cluster-management/#upgrading-a-cluster\r\n\r\n#### Acknowledgements\r\nThis vulnerability was reported by: Nikolaos Moraitis (Red Hat)\r\n/area security\r\n/kind bug\r\n/committee product-security\r\n", + "date_published": "2020-10-15T22:03:19Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2020-8564", + "id": "CVE-2020-8564", + "summary": "Docker config secrets leaked when file is malformed and log level \u003e= 4", + "url": "https://github.com/kubernetes/kubernetes/issues/95622" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2020-8563", + "issue_number": 95621 + }, + "content_text": "CVSS Rating: 5.6 CVSS:3.0/AV:L/AC:H/PR:L/UI:N/S:C/C:H/I:N/A:N (Medium)\r\n\r\nIn Kubernetes clusters using VSphere as a cloud provider, with a logging level set to 4 or above, VSphere cloud credentials will be leaked in the cloud controller manager's log.\r\n\r\n### Am I vulnerable?\r\nIf you are using VSphere as a cloud provider, have verbose logging enabled, and an attacker can access cluster logs, then you may be vulnerable to this.\r\n\r\n#### Affected Versions\r\nkube-controller-manager v1.19.0 - v1.19.2\r\n\r\n#### How do I mitigate this vulnerability?\r\nDo not enable verbose logging in production, limit access to cluster logs.\r\n\r\n#### Fixed Versions\r\nv1.19.3\r\n\r\nTo upgrade, refer to the documentation: https://kubernetes.io/docs/tasks/administer-cluster/cluster-management/#upgrading-a-cluster\r\n\r\n### Acknowledgements\r\nThis vulnerability was reported by: Kaizhe Huang (derek0405)\r\n\r\n/area security\r\n/kind bug\r\n/committee product-security\r\n", + "date_published": "2020-10-15T22:00:44Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2020-8563", + "id": "CVE-2020-8563", + "summary": "Secret leaks in kube-controller-manager when using vSphere provider", + "url": "https://github.com/kubernetes/kubernetes/issues/95621" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2020-8557", + "issue_number": 93032 + }, + "content_text": "CVSS Rating: Medium (5.5) [CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H/CR:H/IR:H/AR:M](https://www.first.org/cvss/calculator/3.1#CVSS:3.1/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H/CR:H/IR:H/AR:M)\r\n\r\nThe `/etc/hosts` file mounted in a pod by kubelet is not included by the kubelet eviction manager when calculating ephemeral storage usage by a pod. If a pod writes a large amount of data to the `/etc/hosts` file, it could fill the storage space of the node and cause the node to fail.\r\n\r\n### Am I vulnerable?\r\n\r\nAny clusters allowing pods with sufficient privileges to write to their own `/etc/hosts` files are affected. This includes containers running with `CAP_DAC_OVERRIDE` in their capabilities bounding set (true by default) and either UID 0 (root) or a security context with `allowPrivilegeEscalation: true` (true by default).\r\n\r\n#### Affected Versions\r\n\r\n- kubelet v1.18.0-1.18.5\r\n- kubelet v1.17.0-1.17.8\r\n- kubelet \u003c v1.16.13\r\n\r\n### How do I mitigate this vulnerability?\r\n\r\nPrior to upgrading, this vulnerability can be mitigated by using PodSecurityPolicies or other admission webhooks to force containers to drop CAP_DAC_OVERRIDE or to prohibit privilege escalation and running as root, but these measures may break existing workloads that rely upon these privileges to function properly.\r\n\r\n#### Fixed Versions\r\n\r\n- kubelet master - fixed by #92916\r\n- kubelet v1.18.6 - fixed by #92921\r\n- kubelet v1.17.9 - fixed by #92923\r\n- kubelet v1.16.13 - fixed by #92924\r\n\r\nTo upgrade, refer to the documentation: https://kubernetes.io/docs/tasks/administer-cluster/cluster-management/#upgrading-a-cluster\r\n\r\n### Detection\r\n\r\nLarge pod `etc-hosts` files may indicate that a pod is attempting to perform a Denial of Service attack using this bug. A command such as\r\n\r\n```\r\nfind /var/lib/kubelet/pods/*/etc-hosts -size +1M\r\n```\r\n\r\nrun on a node can be used to find abnormally large pod etc-hosts files.\r\n\r\n#### Acknowledgements\r\n\r\nThis vulnerability was reported by Kebe Liu of DaoCloud, via the Kubernetes bug bounty program.\r\n\r\n/area security\r\n/kind bug\r\n/committee product-security\r\n/sig node\r\n/area kubelet", + "date_published": "2020-07-13T18:39:08Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2020-8557", + "id": "CVE-2020-8557", + "summary": "Node disk DOS by writing to container /etc/hosts", + "url": "https://github.com/kubernetes/kubernetes/issues/93032" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2020-8559", + "issue_number": 92914 + }, + "content_text": "CVSS Rating: Medium (6.4) [CVSS:3.1/AV:N/AC:H/PR:H/UI:R/S:U/C:H/I:H/A:H](https://www.first.org/cvss/calculator/3.1#CVSS:3.1/AV:N/AC:H/PR:H/UI:R/S:U/C:H/I:H/A:H)\r\n\r\nIf an attacker is able to intercept certain requests to the Kubelet, they can send a redirect response that may be followed by a client using the credentials from the original request. This can lead to compromise of other nodes.\r\n\r\nIf multiple clusters share the same certificate authority trusted by the client, and the same authentication credentials, this vulnerability may allow an attacker to redirect the client to another cluster. In this configuration, this vulnerability should be considered **High** severity.\r\n\r\n### Am I vulnerable?\r\n\r\nYou are only affected by this vulnerability if you treat the node as a security boundary, or if clusters share certificate authorities and authentication credentials.\r\n\r\nNote that this vulnerability requires an attacker to first compromise a node through separate means.\r\n\r\n#### Affected Versions\r\n\r\n- kube-apiserver v1.18.0-1.18.5\r\n- kube-apiserver v1.17.0-1.17.8\r\n- kube-apiserver v1.16.0-1.16.12\r\n- all kube-apiserver versions prior to v1.16.0\r\n\r\n### How do I mitigate this vulnerability?\r\n\r\nTo mitigate this vulnerability you must upgrade the kube-apiserver to a patched version.\r\n\r\n#### Fixed Versions\r\n\r\n- kube-apiserver master - fixed by https://github.com/kubernetes/kubernetes/pull/92941\r\n- kube-apiserver v1.18.6 - fixed by https://github.com/kubernetes/kubernetes/pull/92969\r\n- kube-apiserver v1.17.9 - fixed by https://github.com/kubernetes/kubernetes/pull/92970\r\n- kube-apiserver v1.16.13 - fixed by https://github.com/kubernetes/kubernetes/pull/92971\r\n\r\n\r\n**Fix impact:** Proxied backends (such as an extension API server) that respond to upgrade requests with a non-101 response code may be broken by this patch.\r\n\r\nTo upgrade, refer to the documentation: https://kubernetes.io/docs/tasks/administer-cluster/cluster-management/#upgrading-a-cluster\r\n\r\n### Detection\r\n\r\nUpgrade requests should never respond with a redirect. If any of the following requests have a response code in the 300-399 range, it may be evidence of exploitation. This information can be found in the Kubernetes audit logs.\r\n\r\n- pods/exec\r\n- pods/attach\r\n- pods/portforward\r\n- any resource: proxy\r\n\r\nIf you find evidence that this vulnerability has been exploited, please contact security@kubernetes.io\r\n\r\n#### Acknowledgements\r\n\r\nThis vulnerability was reported by Wouter ter Maat of Offensi, via the Kubernetes bug bounty.\r\n\r\n/area security\r\n/kind bug\r\n/committee product-security\r\n/sig api-machinery\r\n/area apiserver", + "date_published": "2020-07-08T17:03:16Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2020-8559", + "id": "CVE-2020-8559", + "summary": "Privilege escalation from compromised node to cluster", + "url": "https://github.com/kubernetes/kubernetes/issues/92914" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2020-8558", + "issue_number": 92315 + }, + "content_text": "CVSS Rating:\r\n\r\nIn typical clusters: medium (5.4) [CVSS:3.1/AV:A/AC:L/PR:N/UI:N/S:U/C:L/I:L/A:N](https://www.first.org/cvss/calculator/3.1#CVSS:3.1/AV:A/AC:L/PR:N/UI:N/S:U/C:L/I:L/A:N)\r\n\r\nIn clusters where API server insecure port has not been disabled: high (8.8) [CVSS:3.1/AV:A/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H](https://www.first.org/cvss/calculator/3.1#CVSS:3.1/AV:A/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H)\r\n\r\nA security issue was discovered in `kube-proxy` which allows adjacent hosts to reach TCP and UDP services bound to `127.0.0.1` running on the node or in the node's network namespace. For example, if a cluster administrator runs a TCP service on a node that listens on `127.0.0.1:1234`, because of this bug, that service would be potentially reachable by other hosts on the same LAN as the node, or by containers running on the same node as the service. If the example service on port `1234` required no additional authentication (because it assumed that only other localhost processes could reach it), then it could be vulnerable to attacks that make use of this bug.\r\n\r\nThe Kubernetes API Server's default insecure port setting causes the API server to listen on `127.0.0.1:8080` where it will accept requests without authentication. Many Kubernetes installers explicitly disable the API Server's insecure port, but in clusters where it is not disabled, an attacker with access to another system on the same LAN or with control of a container running on the master may be able to reach the API server and execute arbitrary API requests on the cluster. This port is deprecated, and will be removed in Kubernetes v1.20.\r\n\r\n### Am I vulnerable?\r\n\r\nYou may be vulnerable if:\r\n\r\n- You are running a vulnerable version (see below)\r\n- Your cluster nodes run in an environment where untrusted hosts share the same layer 2 domain (i.e. same LAN) as nodes\r\n- Your cluster allows untrusted pods to run containers with `CAP_NET_RAW` (the Kubernetes default is to allow this capability).\r\n- Your nodes (or hostnetwork pods) run any localhost-only services which do not require any further authentication. To list services that are potentially affected, run the following commands on nodes:\r\n - `lsof +c 15 -P -n -i4TCP@127.0.0.1 -sTCP:LISTEN`\r\n - `lsof +c 15 -P -n -i4UDP@127.0.0.1`\r\n\r\n On a master node, an lsof entry like this indicates that the API server may be listening with an insecure port:\r\n\r\n```\r\nCOMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME\r\nkube-apiserver 123 root 7u IPv4 26799 0t0 TCP 127.0.0.1:8080 (LISTEN)\r\n```\r\n\r\n#### Affected Versions\r\n- kubelet/kube-proxy v1.18.0-1.18.3\r\n- kubelet/kube-proxy v1.17.0-1.17.6\r\n- kubelet/kube-proxy \u003c=1.16.10\r\n\r\n### How do I mitigate this vulnerability?\r\nPrior to upgrading, this vulnerability can be mitigated by manually adding an iptables rule on nodes. This rule will reject traffic to 127.0.0.1 which does not originate on the node.\r\n\r\n` iptables -I INPUT --dst 127.0.0.0/8 ! --src 127.0.0.0/8 -m conntrack ! --ctstate RELATED,ESTABLISHED,DNAT -j DROP`\r\n\r\nAdditionally, if your cluster does not already have the API Server insecure port disabled, we strongly suggest that you disable it. Add the following flag to your kubernetes API server command line: `--insecure-port=0`\r\n#### Detection\r\nPackets on the wire with an IPv4 destination in the range 127.0.0.0/8 and a layer-2 destination MAC address of a node may indicate that an attack is targeting this vulnerability.\r\n\r\n#### Fixed Versions\r\nAlthough the issue is caused by `kube-proxy`, the current fix for the issue is in `kubelet` (although future versions may have the fix in `kube-proxy` instead). We recommend updating both `kubelet` and `kube-proxy` to be sure the issue is addressed.\r\n\r\nThe following versions contain the fix:\r\n \r\n- kubelet/kube-proxy master - fixed by #91569\r\n- kubelet/kube-proxy v1.18.4+ - fixed by #92038\r\n- kubelet/kube-proxy v1.17.7+ - fixed by #92039\r\n- kubelet/kube-proxy v1.16.11+ - fixed by #92040\r\n\r\nTo upgrade, refer to the documentation: https://kubernetes.io/docs/tasks/administer-cluster/cluster-management/#upgrading-a-cluster\r\n\r\n\r\n## Additional Details\r\nThis issue was originally raised in issue #90259 which details how the `kube-proxy` sets `net.ipv4.conf.all.route_localnet=1` which causes the system not to reject traffic to localhost which originates on other hosts.\r\n\r\nIPv6-only services that bind to a `localhost` address are not affected. \r\n\r\nThere may be additional attack vectors possible in addition to those fixed by #91569 and its cherry-picks. For those attacks to succeed, the target service would need to be UDP and the attack could only rely upon sending UDP datagrams since it wouldn't receive any replies. Finally, the target node would need to have reverse-path filtering disabled for an attack to have any effect. Work is ongoing to determine whether and how this issue should be fixed. See #91666 for up-to-date status on this issue. \r\n\r\n#### Acknowledgements\r\nThis vulnerability was reported by János Kövér, Ericsson with additional impacts reported by Rory McCune, NCC Group and Yuval Avrahami and Ariel Zelivansky, Palo Alto Networks.\r\n\r\n/area security\r\n/kind bug\r\n/committee product-security\r\n/sig network\r\n/sig node\r\n/area kubelet", + "date_published": "2020-06-19T18:38:58Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2020-8558", + "id": "CVE-2020-8558", + "summary": "Node setting allows for neighboring hosts to bypass localhost boundary", + "url": "https://github.com/kubernetes/kubernetes/issues/92315" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2020-8555", + "issue_number": 91542 + }, + "content_text": "CVSS Rating: [CVSS:3.0/AV:N/AC:H/PR:L/UI:N/S:C/C:H/I:N/A:N](https://www.first.org/cvss/calculator/3.0#CVSS:3.0/AV:N/AC:H/PR:L/UI:N/S:C/C:H/I:N/A:N)\r\n\r\nThere exists a Server Side Request Forgery (SSRF) vulnerability in kube-controller-manager that allows certain authorized users to leak up to 500 bytes of arbitrary information from unprotected endpoints within the master's host network (such as link-local or loopback services).\r\n \r\nAn attacker with permissions to create a pod with certain built-in Volume types (GlusterFS, Quobyte, StorageOS, ScaleIO) or permissions to create a StorageClass can cause kube-controller-manager to make GET requests or POST requests without an attacker controlled request body from the master's host network.\r\n \r\n### Am I vulnerable?\r\n\r\nYou may be vulnerable if:\r\n\r\n- You are running a vulnerable version (see below)\r\n- There are unprotected endpoints normally only visible from the Kubernetes master (including link-local metadata endpoints, unauthenticated services listening on localhost, or other services in the master's private network)\r\n- Untrusted users can create pods with an affected volume type or modify storage classes.\r\n\r\n#### Affected Versions\r\n\r\n- kube-controller-manager v1.18.0\r\n- kube-controller-manager v1.17.0 - v1.17.4\r\n- kube-controller-manager v1.16.0 - v1.16.8\r\n- kube-controller-manager \u003c= v1.15.11\r\n \r\nThe affected volume types are: GlusterFS, Quobyte, StorageOS, ScaleIO\r\n\r\n### How do I mitigate this vulnerability?\r\n\r\nPrior to upgrading, this vulnerability can be mitigated by adding endpoint protections on the master or restricting usage of the vulnerable volume types (for example by constraining usage with a [PodSecurityPolicy](https://kubernetes.io/docs/concepts/policy/pod-security-policy/#volumes-and-file-systems) or third-party admission controller such as [Gatekeeper](https://github.com/open-policy-agent/gatekeeper)) and restricting StorageClass write permissions through RBAC.\r\n\r\n#### Fixed Versions\r\n\r\nThe information leak was patched in the following versions:\r\n\r\n- kube-controller-manager master - fixed by https://github.com/kubernetes/kubernetes/pull/89794\r\n- kube-controller-manager v1.18.1+ - fixed by https://github.com/kubernetes/kubernetes/pull/89796\r\n- kube-controller-manager v1.17.5+ - fixed by https://github.com/kubernetes/kubernetes/pull/89837\r\n- kube-controller-manager v1.16.9+ - fixed by https://github.com/kubernetes/kubernetes/pull/89838\r\n- kube-controller-manager v1.15.12+ - fixed by https://github.com/kubernetes/kubernetes/pull/89839\r\n\r\nTo upgrade, refer to the documentation: https://kubernetes.io/docs/tasks/administer-cluster/cluster-management/#upgrading-a-cluster\r\n\r\n## Additional Details\r\n\r\nExploitation of this vulnerability causes the kube-controller-manager to make a request to a user-supplied, unvalidated URL. The request does not include any kube-controller-manager client credentials.\r\n\r\n#### Acknowledgements\r\n\r\nThis vulnerability was reported by Brice Augras from Groupe-Asten and Christophe Hauquiert from Nokia.\r\n\r\n/area security\r\n/kind bug\r\n/committee product-security\r\n/sig storage\r\n/area controller-manager", + "date_published": "2020-05-28T16:13:34Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2020-8555", + "id": "CVE-2020-8555", + "summary": "Half-Blind SSRF in kube-controller-manager", + "url": "https://github.com/kubernetes/kubernetes/issues/91542" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2020-10749", + "issue_number": 91507 + }, + "content_text": "CVSS Rating: [CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:C/C:L/I:L/A:L](https://www.first.org/cvss/calculator/3.1#CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:C/C:L/I:L/A:L) (6.0 Medium)\r\n\r\nA cluster configured to use an affected container networking implementation is susceptible to man-in-the-middle (MitM) attacks. By sending “rogue” router advertisements, a malicious container can reconfigure the host to redirect part or all of the IPv6 traffic of the host to the attacker-controlled container. Even if there was no IPv6 traffic before, if the DNS returns A (IPv4) and AAAA (IPv6) records, many HTTP libraries will try to connect via IPv6 first then fallback to IPv4, giving an opportunity to the attacker to respond.\r\n\r\n### Am I vulnerable?\r\n\r\nKubernetes itself is not vulnerable. A Kubernetes cluster using an affected networking implementation is vulnerable.\r\n\r\nBinary releases of the kubelet installed from upstream Kubernetes Community repositories hosted at https://packages.cloud.google.com/ may have also installed the `kubernetes-cni` package containing the [containernetworking CNI plugins](https://github.com/containernetworking/plugins), which are affected by CVE-2020-10749.\r\n\r\n#### Affected Versions\r\nThe following official kubelet package versions have an affected `kubernetes-cni` package as a dependency: \r\n- kubelet v1.18.0-v1.18.3\r\n- kubelet v1.17.0-v1.17.6\r\n- kubelet \u003c v1.16.11\r\n\r\nA cluster having an affected `kubernetes-cni` package installed is only affected if configured to use it.\r\n#### Third-party components and versions\r\nMany container networking implementations are affected, including:\r\n\r\n- CNI Plugins maintained by the containernetworking team, prior to version 0.8.6 (CVE-2020-10749) (See https://github.com/containernetworking/plugins/pull/484)\r\n- Calico and Calico Enterprise (CVE-2020-13597) Please refer to the Tigera Advisory TTA-2020-001 at https://www.projectcalico.org/security-bulletins/ for details\r\n- Docker versions prior to 19.03.11 (see https://github.com/docker/docker-ce/releases/v19.03.11) (CVE-2020-13401)\r\n- Flannel, all current versions\r\n- Weave Net, prior to version 2.6.3\r\n\r\nIt is believed that the following are not affected:\r\n\r\n- Cilium\r\n- Juniper Contrail Networking\r\n- OpenShift SDN\r\n- OVN-Kubernetes\r\n- Tungsten Fabric\r\n\r\nInformation about the vulnerability status of any plugins or implementations not listed above is currently unavailable. Please contact the provider directly with questions about their implementation.\r\n\r\n### How do I mitigate this vulnerability?\r\n- Set the host default to reject router advertisements. This should prevent attacks from succeeding, but may break legitimate traffic, depending upon the networking implementation and the network where the cluster is running. To change this setting, set the sysctl `net.ipv6.conf.all.accept_ra` to 0.\r\n- Use TLS with proper certificate validation\r\n- Disallow `CAP_NET_RAW` for untrusted workloads or users. For example, a Pod Security Policy with a `RequiredDropCapabilities` that includes `NET_RAW` will prevent this attack for controlled workloads.\r\n\r\n#### Fixed Versions\r\n\r\nThe following packages will bundle fixed versions of the containernetworking CNI plugins that were formerly installed via the `kubernetes-cni` package.\r\n- kubelet v1.19.0+ (master branch #91370)\r\n- kubelet v1.18.4+ (#91387)\r\n- kubelet v1.17.7+ (#91386)\r\n- kubelet v1.16.11+ (#91388)\r\n\r\nBecause these versions are not yet available, cluster administrators using packages from the Kubernetes repositories may choose to manually upgrade CNI plugins by retrieving the relevant arch tarball from the containernetworking/plugins [v0.8.6 release](https://github.com/containernetworking/plugins/releases/tag/v0.8.6). The patch versions are [expected to be released on June 17th](https://github.com/kubernetes/sig-release/blob/master/releases/patch-releases.md#timelines), subject to change.\r\n\r\n## Additional Details\r\n#### Detection\r\n\r\n- The IPv6 routing table on nodes will show any attacker-created entries. For example, a host with IPv6 disabled might show no default route when running `ip -6 route` but the same host with an attack in progress might show an updated default route or a route to the target address(es). Any IPv6 route with a destination interface of a host-side container network interface should be investigated.\r\n- The host-side of a container network interface may show additional configured IPv6 addresses after receiving a rogue RA packet. For example, given a host-side interface of `cbr0` which might normally have no IPv6 address, a dynamic-configured address on the interface may signal an attack in progress. Use this command to view interface addresses: `ip a show dynamic cbr0`\r\n\r\n#### Affected configurations\r\n\r\n- Clusters using an affected networking implementation and allowing workloads to run with `CAP_NET_RAW privileges`. The default Kubernetes security context runs workloads with a capabilities bounding set that includes `CAP_NET_RAW`. \r\n\r\n#### Vulnerability impact\r\n\r\n- A user able to create containers with `CAP_NET_RAW` privileges on an affected cluster can intercept traffic from other containers on the host or from the host itself.\r\n\r\n#### Acknowledgements\r\n\r\nThis vulnerability was reported by Etienne Champetier (@champtar).\r\n\r\nThe issue was fixed by Casey Callendrello (@squeed) and maintainers of various container networking implementations. Updates to Kubernetes builds were coordinated by Stephen Augustus (@justaugustus) and Tim Pepper (@tpepper).\r\n\r\n/area security\r\n/kind bug\r\n/committee product-security\r\n/sig network\r\n", + "date_published": "2020-05-27T19:32:29Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2020-10749", + "id": "CVE-2020-10749", + "summary": "IPv4 only clusters susceptible to MitM attacks via IPv6 rogue router advertisements", + "url": "https://github.com/kubernetes/kubernetes/issues/91507" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2019-11254", + "issue_number": 89535 + }, + "content_text": "CVE-2019-11254 is a denial of service vulnerability in the kube-apiserver, allowing authorized users sending malicious YAML payloads to cause kube-apiserver to consume excessive CPU cycles while parsing YAML.\r\n \r\nThe issue was discovered via the fuzz test kubernetes/kubernetes#83750.\r\n \r\n**Affected components:**\r\nKubernetes API server\r\n \r\n**Affected versions:**\r\n\u003c= v1.15.9, resolved in 1.15.10 by https://github.com/kubernetes/kubernetes/pull/87640\r\nv1.16.0-v1.16.7, resolved in 1.16.8 by https://github.com/kubernetes/kubernetes/pull/87639\r\nv1.17.0-v1.17.2, resolved in 1.17.3 by https://github.com/kubernetes/kubernetes/pull/87637\r\nFixed in master by https://github.com/kubernetes/kubernetes/pull/87467\r\n \r\n**How do I mitigate this vulnerability?**\r\nPrior to upgrading, these vulnerabilities can be mitigated by preventing unauthenticated or unauthorized access to kube-apiserver.", + "date_published": "2020-03-26T18:55:26Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2019-11254", + "id": "CVE-2019-11254", + "summary": "kube-apiserver Denial of Service vulnerability from malicious YAML payloads", + "url": "https://github.com/kubernetes/kubernetes/issues/89535" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2020-8552", + "issue_number": 89378 + }, + "content_text": "CVSS Rating: [CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L](https://www.first.org/cvss/calculator/3.0#CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L) (Medium)\r\n\r\nThe Kubernetes API server has been found to be vulnerable to a denial of service attack via authorized API requests.\r\n\r\n### Am I vulnerable?\r\n\r\nIf an attacker that can make an authorized resource request to an unpatched API server (see below), then you are vulnerable to this. Prior to v1.14, this was possible via unauthenticated requests by default.\r\n\r\n#### Affected Versions\r\n\r\n- kube-apiserver v1.17.0 - v1.17.2\r\n- kube-apiserver v1.16.0 - v1.16.6\r\n- kube-apiserver \u003c v1.15.10\r\n\r\n### How do I mitigate this vulnerability?\r\n\r\nPrior to upgrading, this vulnerability can be mitigated by:\r\n- Preventing unauthenticated or unauthorized access to all apis\r\n- The apiserver should auto restart if it OOMs\r\n\r\n#### Fixed Versions\r\n\r\n- v1.17.3\r\n- v1.16.7\r\n- v1.15.10\r\n\r\nTo upgrade, refer to the documentation: https://kubernetes.io/docs/tasks/administer-cluster/cluster-management/#upgrading-a-cluster\r\n\r\n#### Acknowledgements\r\n\r\nThis vulnerability was reported by: Gus Lees (Amazon)\r\n\r\n/area security\r\n/kind bug\r\n/committee product-security\r\n/sig api-machinery", + "date_published": "2020-03-23T18:35:34Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2020-8552", + "id": "CVE-2020-8552", + "summary": "apiserver DoS (oom)", + "url": "https://github.com/kubernetes/kubernetes/issues/89378" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2020-8551", + "issue_number": 89377 + }, + "content_text": "CVSS Rating: [CVSS:3.0/AV:A/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L](https://www.first.org/cvss/calculator/3.0#CVSS:3.0/AV:A/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:L) (Medium)\r\n\r\nThe Kubelet has been found to be vulnerable to a denial of service attack via the kubelet API, including the unauthenticated HTTP read-only API typically served on port 10255, and the authenticated HTTPS API typically served on port 10250.\r\n\r\n### Am I vulnerable?\r\n\r\nIf an attacker can make a request to an unpatched kubelet, then you may be vulnerable to this.\r\n\r\n#### Affected Versions\r\n\r\n- kubelet v1.17.0 - v1.17.2\r\n- kubelet v1.16.0 - v1.16.6\r\n- kubelet v1.15.0 - v1.15.9\r\n\r\n### How do I mitigate this vulnerability?\r\n\r\nLimit access to the Kubelet API or patch the Kubelet.\r\n\r\n#### Fixed Versions\r\n\r\n- v1.17.3\r\n- v1.16.7\r\n- v1.15.10\r\n\r\nTo upgrade, refer to the documentation: https://kubernetes.io/docs/tasks/administer-cluster/cluster-management/#upgrading-a-cluster\r\n\r\n#### Acknowledgements\r\n\r\nThis vulnerability was reported by: Henrik Schmidt\r\n\r\n/area security\r\n/kind bug\r\n/committee product-security\r\n/sig node\r\n/area kubelet", + "date_published": "2020-03-23T18:34:40Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2020-8551", + "id": "CVE-2020-8551", + "summary": "Kubelet DoS via API", + "url": "https://github.com/kubernetes/kubernetes/issues/89377" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2019-11251", + "issue_number": 87773 + }, + "content_text": "A security issue was discovered in kubectl versions v1.13.10, v1.14.6, and v1.15.3. The issue is of a medium severity and upgrading of kubectl is encouraged to fix the vulnerability.\r\n\r\n**Am I vulnerable?**\r\n\r\nRun kubectl version --client and if it returns versions v1.13.10, v1.14.6, and v1.15.3, you are running a vulnerable version.\r\n\r\n**How do I upgrade?**\r\n\r\nFollow installation instructions [here](https://kubernetes.io/docs/tasks/tools/install-kubectl/)\r\n\r\n**Vulnerability Details**\r\n\r\nThe details for this vulnerability are very similar to CVE-2019-1002101 and CVE-2019-11246.\r\nA vulnerability has been discovered in kubectl cp that allows a combination of two symlinks to copy a file outside of its destination directory. This could be used to allow an attacker to place a nefarious file using a symlink, outside of the destination tree.\r\n\r\nThis issue is filed as CVE-2019-11251.\r\n\r\nTwo fixes were formulated, one fix to remove symlink support going forwards and a fix with cherry picks made to ensure backwards compatibility.\r\n\r\nSee https://github.com/kubernetes/kubernetes/pull/82143 for the primary fix in v1.16.0 which removes the support of symlinks in kubectl cp. After version 1.16.0, symlink support with kubectl cp is removed, it is recommended instead to use a combination of exec+tar.\r\n\r\nA second fix has been made to 1.15.4 and backported to 1.14.7 and 1.13.11. This changes the kubectl cp un-tar symlink logic, by unpacking the symlinks after all the regular files have been unpacked. This then guarantees that a file can’t be written through a symlink.\r\n\r\nSee https://github.com/kubernetes/kubernetes/pull/82384 for the fix to version 1.15.4. The following Cherry picks were made from this fix to earlier versions of v1.14.7 and v1.13.11:\r\n\r\nSee https://github.com/kubernetes/kubernetes/pull/82502 for version 1.14.7\r\nSee https://github.com/kubernetes/kubernetes/pull/82503 for version 1.13.11\r\n\r\nThank you to Erik Sjölund (@eriksjolund) for discovering this issue, Tim Allclair and Maciej Szulik for both fixes and the patch release managers for including the fix in their releases.\r\n\r\n/close", + "date_published": "2020-02-03T15:12:22Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2019-11251", + "id": "CVE-2019-11251", + "summary": "kubectl cp symlink vulnerability", + "url": "https://github.com/kubernetes/kubernetes/issues/87773" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2018-1002102", + "issue_number": 85867 + }, + "content_text": "CVSS Rating: [CVSS:3.0/AV:N/AC:H/PR:H/UI:R/S:C/C:L/I:N/A:N/E:F (Low)](https://www.first.org/cvss/calculator/3.0#CVSS:3.0/AV:N/AC:H/PR:H/UI:R/S:C/C:L/I:N/A:N/E:F)\r\n\r\nAn attacker-controlled Kubelet can return an arbitrary redirect when responding to certain apiserver requests. Impacted kube-apiservers will follow the redirect as a GET request with client-cert credentials for authenticating to the Kubelet.\r\n\r\n### Am I vulnerable?\r\n\r\nKubernetes API servers with the `StreamingProxyRedirects` [feature](https://kubernetes.io/docs/reference/command-line-tools-reference/feature-gates/) enabled AND without the `ValidateProxyRedirects` feature are affected.\r\n\r\nAPI servers using SSH tunnels (--ssh-user / --ssh-keyfile) are not affected.\r\n\r\nUsing the default feature gate values, kube-apiserver versions before v1.14 are affected.\r\n\r\n### How do I mitigate this vulnerability?\r\n\r\nFor Kubernetes versions \u003e= v1.10.0, the `ValidateProxyRedirects` can be manually enabled with the `kube-apiserver` flag `--feature-gates=ValidateProxyRedirects=true`.\r\n\r\n#### Fix impact\r\nThe `ValidateProxyRedirects` feature will cause the kube-apiserver to check that redirects go to the same host. If nodes are configured to respond to CRI streaming requests on a different host interface than what the apiserver makes requests on (only the case if not using the built-in dockershim \u0026 setting the kubelet flag `--redirect-container-streaming=true`), then these requests will be broken. In that case, the feature can be temporarily disabled until the node configuration is corrected. We suggest setting `--redirect-container-streaming=false` on the kubelet to avoid issues.\r\n\r\n#### Fixed Versions\r\n\r\n- Kubernetes v1.14+ - Fixed by default in https://github.com/kubernetes/kubernetes/pull/72552\r\n- Kubernetes v1.10-v1.14 - Fix available as alpha in https://github.com/kubernetes/kubernetes/pull/66516\r\n\r\n## Additional Details\r\n\r\nIn a future release, we plan to deprecate the `StreamingProxyRedirects` feature, instead opting to handle the redirection locally through the Kubelet. Once the deprecation is complete, we can completely remove apiserver redirect handling (at least for Kubelet requests).\r\n\r\n#### Acknowledgements\r\n\r\nThis vulnerability was reported by Alban Crequy.\r\n\r\n/area security\r\n/kind bug\r\n/committee product-security\r\n/sig api-machinery node\r\n/area apiserver\r\n\r\n/close", + "date_published": "2019-12-03T22:58:37Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2018-1002102", + "id": "CVE-2018-1002102", + "summary": "Unvalidated redirect", + "url": "https://github.com/kubernetes/kubernetes/issues/85867" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2019-11255", + "issue_number": 85233 + }, + "content_text": "\u003c!-- Please use this template while reporting a bug and provide as much info as possible. Not doing so may result in your bug not being addressed in a timely manner. Thanks!\r\n\r\nIf the matter is security related, please disclose it privately via https://kubernetes.io/security/\r\n--\u003e\r\n\r\n**Am I vulnerable?**\r\n\r\nCSI snapshot, cloning and resizing features are affected. Prior to Kubernetes 1.16, these features were all alpha and disabled by default. Starting in Kubernetes 1.16, CSI cloning and resizing features are beta and enabled by default. \r\n\r\nThese features also require CSI drivers to be installed in a Kubernetes cluster and the CSI driver also has to support those features. An unofficial list of CSI drivers and their supported features is available [here](https://kubernetes-csi.github.io/docs/drivers.html), however it is best to check with the CSI driver vendor for the latest information.\r\n\r\nCheck if you have the following Kubernetes feature gates enabled:\r\n\r\n```\r\nVolumeSnapshotDataSource: alpha starting with K8s 1.12\r\nExpandCSIVolumes: alpha starting with K8s 1.14, beta starting with K8s 1.16\r\nVolumePVCDataSource: alpha starting with K8s 1.15, beta starting with K8s 1.16\r\n```\r\n\r\nCheck if you are using CSI drivers in your cluster. If so, the following command’s output will be non-empty:\r\n\r\n```\r\n$ kubectl get nodes -o jsonpath='{.items[*].metadata.annotations.csi\\.volume\\.kubernetes\\.io\\/nodeid}'\r\n {\"my-csi-plugin\":\"kubernetes-minion-group-433q\"}\r\n```\r\n\r\nThen, check the CSI driver’s pod specifications to see if they are using the following vulnerable versions of sidecars:\r\n\r\n```\r\nexternal-provisioner: v0.4.1-0.4.2, v1.0.0-1.0.1, v1.1.0-1.2.1, v1.3.0\r\nexternal-snapshotter: v0.4.0-0.4.1, v1.0.0-1.0.1, v1.1.0-v1.2.1\r\nexternal-resizer: v0.1.0-0.2.0\r\n```\r\n\r\nAn example query:\r\n```\r\n$ kubectl get pods --all-namespaces -o jsonpath='{..image}' | tr ' ' $'\\n' | grep \"csi-provisioner\\|csi-snapshotter\\|csi-resizer\"\r\n image: quay.io/k8scsi/csi-provisioner:v1.2.0\r\n```\r\n\r\nNote that the exact container image name may vary across CSI driver vendors. It is recommended to inspect the Pod specifications directly.\r\n\r\n**How do I mitigate the vulnerability?**\r\n\r\nAs a short term mitigation, disable the `VolumeSnapshotDataSource`, `ExpandCSIVolumes`, and `VolumePVCDataSource` Kubernetes feature gates in kube-apiserver and kube-controller-manager. This will cause new PersistentVolumeClaims to be provisioned ignoring the DataSource and resizing requests will also be ignored. Note that this will cause new PVCs that are intended to be provisioned from a snapshot or clone to instead provision a blank disk.\r\n\r\nAlso, to disable taking volume snapshots, either remove the external-snapshotter sidecar from any CSI drivers or revoke the CSI driver’s RBAC permissions on the `snapshot.storage.k8s.io` API group.\r\n\r\nLonger term, upgrade your CSI driver with patched versions of the affected sidecars. Fixes are available in the following sidecar versions:\r\n\r\nexternal-provisioner: \r\nv0.4.3\r\nv1.0.2\r\nv1.2.2\r\nv1.3.1\r\nv1.4.0 \r\n\r\nexternal-snapshotter:\r\nv0.4.2\r\nv1.0.2\r\nv1.2.2\r\n\r\nexternal-resizer\r\nv0.3.0\r\n\r\nFixes for each of the sidecars can be tracked by:\r\nhttps://github.com/kubernetes-csi/external-provisioner/issues/380\r\nhttps://github.com/kubernetes-csi/external-snapshotter/issues/193\r\nhttps://github.com/kubernetes-csi/external-resizer/issues/63\r\n\r\n**How do I upgrade?**\r\n\r\nCheck with your CSI driver vendor for upgrade instructions. No Kubernetes control plane or node upgrades are required unless the CSI driver is bundled into the Kubernetes distribution.\r\n\r\n**Vulnerability details**\r\n\r\nThere are two different vulnerabilities impacting the same features.\r\n\r\nWhen PersistentVolumeClaim and PersistentVolume objects are bound, they have bidirectional references to each other. When dereferencing a PersistentVolumeClaim to get a PersistentVolume, the impacted sidecar controllers were not validating that the PersistentVolume referenced back to the same PersistentVolumeClaim, potentially operating on unauthorized PersistentVolumes for snapshot, cloning and resizing operations.\r\n\r\nA similar issue exists for VolumeSnapshot and VolumeSnapshotContent objects when creating a new PersistentVolumeClaim from a snapshot.\r\n\r\nThe second issue is related to the property that CSI volume and snapshot ids are only required to be unique within a single CSI driver. Impacted sidecar controllers were not validating that the requested source VolumeSnapshot or PersistentVolumeClaim specified were from the same driver processing the request, potentially operating on unauthorized volumes during snapshot, restore from snapshot, or cloning operations.\r\n\r\n", + "date_published": "2019-11-13T20:57:31Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2019-11255", + "id": "CVE-2019-11255", + "summary": "CSI volume snapshot, cloning and resizing features can result in unauthorized volume data access or mutation", + "url": "https://github.com/kubernetes/kubernetes/issues/85233" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2019-11253", + "issue_number": 83253 + }, + "content_text": "CVE-2019-11253 is a denial of service vulnerability in the kube-apiserver, allowing authorized users sending malicious YAML or JSON payloads to cause kube-apiserver to consume excessive CPU or memory, potentially crashing and becoming unavailable. This vulnerability has been given an initial severity of High, with a score of 7.5 ([CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H](https://www.first.org/cvss/calculator/3.0#CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H)).\r\n\r\nPrior to v1.14.0, default RBAC policy authorized anonymous users to submit requests that could trigger this vulnerability. Clusters upgraded from a version prior to v1.14.0 keep the more permissive policy by default for backwards compatibility. See the mitigation section below for instructions on how to install the more restrictive v1.14+ policy.\r\n\r\n**Affected versions:**\r\n* Kubernetes v1.0.0-1.12.x\r\n* Kubernetes v1.13.0-1.13.11, resolved in v1.13.12 by https://github.com/kubernetes/kubernetes/pull/83436\r\n* Kubernetes v1.14.0-1.14.7, resolved in v1.14.8 by https://github.com/kubernetes/kubernetes/pull/83435\r\n* Kubernetes v1.15.0-1.15.4, resolved in v1.15.5 by https://github.com/kubernetes/kubernetes/pull/83434\r\n* Kubernetes v1.16.0-1.16.1, resolved in v1.16.2 by https://github.com/kubernetes/kubernetes/pull/83433\r\n\r\nAll four patch releases are now available.\r\n\r\nFixed in master by #83261\r\n\r\n**Mitigation:**\r\n\r\nRequests that are rejected by authorization do not trigger the vulnerability, so managing authorization rules and/or access to the Kubernetes API server mitigates which users are able to trigger this vulnerability.\r\n\r\nTo manually apply the more restrictive v1.14.x+ policy, either as a pre-upgrade mitigation, or as an additional protection for an upgraded cluster, save the [attached file](https://github.com/kubernetes/kubernetes/files/3735508/rbac.yaml.txt) as `rbac.yaml`, and run:\r\n\r\n```sh\r\nkubectl auth reconcile -f rbac.yaml --remove-extra-subjects --remove-extra-permissions \r\n```\r\n\r\n**Note: this removes the ability for unauthenticated users to use `kubectl auth can-i`**\r\n\r\nIf you are running a version prior to v1.14.0:\r\n* in addition to installing the restrictive policy, turn off autoupdate for this clusterrolebinding so your changes aren’t replaced on an API server restart:\r\n ```sh\r\n kubectl annotate --overwrite clusterrolebinding/system:basic-user rbac.authorization.kubernetes.io/autoupdate=false\r\n ```\r\n* after upgrading to v1.14.0 or greater, you can remove this annotation to reenable autoupdate:\r\n ```sh\r\n kubectl annotate --overwrite clusterrolebinding/system:basic-user rbac.authorization.kubernetes.io/autoupdate=true\r\n ```\r\n\r\n=============\r\n\r\n**Original description follows:**\r\n\r\n**Introduction** \r\n\r\nPosting this as an issue following report to the security list who suggested putting it here as it's already public in a Stackoverflow question [here](https://stackoverflow.com/questions/58129150/security-yaml-bomb-user-can-restart-kube-api-by-sending-configmap/58133282#58133282)\r\n\r\n**What happened**:\r\n\r\nWhen creating a ConfigMap object which has recursive references contained in it, excessive CPU usage can occur. This appears to be an instance of a [\"Billion Laughs\" attack](https://en.wikipedia.org/wiki/Billion_laughs_attack) which is quite well known as an XML parsing issue.\r\n\r\nApplying this manifest to a cluster causes the client to hang for some time with considerable CPU usage.\r\n\r\n```\r\napiVersion: v1\r\ndata:\r\n a: \u0026a [\"web\",\"web\",\"web\",\"web\",\"web\",\"web\",\"web\",\"web\",\"web\"]\r\n b: \u0026b [*a,*a,*a,*a,*a,*a,*a,*a,*a]\r\n c: \u0026c [*b,*b,*b,*b,*b,*b,*b,*b,*b]\r\n d: \u0026d [*c,*c,*c,*c,*c,*c,*c,*c,*c]\r\n e: \u0026e [*d,*d,*d,*d,*d,*d,*d,*d,*d]\r\n f: \u0026f [*e,*e,*e,*e,*e,*e,*e,*e,*e]\r\n g: \u0026g [*f,*f,*f,*f,*f,*f,*f,*f,*f]\r\n h: \u0026h [*g,*g,*g,*g,*g,*g,*g,*g,*g]\r\n i: \u0026i [*h,*h,*h,*h,*h,*h,*h,*h,*h]\r\nkind: ConfigMap\r\nmetadata:\r\n name: yaml-bomb\r\n namespace: default\r\n```\r\n**What you expected to happen**:\r\n\r\nIdeally it would be good for a maximum size of entity to be defined, or perhaps some limit on recursive references in YAML parsed by kubectl.\r\n\r\nOne note is that the original poster on Stackoverflow indicated that the resource consumption was in `kube-apiserver` but both tests I did (1.16 client against 1.15 Kubeadm cluster and 1.16 client against 1.16 kubeadm cluster) showed the CPU usage client-side.\r\n\r\n**How to reproduce it (as minimally and precisely as possible)**:\r\n\r\nGet the manifest above and apply to a cluster as normal with `kubectl create -f \u003cmanifest\u003e`. Use `top` or another CPU monitor to observe the quantity of CPU time used.\r\n\r\n**Anything else we need to know?**:\r\n\r\n**Environment**:\r\n- Kubernetes version (use `kubectl version`):\r\n\r\n**test 1** (linux AMD64 client, Kubeadm cluster running in kind)\r\n```\r\nClient Version: version.Info{Major:\"1\", Minor:\"16\", GitVersion:\"v1.16.0\", GitCommit:\"2bd9643cee5b3b3a5ecbd3af49d09018f0773c77\", GitTreeState:\"clean\", BuildDate:\"2019-09-18T14:36:53Z\", GoVersion:\"go1.12.9\", Compiler:\"gc\", Platform:\"linux/amd64\"}\r\nServer Version: version.Info{Major:\"1\", Minor:\"15\", GitVersion:\"v1.15.0\", GitCommit:\"e8462b5b5dc2584fdcd18e6bcfe9f1e4d970a529\", GitTreeState:\"clean\", BuildDate:\"2019-06-25T23:41:27Z\", GoVersion:\"go1.12.5\", Compiler:\"gc\", Platform:\"linux/amd64\"}\r\n```\r\n\r\n**test 2** (Linux AMD64 client, Kubeadm cluster running in VMWare Workstation)\r\n```\r\nClient Version: version.Info{Major:\"1\", Minor:\"16\", GitVersion:\"v1.16.0\", GitCommit:\"2bd9643cee5b3b3a5ecbd3af49d09018f0773c77\", GitTreeState:\"clean\", BuildDate:\"2019-09-18T14:36:53Z\", GoVersion:\"go1.12.9\", Compiler:\"gc\", Platform:\"linux/amd64\"}\r\nServer Version: version.Info{Major:\"1\", Minor:\"16\", GitVersion:\"v1.16.0\", GitCommit:\"2bd9643cee5b3b3a5ecbd3af49d09018f0773c77\", GitTreeState:\"clean\", BuildDate:\"2019-09-18T14:27:17Z\", GoVersion:\"go1.12.9\", Compiler:\"gc\", Platform:\"linux/amd64\"}\r\n```\r\n\r\n", + "date_published": "2019-09-27T16:53:31Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2019-11253", + "id": "CVE-2019-11253", + "summary": "Kubernetes API Server JSON/YAML parsing vulnerable to resource exhaustion attack", + "url": "https://github.com/kubernetes/kubernetes/issues/83253" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2019-11250", + "issue_number": 81114 + }, + "content_text": "This issue was reported in the [Kubernetes Security Audit Report](https://github.com/kubernetes/community/blob/master/wg-security-audit/findings/Kubernetes%20Final%20Report.pdf)\r\n\r\n**Description**\r\nKubernetes requires an authentication mechanism to enforce users’ privileges. One method of authentication, bearer tokens, are opaque strings used to associate a user with their having successfully authenticated previously. Any user with possession of this token may masquerade as the original user (the “bearer”) without further authentication.\r\n\r\nWithin Kubernetes, the bearer token is captured within the hyperkube kube-apiserver system logs at high verbosity levels (--v 10). A malicious user with access to the system logs on such a system could masquerade as any user who has previously logged into the system.\r\n\r\n**Exploit Scenario**\r\nAlice logs into a Kubernetes cluster and is issued a Bearer token. The system logs her token. Eve, who has access to the logs but not the production Kubernetes cluster, replays Alice’s Bearer token, and can masquerade as Alice to the cluster.\r\n\r\n**Recommendation**\r\nShort term, remove the Bearer token from the log. Do not log any authentication credentials within the system, including tokens, private keys, or passwords that may be used to authenticate to the production Kubernetes cluster, regardless of the logging level.\r\n\r\nLong term, either implement policies that enforce code review to ensure that sensitive data is not exposed in logs, or implement logging filters that check for sensitive data and remove it prior to outputting the log. In either case, ensure that sensitive data cannot be trivially stored in logs. \r\n\r\n**Anything else we need to know?**:\r\n\r\nSee #81146 for current status of all issues created from these findings.\r\n\r\nThe vendor gave this issue an ID of TOB-K8S-001 and it was finding 6 of the report.\r\n\r\nThe vendor considers this issue Medium Severity.\r\n\r\nTo view the original finding, begin on page 31 of the [Kubernetes Security Review Report](https://github.com/kubernetes/community/blob/master/wg-security-audit/findings/Kubernetes%20Final%20Report.pdf)\r\n\r\n**Environment**:\r\n\r\n- Kubernetes version: 1.13.4", + "date_published": "2019-08-08T02:03:04Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2019-11250", + "id": "CVE-2019-11250", + "summary": "Bearer tokens are revealed in logs", + "url": "https://github.com/kubernetes/kubernetes/issues/81114" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2019-11248", + "issue_number": 81023 + }, + "content_text": "The debugging endpoint `/debug/pprof` is exposed over the unauthenticated Kubelet healthz port. Versions prior to 1.15.0, 1.14.4, 1.13.8, and 1.12.10 are affected. The issue is of medium severity, but not exposed by the default configuration. If you are exposed we recommend upgrading to at least one of the versions listed.\r\n\r\n**Am I vulnerable?**\r\nBy default, the Kubelet exposes unauthenticated healthz endpoints on port :10248, but only over localhost. If your nodes are using a non-localhost healthzBindAddress (--health-bind-address), and an older version, you may be vulnerable. If your nodes are using the default localhost healthzBindAddress, it is only exposed to pods or processes running in the host network namespace.\r\n\r\nRun `kubectl get nodes` to see whether nodes are running a vulnerable version.\r\n\r\nRun `kubectl get --raw /api/v1/nodes/${NODE_NAME}/proxy/configz` to check whether the \"healthzBindAddress\" is non-local.\r\n\r\n**How do I mitigate the vulnerability?**\r\n* Upgrade to a patched version (1.15.0+, 1.14.4+, 1.13.8+, or 1.12.10+)\r\n* or, update node configurations to set the \"healthzBindAddress\" to \"127.0.0.1\".\r\n\r\nhttps://github.com/kubernetes/kubernetes/pull/79184 fixed in 1.12.10\r\nhttps://github.com/kubernetes/kubernetes/pull/79183 fixed in 1.13.8\r\nhttps://github.com/kubernetes/kubernetes/pull/79182 fixed in 1.14.4\r\nhttps://github.com/kubernetes/kubernetes/pull/78313 fixed in 1.15.0\r\n\r\n**Vulnerability Details**\r\nThe `go pprof` endpoint is exposed over the Kubelet's healthz port. This debugging endpoint can potentially leak sensitive information such as internal Kubelet memory addresses and configuration, or for limited denial of service.\r\n\r\nThanks to Jordan Zebor of F5 Networks for reporting this problem.\r\n\r\n/area security\r\n/close", + "date_published": "2019-08-06T14:34:33Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2019-11248", + "id": "CVE-2019-11248", + "summary": "/debug/pprof exposed on kubelet's healthz port", + "url": "https://github.com/kubernetes/kubernetes/issues/81023" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2019-11249", + "issue_number": 80984 + }, + "content_text": "[CVSS:3.0/AV:N/AC:H/PR:L/UI:R/S:U/C:N/I:H/A:N](https://www.first.org/cvss/calculator/3.0#CVSS:3.0/AV:N/AC:H/PR:L/UI:R/S:U/C:N/I:H/A:N)\r\n\r\nA third issue was discovered with the Kubernetes `kubectl cp` command that could enable a directory traversal such that a malicious container could replace or create files on a user’s workstation. The vulnerability is a client-side defect and requires user interaction to be exploited.\r\n \r\n**Vulnerable versions:**\r\nKubernetes 1.0.x-1.12.x\r\nKubernetes 1.13.0-1.13.8\r\nKubernetes 1.14.0-1.14.4\r\nKubernetes 1.15.0-1.15.1\r\n \r\n**Vulnerable configurations:**\r\nAll `kubectl` clients running a vulnerable version and using the `cp` operation.\r\n \r\n**Vulnerability impact:**\r\nA malicious user can potentially create or overwrite files outside of the destination directory of the `kubectl cp` operation.\r\n \r\n**Mitigations prior to upgrading:**\r\nAvoid using `kubectl cp` with any untrusted workloads.\r\n \r\n**Fixed versions:**\r\nFixed in v1.13.9 by #80871\r\nFixed in v1.14.5 by #80870\r\nFixed in v1.15.2 by #80869\r\nFixed in master by #80436\r\n \r\n**Fix impact:**\r\nThe `kubectl cp` function is prevented from creating or modifying files outside the destination directory.\r\n\r\n**Acknowledgements:**\r\nThis issue was discovered by Yang Yang of Amazon, who also provided a patch. Thanks also to the release managers for creating the security releases.", + "date_published": "2019-08-05T12:44:23Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2019-11249", + "id": "CVE-2019-11249", + "summary": "Incomplete fixes for CVE-2019-1002101 and CVE-2019-11246, kubectl cp potential directory traversal", + "url": "https://github.com/kubernetes/kubernetes/issues/80984" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2019-11247", + "issue_number": 80983 + }, + "content_text": "[CVSS:3.0/AV:N/AC:H/PR:L/UI:N/S:U/C:L/I:L/A:L](https://www.first.org/cvss/calculator/3.0#CVSS:3.0/AV:N/AC:H/PR:L/UI:N/S:U/C:L/I:L/A:L)\r\n \r\nThe API server mistakenly allows access to a cluster-scoped custom resource if the request is made as if the resource were namespaced. Authorizations for the resource accessed in this manner are enforced using roles and role bindings within the namespace, meaning that a user with access only to a resource in one namespace could create, view update or delete the cluster-scoped resource (according to their namespace role privileges).\r\n \r\n**Vulnerable versions:**\r\nKubernetes 1.7.x-1.12.x\r\nKubernetes 1.13.0-1.13.8\r\nKubernetes 1.14.0-1.14.4\r\nKubernetes 1.15.0-1.15.1\r\n \r\n**Vulnerable configurations:**\r\nAll clusters that have rolebindings to roles and clusterroles that include authorization rules for cluster-scoped custom resources.\r\n \r\n**Vulnerability impact:**\r\nA user with access to custom resources in a single namespace can access custom resources with cluster scope.\r\n \r\n**Mitigations prior to upgrading:**\r\nTo mitigate, remove authorization rules that grant access to cluster-scoped resources within namespaces. For example, RBAC roles and clusterroles intended to be referenced by namespaced rolebindings should not grant access to `resources:[*], apiGroups:[*]`, or grant access to cluster-scoped custom resources.\r\n \r\n \r\n**Fixed versions:**\r\nFixed in v1.13.9 by #80852\r\nFixed in v1.14.5 by #80851\r\nFixed in v1.15.2 by #80850\r\nFixed in master by #80750\r\n \r\n**Fix impact:**\r\nPermission to the correct scope will be required to access cluster-scoped custom resources.\r\n\r\n**Acknowledgements:**\r\nThis issue was discovered by Prabu Shyam of Verizon Media. Thanks to Stefan Schimanski for the fix, to David Eads for the fix review, and to the release managers for creating the security releases.\r\n", + "date_published": "2019-08-05T12:44:08Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2019-11247", + "id": "CVE-2019-11247", + "summary": "API server allows access to custom resources via wrong scope", + "url": "https://github.com/kubernetes/kubernetes/issues/80983" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2019-11245", + "issue_number": 78308 + }, + "content_text": "[CVSS:3.0/AV:L/AC:H/PR:N/UI:N/S:U/C:L/I:L/A:L](https://www.first.org/cvss/calculator/3.0#CVSS:3.0/AV:L/AC:H/PR:N/UI:N/S:U/C:L/I:L/A:L), 4.9 (medium)\r\n\r\nIn kubelet v1.13.6 and v1.14.2, containers for pods that do not specify an explicit `runAsUser` attempt to run as uid 0 (root) on container restart, or if the image was previously pulled to the node. If the pod specified `mustRunAsNonRoot: true`, the kubelet will refuse to start the container as root. If the pod did not specify `mustRunAsNonRoot: true`, the kubelet will run the container as uid 0.\r\n\r\nCVE-2019-11245 will be **fixed** in the following Kubernetes releases:\r\n\r\n* v1.13.7 in https://github.com/kubernetes/kubernetes/pull/78320\r\n* v1.14.3 in https://github.com/kubernetes/kubernetes/pull/78316\r\n\r\nFixed by #78261 in master\r\n\r\n### Affected components:\r\n\r\n* Kubelet\r\n\r\n### Affected versions:\r\n\r\n* Kubelet v1.13.6\r\n* Kubelet v1.14.2\r\n\r\n### Affected configurations:\r\n\r\nClusters with:\r\n* Kubelet versions v1.13.6 or v1.14.2\r\n* Pods that do not specify an explicit `runAsUser: \u003cuid\u003e` or `mustRunAsNonRoot:true`\r\n\r\n### Impact:\r\n\r\nIf a pod is run without any user controls specified in the pod spec (like `runAsUser: \u003cuid\u003e` or `mustRunAsNonRoot:true`), a container in that pod that would normally run as the USER specified in the container image manifest can sometimes be run as root instead (on container restart, or if the image was previously pulled to the node)\r\n\r\n* pods that specify an explicit `runAsUser` are unaffected and continue to work properly\r\n* podSecurityPolicies that force a `runAsUser` setting are unaffected and continue to work properly\r\n* pods that specify `mustRunAsNonRoot:true` will refuse to start the container as uid 0, which can affect availability\r\n* pods that do not specify `runAsUser` or `mustRunAsNonRoot:true` will run as uid 0 on restart or if the image was previously pulled to the node\r\n\r\n### Mitigations:\r\n\r\nThis section lists possible mitigations to use prior to upgrading.\r\n\r\n* Specify `runAsUser` directives in pods to control the uid a container runs as\r\n* Specify `mustRunAsNonRoot:true` directives in pods to prevent starting as root (note this means the attempt to start the container will fail on affected kubelet versions)\r\n* Downgrade kubelets to v1.14.1 or v1.13.5 as instructed by your Kubernetes distribution.\r\n\r\n**original issue description follows**\r\n\r\n**What happened**:\r\n\r\nWhen I launch a pod from a docker image that specifies a USER in the Dockerfile, the container only runs as that user on its first launch. After that the container runs as UID=0.\r\n\r\n**What you expected to happen**:\r\nI expect the container to act consistently every launch, and probably with the USER specified in the container.\r\n\r\n**How to reproduce it (as minimally and precisely as possible)**:\r\nTesting with minikube (same test specifying v1.14.1, `kubectl logs test` always returns 11211):\r\n```\r\n$ minikube start --kubernetes-version v1.14.2\r\n😄 minikube v1.1.0 on linux (amd64)\r\n💿 Downloading Minikube ISO ...\r\n 131.28 MB / 131.28 MB [============================================] 100.00% 0s\r\n🔥 Creating virtualbox VM (CPUs=2, Memory=2048MB, Disk=20000MB) ...\r\n🐳 Configuring environment for Kubernetes v1.14.2 on Docker 18.09.6\r\n💾 Downloading kubeadm v1.14.2\r\n💾 Downloading kubelet v1.14.2\r\n🚜 Pulling images ...\r\n🚀 Launching Kubernetes ... \r\n⌛ Verifying: apiserver proxy etcd scheduler controller dns\r\n🏄 Done! kubectl is now configured to use \"minikube\"\r\n$ cat test.yaml\r\n---\r\napiVersion: v1\r\nkind: Pod\r\nmetadata:\r\n name: test\r\nspec:\r\n containers:\r\n - name: test\r\n image: memcached:latest\r\n imagePullPolicy: IfNotPresent\r\n command: [\"/bin/bash\"]\r\n args:\r\n - -c\r\n - 'id -u; sleep 30'\r\n$ kubectl apply -f test.yaml \r\npod/test created\r\n\r\n# as soon as pod starts\r\n$ kubectl logs test\r\n11211\r\n# Wait 30 seconds for container to restart\r\n$ kubectl logs test\r\n0\r\n# Try deleting/recreating the pod\r\n$ kubectl delete pod test\r\npod \"test\" deleted\r\n$ kubectl apply -f test.yaml \r\npod/test created\r\n$ kubectl logs test\r\n0\r\n```\r\n\r\n**Anything else we need to know?**:\r\n\r\n**Environment**:\r\n- Kubernetes version (use `kubectl version`): I get the results I expect in v1.13.5 and v1.14.1. The problem exists in v1.13.6 and v1.14.2\r\n- Cloud provider or hardware configuration: minikube v1.1.0 using VirtualBox\r\n- OS (e.g: `cat /etc/os-release`):\r\n- Kernel (e.g. `uname -a`):\r\n- Install tools:\r\n- Network plugin and version (if this is a network-related bug):\r\n- Others:\r\n", + "date_published": "2019-05-24T16:14:49Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2019-11245", + "id": "CVE-2019-11245", + "summary": "container uid changes to root after first restart or if image is already pulled to the node", + "url": "https://github.com/kubernetes/kubernetes/issues/78308" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2019-11243", + "issue_number": 76797 + }, + "content_text": "CVSS:3.0/AV:N/AC:H/PR:L/UI:N/S:U/C:L/I:N/A:N\r\n\r\nThe `rest.AnonymousClientConfig()` method returns a copy of the provided config, with credentials removed (bearer token, username/password, and client certificate/key data).\r\n\r\nIn the following versions, `rest.AnonymousClientConfig()` did not effectively clear service account credentials loaded using `rest.InClusterConfig()`:\r\n* v1.12.0-v1.12.4\r\n* v1.13.0\r\n\r\n**What is the impact?**\r\n* `k8s.io/client-go` users that use the `rest.AnonymousClientConfig()` method directly with client config loaded with `rest.InClusterConfig()` receive back a client config which can still send the loaded service account token with requests.\r\n\r\n**How was the issue fixed?**\r\n* In 1.12.5+ and 1.13.1+, `rest.InClusterConfig()` was modified to return a client config that is safe to use with the `rest.AnonymousClientConfig()` method (https://github.com/kubernetes/kubernetes/pull/71713)\r\n* In v1.15.0, the `rest.AnonymousClientConfig()` will also exclude the `config.Transport` and `config.WrapTransport` fields, in addition to the explicit credential-carrying fields. (https://github.com/kubernetes/kubernetes/pull/75771)\r\n\r\n**How do I resolve the issue?**\r\n* Upgrade `k8s.io/client-go` to `kubernetes-1.12.5`, `kubernetes-1.13.1`, `kubernetes-1.14.0`, or higher\r\n* or manually clear the `config.WrapTransport` and `config.Transport` fields in addition to calling `rest.AnonymousClientConfig()`\r\n\r\nThanks to Oleg Bulatov of Red Hat for reporting this issue.\r\n\r\n/area security\r\n/kind bug\r\n/sig auth\r\n/sig api-machinery\r\n/assign\r\n/close", + "date_published": "2019-04-18T21:31:53Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2019-11243", + "id": "CVE-2019-11243", + "summary": "rest.AnonymousClientConfig() does not remove the serviceaccount credentials from config created by rest.InClusterConfig()", + "url": "https://github.com/kubernetes/kubernetes/issues/76797" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2019-11244", + "issue_number": 76676 + }, + "content_text": "In kubectl v1.8.0+, schema info is cached in the location specified by `--cache-dir` (defaulting to `$HOME/.kube/http-cache`), written with world-writeable permissions (rw-rw-rw-).\r\n\r\nIf `--cache-dir` is specified and pointed at a different location accessible to other users/groups, the written files may be modified by other users/groups and disrupt the kubectl invocation.\r\n\r\nCVSS score: CVSS:3.0/AV:L/AC:H/PR:L/UI:R/S:U/C:L/I:L/A:N (3.3, low)\r\n\r\n**What versions are affected?**\r\nkubectl v1.8.0+\r\n\r\n**What configurations are affected?**\r\nInvocations that point `--cache-dir` at world-writeable locations\r\n\r\n**Impact**\r\nMalformed responses written to the cache directory can disrupt the kubectl invocation\r\n\r\n**Workaround**\r\nUse the default `--http-cache` location in the $HOME directory or point it at a directory that is only accessible to desired users/groups.\r\n\r\n\r\n\r\n(original description follows) ====\r\nWhat happened: The files inside of \".kube/http-cache\" are world writeable (rw-rw-rw-). While the default for these files appears to be the home directory, using the \"--cache-dir\" flag could put these files into a place where world writeable files would allow any user / process to modify the cache files. Modification of the cache files could influence the kubectl utility in a negative way for other users.\r\n\r\nWhat you expected to happen: Apply stricter file permissions to the http-cache files.\r\n\r\nHow to reproduce it (as minimally and precisely as possible): Run any generic kubectl command which is successful and then list the cache directory ~/.kube/http-cache/*\r\n \r\n$ kubectl get pods --all-namespaces\r\n$ ls -la ~/.kube/http-cache/*\r\n\r\nAnything else we need to know?: I estimate this is a low severity security issue with a CVSS score of \"3.3 / CVSS:3.0/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:L/A:N\" - https://www.first.org/cvss/calculator/3.0#CVSS:3.0/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:L/A:N\r\n\r\nEnvironment: Linux\r\n \r\nKubernetes version (use kubectl version):Client Version: version.Info{Major:\"1\", Minor:\"12\", GitVersion:\"v1.12.6\", GitCommit:\"ab91afd7062d4240e95e51ac00a18bd58fddd365\", GitTreeState:\"clean\", BuildDate:\"2019-02-26T12:49:28Z\", GoVersion:\"go1.10.8\", Compiler:\"gc\", Platform:\"linux/amd64\"}\r\nServer Version: version.Info{Major:\"1\", Minor:\"12\", GitVersion:\"v1.12.6\", GitCommit:\"ab91afd7062d4240e95e51ac00a18bd58fddd365\", GitTreeState:\"clean\", BuildDate:\"2019-02-26T12:49:28Z\", GoVersion:\"go1.10.8\", Compiler:\"gc\", Platform:\"linux/amd64\"}\r\n\r\nCloud provider or hardware configuration: AWS. Running kube api server in hyperkube.\r\n\r\nOS (e.g: cat /etc/os-release):\r\nNAME=\"CentOS Linux\"\r\nVERSION=\"7.1808 (Core)\"\r\nID=\"centos\"\r\nID_LIKE=\"rhel fedora\"\r\nVERSION_ID=\"7\"\r\nPRETTY_NAME=\"CentOS Linux 7.1808 (Core)\"\r\nANSI_COLOR=\"0;31\"\r\nCPE_NAME=\"cpe:/o:centos:centos:7\"\r\nHOME_URL=\"https://www.centos.org/\"\r\nBUG_REPORT_URL=\"https://bugs.centos.org/\"\r\nCENTOS_MANTISBT_PROJECT=\"CentOS-7\"\r\nCENTOS_MANTISBT_PROJECT_VERSION=\"7\"\r\nREDHAT_SUPPORT_PRODUCT=\"centos\"\r\nREDHAT_SUPPORT_PRODUCT_VERSION=\"7\"\r\nOSTREE_VERSION=7.1808\r\n \r\nKernel (e.g. uname -a): Linux hackit.internal 3.10.0-862.11.6.el7.x86_64 #1 SMP Tue Aug 14 21:49:04 UTC 2018 x86_64 x86_64 x86_64 GNU/Linux\r\n \r\nInstall tools: Manual installation.\r\n \r\nOthers: n/a\r\n", + "date_published": "2019-04-16T20:14:25Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2019-11244", + "id": "CVE-2019-11244", + "summary": "`kubectl:-http-cache=\u003cworld-accessible dir\u003e` creates world-writeable cached schema files", + "url": "https://github.com/kubernetes/kubernetes/issues/76676" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2019-1002100", + "issue_number": 74534 + }, + "content_text": "CVSS:3.0/AV:N/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H](https://www.first.org/cvss/calculator/3.0#CVSS:3.0/AV:N/AC:L/PR:L/UI:N/S:U/C:N/I:N/A:H) (6.5, medium)\r\n\r\nUsers that are authorized to make patch requests to the Kubernetes API Server can send a specially crafted patch of type “json-patch” (e.g. `kubectl patch --type json` or `\"Content-Type: application/json-patch+json\"`) that consumes excessive resources while processing, causing a Denial of Service on the API Server.\r\n\r\nThanks to Carl Henrik Lunde for reporting this problem.\r\n\r\nCVE-2019-1002100 is **fixed** in the following Kubernetes releases:\r\n\r\n* [v1.11.8](https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG-1.11.md/#v1118)\r\n* [v1.12.6](https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG-1.12.md/#v1126)\r\n* [v1.13.4](https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG-1.13.md/#v1134)\r\n\r\n### Affected components:\r\n* Kubernetes API server\r\n\r\n### Affected versions:\r\n* Kubernetes v1.0.x-1.10.x\r\n* Kubernetes v1.11.0-1.11.7 (fixed in [v1.11.8](https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG-1.11.md/#v1118))\r\n* Kubernetes v1.12.0-1.12.5 (fixed in [v1.12.6](https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG-1.12.md/#v1126))\r\n* Kubernetes v1.13.0-1.13.3 (fixed in [v1.13.4](https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG-1.13.md/#v1134))\r\n\r\n### Mitigations:\r\n* Remove ‘patch’ permissions from untrusted users.\r\n\r\nNote: If you are using binaries or packages provided by a distributor (not the ones provided in the open source release artifacts), you should contact them to determine what versions resolve this CVE. Distributors may choose to provide support for older releases beyond the ones maintained by the open source project.\r\n\r\n### Post-mortem:\r\n* [Document](https://github.com/kubernetes/kubernetes/files/3005552/PM-CVE-2019-1002100.pdf)\r\n", + "date_published": "2019-02-25T19:39:09Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2019-1002100", + "id": "CVE-2019-1002100", + "summary": "json-patch requests can exhaust apiserver resources", + "url": "https://github.com/kubernetes/kubernetes/issues/74534" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2018-1002105", + "issue_number": 71411 + }, + "content_text": "[CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H](https://www.first.org/cvss/calculator/3.0#CVSS:3.0/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H) (9.8, critical)\r\n\r\nWith a specially crafted request, users that are authorized to establish a connection through the Kubernetes API server to a backend server can then send arbitrary requests over the same connection directly to that backend, authenticated with the Kubernetes API server’s TLS credentials used to establish the backend connection.\r\n\r\nThanks to Darren Shepherd for reporting this problem.\r\n\r\nCVE-2018-1002105 is **fixed** in the following Kubernetes releases:\r\n\r\n* [v1.10.11](https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG-1.10.md/#v11011)\r\n* [v1.11.5](https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG-1.11.md/#v1115)\r\n* [v1.12.3](https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG-1.12.md/#v1123)\r\n* [v1.13.0-rc.1](https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG-1.13.md/#v1130-rc1)\r\n\r\n### Affected components:\r\n\r\n* Kubernetes API server\r\n\r\n### Affected versions:\r\n\r\n* Kubernetes v1.0.x-1.9.x\r\n* Kubernetes v1.10.0-1.10.10 (fixed in [v1.10.11](https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG-1.10.md/#v11011))\r\n* Kubernetes v1.11.0-1.11.4 (fixed in [v1.11.5](https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG-1.11.md/#v1115))\r\n* Kubernetes v1.12.0-1.12.2 (fixed in [v1.12.3](https://github.com/kubernetes/kubernetes/blob/master/CHANGELOG-1.12.md/#v1123))\r\n\r\nNote: If you are using binaries or packages provided by a distributor (not the ones provided in the open source release artifacts), you should contact them to determine what versions resolve this CVE. Distributors may choose to provide support for older releases beyond the ones maintained by the open source project.\r\n\r\n### Affected configurations:\r\n\r\n* Clusters \u003e= 1.6.x that run aggregated API servers (like the metrics server) that are directly accessible from the Kubernetes API server’s network. If there are aggregated API servers configured in a cluster, the following command will return the names of the associated APIService objects (if no names are listed, or the kube-apiserver is an older version that does not have the apiservices API, then the cluster has no aggregated API servers configured):\r\n ```\r\n kubectl get apiservices \\\r\n -o 'jsonpath={range .items[?(@.spec.service.name!=\"\")]}{.metadata.name}{\"\\n\"}{end}'\r\n ```\r\n* Clusters \u003e= 1.0.x that grant pod exec/attach/portforward permissions to users that are not expected to have full access to kubelet APIs\r\n\r\n### Vulnerability impact:\r\n\r\n* An API call to any aggregated API server endpoint can be escalated to perform any API request against that aggregated API server, as long as that aggregated API server is directly accessible from the Kubernetes API server’s network. **[Default RBAC policy](https://kubernetes.io/docs/reference/access-authn-authz/rbac/#discovery-roles) allows all users (authenticated and unauthenticated) to perform discovery API calls that allow this escalation against any aggregated API servers configured in the cluster.**\r\n* A pod exec/attach/portforward API call can be escalated to perform any API request against the kubelet API on the node specified in the pod spec (e.g. listing all pods on the node, running arbitrary commands inside those pods, and obtaining the command output). **Pod exec/attach/portforward permissions are included in the admin/edit RBAC roles intended for namespace-constrained users.**\r\n\r\n### Mitigations:\r\n\r\nThis section lists possible mitigations to use prior to upgrading. Note that many of the mitigations are likely to be disruptive, and upgrading to a fixed version is strongly recommended.\r\n\r\n#### Mitigations for the anonymous user -\u003e aggregated API server escalation include:\r\n* suspend use of aggregated API servers (note that this will disrupt users of the APIs provided by the aggregated server)\r\n* disable anonymous requests by passing `--anonymous-auth=false` to the kube-apiserver (note that this may disrupt load balancer or kubelet health checks of the kube-apiserver, and breaks `kubeadm join` setup flows)\r\n* remove *all* anonymous access to *all* aggregated APIs (including discovery permissions granted by the [default discovery role bindings](https://kubernetes.io/docs/reference/access-authn-authz/rbac/#discovery-roles))\r\n\r\n#### Mitigations for the authenticated user -\u003e aggregated API server escalation include:\r\n* suspend use of aggregated API servers (note that this will disrupt users of the APIs provided by the aggregated server)\r\n* remove *all* access to *all* aggregated APIs (including discovery permissions granted by the [default discovery role bindings](https://kubernetes.io/docs/reference/access-authn-authz/rbac/#discovery-roles)) from users that should not have full access to the aggregated APIs (note that this may disrupt users and controllers that make use of discovery information to map API types to URLs)\r\n\r\n#### Mitigation for the authorized pod exec/attach/portforward -\u003e kubelet API escalation:\r\n* Remove pod exec/attach/portforward permissions from users that should not have full access to the kubelet API\r\n\r\n### Detection:\r\n\r\nThere is no simple way to detect whether this vulnerability has been used. Because the unauthorized requests are made over an established connection, they do not appear in the Kubernetes API server audit logs or server log. The requests do appear in the kubelet or aggregated API server logs, but are indistinguishable from correctly authorized and proxied requests via the Kubernetes API server.\r\n\r\n### Post-mortem:\r\n\r\n* [Document](https://github.com/kubernetes/kubernetes/files/2700818/PM-CVE-2018-1002105.pdf)\r\n* [Recorded meeting](https://youtu.be/1M4oXPgxYyE)", + "date_published": "2018-11-26T11:07:36Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2018-1002105", + "id": "CVE-2018-1002105", + "summary": "proxy request handling in kube-apiserver can leave vulnerable TCP connections", + "url": "https://github.com/kubernetes/kubernetes/issues/71411" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2018-1002101", + "issue_number": 65750 + }, + "content_text": "This issue is tracked under CVE-2018-1002101\r\n\r\n\u003c!-- This form is for bug reports and feature requests ONLY!\r\n\r\nIf you're looking for help check [Stack Overflow](https://stackoverflow.com/questions/tagged/kubernetes) and the [troubleshooting guide](https://kubernetes.io/docs/tasks/debug-application-cluster/troubleshooting/).\r\n\r\nIf the matter is security related, please disclose it privately via https://kubernetes.io/security/.\r\n--\u003e\r\n\r\n**Is this a BUG REPORT or FEATURE REQUEST?**:\r\n/kind bug\r\n\r\n\u003e Uncomment only one, leave it on its own line:\r\n\u003e\r\n\u003e /kind bug\r\n\u003e /kind feature\r\n\r\n\r\n**What happened**:\r\nuser PowerShell Environment Variables to store user input string to prevent command line injection, the env var in PowerShell would be taken as literal values and not as executable vulnerable code, this kind of fix is common for command line injection issue (called: parameterized way)\r\n\r\n**What you expected to happen**:\r\n\r\n**How to reproduce it (as minimally and precisely as possible)**:\r\n\r\n\r\n**Anything else we need to know?**:\r\n\r\n**Environment**:\r\n- Kubernetes version (use `kubectl version`):\r\n- Cloud provider or hardware configuration:\r\n- OS (e.g. from /etc/os-release):\r\n- Kernel (e.g. `uname -a`):\r\n- Install tools:\r\n- Others:\r\n\r\n/sig windows\r\n/sig storage\r\n/assign", + "date_published": "2018-07-03T08:06:15Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2018-1002101", + "id": "CVE-2018-1002101", + "summary": "smb mount security issue", + "url": "https://github.com/kubernetes/kubernetes/issues/65750" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2018-1002100", + "issue_number": 61297 + }, + "content_text": "**Is this a BUG REPORT or FEATURE REQUEST?**: Bug\r\n\r\n/kind bug\r\n\r\n**What happened**:\r\nkubectl cp \u003cpod-name\u003e:/some/remote/dir /some/local/dir\r\n\r\nIf the container returns a malformed tarfile with paths like:\r\n\r\n'/some/remote/dir/../../../../tmp/foo' kubectl writes this to `/tmp/foo` instead of `/some/local/dir/tmp/foo`\r\n\r\n**What you expected to happen**:\r\n\r\nI expect kubectl to clean up the path and write to `/some/local/dir/tmp/foo`\r\n\r\n**Notes**\r\nOriginal credit to @hansmi (Michael Hanselmann) for originally reporting the bug.\r\n\r\nTracked as CVE-2018-1002100\r\n", + "date_published": "2018-03-16T19:24:46Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2018-1002100", + "id": "CVE-2018-1002100", + "summary": "Kubectl copy doesn't check for paths outside of it's destination directory.", + "url": "https://github.com/kubernetes/kubernetes/issues/61297" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2017-1002102", + "issue_number": 60814 + }, + "content_text": "[CVSS:3.0/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:L/A:H](https://www.first.org/cvss/calculator/3.0#CVSS:3.0/AV:L/AC:L/PR:L/UI:N/S:U/C:N/I:L/A:H)\r\n\r\nThis vulnerability allows containers using a secret, configMap, projected or downwardAPI volume to trigger deletion of arbitrary files and directories on the nodes where they are running.\r\n\r\nThanks to Joel Smith of Red Hat for reporting this problem.\r\n\r\n**Vulnerable versions:**\r\n* Kubernetes 1.3.x-1.6.x\r\n* Kubernetes 1.7.0-1.7.13\r\n* Kubernetes 1.8.0-1.8.8\r\n* Kubernetes 1.9.0-1.9.3\r\n\r\n**Vulnerable configurations:**\r\n* Clusters that run untrusted containers with secret, configMap, downwardAPI or projected volumes mounted (including auto-added service account token mounts).\r\n\r\n**Vulnerability impact:**\r\nA malicious container running in a pod with a secret, configMap, downwardAPI or projected volume mounted (including auto-added service account token mounts) can cause the Kubelet to remove any file or directory on the host filesystem.\r\n\r\n**Mitigations prior to upgrading:**\r\nDo not allow containers to be run with secret, configMap, downwardAPI and projected volumes (note that this prevents use of service account tokens in pods, and requires use of [`automountServiceAccountToken: false`](https://kubernetes.io/docs/tasks/configure-pod-container/configure-service-account/#use-the-default-service-account-to-access-the-api-server))\r\n\r\n**Fixed versions:**\r\n* Fixed in v1.7.14 by #60516\r\n* Fixed in v1.8.9 by #60515\r\n* Fixed in v1.9.4 by #60258\r\n* Fixed in master by #58720 (included in v1.10.0-beta.1 and up, will be in v1.10.0)\r\n\r\n**Fix impact:**\r\nSecret, configMap, downwardAPI and projected volumes will be mounted as read-only volumes. Applications that attempt to write to these volumes will receive read-only filesystem errors. Previously, applications were allowed to make changes to these volumes, but those changes were reverted at an arbitrary interval by the system. Applications should be re-configured to write derived files to another location.\r\n", + "date_published": "2018-03-05T20:55:20Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2017-1002102", + "id": "CVE-2017-1002102", + "summary": "atomic writer volume handling allows arbitrary file deletion in host filesystem", + "url": "https://github.com/kubernetes/kubernetes/issues/60814" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2017-1002101", + "issue_number": 60813 + }, + "content_text": "[CVSS:3.0/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H](https://www.first.org/cvss/calculator/3.0#CVSS:3.0/AV:N/AC:L/PR:L/UI:N/S:U/C:H/I:H/A:H)\r\n\r\nThis vulnerability allows containers using [subpath volume mounts](https://kubernetes.io/docs/concepts/storage/volumes/#using-subpath) with any volume type (including non-privileged pods, subject to file permissions) to access files/directories outside of the volume, including the host’s filesystem.\r\n\r\nThanks to Maxim Ivanov for reporting this problem.\r\n\r\n**Vulnerable versions:**\r\n* Kubernetes 1.3.x-1.6.x\r\n* Kubernetes 1.7.0-1.7.13\r\n* Kubernetes 1.8.0-1.8.8\r\n* Kubernetes 1.9.0-1.9.3\r\n\r\n**Vulnerable configurations:**\r\n* Clusters that allow untrusted users to control pod spec content, and prevent host filesystem access via hostPath volumes (or other volume types) using PodSecurityPolicy (or custom admission plugins)\r\n* Clusters that make use of [subpath volume mounts](https://kubernetes.io/docs/concepts/storage/volumes/#using-subpath) with untrusted containers or containers that can be compromised\r\n\r\n**Vulnerability impact:**\r\nA specially crafted pod spec combined with malicious container behavior can allow read/write access to arbitrary files outside volumes specified in the pod, including the host’s filesystem. This can be accomplished with any volume type, including emptyDir, and can be accomplished with a non-privileged pod (subject to file permissions).\r\n\r\n**Mitigations prior to upgrading:**\r\nPrevent untrusted users from creating pods (and pod-creating objects like deployments, replicasets, etc), or [disable all volume types](https://kubernetes.io/docs/concepts/policy/pod-security-policy/#volumes-and-file-systems) with PodSecurityPolicy (note that this prevents use of service account tokens in pods, and requires use of [`automountServiceAccountToken: false`](https://kubernetes.io/docs/tasks/configure-pod-container/configure-service-account/#use-the-default-service-account-to-access-the-api-server))\r\n\r\n**Fixed versions:**\r\n* Fixed in v1.7.14 by #61047\r\n* Fixed in v1.8.9 by #61046\r\n* Fixed in v1.9.4 by #61045\r\n* Fixed in master by #61044 (included in v1.10.0-beta.3, will be in v1.10.0)\r\n\r\n**Action Required:**\r\nIn addition to upgrading, PodSecurityPolicy objects designed to limit container permissions must completely [disable hostPath volumes](https://kubernetes.io/docs/concepts/policy/pod-security-policy/#volumes-and-file-systems), as the allowedHostPaths feature does not restrict symlink creation and traversal. Future enhancements (tracked in issue #61043) are required to limit hostPath use to read only volumes or exact path matches before a PodSecurityPolicy can effectively restrict hostPath usage to a given subpath.\r\n\r\n**Known issues:**\r\n* Status and availability of fixes for regressions in subPath volume mount handling are tracked in https://github.com/kubernetes/kubernetes/issues/61563", + "date_published": "2018-03-05T20:53:58Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2017-1002101", + "id": "CVE-2017-1002101", + "summary": "subpath volume mount handling allows arbitrary file access in host filesystem", + "url": "https://github.com/kubernetes/kubernetes/issues/60813" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2017-1002100", + "issue_number": 47611 + }, + "content_text": "", + "date_published": "2017-06-15T18:59:13Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2017-1002100", + "id": "CVE-2017-1002100", + "summary": "Azure PV should be Private scope not Container scope", + "url": "https://github.com/kubernetes/kubernetes/issues/47611" + }, + { + "_kubernetes_io": { + "google_group_url": "https://groups.google.com/g/kubernetes-announce/search?q=CVE-2017-1000056", + "issue_number": 43459 + }, + "content_text": "A PodSecurityPolicy admission plugin vulnerability allows users to make use of any PodSecurityPolicy object, even ones they are not authorized to use.\r\n\r\nCVE: CVE-2017-1000056\r\n\r\n* Fixed in [v1.5.5](https://github.com/kubernetes/kubernetes/releases/tag/v1.5.5) in https://github.com/kubernetes/kubernetes/commit/7fef0a4f6a44ea36f166c39fdade5324eff2dd5e\r\n* Fixed in release-1.5 branch in https://github.com/kubernetes/kubernetes/pull/43491\r\n* Fixed in master in https://github.com/kubernetes/kubernetes/pull/43489\r\n\r\n**Who is affected?**\r\nOnly Kubernetes 1.5.0-1.5.4 installations that do _all_ of the following:\r\n* Enable the PodSecurityPolicy API (which is not enabled by default):\r\n `--runtime-config=extensions/v1beta1/podsecuritypolicy=true`\r\n* Enable the PodSecurityPolicy admission plugin (which is not enabled by default):\r\n `--admission-control=...,PodSecurityPolicy,...`\r\n* Use authorization to limit users' ability to use specific PodSecurityPolicy objects\r\n\r\nkubeadm and GKE do not allow enabling PodSecurityPolicy in 1.5, so are not affected by this vulnerability.\r\n\r\nkube-up.sh and kops do not enable PodSecurityPolicy by default, so are not affected by this vulnerability. A modified kube-up.sh or kops deployment could have enabled it.\r\n\r\n**What is the impact?**\r\nA user that is authorized to create pods can make use of any existing PodSecurityPolicy, even ones they are not authorized to use.\r\n\r\n**How can I mitigate this prior to installing 1.5.5?**\r\n1. Export existing PodSecurityPolicy objects:\r\n `kubectl get podsecuritypolicies -o yaml \u003e psp.yaml`\r\n\r\n2. Review and delete any PodSecurityPolicy objects you do not want all pod-creating users to be able to use (NOTE: Privileged users that were making use of those policies will also lose access to those policies). For example:\r\n `kubectl delete podsecuritypolicies/my-privileged-policy`\r\n\r\n3. After upgrading to 1.5.5, re-create the exported PodSecurityPolicy objects:\r\n `kubectl create -f psp.yaml`", + "date_published": "2017-03-21T15:22:29Z", + "external_url": "https://www.cve.org/cverecord?id=CVE-2017-1000056", + "id": "CVE-2017-1000056", + "summary": "PodSecurityPolicy admission plugin authorizes incorrectly", + "url": "https://github.com/kubernetes/kubernetes/issues/43459" + } + ], + "title": "Kubernetes Vulnerability Announcements - CVE Feed", + "version": "https://jsonfeed.org/version/1.1" +} \ No newline at end of file diff --git a/main.go b/main.go index be2064c..0ed6774 100644 --- a/main.go +++ b/main.go @@ -21,6 +21,7 @@ import ( "github.com/aquasecurity/vuln-list-update/debian/tracker" "github.com/aquasecurity/vuln-list-update/ghsa" "github.com/aquasecurity/vuln-list-update/glad" + "github.com/aquasecurity/vuln-list-update/k8s" "github.com/aquasecurity/vuln-list-update/kevc" "github.com/aquasecurity/vuln-list-update/mariner" "github.com/aquasecurity/vuln-list-update/nvd" @@ -38,7 +39,7 @@ import ( var ( target = flag.String("target", "", "update target (nvd, alpine, alpine-unfixed, redhat, redhat-oval, "+ - "debian, ubuntu, amazon, oracle-oval, suse-cvrf, photon, arch-linux, ghsa, glad, cwe, osv, mariner, kevc, wolfi, chainguard)") + "debian, ubuntu, amazon, oracle-oval, suse-cvrf, photon, arch-linux, ghsa, glad, cwe, osv, mariner, kevc, wolfi, chainguard, k8s)") vulnListDir = flag.String("vuln-list-dir", "", "vuln-list dir") targetUri = flag.String("target-uri", "", "alternative repository URI (only glad)") targetBranch = flag.String("target-branch", "", "alternative repository branch (only glad)") @@ -171,6 +172,10 @@ func run() error { if err := cu.Update(); err != nil { return xerrors.Errorf("Chainguard update error: %w", err) } + case "k8s": + if err := k8s.Update(); err != nil { + return xerrors.Errorf("Chainguard update error: %w", err) + } default: return xerrors.New("unknown target") } diff --git a/osv/types.go b/osv/types.go index ac62fbf..95a2f31 100644 --- a/osv/types.go +++ b/osv/types.go @@ -1,13 +1,20 @@ package osv type Affected struct { - Package Package `json:"package,omitempty"` - Ranges []Range `json:"ranges,omitempty"` - Versions []string `json:"versions,omitempty"` - Ecosystem interface{} `json:"ecosystem_specific,omitempty"` //The meaning of the values within the object is entirely defined by the ecosystem - Database interface{} `json:"database_specific,omitempty"` //The meaning of the values within the object is entirely defined by the database + Package Package `json:"package,omitempty"` + Severities []Severity `json:"severity,omitempty"` + Ranges []Range `json:"ranges,omitempty"` + Versions []string `json:"versions,omitempty"` + Ecosystem interface{} `json:"ecosystem_specific,omitempty"` //The meaning of the values within the object is entirely defined by the ecosystem + Database interface{} `json:"database_specific,omitempty"` //The meaning of the values within the object is entirely defined by the database } + +type Severity struct { + Type string `json:"type"` + Score string `json:"score"` +} + type Package struct { Ecosystem string `json:"ecosystem,omitempty"` Name string `json:"name,omitempty"`