| // Copyright 2023 The Go Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style |
| // license that can be found in the LICENSE file. |
| |
| package semver |
| |
| import "golang.org/x/vuln/internal/osv" |
| |
| // NonSupersededFix returns a fixed version from ranges |
| // that is not superseded by any other fix or any other |
| // introduction of a vulnerability. Returns "" in case |
| // there is no such fixed version. |
| func NonSupersededFix(ranges []osv.Range) string { |
| var latestFixed string |
| for _, r := range ranges { |
| if r.Type == "SEMVER" { |
| for _, e := range r.Events { |
| fixed := e.Fixed |
| if fixed != "" && Less(latestFixed, fixed) { |
| latestFixed = fixed |
| } |
| } |
| |
| // If the vulnerability was re-introduced after the latest fix |
| // we found, there is no latest fix for this range. |
| for _, e := range r.Events { |
| introduced := e.Introduced |
| if introduced != "" && introduced != "0" && Less(latestFixed, introduced) { |
| latestFixed = "" |
| break |
| } |
| } |
| } |
| } |
| return latestFixed |
| } |