Skip to content

EPSS(Exploit Prediction Scoring System) API client

License

Notifications You must be signed in to change notification settings

kannkyo/epss-api

Repository files navigation

EPSS API Client

https://img.shields.io/pypi/dw/epss-api?style=flat https://codecov.io/gh/kannkyo/epss-api/branch/main/graph/badge.svg?token=R40FT0KITO

EPSS(Exploit Prediction Scoring System) API client.

EPSS is the one of famous vulnerability score developed by FIRST (the Forum of Incident Response and Security Teams).

EPSS's definition:

The Exploit Prediction Scoring System (EPSS) is an open, data-driven effort for estimating the likelihood (probability) that a software vulnerability will be exploited in the wild. Our goal is to assist network defenders to better prioritize vulnerability remediation efforts. While other industry standards have been useful for capturing innate characteristics of a vulnerability and provide measures of severity, they are limited in their ability to assess threat. EPSS fills that gap because it uses current threat information from CVE and real-world exploit data. The EPSS model produces a probability score between 0 and 1 (0 and 100%). The higher the score, the greater the probability that a vulnerability will be exploited.

https://www.first.org/epss/

This package is most easiest and efficient EPSS api client.

Usage

EPSS has some methods.

from epss_api import EPSS

client = EPSS()

value = client.scores()
# value = [
#   {'cve': 'CVE-2022-39952', 'epss': '0.09029', 'percentile': '0.94031'},
#   {'cve': 'CVE-2023-0669', 'epss': '0.78437', 'percentile': '0.99452'},
#  ...
# ]

value = client.epss_lt(0.5)
# value = [
#   {'cve': 'CVE-2022-39952', 'epss': '0.09029', 'percentile': '0.24031'},
#   {'cve': 'CVE-2023-0669', 'epss': '0.18437', 'percentile': '0.19452'},
#  ...
# ]

value = client.percentile_lt(0.5)
# value = [
#   {'cve': 'CVE-2022-39952', 'epss': '0.09029', 'percentile': '0.24031'},
#   {'cve': 'CVE-2023-0669', 'epss': '0.78437', 'percentile': '0.19452'},
#  ...
# ]

value = client.epss_gt(0.5)
# value = [
#   {'cve': 'CVE-2022-39952', 'epss': '0.59029', 'percentile': '0.94031'},
#   {'cve': 'CVE-2023-0669', 'epss': '0.78437', 'percentile': '0.99452'},
#  ...
# ]

value = client.percentile_gt(0.5)
# value = [
#   {'cve': 'CVE-2022-39952', 'epss': '0.59029', 'percentile': '0.94031'},
#   {'cve': 'CVE-2023-0669', 'epss': '0.78437', 'percentile': '0.99452'},
#  ...
# ]

value = client.score(cve_id='CVE-2022-0669')
# value = {'cve': 'CVE-2022-39952', 'epss': 0.0095, 'percentile': 0.32069}

value = client.epss(cve_id='CVE-2022-0669')
# value == 0.0095

value = client.percentile(cve_id='CVE-2022-0669')
# value == 0.32069

If you call either one method, EPSS client cache all CVE's score in memory. After caching, you can get all data very fast.