Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/wenerme/coredns-pdsql
CoreDNS PowerDNS adapter
https://github.com/wenerme/coredns-pdsql
Last synced: 3 months ago
JSON representation
CoreDNS PowerDNS adapter
- Host: GitHub
- URL: https://github.com/wenerme/coredns-pdsql
- Owner: wenerme
- License: mit
- Created: 2021-05-15T07:56:51.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2023-10-09T03:15:11.000Z (about 1 year ago)
- Last Synced: 2024-04-10T20:39:20.161Z (7 months ago)
- Language: Go
- Size: 42 KB
- Stars: 10
- Watchers: 3
- Forks: 15
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-coredns - pdsql - uses powerdns generic sql as backend. (External Plguins)
README
---
title: "pdsql"
description: "*pdsql* use powerdns generic sql as backend."
weight: 10
tags: [ "plugin" , "pdsql" ]
categories: [ "plugin", "external" ]
date: "2017-12-09T10:26:00+08:00"
repo: "https://github.com/wenerme/coredns-pdsql"
home: "https://github.com/wenerme/coredns-pdsql/blob/master/README.md"
---# pdsql
*pdsql* use PowerDNS [generic sql](https://github.com/PowerDNS/pdns/tree/master/pdns/backends/gsql) as backend.
Use [jinzhu/gorm](https://github.com/jinzhu/gorm) to handle database, support many database as gorm dose.
## Syntax
~~~ txt
pdsql {
# enable debug mode
debug [db]
# create table for test
auto-migrate
}
~~~## Install Driver
pdsql need db driver for dialect, to install a driver you need to add import in plugin.cfg, like
~~~ txt
pdsql_mysql:github.com/jinzhu/gorm/dialects/mysql
pdsql_sqlite:github.com/jinzhu/gorm/dialects/sqlite
~~~pdsql_mysql and pdsql_sqlite are meaningless, choose to prevent duplicated.
## Examples
Start a server on the 1053 port, use test.db as backend.
~~~ corefile
test.:1053 {
pdsql sqlite3 ./test.db {
debug db
auto-migrate
}
}
~~~Prepare data for test.
~~~ bash
# Insert records for wener.test
sqlite3 ./test.db 'insert into records(name,type,content,ttl,disabled)values("wener.test","A","192.168.1.1",3600,0)'
sqlite3 ./test.db 'insert into records(name,type,content,ttl,disabled)values("wener.test","TXT","TXT Here",3600,0)'
~~~When queried for "wener.test. A", CoreDNS will respond with:
~~~ txt
;; QUESTION SECTION:
;wener.test. IN A;; ANSWER SECTION:
wener.test. 3600 IN A 192.168.1.1
~~~When queried for "wener.test. ANY", CoreDNS will respond with:
~~~ txt
;; QUESTION SECTION:
;wener.test. IN ANY;; ANSWER SECTION:
wener.test. 3600 IN A 192.168.1.1
wener.test. 3600 IN TXT "TXT Here"
~~~### Wildcard
~~~ bash
# domain id 1
sqlite3 ./test.db 'insert into domains(name,type)values("example.test","NATIVE")'
sqlite3 ./test.db 'insert into records(domain_id,name,type,content,ttl,disabled)values(1,"*.example.test","A","192.168.1.1",3600,0)'
~~~When queried for "first.example.test. A", CoreDNS will respond with:
~~~ txt
;; QUESTION SECTION:
;first.example.test. IN A;; ANSWER SECTION:
first.example.test. 3600 IN A 192.168.1.1
~~~## TODO
* [x] support wildcard record