IDnsApplicationRequestHandler.cs 3.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. /*
  2. Technitium DNS Server
  3. Copyright (C) 2021 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;
  16. using System.Net;
  17. using System.Threading.Tasks;
  18. using TechnitiumLibrary.Net.Dns;
  19. namespace DnsApplicationCommon
  20. {
  21. public interface IDnsApplicationRequestHandler : IDisposable
  22. {
  23. /// <summary>
  24. /// Allows initializing the DNS application with a config. This function is also called when the config is updated to allow reloading.
  25. /// </summary>
  26. /// <param name="dnsServer">The DNS server interface object that allows access to DNS server properties.</param>
  27. /// <param name="config">The DNS application config stored in the <c>dnsApp.config</c> file.</param>
  28. Task InitializeAsync(IDnsServer dnsServer, string config);
  29. /// <summary>
  30. /// This method is called by the DNS Server to process the DNS application request when an APP record in an Application zone is hit.
  31. /// </summary>
  32. /// <param name="request">The DNS request object to be processed.</param>
  33. /// <param name="remoteEP">The end point (IP address and port) of the client making the request.</param>
  34. /// <param name="zoneName">The name of the application zone that the APP record belongs to.</param>
  35. /// <param name="appRecordTtl">The TTL value set in the APP record.</param>
  36. /// <param name="appRecordData">The record data in the APP record as required for processing the request.</param>
  37. /// <param name="isRecursionAllowed">Tells if the DNS server is configured to allow recursion for the client making this request.</param>
  38. /// <param name="dnsServer">The DNS server object that allows access to the DNS server properties.</param>
  39. /// <returns>The DNS response for the DNS request or <c>null</c> to send no answer response with an SOA authority.</returns>
  40. Task<DnsDatagram> ProcessRequestAsync(DnsDatagram request, IPEndPoint remoteEP, string zoneName, uint appRecordTtl, string appRecordData, bool isRecursionAllowed, IDnsServer dnsServer);
  41. /// <summary>
  42. /// The description about this app to be shown in the Apps section of the DNS web console.
  43. /// </summary>
  44. string Description { get; }
  45. /// <summary>
  46. /// 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 <c>null</c> if no APP record data is required by the app.
  47. /// </summary>
  48. string ApplicationRecordDataTemplate { get; }
  49. }
  50. }