1 /**
2  * Copyright (c) 2019, The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *     http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 #include "DnsResolver.h"
18 
19 #include <android-base/logging.h>
20 
21 #include "DnsProxyListener.h"
22 #include "DnsResolverService.h"
23 #include "DnsTlsDispatcher.h"
24 #include "PrivateDnsConfiguration.h"
25 #include "netd_resolv/resolv.h"
26 #include "res_debug.h"
27 #include "util.h"
28 
29 bool resolv_init(const ResolverNetdCallbacks* callbacks) {
30     android::base::InitLogging(/*argv=*/nullptr);
31     android::base::SetDefaultTag("libnetd_resolv");
32     LOG(INFO) << __func__ << ": Initializing resolver";
33     // TODO(b/170539625): restore log level to WARNING after clarifying flaky tests.
34     resolv_set_log_severity(isUserDebugBuild() ? android::base::DEBUG : android::base::WARNING);
35     using android::net::gApiLevel;
36     gApiLevel = getApiLevel();
37     using android::net::gResNetdCallbacks;
38     gResNetdCallbacks.check_calling_permission = callbacks->check_calling_permission;
39     gResNetdCallbacks.get_network_context = callbacks->get_network_context;
40     gResNetdCallbacks.log = callbacks->log;
41     if (gApiLevel >= 30) {
42         gResNetdCallbacks.tagSocket = callbacks->tagSocket;
43         gResNetdCallbacks.evaluate_domain_name = callbacks->evaluate_domain_name;
44     }
45     android::net::gDnsResolv = android::net::DnsResolver::getInstance();
46     return android::net::gDnsResolv->start();
47 }
48 
49 namespace android {
50 namespace net {
51 
52 namespace {
53 
54 bool verifyCallbacks() {
55     if (!(gResNetdCallbacks.check_calling_permission && gResNetdCallbacks.get_network_context &&
56           gResNetdCallbacks.log)) {
57         return false;
58     }
59     if (gApiLevel >= 30) {
60         return gResNetdCallbacks.tagSocket != nullptr;
61     }
62     return true;
63 }
64 
65 }  // namespace
66 
67 DnsResolver* gDnsResolv = nullptr;
68 ResolverNetdCallbacks gResNetdCallbacks;
69 netdutils::Log gDnsResolverLog("dnsResolver");
70 uint64_t gApiLevel = 0;
71 
72 DnsResolver* DnsResolver::getInstance() {
73     // Instantiated on first use.
74     static DnsResolver instance;
75     return &instance;
76 }
77 
78 DnsResolver::DnsResolver() {
79     // TODO: make them member variables after fixing the circular dependency:
80     //   DnsTlsDispatcher.h -> resolv_private.h -> DnsResolver.h -> DnsTlsDispatcher.h
81     auto& dnsTlsDispatcher = DnsTlsDispatcher::getInstance();
82     auto& privateDnsConfiguration = PrivateDnsConfiguration::getInstance();
83     privateDnsConfiguration.setObserver(&dnsTlsDispatcher);
84 }
85 
86 bool DnsResolver::start() {
87     if (!verifyCallbacks()) {
88         LOG(ERROR) << __func__ << ": Callback verification failed";
89         return false;
90     }
91     if (mDnsProxyListener.startListener()) {
92         PLOG(ERROR) << __func__ << ": Unable to start DnsProxyListener";
93         return false;
94     }
95     binder_status_t ret;
96     if ((ret = DnsResolverService::start()) != STATUS_OK) {
97         LOG(ERROR) << __func__ << ": Unable to start DnsResolverService: " << ret;
98         return false;
99     }
100     return true;
101 }
102 
103 int DnsResolver::setLogSeverity(int32_t logSeverity) {
104     return resolv_set_log_severity(logSeverity);
105 }
106 
107 }  // namespace net
108 }  // namespace android
109