Skip to content

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) !