develop.luadns #
LuaDNS Vlang Module
Overview
This module provides functionality to parse and manage DNS configurations from Lua scripts. It supports creating, updating, and validating DNS records for multiple domains.
Features
- Parse Lua DNS configuration files.
- Manage DNS records for multiple domains.
- Validate IP addresses and domain names.
- Automatically add default CNAME and CAA records.
Usage
Load DNS Configurations
Load DNS configurations from a git repository.
import luadns
// Load configurations from a git URL
dns := luadns.load('https://git.example.com/repo.git')!
Set Domain
Add or update an A record for a domain or subdomain.
dns.set_domain('example.com', '51.129.54.234')!
dns.set_domain('auth.example.com', '231.29.54.234')!
Validate Inputs
The module ensures that only valid IP addresses and domain names are accepted.
fn load #
fn load(url string) !LuaDNS
returns the path of the fetched repo
fn (LuaDNS) directory #
fn (dns LuaDNS) directory() !pathlib.Path
returns the directory of the git repository for the dns
fn (LuaDNS) domain_file #
fn (dns LuaDNS) domain_file(domain string) !pathlib.Path
fn (LuaDNS) repository #
fn (dns LuaDNS) repository() !&gittools.GitRepo
returns the git repository for the dns
fn (LuaDNS) set_domain #
fn (mut dns LuaDNS) set_domain(domain string, ip string) !