Skip to main content

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.

build_status coverage_status docker_pulls pypy_version pypy_python_support github_license

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

config = ConfigResolver().with_env().with_dict({
    "provider_name" : "cloudflare",
    "domain": "domain.net",
})

with Client(config) as operations:
    operations.create_record("TXT", "foo", "bar")

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:

aliyun

aurora

azure

cloudflare

cloudns

cloudxns

conoha

constellix

ddns

digitalocean

dinahosting

directadmin

dnsimple

dnsmadeeasy

dnspark

dnspod

dnsservices

dreamhost

duckdns

dynu

easydns

easyname

euserv

exoscale

flexibleengine

gandi

gehirn

glesys

godaddy

googleclouddns

gransy

gratisdns

henet

hetzner

hostingde

hover

infoblox

infomaniak

internetbs

inwx

joker

linode

linode4

localzone

luadns

memset

misaka

mythicbeasts

namecheap

namecom

namesilo

netcup

nfsn

njalla

nsone

oci

onapp

online

ovh

plesk

pointhq

porkbun

powerdns

rackspace

rage4

rcodezero

route53

safedns

sakuracloud

softlayer

transip

ultradns

valuedomain

vercel

vultr

webgo

wedos

yandex

yandexcloud

zeit

zilore

zonomi

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

dns_lexicon-3.17.0.tar.gz (154.7 kB view details)

Uploaded Source

Built Distribution

dns_lexicon-3.17.0-py3-none-any.whl (243.9 kB view details)

Uploaded Python 3

File details

Details for the file dns_lexicon-3.17.0.tar.gz.

File metadata

  • Download URL: dns_lexicon-3.17.0.tar.gz
  • Upload date:
  • Size: 154.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.7.0 CPython/3.12.0 Linux/6.2.0-1015-azure

File hashes

Hashes for dns_lexicon-3.17.0.tar.gz
Algorithm Hash digest
SHA256 25871a7c145095ee21405525077856eadc059ab7692ae4c333f16563385d3c40
MD5 a479422d34dae7460cf7c64ae7c8448b
BLAKE2b-256 01a60e889bff0516d3cfec95d78139f896c31e89639a8e1f9bc93a5b7be363f7

See more details on using hashes here.

File details

Details for the file dns_lexicon-3.17.0-py3-none-any.whl.

File metadata

  • Download URL: dns_lexicon-3.17.0-py3-none-any.whl
  • Upload date:
  • Size: 243.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.7.0 CPython/3.12.0 Linux/6.2.0-1015-azure

File hashes

Hashes for dns_lexicon-3.17.0-py3-none-any.whl
Algorithm Hash digest
SHA256 eb45d67d17b37f9c9f18638cd4723fbaa36b92b380b8eefae307121acf2c9c6e
MD5 0b330cc7bba0bbaac1522343dab5cd95
BLAKE2b-256 c34b3795c20b43bf489f4bd8429efe59799ac1d0b23917a12b458814fba9450c

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