-
Notifications
You must be signed in to change notification settings - Fork 86
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Unified field for describing affected functions #127
Comments
@darakian FYI! filing this issue as promised for starting discussion. |
Many thanks for starting the thread! If we want this to be a single unified field then I think a first step would be to define that field as typed with possible type values of whatever language is supported.
A second point to make is that ideally we should aim to capture more than functions. I can dig up an example if you like but I've come across a number of redos vulns which affect some variable which exists outside a function body and the fix tends to be altering that variable. That said, if you'd like to keep this issue scoped to functions only then I'm happy to do so 😄 |
To pop this back onto the stack would it make sense to start with a minimal, functional format where we root the affected functions/constants/code points at the entry to the package. The separator syntax is something I'm unsure if we can normalize or not, but perhaps for v1 we accept whatever the "norm" is for the ecosystem is. so, the proposal for a functions v1 would introduce values that look like Known gaps
Thoughts? |
Sorry for the delay on the response! Wanted to give a proper one. I think for some ecosystems, e.g. Go, there are additional considerations. e.g. with Go, the function/symbol needs to be qualified with the package within the module (https://go.dev/security/vuln/database), and there's additional qualifiers like goos, goarch. I think we should use whatever is canonical for the ecosystem, rather than try to normalize separators and introduce potential confusion. The question here though, is how we can generalize this in a way that works for all, while giving enough flexibility to express additional ecosystem_specific details. Looking at the current formats out there today, there's Go, GHSA's affected_functions, and Rust Advisory DB: Go "ecosystem_specific": {
"imports": [
{
"path": "cmd/link",
"goos": [
"js"
],
"goarch": [
"wasm"
],
"symbols": [
"Link.address"
]
}
]
}
"ecosystem_specific": {
"imports": [
{
"path": "golang.org/x/text/encoding/unicode",
"symbols": [
"bomOverride.Transform",
"utf16Decoder.Transform"
]
},
{
"path": "golang.org/x/text/transform",
"symbols": [
"String"
]
}
]
}
Rust "ecosystem_specific": {
"affects": {
"arch": [],
"os": [],
"functions": [
"lzf::compress",
"lzf::decompress"
]
}
}, GHSA "ecosystem_specific": {
"affected_functions": [
"tokio::task::JoinHandle::abort"
]
}, As a first attempt to standardize this: perhaps we can define something like: "scope": [
{
"symbol": string, # language specific function name
"os": string # language specific OS qualifier
"arch": string # language specific arch
"additional_qualifiers": {
<anything goes here, e.g. Go package path >
}
}
] But then, this ends up being essentially equivalent to Alternatively should we just aim to unify the definitions of all the ecosystem_specific fields in one place in the OSV schema to provide this functionality? |
100% agree.
Stepping back a moment. We don't necessarily need to generalize a for all path. Perhaps it's better to add language support on a case by case basis to ensure we have quality data and don't start generating bad data which will exist forever™️ With respect to the generalized format you're suggesting; how would os and/or arch specifiers interact with the broader advisory payload if the broader payload disagreed with either? Do we need to iterate all os versions and uarch types? The additional qualifiers field feels like a free form field and I doubt we'd see standardized usage of it unless we nail down what it's for. For the generalized case my $0.02 is that if we head down that path we start small and add on as need be, so I'd suggest we trim your suggestion down to the https://rustsec.org/advisories/RUSTSEC-2021-0072.html Edit: Thinking on the above a little more. Maybe it does make sense to include the |
Also just so we have them here are a few references on what some of the languages think a fully qualified function is |
Thanks @darakian ! If we minimize the definition to just "symbols", I wonder if that will cause confusion with other similar data included in Even if we extend this hypothetical new field to be more flexible with ecosystem-specific fields, it becomes pretty much the same as existing i.e. we encourage ecosystems to clearly define their ecosystem_specific to capture vulnerable symbols, OS, arch etc similar to how Go already does it in https://go.dev/security/vuln/database. Then the OSV schema would link to these canonical definitions. Many language ecosystems (e.g. Rust, Python, Haskell, R) already have canonical advisory-database repositories so potentially they can just live there. |
Certainly if both paths are supported for a given ecosystem at the same time I could see that causing confusion. Perhaps it makes sense to cut over on an OSV schema version bump.
That's how I feel for sure. I think there's a question about what to do if languages end up being shared across ecosystems (C springs to mind), but generally I tend to want to lean on the expertise of those already involved with the specific domain. For Go specifically I have no problems leaning on their definitions. |
I believe there's also openjs-foundation/security-collab-space#66 for the JS discussion. |
Go, GitHub, and Rust all define their own way of specifying affected functions:
We should define a unified field for expressing these in a way that works for all languages and their nuances.
The text was updated successfully, but these errors were encountered: