blob: cf8da9779e77a8b8edc35d1f07fdc8f66fdb6ded [file] [log] [blame]
Shock Jiang6cce21a2014-09-07 10:14:12 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
Yumin Xia2c509c22017-02-09 14:37:36 -08002/*
Davide Pesavento872f18e2022-09-20 17:03:22 -04003 * Copyright (c) 2014-2022, Regents of the University of California.
Shock Jiang6cce21a2014-09-07 10:14:12 -07004 *
5 * This file is part of NDNS (Named Data Networking Domain Name Service).
6 * See AUTHORS.md for complete list of NDNS authors and contributors.
7 *
8 * NDNS is free software: you can redistribute it and/or modify it under the terms
9 * of the GNU General Public License as published by the Free Software Foundation,
10 * either version 3 of the License, or (at your option) any later version.
11 *
12 * NDNS is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
13 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
14 * PURPOSE. See the GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License along with
17 * NDNS, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
18 */
19
20#ifndef NDNS_NDNS_LABEL_HPP
21#define NDNS_NDNS_LABEL_HPP
22
23#include "ndns-enum.hpp"
24
25#include <ndn-cxx/name.hpp>
26#include <ndn-cxx/interest.hpp>
27
Davide Pesavento872f18e2022-09-20 17:03:22 -040028namespace ndn::ndns::label {
Shock Jiang895bc1b2014-10-01 20:00:58 -070029
Shock Jiang6cce21a2014-09-07 10:14:12 -070030/**
31 * @brief NDNS iterative query type
32 */
Davide Pesavento872f18e2022-09-20 17:03:22 -040033inline const name::Component NDNS_ITERATIVE_QUERY{"NDNS"};
Shock Jiang6cce21a2014-09-07 10:14:12 -070034
35/**
36 * @brief NDNS recursive query type
37 */
Yumin Xia6343c5b2016-10-20 15:45:50 -070038// it is not supported now
Davide Pesavento872f18e2022-09-20 17:03:22 -040039// inline const name::Component NDNS_RECURSIVE_QUERY{"NDNS-R"};
Shock Jiang6cce21a2014-09-07 10:14:12 -070040
41/**
Davide Pesavento872f18e2022-09-20 17:03:22 -040042 * @brief Label of update message, located at the last component in Interest name
Shock Jiang6cce21a2014-09-07 10:14:12 -070043 */
Davide Pesavento872f18e2022-09-20 17:03:22 -040044inline const name::Component NDNS_UPDATE_LABEL{"UPDATE"};
Shock Jiang6cce21a2014-09-07 10:14:12 -070045
46/**
47 * @brief NS resource record type
48 */
Davide Pesavento872f18e2022-09-20 17:03:22 -040049inline const name::Component NS_RR_TYPE{"NS"};
Shock Jiang6cce21a2014-09-07 10:14:12 -070050
51/**
Davide Pesavento872f18e2022-09-20 17:03:22 -040052 * @brief NDNS related certificate resource record type
Shock Jiang6cce21a2014-09-07 10:14:12 -070053 */
Davide Pesavento872f18e2022-09-20 17:03:22 -040054inline const name::Component CERT_RR_TYPE{"CERT"};
Shock Jiang895bc1b2014-10-01 20:00:58 -070055
56/**
Davide Pesavento872f18e2022-09-20 17:03:22 -040057 * @brief Application stored certificate resource record type
Yumin Xia53f31672017-03-17 19:18:10 -070058 */
Davide Pesavento872f18e2022-09-20 17:03:22 -040059inline const name::Component APPCERT_RR_TYPE{"APPCERT"};
Yumin Xia53f31672017-03-17 19:18:10 -070060
61/**
Shock Jiang895bc1b2014-10-01 20:00:58 -070062 * @brief TXT resource record type
63 */
Davide Pesavento872f18e2022-09-20 17:03:22 -040064inline const name::Component TXT_RR_TYPE{"TXT"};
Shock Jiang895bc1b2014-10-01 20:00:58 -070065
Yumin Xia55a7cc42017-05-14 18:43:34 -070066/**
67 * @brief Denial of Existance record type
68 */
Davide Pesavento872f18e2022-09-20 17:03:22 -040069inline const name::Component DOE_RR_TYPE{"DOE"};
Shock Jiang6cce21a2014-09-07 10:14:12 -070070
71//////////////////////////////////////////
72
73/**
74 * @brief result of Matching. version only works when matching a Interest Name
75 */
76struct MatchResult
77{
78 Name rrLabel;
79 name::Component rrType;
80 name::Component version;
81};
82
83/**
84 * @brief match the Interest (NDNS query, NDNS update) name
85 *
86 * @param[in] interest Interest to parse
Shock Jiang6cce21a2014-09-07 10:14:12 -070087 * @param[in] zone Zone that the Interest is related to
88 * (only the length will be taken into account)
89 * @param[out] result The matching result
90 * @return true if match succeeds, or false
91 */
92bool
93matchName(const Interest& interest,
Yumin Xia6343c5b2016-10-20 15:45:50 -070094 const Name& zone,
Shock Jiang895bc1b2014-10-01 20:00:58 -070095 MatchResult& result);
Shock Jiang6cce21a2014-09-07 10:14:12 -070096
97/**
98 * @brief match the Data (NDNS query response, NDNS update response) name
99 *
100 * @param[in] data Data to parse
Shock Jiang6cce21a2014-09-07 10:14:12 -0700101 * @param[in] zone Zone that the Data is related to
102 * (only the length will be taken into account)
103 * @param[out] result The matching result
104 * @return true if match succeeds, or false
105 */
106bool
107matchName(const Data& data,
Yumin Xia6343c5b2016-10-20 15:45:50 -0700108 const Name& zone,
Shock Jiang6cce21a2014-09-07 10:14:12 -0700109 MatchResult& result);
110
Davide Pesavento872f18e2022-09-20 17:03:22 -0400111} // namespace ndn::ndns::label
Shock Jiang6cce21a2014-09-07 10:14:12 -0700112
113#endif // NDNS_NDNS_LABEL_HPP