Manipulate DNS records on various DNS providers in a standardized/agnostic way
Project description
Manipulate DNS records on various DNS providers in a standardized/agnostic way.
Why using Lexicon?
Lexicon provides a way to manipulate DNS records on multiple DNS providers in a standardized way.
Lexicon can be used as:
a CLI tool:
# Create a TXT entry in domain.net zone hosted by CloudFlare
lexicon cloudflare create domain.net TXT --name foo --content bar
or a Python library:
# Create a TXT entry in domain.net zone hosted by CloudFlare
from lexicon.client import Client
from lexicon.config import ConfigResolver
action = {
"provider_name" : "cloudflare",
"action": "create",
"domain": "domain.net",
"type": "TXT",
"name": "foo",
"content": "bar",
}
config = ConfigResolver().with_env().with_dict(action)
Client(config).execute()
Lexicon was designed to be used in automation, specifically letsencrypt.
Supported providers
Only DNS providers who have an API can be supported by lexicon.
The current supported providers are:
Documentation
Online documentation (user guide, configuration reference) is available in the Lexicon documentation.
For a quick start, please have a look in particular at the User guide.
Contributing
If you want to help in the Lexicon development, you are welcome!
Please have a look at the Developer guide page to know how to start.
Licensing
MIT
Logo: transform by Mike Rowe from the Noun Project
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for dns_lexicon-3.11.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | dde5fee503a1f79a44e8c12891e37b9923a2d1f7125a08e73e4788deb146cdfc |
|
MD5 | c84fd481ee2922275c3bf16b4da77c69 |
|
BLAKE2b-256 | a1655187520789c760106e2851f269bc450d6d7eaa1bab09cdc9a4091ba04e0a |