Skip to main content

Democritus functions for working with domains.

Project description

Democritus Domains

PyPI CI Lint codecov The Democritus Project uses semver version 2.0.0 The Democritus Project uses ruff to format and lint code License: LGPL v3

Democritus functions[1] for working with domains.

[1] Democritus functions are simple, effective, modular, well-tested, and well-documented Python functions.

We use d8s (pronounced "dee-eights") as an abbreviation for democritus (you can read more about this here).

Installation

pip install d8s-domains

Usage

You import the library like:

from d8s_domains import *

Once imported, you can use any of the functions listed below.

Functions

  • def is_domain(possible_domain: str) -> bool:
        """Check if the given string is a domain."""
    
  • def domain_examples(n: int = 10) -> List[str]:
        """Create n domain names."""
    
  • def domains_find(text: str, **kwargs: bool) -> List[str]:
        """Parse domain names from the given text."""
    
  • def domain_dns(domain: str) -> str:
        """Get the DNS results for the given domain."""
    
  • def domain_certificate_peers(domain: str) -> List[str]:
        """Return a list of all domains sharing a certificate with the given domain."""
    
  • def domain_whois(domain: str) -> Optional[Dict[str, Any]]:
        """."""
    
  • def domain_subdomains(domain_name: str) -> str:
        """Get the subdomains for the given domain name."""
    
  • def domain_second_level_name(domain_name: str) -> str:
        """Get the second level name for the given domain name (e.g. google from https://google.co.uk)."""
    
  • def domain_tld(domain_name: str) -> str:
        """Get the top level domain for the given domain name."""
    
  • def domain_rank(domain_name: str) -> int:
        """."""
    
  • def domain_is_member(domain_to_check: str, domain_base: str) -> bool:
        """Given two domains, check if the first domain is a member of the second domain.
    A member means it is either the domain itself, or a subdomain of the domain."""
    
  • def domain_as_punycode(domain_name: str) -> str:
        """Convert the given domain name to Punycode (https://en.wikipedia.org/wiki/Punycode)."""
    
  • def domain_as_unicode(domain_name: str) -> str:
        """Convert a given domain name to Unicode (https://en.wikipedia.org/wiki/Unicode)."""
    
  • def tlds() -> List[str]:
        """Get the top level domains from https://iana.org/."""
    
  • def is_tld(possible_tld: str) -> bool:
        """Return whether or not the possible_tld is a valid tld."""
    

Development

👋  If you want to get involved in this project, we have some short, helpful guides below:

If you have any questions or there is anything we did not cover, please raise an issue and we'll be happy to help.

Credits

This package was created with Cookiecutter and Floyd Hightower's Python project template.

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

d8s_domains-0.7.0.tar.gz (95.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

d8s_domains-0.7.0-py3-none-any.whl (20.3 kB view details)

Uploaded Python 3

File details

Details for the file d8s_domains-0.7.0.tar.gz.

File metadata

  • Download URL: d8s_domains-0.7.0.tar.gz
  • Upload date:
  • Size: 95.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for d8s_domains-0.7.0.tar.gz
Algorithm Hash digest
SHA256 e9627eb843389e8d34d6c10cd9913952fe1220c0b68983cfea73017354d270a5
MD5 8100128ab977d7599e7f79975a07400d
BLAKE2b-256 8e9b038d8978d6e1d8f3d858e70d2202dfc4257b57695bac06d3f159291bc63b

See more details on using hashes here.

Provenance

The following attestation bundles were made for d8s_domains-0.7.0.tar.gz:

Publisher: release-please.yml on democritus-project/d8s-domains

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file d8s_domains-0.7.0-py3-none-any.whl.

File metadata

  • Download URL: d8s_domains-0.7.0-py3-none-any.whl
  • Upload date:
  • Size: 20.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for d8s_domains-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c94a3b328edd1023eaa7697f5dc2a6d47bd594a5f173cc3a0b7f45716d1befb0
MD5 c5b03cf8f7053e61f88d696bf1a3ebfa
BLAKE2b-256 8643e65a5cb1425449619303d03c72db09bb5d6c97f4def0710035687be7698f

See more details on using hashes here.

Provenance

The following attestation bundles were made for d8s_domains-0.7.0-py3-none-any.whl:

Publisher: release-please.yml on democritus-project/d8s-domains

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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