IDnsRequestBlockingHandler.cs 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. /*
  2. Technitium DNS Server
  3. Copyright (C) 2023 Shreyas Zare (shreyas@technitium.com)
  4. This program is free software: you can redistribute it and/or modify
  5. it under the terms of the GNU General Public License as published by
  6. the Free Software Foundation, either version 3 of the License, or
  7. (at your option) any later version.
  8. This program is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. GNU General Public License for more details.
  12. You should have received a copy of the GNU General Public License
  13. along with this program. If not, see <http://www.gnu.org/licenses/>.
  14. */
  15. using System.Net;
  16. using System.Threading.Tasks;
  17. using TechnitiumLibrary.Net.Dns;
  18. namespace DnsServerCore.ApplicationCommon
  19. {
  20. /// <summary>
  21. /// Lets DNS Apps provide DNS level domain name blocking feature.
  22. /// </summary>
  23. public interface IDnsRequestBlockingHandler
  24. {
  25. /// <summary>
  26. /// Specifies if the query domain name in the incoming DNS request is allowed to bypass any configured block lists (including for DNS server's built-in blocking feature).
  27. /// </summary>
  28. /// <param name="request">The incoming DNS request to be processed.</param>
  29. /// <param name="remoteEP">The end point (IP address and port) of the client making the request.</param>
  30. /// <returns>Returns <c>true</c> if the query domain name in the incoming DNS request is allowed to bypass blocking.</returns>
  31. Task<bool> IsAllowedAsync(DnsDatagram request, IPEndPoint remoteEP);
  32. /// <summary>
  33. /// Specifies if the query domain name in the incoming DNS request is blocked based on the app's own configured block lists.
  34. /// </summary>
  35. /// <param name="request">The incoming DNS request to be processed.</param>
  36. /// <param name="remoteEP">The end point (IP address and port) of the client making the request.</param>
  37. /// <returns>The blocked DNS response for the DNS request or <c>null</c> to let the DNS server core process the request as usual.</returns>
  38. Task<DnsDatagram> ProcessRequestAsync(DnsDatagram request, IPEndPoint remoteEP);
  39. }
  40. }