Skip to main content

Python Client for Yuleak API.

Project description

Yuleak API

Latest Version on PyPI Documentation Status Licence

The official Python library for the Yuleak API.

Features

  • Convenient methods for making calls to the API.
  • Automatic parsing of API responses into Python objects.

Installation

yuleak-api is available on PYPI

pip install yuleak-api

Documentation

You can use the API with default demo key for development purpose but to use it you'll need to register to Yuleak.

Authentication

from yuleak_api.client import YuleakClient
YuleakClient.set_apikey('my_secret_api_key')

Errors

In case of error, GET methods will return an empty list and POST/DELETE will return False.

The error will be displayed in yuleak-api logger.

Warnings will (such as a deprecated endpoint) will also be displayed in yuleak-api logger.

Pagination

Pagination will be handle by the YuleakClient, you do not have to care about.

Usage

This is not intended to provide complete documentation of the API.

For more details, please refer to the official documentation.

For more information on the included models and abstractions, please read the code.

Credits

Please check your credits amount before making any search or renew action to avoid errors.

print(YuleakClient.credits())

Dashboards

dashboards = YuleakClient.dashboards()
for dashboard in dashboards:
    # Display stats (similar to dashboard view in WebUI)
    print(dashboard.stats())
    # Display map (similar to map widget in WebUI)
    print(dashboard.map())
    # Display graph (similar to graph view in WebUI)
    for node in dashboard.graph():
        if node.type == 'asn':
            print('AS: {0}'.format(node.label))
            for child in node.neighbors:
                if child.type == 'server':
                    print(child)
    # Display timeline (similar to timeline widget in WebUI)
    print(dashboard.timeline())
    # Display details (similar to details view in WebUI)
    for server in dashboard.details():
        print(server.geo.country_name)
        # Download screenshots
        for domain in server.domains:
            if domain.screenshot is not None:
                domain.screenshot.download('/tmp/{0}.png'.format(domain.value))
    dashboard.delete()

Resources

resources = dashboard.resources()
for resource in resources:
    print('{0} :: {1}'.format(resource.value, resource.status))
    if resource.type == 'server':
        resource.renew()
    else:
        resource.delete()

Bookmarks

server = dashboard.details()[0]
assert not server.bookmark
server.add_bookmark()
assert server.bookmark
server.del_bookmark()
assert not server.bookmark

Filters

dashboard.add_filter('domain', 'all')
for f in dashboard.filters():
    print(f)
    f.delete()

Search

YuleakClient.search('yuleak.com')
dashboard = YuleakClient.dashboards()[-1]
dashboard.search('yuleak.io')
# Mass search
new_servers = dashboard.list_new_servers()
if YuleakClient.credits() >= new_servers > 0:
    dashboard.searchall()

Changelog

v1.5.0

  • GET dashboard/{id}/statsdns added
  • GET dashboard/{id}/dns added
  • you can now add custom headers in YuleakClient requests

v1.4.0

  • preview screenshot can now be recovered using server.domain.screenshot.download()

v1.3.4

  • requests timeout can now be set with YuleakClient.REQUESTS_TIMEOUT
  • requests retry on error can now be set with YuleakClient.REQUESTS_RETRY

v1.3.3

  • correct error on 'DELETE dashboard/{id}' endpoint

v1.3.2

  • correct error on 'searchall' endpoint

v1.3.1

  • correct error on pip install

v1.3.0

  • GET dashboard/{id}/renewall added
  • POST dashboard/{id}/renewall added

v1.2.0

  • GET dashboard/{id}/searchall added
  • POST dashboard/{id}/searchall added

v1.1.0

  • Change to match the Yuleak API path modifications

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

yuleak-api-1.5.0.tar.gz (11.0 kB view details)

Uploaded Source

File details

Details for the file yuleak-api-1.5.0.tar.gz.

File metadata

  • Download URL: yuleak-api-1.5.0.tar.gz
  • Upload date:
  • Size: 11.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.43.0 CPython/3.7.6

File hashes

Hashes for yuleak-api-1.5.0.tar.gz
Algorithm Hash digest
SHA256 f4ef0266e3aac5e779dc7ccc1f63432af1e4eac94e764ff4b172e7a990792ef5
MD5 ecde5ea7f0d181f80466712c4077788e
BLAKE2b-256 eaf776fa2882015697b086a8c7c2108d6f0df395e5e84358181710838d5f92e8

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page