Security flaw parser for upstream security advisories
Upstream repository: https://github.com/mprpic/advisory-parser
This library allows you to parse data from security advisories of certain projects to extract information about security issues. The parsed information includes metadata such as impact, CVSS score, summary, description, and others; for a full list, see the advisory_parser/flaw.py file.
DISCLAIMER: Much of the advisory parsing is fairly fragile. Because web pages change all the time, it is not uncommon for parsers to break when a page is changed in some way. Also, the advisory parsers only work with the latest version of the advisory pages.
The need for parsing raw security advisories in this way could be avoided if vendors provided their security pages in a machine readable (and preferably standardized) format. An example of this would be Red Hat’s security advisories that can be pulled in from a separate Security Data API (RHSA-2016:1883.json) or downloaded as an XML file (cvrf-rhsa-2016-1883.xml), or OpenSSL’s list of issues available in XML (vulnerabilities.xml).
If you are a vendor or an upstream project owner interested in providing your security advisories in a machine readable format and don’t know where to start, feel free to reach out to firstname.lastname@example.org.
Currently available parsers include:
pip install advisory-parser
from pprint import pprint from advisory_parser import Parser url = 'https://helpx.adobe.com/security/products/flash-player/apsb17-17.html' flaws, warnings = Parser.parse_from_url(url) for flaw in flaws: print() pprint(vars(flaw))
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
|Filename, size||File type||Python version||Upload date||Hashes|
|Filename, size advisory_parser-1.11-py2.py3-none-any.whl (15.5 kB)||File type Wheel||Python version py2.py3||Upload date||Hashes View|
|Filename, size advisory-parser-1.11.tar.gz (80.8 kB)||File type Source||Python version None||Upload date||Hashes View|
Hashes for advisory_parser-1.11-py2.py3-none-any.whl