Skip to main content

No project description provided

Project description

README

This repository wraps the cloudfloordns API into a python library. The set of features supported is limited to our current usage and may grow accordingly to our needs.

Documentation

Documentation can be found here It is automatically generated using pdoc

Features

All features can be accessed through the Client class:

  • Generic get/post/patch/delete methods that handle the result errors
  • records: all CRUD operations + .is_same(...) method to compare 2 records (see limitations)
  • domains: list all domains

NOTE: All objects (records/domains/...) are validated and wrapped inside a python class for convenience.

from cloudfloordns import Client, Record, Domain

client = Client()

domains = client.domains.list()
mydomain = domains[0]

my_record = Record(...)
client.records.create(mydomain, my_record)

client.records.list(mydomain)

Known Limitations

  • The API is really old and still use Swagger v1 (Swagger v2 has been out since 2014-09-08)

  • Authentication parameters are passed in the body.

    • This is considered unsafe since the body can easily be logged (same for the url). The credentials should have been passed in HTTP headers.
    • The standard does not allow to send a body with a GET method, some libraries may therefore not send the body.
  • The online documentation contains wrong/incomplete informations

    • Wrong types (e.g. IDs are said to be of type int when they are str).
    • Required parameters are not explicited
    • Create operation (POST method) acts silently as an Update operation (PATCH method) on conflict instead of throwing an error.

    The current result is obtained through manual experimentation

  • The Create/Update/Delete operations don't return any information about the remote data (e.g. New state, including the generated ID) => The only workaround to retrieve the changes is to make a request

  • The API doesn't provide a way to retrieve a single object (domain/record/...) by its ID. The only way is to ask for all objects and filter them based on unique groupe of attributes. This limitation force us to provide a comparison method .is_same(...) to be able to check the remote objects and identify the corresponding one.

    client = Client()
    my_record = Record(...)
    client.records.create("mydomain.com", my_record)
    
    remote_records = client.records.list("mydomain.com")
    created_record = next((r for r in remote_records if my_record.is_same(r)), None)
    

    This consume a lot more bandwidth than required (hopefully, the server response is fast enough). The results should be cached as much as possible

Run the project:

  1. Enter your virtual environment doing poetry shell (only need to do that once in the terminal)
  2. Run the project
    python cloudfloordns
    

Develop

  • Add a library using poetry add mypackage (same as you would do with pip install mypackage)
  • Edit only the sources in cloudfloordns/
  • Check our online documentation for useful libraries.

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

cloudfloordns-0.1.8.tar.gz (17.8 kB view details)

Uploaded Source

Built Distribution

cloudfloordns-0.1.8-py3-none-any.whl (21.7 kB view details)

Uploaded Python 3

File details

Details for the file cloudfloordns-0.1.8.tar.gz.

File metadata

  • Download URL: cloudfloordns-0.1.8.tar.gz
  • Upload date:
  • Size: 17.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.9.19

File hashes

Hashes for cloudfloordns-0.1.8.tar.gz
Algorithm Hash digest
SHA256 08a8d1d67adc3d32b6bc4012ad652f8a9a4811c014caa74713254f493a8b0ac8
MD5 d192befb49226e6ad4ef7c2500297999
BLAKE2b-256 65f71d8ea24c8ce4f14ae2f64a899a8f3316c8f2b77add260ab93d6737d9ce9e

See more details on using hashes here.

File details

Details for the file cloudfloordns-0.1.8-py3-none-any.whl.

File metadata

File hashes

Hashes for cloudfloordns-0.1.8-py3-none-any.whl
Algorithm Hash digest
SHA256 ba1ad051d50585c03d6fa6336c4ef4adb501e52e47eb33239ae6069856d114b4
MD5 ac943e7525761d310cfd9370ad6d1809
BLAKE2b-256 2786393533f9ac8500fddaed175d3e1913b3474fe490d05c08afacb87fb84faf

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