/* Technitium DNS Server Copyright (C) 2021 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; using System.Net; using System.Threading.Tasks; using TechnitiumLibrary.Net.Dns; namespace DnsServerCore.ApplicationCommon { public enum DnsRequestControllerAction { /// /// Allow the request to be processed. /// Allow = 0, /// /// Drop the request without any response. /// DropSilently = 1, /// /// Drop the request with a Refused response. /// DropWithRefused = 2 } /// /// Allows a DNS App to inspect and optionally block incoming DNS requests before they are processed by the DNS Server core. /// public interface IDnsRequestController : IDisposable { /// /// Allows initializing the DNS application with a config. This function is also called when the config is updated to allow reloading. /// /// The DNS server interface object that allows access to DNS server properties. /// The DNS application config stored in the dnsApp.config file. Task InitializeAsync(IDnsServer dnsServer, string config); /// /// Allows a DNS App to inspect an incoming DNS request and decide whether to allow or block it. This method is called by the DNS Server before an incoming request is processed. /// /// The incoming DNS request. /// The end point (IP address and port) of the client making the request. /// The protocol using which the request was received. /// The action that must be taken by the DNS server i.e. if the request must be allowed or dropped. Task GetRequestActionAsync(DnsDatagram request, IPEndPoint remoteEP, DnsTransportProtocol protocol); /// /// The description about this app to be shown in the Apps section of the DNS web console. /// string Description { get; } } }