mirror of
https://github.com/fergalmoran/DnsServer.git
synced 2025-12-22 09:29:50 +00:00
NoDataApp: implemented no data app to be used to block DNS resource records in forwarder zones with a NO DATA response.
This commit is contained in:
91
Apps/NoDataApp/App.cs
Normal file
91
Apps/NoDataApp/App.cs
Normal file
@@ -0,0 +1,91 @@
|
||||
/*
|
||||
Technitium DNS Server
|
||||
Copyright (C) 2022 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 <http://www.gnu.org/licenses/>.
|
||||
|
||||
*/
|
||||
|
||||
using DnsServerCore.ApplicationCommon;
|
||||
using Newtonsoft.Json;
|
||||
using System;
|
||||
using System.Net;
|
||||
using System.Threading.Tasks;
|
||||
using TechnitiumLibrary.Net.Dns;
|
||||
using TechnitiumLibrary.Net.Dns.ResourceRecords;
|
||||
|
||||
namespace NoData
|
||||
{
|
||||
public class App : IDnsApplication, IDnsAppRecordRequestHandler
|
||||
{
|
||||
#region IDisposable
|
||||
|
||||
public void Dispose()
|
||||
{
|
||||
//do nothing
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
#region public
|
||||
|
||||
public Task InitializeAsync(IDnsServer dnsServer, string config)
|
||||
{
|
||||
//do nothing
|
||||
return Task.CompletedTask;
|
||||
}
|
||||
|
||||
public Task<DnsDatagram> ProcessRequestAsync(DnsDatagram request, IPEndPoint remoteEP, DnsTransportProtocol protocol, bool isRecursionAllowed, string zoneName, string appRecordName, uint appRecordTtl, string appRecordData)
|
||||
{
|
||||
DnsQuestionRecord question = request.Question[0];
|
||||
|
||||
if (question.Name.Equals(appRecordName, StringComparison.OrdinalIgnoreCase))
|
||||
{
|
||||
dynamic jsonAppRecordData = JsonConvert.DeserializeObject(appRecordData);
|
||||
|
||||
foreach (dynamic jsonBlockedType in jsonAppRecordData.blockedTypes)
|
||||
{
|
||||
DnsResourceRecordType blockedType = Enum.Parse<DnsResourceRecordType>(jsonBlockedType.Value, true);
|
||||
if ((blockedType == question.Type) || (blockedType == DnsResourceRecordType.ANY))
|
||||
return Task.FromResult(new DnsDatagram(request.Identifier, true, request.OPCODE, false, false, request.RecursionDesired, isRecursionAllowed, false, false, DnsResponseCode.NoError, request.Question));
|
||||
}
|
||||
}
|
||||
|
||||
return Task.FromResult<DnsDatagram>(null);
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
||||
#region properties
|
||||
|
||||
public string Description
|
||||
{ get { return "Returns a NO DATA response for requests that query for the blocked resource record types in Conditional Forwarder zones."; } }
|
||||
|
||||
public string ApplicationRecordDataTemplate
|
||||
{
|
||||
get
|
||||
{
|
||||
return @"{
|
||||
""blockedTypes"": [
|
||||
""A"",
|
||||
""AAAA"",
|
||||
""ANY""
|
||||
]
|
||||
}";
|
||||
}
|
||||
}
|
||||
|
||||
#endregion
|
||||
}
|
||||
}
|
||||
1
Apps/NoDataApp/dnsApp.config
Normal file
1
Apps/NoDataApp/dnsApp.config
Normal file
@@ -0,0 +1 @@
|
||||
#This app requires no config.
|
||||
Reference in New Issue
Block a user