vulndb: move from package structured vulnerabilities to module

Adapts govulncheck to work with a database structured around per-module
vulnerabilities, rather than per-package vulnerabilities.

This requires a significant refactor of various aspects of the main
package and the internal/audit packages which, while large, I think
makes the overall program flow somewhat simpler to understand. Some
changes to tests are also required, although similarly I believe they
end up with easier to understand/modify tests.

This also paves the way for more comprehensive details around which
vulnerabilities are unreachable.

Change-Id: I3dd402db344849db6f1a118feee65734daf924cf
Trust: Roland Shoemaker <>
Run-TryBot: Roland Shoemaker <>
TryBot-Result: Go Bot <>
Reviewed-by: Zvonimir Pavlinovic <>
20 files changed
tree: 639580b83a8765d3522956fa375eb8b3811f30f8
  1. .gitattributes
  2. .gitignore
  9. apidiff/
  10. cmd/
  11. codereview.cfg
  12. ebnf/
  13. ebnflint/
  14. errors/
  15. event/
  16. fsnotify/
  17. go.mod
  18. go.sum
  19. inotify/
  20. internal/
  21. io/
  22. jsonrpc2/
  23. mmap/
  24. rand/
  25. shiny/
  26. shootout/
  27. sumdb/
  28. utf8string/
  29. vulndb/
  30. winfsnotify/



This subrepository holds experimental and deprecated (in the old directory) packages.

The idea for this subrepository originated as the pkg/exp directory of the main repository, but its presence there made it unavailable to users of the binary downloads of the Go installation. The subrepository has therefore been created to make it possible to go get these packages.

Warning: Packages here are experimental and unreliable. Some may one day be promoted to the main repository or other subrepository, or they may be modified arbitrarily or even disappear altogether.

In short, code in this subrepository is not subject to the Go 1 compatibility promise. (No subrepo is, but the promise is even more likely to be violated by go.exp than the others.)

Caveat emptor.