Skip to content
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

Consolidate 'Fixed by packages' tab and 'Affected packages' tab in Vulnerability details page #1287

Closed
johnmhoran opened this issue Aug 30, 2023 · 4 comments
Assignees

Comments

@johnmhoran
Copy link
Member

We need to consolidate the Fixed by packages tab and the Affected packages tab in the Vulnerability details page into a single tab with a table in which the rows contain relevant pairing of affected and fixed packages.

@johnmhoran
Copy link
Member Author

@pombredanne @TG1999

(1) When we match fixed by packages to a particular affected package, do we want to match all of these attributes?

"name"
"namespace"
"type"
"qualifiers"
"subpath"

That's what we currently do in my pending Package UI/API issue PR 1249 (issue 1228).

(2) This question likely also applies to the results of a PURL search -- do you agree? For example, a search for pkg:deb/debian/[email protected]?distro=sid displays results that include non-matching qualifiers:

image

In addition, this screenshot reflects the poor sorting AND the apparent existence in the DB of duplicate records. I can address the sorting in this issue, though I suspect the problem of duplicate records is more complex and not directly related and will need to be addressed in a separate issue. (See issue 1278, which I opened back in August.)

@johnmhoran
Copy link
Member Author

Note that in views.py, in the PackageSearch class, this docstring is not as precisely focused.

    def get_queryset(self, query=None):
        """
        Return a Package queryset for the ``query``.
        Make a best effort approach to find matching packages either based
        on exact purl, partial purl or just name and namespace.
        """
        query = query or self.request.GET.get("search") or ""
        return self.model.objects.search(query).with_vulnerability_counts().prefetch_related()

@johnmhoran
Copy link
Member Author

I see the same docstring in the search() method of the PackageQuerySet() class in models.py.

I take this to mean that we do want a broad and flexible search result in case the user submits an abbreviated search, e.g., a search for jackson-databind will return maven, deb and rpm packages. When we get to that issue, it will be interesting to see how we apply the univers RANGE_CLASS_BY_SCHEMES to a group of potentially many different combos of type, namespace etc.

Meanwhile, please focus on my questions (1) and (2) above at your earliest opportunity.

johnmhoran added a commit that referenced this issue Oct 6, 2023
@johnmhoran johnmhoran moved this from Needs Review to Reviewed in VulnerableCode Data Quality and next Jun 20, 2024
johnmhoran added a commit that referenced this issue Jul 30, 2024
johnmhoran added a commit that referenced this issue Jul 30, 2024
johnmhoran added a commit that referenced this issue Aug 7, 2024
Reference: #1287
- Matched affected/fixed-by Package data added to Vulnerability details.
- version_class-based sorting added to that data as well.
- Note that version_class-based Packages sorting still needs to be added
  to Package search results.
- Filter added to encode Package URLs.
- Next: will add tests.
Signed-off-by: John M. Horan <[email protected]>
johnmhoran added a commit that referenced this issue Aug 7, 2024
Reference: #1287
- Fixed merge conflicts.
Signed-off-by: John M. Horan <[email protected]>
@johnmhoran johnmhoran moved this from Reviewed to Assigned in VulnerableCode Data Quality and next Aug 8, 2024
johnmhoran added a commit that referenced this issue Aug 12, 2024
johnmhoran added a commit that referenced this issue Aug 12, 2024
johnmhoran added a commit that referenced this issue Aug 13, 2024
Reference: #1287
Signed-off-by: John M. Horan <[email protected]>
@pombredanne pombredanne assigned TG1999 and unassigned johnmhoran Sep 23, 2024
@pombredanne
Copy link
Member

This is done and has been merged in:

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants