Metadata-Version: 2.1
Name: domain-reputation
Version: 1.0.0
Summary: Python client library for Domain Reputation API.
Home-page: https://github.com/whois-api-llc/domain-reputation-py
Author: WHOIS API, Inc
Author-email: support@whoisxmlapi.com
License: MIT
Keywords: domain,domain reputation,domain reputation api,threat intelligence,api,whois,whoisxmlapi
Platform: UNKNOWN
Classifier: Development Status :: 5 - Production/Stable
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: Unix
Classifier: Operating System :: POSIX
Classifier: Operating System :: Microsoft :: Windows
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Topic :: Utilities
Requires-Python: >=3.6
Provides-Extra: dev
License-File: LICENSE
License-File: AUTHORS.rst

.. image:: https://img.shields.io/badge/License-MIT-green.svg
    :alt: domain-reputation-py license
    :target: https://opensource.org/licenses/MIT

.. image:: https://img.shields.io/pypi/v/domain-reputation.svg
    :alt: domain-reputation-py release
    :target: https://pypi.org/project/domain-reputation

.. image:: https://github.com/whois-api-llc/domain-reputation-py/workflows/Build/badge.svg
    :alt: domain-reputation-py build
    :target: https://github.com/whois-api-llc/domain-reputation-py/actions

========
Overview
========

The client library for
`Domain Reputation API <https://domain-reputation.whoisxmlapi.com/api>`_
in Python language.

The minimum Python version is 3.6.

Installation
============

.. code-block:: shell

    pip install domain-reputation

Examples
========

Full API documentation available `here <https://domain-reputation.whoisxmlapi.com/api/documentation/making-requests>`_

Create a new client
-------------------

.. code-block:: python

    from domainreputation import *

    client = Client('Your API key')

Make basic requests
-------------------

.. code-block:: python

    # Get DNS records for a domain name.
    response = client.get('youtube.com')
    print(response)

    # Get raw API response in XML format
    raw_result = client.get_raw('bbc.com',
        output_format=Client.XML_FORMAT)

Advanced usage
-------------------

Extra request parameters

.. code-block:: python

    result = client.get(
        'samsung.com',
        Client.MODE_FULL)

Response model overview
-----------------------

.. code-block:: python

    Response:
        - mode: str
        - reputation_score: float
        - test_results: [TestResult]
            - test: str
            - test_code: int
            - warnings: [str]
            - warning_codes: [int]


Sample response
---------------

.. code-block:: python

  {
  'mode': 'full',
  'reputation_score': 81.16,
  'test_results':
    [
        {
            "test": "Name servers configuration meets best practices",
            "testCode": 76,
            "warnings": [
                "Some name servers are located on a single ASN: \
                 ns44.domaincontrol.com - AS44273, ns43.domaincontrol.com - AS44273"
            ],
            "warningCodes": [
                1013
            ]
        },
        {
            "test": "Mail servers configuration check",
            "testCode": 80,
            "warnings": [
                "AAAA records not configured for mail servers",
                "SPF record not configured",
                "DMARC is not configured"
            ],
            "warningCodes": [
                5007,
                5015,
                5016
            ]
        },
        {
            "test": "Malware databases check",
            "testCode": 82,
            "warnings": [
                "Status: dangerous"
            ],
            "warningCodes": [
                4001
            ]
        },
        {
            "test": "SSL Certificate configuration",
            "testCode": 89,
            "warnings": [
                "No SSL certificates found"
            ],
            "warningCodes": [
                6023
            ]
        }
    ]
  }



Changelog
=========

1.0.0 (2021-10-25)
------------------

* First release

