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:
NFSN (NearlyFreeSpeech)
Online
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.9.2-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | d474426f7bf2b10c49507b432fc70a75bd694da52911a4955c1cbe2efb573ffa |
|
MD5 | 38c4f3a4b32cdf887754fa73b1e8b271 |
|
BLAKE2b-256 | 9534c4896a54ca484bf815b43f837387b252f1f45567d33e1c2c9b0c1338f943 |