DNS library for Elixir
Tung Dao 226e9810ca update example in README, fix #23 2 months ago
config extract server behavior 2 years ago
example add behaviour 8 months ago
lib Don't fail if we receive an unexpected RR type 3 months ago
test switch off failing tests 8 months ago
.formatter.exs add behaviour 8 months ago
.gitignore add docs generator 2 years ago
.travis.yml switch to Travis 3 months ago
LICENSE.md add LICENSE 2 years ago
README.md update example in README, fix #23 2 months ago
mix.exs version bump 3 months ago
mix.lock add behaviour 8 months ago

README.md

DNS

Hex.pm Hex.pm Build Status

DNS library for Elixir. Currently, the package provides:

  • Elixir structs to interface with inet_dns module.
  • DNS.Server behavior
  • DNS client

Note: the inet_dns module is considered internal to Erlang and subject to change. If this happened this library will be updated to accommodate for that, but for now inet_dns is simple and worked for me.

Installation

The package is available in Hex and can be installed as:

  1. Make sure you have the Erlang/OTP source files installed, otherwise the compilation will fail with an {:error, :enoent} message. On Ubuntu, this can be done using apt-get install erlang-src.

  2. Add dns to your list of dependencies in mix.exs:

    ```elixir
    def deps do
      [{:dns, "~> 2.1.2"}]
    end
    ```
    

Usage

DNS client

iex> DNS.resolve("google.com")
{:ok, [{216, 58, 221, 110}]}

iex> DNS.resolve("notfound.domain")
{:error, :not_found}

iex> DNS.query("google.com")
%DNS.Record{anlist: [%DNS.Resource{bm: [], class: :in, cnt: 0,
   data: {216, 58, 221, 110}, domain: 'google.com', func: false, tm: :undefined,
   ttl: 129, type: :a}], arlist: [],
 header: %DNS.Header{aa: false, id: 0, opcode: :query, pr: false, qr: true,
  ra: true, rcode: 0, rd: false, tc: false}, nslist: [],
 qdlist: [%DNS.Query{class: :in, domain: 'google.com', type: :a}]}

iex> DNS.resolve("google.com", :a, {"8.8.8.8", 53})
...

DNS server

defmodule ServerExample do
  @moduledoc """
  Example implementing DNS.Server behaviour
  """
  @behaviour DNS.Server
  use DNS.Server

  def handle(record, _cl) do
    Logger.info(fn -> "#{inspect(record)}" end)
    query = hd(record.qdlist)

    result =
      case query.type do
        :a -> {127, 0, 0, 1}
        :cname -> 'your.domain.com'
        :txt -> ['your txt value']
        _ -> nil
      end

    resource = %DNS.Resource{
      domain: query.domain,
      class: query.class,
      type: query.type,
      ttl: 0,
      data: result
    }

    %{record | anlist: [resource], header: %{record.header | qr: true}}
  end
end
# To create a server
{:ok, server_pid} = ServerExample.start_link 8000

For more information, see API Reference

License

BSD-3-Clauses