2021-04-02 20:09:51 +00:00
|
|
|
use rocket::State;
|
|
|
|
use rocket::http::Status;
|
|
|
|
|
|
|
|
use rocket_contrib::json::Json;
|
|
|
|
|
|
|
|
use trust_dns_client::client::{Client};
|
|
|
|
use trust_dns_client::op::{DnsResponse, ResponseCode};
|
|
|
|
use trust_dns_client::rr::{DNSClass, Name, RecordType};
|
|
|
|
|
|
|
|
use crate::models::dns;
|
|
|
|
use crate::models::errors::ErrorResponse;
|
|
|
|
use crate::models::users::UserInfo;
|
|
|
|
use crate::DnsClient;
|
|
|
|
|
|
|
|
|
|
|
|
#[get("/zones/<zone>/records")]
|
|
|
|
pub fn get_zone_records(
|
|
|
|
client: State<DnsClient>,
|
2021-04-02 21:12:29 +00:00
|
|
|
user_info: Result<UserInfo, ErrorResponse>,
|
2021-04-02 20:09:51 +00:00
|
|
|
zone: String
|
2021-04-02 21:12:29 +00:00
|
|
|
) -> Result<Json<Vec<dns::Record>>, ErrorResponse> {
|
|
|
|
user_info?;
|
2021-04-02 20:09:51 +00:00
|
|
|
|
|
|
|
// TODO: Implement FromParam for Name
|
|
|
|
let name = Name::from_utf8(&zone).unwrap();
|
|
|
|
|
|
|
|
let response: DnsResponse = client.query(&name, DNSClass::IN, RecordType::AXFR).unwrap();
|
|
|
|
|
|
|
|
if response.response_code() != ResponseCode::NoError {
|
|
|
|
return ErrorResponse::new(
|
|
|
|
Status::NotFound,
|
|
|
|
format!("zone {} could not be found", name.to_utf8())
|
|
|
|
).err()
|
|
|
|
}
|
|
|
|
|
|
|
|
let answers = response.answers();
|
|
|
|
let mut records: Vec<_> = answers.to_vec().into_iter()
|
|
|
|
.map(|record| dns::Record::from(record))
|
|
|
|
.filter(|record| match record.rdata {
|
|
|
|
dns::RData::NULL { .. } | dns::RData::DNSSEC(_) => false,
|
|
|
|
_ => true,
|
|
|
|
}).collect();
|
|
|
|
|
|
|
|
// AXFR response ends with SOA, we remove it so it is not doubled in the response.
|
|
|
|
records.pop();
|
|
|
|
|
|
|
|
Ok(Json(records))
|
|
|
|
}
|