/*
Technitium DNS Server
Copyright (C) 2023 Shreyas Zare (shreyas@technitium.com)
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see .
*/
using System.Net;
using System.Threading.Tasks;
using TechnitiumLibrary.Net.Dns;
namespace DnsServerCore.ApplicationCommon
{
///
/// Allows a DNS App to handle incoming DNS requests for configured APP records in the DNS server zones.
///
public interface IDnsAppRecordRequestHandler
{
///
/// Allows a DNS App to respond to the incoming DNS requests for an APP record in a primary or secondary zone.
///
/// The incoming DNS request to be processed.
/// The end point (IP address and port) of the client making the request.
/// The protocol using which the request was received.
/// Tells if the DNS server is configured to allow recursion for the client making this request.
/// The name of the application zone that the APP record belongs to.
/// The domain name of the APP record.
/// The TTL value set in the APP record.
/// The record data in the APP record as required for processing the request.
/// The DNS response for the DNS request or null to send NODATA response when QNAME matches APP record name or else NXDOMAIN response with an SOA authority.
Task ProcessRequestAsync(DnsDatagram request, IPEndPoint remoteEP, DnsTransportProtocol protocol, bool isRecursionAllowed, string zoneName, string appRecordName, uint appRecordTtl, string appRecordData);
///
/// A template of the record data format that is required by this app. This template is populated in the UI to allow the user to edit in the expected values. The format could be JSON or any other custom text based format which the app is programmed to parse. This property is optional and can return null if no APP record data is required by the app.
///
string ApplicationRecordDataTemplate { get; }
}
}