Skip to main content

Manipulate DNS records on various DNS providers in a standardized/agnostic way

Project description

Lexicon

Manipulate DNS records on various DNS providers in a standardized/agnostic way.

build_status tests_status coverage_status docker_pulls pypy_version 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.

Lexicon currently supports 88 providers:

aliyun

arvancloud

aurora

azure

cloudflare

cloudns

cloudxns

conoha

constellix

ddns

devnomads

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

ionos

joker

linode

linode4

localzone

luadns

memset

misaka

mythicbeasts

namecheap

namecom

namesilo

netcup

nfsn

njalla

nsone

oci

onapp

online

ovh

plesk

pointhq

porkbun

powerdns

qcloud

rackspace

rage4

rcodezero

regfish

route53

safedns

sakuracloud

scaleway

softlayer

timeweb

transip

ultradns

valuedomain

vercel

vultr

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.21.1.tar.gz (155.8 kB view details)

Uploaded Source

Built Distribution

dns_lexicon-3.21.1-py3-none-any.whl (256.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: dns_lexicon-3.21.1.tar.gz
  • Upload date:
  • Size: 155.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.6.17

File hashes

Hashes for dns_lexicon-3.21.1.tar.gz
Algorithm Hash digest
SHA256 7cd19f692b384fe5eaa47cce334d24c78ae2eba1d2fb24d2b8a05e04fe294497
MD5 a561d567d8d21798c90c38d6038c9745
BLAKE2b-256 6058055f9552cafeeac094a5e0334fe0eaf4cbf8e1485cc545a26c079ca632f1

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for dns_lexicon-3.21.1-py3-none-any.whl
Algorithm Hash digest
SHA256 45aa4ef08911f885ba0e5e6e4ed7459f988a3207c792b19ecebaf6be86b5d3b6
MD5 ee89f2abbd0d5ade66ffd7b8171c945a
BLAKE2b-256 c11e69a6679e5fb753957154666f4c5ece9007b60c2a26677c0c3eb69aeab9c2

See more details on using hashes here.

Supported by

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