Skip to content

Commit

Permalink
Include notes in the CVEs text field search (canonical#158)
Browse files Browse the repository at this point in the history
  • Loading branch information
carkod authored Jun 27, 2024
1 parent a93d5e4 commit 0b9485a
Show file tree
Hide file tree
Showing 6 changed files with 32 additions and 6 deletions.
2 changes: 1 addition & 1 deletion scripts/generate-sample-security-data.py
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@
published=datetime.now(),
description="",
ubuntu_description="",
notes={},
notes=[],
priority="unknown",
cvss3=2.3,
mitigation="",
Expand Down
1 change: 0 additions & 1 deletion scripts/payloads/cves.json
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,6 @@
"impactScore": 5.9
}
},
"notes": [],
"packages": [
{
"debian": "https://tracker.debian.org/pkg/chromium-browser",
Expand Down
7 changes: 6 additions & 1 deletion tests/fixtures/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,12 @@ def make_models():
published=datetime.now(),
description="",
ubuntu_description="",
notes={},
notes=[
{
"author": "mysql",
"note": "mysql-1.2 is not affected by this CVE",
}
],
priority="critical",
cvss3=2.3,
impact={},
Expand Down
12 changes: 12 additions & 0 deletions tests/test_routes.py
Original file line number Diff line number Diff line change
Expand Up @@ -1083,6 +1083,18 @@ def test_delete_release(self):
)
assert response.status_code == 200

def test_cves_query_notes(self):
"""
Query text field should include notes
"""
# Act
response = self.client.get("/security/cves.json?q=sql")

# Assert
assert response.status_code == 200
assert response.json["total_results"] == 1
assert len(response.json["cves"]) == 1


if __name__ == "__main__":
unittest.main()
2 changes: 1 addition & 1 deletion webapp/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ class CVE(db.Model):
updated_at = Column(
DateTime(timezone=True), server_default=func.now(), onupdate=func.now()
)
notes = Column(JSON)
notes = Column(JSON) # JSON array
codename = Column(String)
priority = Column(
Enum(
Expand Down
14 changes: 12 additions & 2 deletions webapp/views.py
Original file line number Diff line number Diff line change
@@ -1,13 +1,13 @@
import dateutil
from collections import defaultdict
from datetime import datetime
from distutils.util import strtobool

from flask import make_response, jsonify, request
from flask_apispec import marshal_with, use_kwargs
from sqlalchemy import desc, or_, and_, case, asc
from sqlalchemy import desc, or_, and_, case, asc, text
from sqlalchemy.exc import DataError, IntegrityError
from sqlalchemy.orm import load_only, selectinload, Query
import dateutil

from webapp.app import db
from webapp.auth import authorization_required
Expand Down Expand Up @@ -115,6 +115,16 @@ def get_cves(**kwargs):
CVE.ubuntu_description.ilike(f"%{query}%"),
CVE.codename.ilike(f"%{query}%"),
CVE.mitigation.ilike(f"%{query}%"),
# search through notes
text(
"""
EXISTS (
SELECT 1 FROM json_array_elements(notes) AS note
WHERE note->>'note' ilike :query
OR note->>'author' ilike :query
)
"""
).params(query=f"%{query}%"),
)
)

Expand Down

0 comments on commit 0b9485a

Please sign in to comment.