1d18304287dbabc7835be771400b85d4ae8b63de6San Mehat/*
2d18304287dbabc7835be771400b85d4ae8b63de6San Mehat * Copyright (C) 2008 The Android Open Source Project
3d18304287dbabc7835be771400b85d4ae8b63de6San Mehat *
4d18304287dbabc7835be771400b85d4ae8b63de6San Mehat * Licensed under the Apache License, Version 2.0 (the "License");
5d18304287dbabc7835be771400b85d4ae8b63de6San Mehat * you may not use this file except in compliance with the License.
6d18304287dbabc7835be771400b85d4ae8b63de6San Mehat * You may obtain a copy of the License at
7d18304287dbabc7835be771400b85d4ae8b63de6San Mehat *
8d18304287dbabc7835be771400b85d4ae8b63de6San Mehat *      http://www.apache.org/licenses/LICENSE-2.0
9d18304287dbabc7835be771400b85d4ae8b63de6San Mehat *
10d18304287dbabc7835be771400b85d4ae8b63de6San Mehat * Unless required by applicable law or agreed to in writing, software
11d18304287dbabc7835be771400b85d4ae8b63de6San Mehat * distributed under the License is distributed on an "AS IS" BASIS,
12d18304287dbabc7835be771400b85d4ae8b63de6San Mehat * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13d18304287dbabc7835be771400b85d4ae8b63de6San Mehat * See the License for the specific language governing permissions and
14d18304287dbabc7835be771400b85d4ae8b63de6San Mehat * limitations under the License.
15d18304287dbabc7835be771400b85d4ae8b63de6San Mehat */
16d18304287dbabc7835be771400b85d4ae8b63de6San Mehat
170b454ea4abdc8a563af6da58fa37835729220acfLorenzo Colitti#include <stdarg.h>
18d18304287dbabc7835be771400b85d4ae8b63de6San Mehat#include <stdio.h>
19d18304287dbabc7835be771400b85d4ae8b63de6San Mehat#include <stdlib.h>
20ff2c0d8c13457e43f0d4bf06d3177271aac104c1Olivier Bailly#include <string.h>
21d18304287dbabc7835be771400b85d4ae8b63de6San Mehat#include <errno.h>
22d18304287dbabc7835be771400b85d4ae8b63de6San Mehat
23d18304287dbabc7835be771400b85d4ae8b63de6San Mehat#define LOG_TAG "Netd"
24d18304287dbabc7835be771400b85d4ae8b63de6San Mehat
25d18304287dbabc7835be771400b85d4ae8b63de6San Mehat#include <cutils/log.h>
26d18304287dbabc7835be771400b85d4ae8b63de6San Mehat
27af37dd3e6f40b9fc5a30ec462a8d2504380a3c9fSreeram Ramachandran#include <netutils/ifc.h>
28d18304287dbabc7835be771400b85d4ae8b63de6San Mehat#include <sysutils/NetlinkEvent.h>
29d18304287dbabc7835be771400b85d4ae8b63de6San Mehat#include "NetlinkHandler.h"
3067c5753274ee828b56f96b5e9cdae64c8562ad52Robert Greenwalt#include "NetlinkManager.h"
3167c5753274ee828b56f96b5e9cdae64c8562ad52Robert Greenwalt#include "ResponseCode.h"
32f32fc598b01ba8d59873b0a1085716fd84678b54Lorenzo Colitti#include "SockDiag.h"
33d18304287dbabc7835be771400b85d4ae8b63de6San Mehat
34bd0f224f077264f21fa858b7a93062e3b8564006Lorenzo Colittistatic const char *kUpdated = "updated";
35bd0f224f077264f21fa858b7a93062e3b8564006Lorenzo Colittistatic const char *kRemoved = "removed";
36bd0f224f077264f21fa858b7a93062e3b8564006Lorenzo Colitti
377035f228d17e925116b1b64a7c917b3196ab8818Lorenzo Colittinamespace android {
387035f228d17e925116b1b64a7c917b3196ab8818Lorenzo Colittinamespace net {
397035f228d17e925116b1b64a7c917b3196ab8818Lorenzo Colitti
40564df4efc87f3d04c3570836d38134fd949c4cafMike J. ChenNetlinkHandler::NetlinkHandler(NetlinkManager *nm, int listenerSocket,
41564df4efc87f3d04c3570836d38134fd949c4cafMike J. Chen                               int format) :
42564df4efc87f3d04c3570836d38134fd949c4cafMike J. Chen                        NetlinkListener(listenerSocket, format) {
4367c5753274ee828b56f96b5e9cdae64c8562ad52Robert Greenwalt    mNm = nm;
44d18304287dbabc7835be771400b85d4ae8b63de6San Mehat}
45d18304287dbabc7835be771400b85d4ae8b63de6San Mehat
46d18304287dbabc7835be771400b85d4ae8b63de6San MehatNetlinkHandler::~NetlinkHandler() {
47d18304287dbabc7835be771400b85d4ae8b63de6San Mehat}
48d18304287dbabc7835be771400b85d4ae8b63de6San Mehat
49d18304287dbabc7835be771400b85d4ae8b63de6San Mehatint NetlinkHandler::start() {
50d18304287dbabc7835be771400b85d4ae8b63de6San Mehat    return this->startListener();
51d18304287dbabc7835be771400b85d4ae8b63de6San Mehat}
52d18304287dbabc7835be771400b85d4ae8b63de6San Mehat
53d18304287dbabc7835be771400b85d4ae8b63de6San Mehatint NetlinkHandler::stop() {
54d18304287dbabc7835be771400b85d4ae8b63de6San Mehat    return this->stopListener();
55d18304287dbabc7835be771400b85d4ae8b63de6San Mehat}
56d18304287dbabc7835be771400b85d4ae8b63de6San Mehat
57d18304287dbabc7835be771400b85d4ae8b63de6San Mehatvoid NetlinkHandler::onEvent(NetlinkEvent *evt) {
58d18304287dbabc7835be771400b85d4ae8b63de6San Mehat    const char *subsys = evt->getSubsystem();
59d18304287dbabc7835be771400b85d4ae8b63de6San Mehat    if (!subsys) {
600e76b761a1514d5182675dd7b7d33725f62d6bc5Steve Block        ALOGW("No subsystem found in netlink event");
61d18304287dbabc7835be771400b85d4ae8b63de6San Mehat        return;
62d18304287dbabc7835be771400b85d4ae8b63de6San Mehat    }
63564df4efc87f3d04c3570836d38134fd949c4cafMike J. Chen
644da12db25b4a2947b1a98b0322e4be56a30c5e17Lorenzo Colitti    if (!strcmp(subsys, "net")) {
6532fa9ba006ce62737cdcc48b9df2b2f4a432d5e1Jeff Sharkey        NetlinkEvent::Action action = evt->getAction();
66564df4efc87f3d04c3570836d38134fd949c4cafMike J. Chen        const char *iface = evt->findParam("INTERFACE");
67564df4efc87f3d04c3570836d38134fd949c4cafMike J. Chen
6832fa9ba006ce62737cdcc48b9df2b2f4a432d5e1Jeff Sharkey        if (action == NetlinkEvent::Action::kAdd) {
6967c5753274ee828b56f96b5e9cdae64c8562ad52Robert Greenwalt            notifyInterfaceAdded(iface);
7032fa9ba006ce62737cdcc48b9df2b2f4a432d5e1Jeff Sharkey        } else if (action == NetlinkEvent::Action::kRemove) {
7167c5753274ee828b56f96b5e9cdae64c8562ad52Robert Greenwalt            notifyInterfaceRemoved(iface);
7232fa9ba006ce62737cdcc48b9df2b2f4a432d5e1Jeff Sharkey        } else if (action == NetlinkEvent::Action::kChange) {
7367c5753274ee828b56f96b5e9cdae64c8562ad52Robert Greenwalt            evt->dump();
7467c5753274ee828b56f96b5e9cdae64c8562ad52Robert Greenwalt            notifyInterfaceChanged("nana", true);
7532fa9ba006ce62737cdcc48b9df2b2f4a432d5e1Jeff Sharkey        } else if (action == NetlinkEvent::Action::kLinkUp) {
76564df4efc87f3d04c3570836d38134fd949c4cafMike J. Chen            notifyInterfaceLinkChanged(iface, true);
7732fa9ba006ce62737cdcc48b9df2b2f4a432d5e1Jeff Sharkey        } else if (action == NetlinkEvent::Action::kLinkDown) {
78564df4efc87f3d04c3570836d38134fd949c4cafMike J. Chen            notifyInterfaceLinkChanged(iface, false);
7932fa9ba006ce62737cdcc48b9df2b2f4a432d5e1Jeff Sharkey        } else if (action == NetlinkEvent::Action::kAddressUpdated ||
8032fa9ba006ce62737cdcc48b9df2b2f4a432d5e1Jeff Sharkey                   action == NetlinkEvent::Action::kAddressRemoved) {
814da12db25b4a2947b1a98b0322e4be56a30c5e17Lorenzo Colitti            const char *address = evt->findParam("ADDRESS");
824da12db25b4a2947b1a98b0322e4be56a30c5e17Lorenzo Colitti            const char *flags = evt->findParam("FLAGS");
834da12db25b4a2947b1a98b0322e4be56a30c5e17Lorenzo Colitti            const char *scope = evt->findParam("SCOPE");
8432fa9ba006ce62737cdcc48b9df2b2f4a432d5e1Jeff Sharkey            if (action == NetlinkEvent::Action::kAddressRemoved && iface && address) {
85f32fc598b01ba8d59873b0a1085716fd84678b54Lorenzo Colitti                // Note: if this interface was deleted, iface is "" and we don't notify.
86f32fc598b01ba8d59873b0a1085716fd84678b54Lorenzo Colitti                SockDiag sd;
87f32fc598b01ba8d59873b0a1085716fd84678b54Lorenzo Colitti                if (sd.open()) {
88f32fc598b01ba8d59873b0a1085716fd84678b54Lorenzo Colitti                    char addrstr[INET6_ADDRSTRLEN];
89f32fc598b01ba8d59873b0a1085716fd84678b54Lorenzo Colitti                    strncpy(addrstr, address, sizeof(addrstr));
90f32fc598b01ba8d59873b0a1085716fd84678b54Lorenzo Colitti                    char *slash = strchr(addrstr, '/');
91f32fc598b01ba8d59873b0a1085716fd84678b54Lorenzo Colitti                    if (slash) {
92f32fc598b01ba8d59873b0a1085716fd84678b54Lorenzo Colitti                        *slash = '\0';
93f32fc598b01ba8d59873b0a1085716fd84678b54Lorenzo Colitti                    }
94f32fc598b01ba8d59873b0a1085716fd84678b54Lorenzo Colitti
95f32fc598b01ba8d59873b0a1085716fd84678b54Lorenzo Colitti                    int ret = sd.destroySockets(addrstr);
96f32fc598b01ba8d59873b0a1085716fd84678b54Lorenzo Colitti                    if (ret < 0) {
97f32fc598b01ba8d59873b0a1085716fd84678b54Lorenzo Colitti                        ALOGE("Error destroying sockets: %s", strerror(ret));
98f32fc598b01ba8d59873b0a1085716fd84678b54Lorenzo Colitti                    }
99f32fc598b01ba8d59873b0a1085716fd84678b54Lorenzo Colitti                } else {
100f32fc598b01ba8d59873b0a1085716fd84678b54Lorenzo Colitti                    ALOGE("Error opening NETLINK_SOCK_DIAG socket: %s", strerror(errno));
101f32fc598b01ba8d59873b0a1085716fd84678b54Lorenzo Colitti                }
102af37dd3e6f40b9fc5a30ec462a8d2504380a3c9fSreeram Ramachandran            }
103f32fc598b01ba8d59873b0a1085716fd84678b54Lorenzo Colitti            if (iface && iface[0] && address && flags && scope) {
1044da12db25b4a2947b1a98b0322e4be56a30c5e17Lorenzo Colitti                notifyAddressChanged(action, address, iface, flags, scope);
1054da12db25b4a2947b1a98b0322e4be56a30c5e17Lorenzo Colitti            }
10632fa9ba006ce62737cdcc48b9df2b2f4a432d5e1Jeff Sharkey        } else if (action == NetlinkEvent::Action::kRdnss) {
10712acae8db9dee865a41f0fd11dacf01112115920Lorenzo Colitti            const char *lifetime = evt->findParam("LIFETIME");
10812acae8db9dee865a41f0fd11dacf01112115920Lorenzo Colitti            const char *servers = evt->findParam("SERVERS");
10912acae8db9dee865a41f0fd11dacf01112115920Lorenzo Colitti            if (lifetime && servers) {
11012acae8db9dee865a41f0fd11dacf01112115920Lorenzo Colitti                notifyInterfaceDnsServers(iface, lifetime, servers);
11112acae8db9dee865a41f0fd11dacf01112115920Lorenzo Colitti            }
11232fa9ba006ce62737cdcc48b9df2b2f4a432d5e1Jeff Sharkey        } else if (action == NetlinkEvent::Action::kRouteUpdated ||
11332fa9ba006ce62737cdcc48b9df2b2f4a432d5e1Jeff Sharkey                   action == NetlinkEvent::Action::kRouteRemoved) {
114bd0f224f077264f21fa858b7a93062e3b8564006Lorenzo Colitti            const char *route = evt->findParam("ROUTE");
115bd0f224f077264f21fa858b7a93062e3b8564006Lorenzo Colitti            const char *gateway = evt->findParam("GATEWAY");
116bd0f224f077264f21fa858b7a93062e3b8564006Lorenzo Colitti            const char *iface = evt->findParam("INTERFACE");
117bd0f224f077264f21fa858b7a93062e3b8564006Lorenzo Colitti            if (route && (gateway || iface)) {
118bd0f224f077264f21fa858b7a93062e3b8564006Lorenzo Colitti                notifyRouteChange(action, route, gateway, iface);
119bd0f224f077264f21fa858b7a93062e3b8564006Lorenzo Colitti            }
1209b3cd7635caf5948d7d4b11f8f588c9d2811d58eLorenzo Colitti        }
1219b3cd7635caf5948d7d4b11f8f588c9d2811d58eLorenzo Colitti
122bc5f0602e12ae915ab6b5e47c8d312e6f3001ecfBryse Flowers    } else if (!strcmp(subsys, "qlog") || !strcmp(subsys, "xt_quota2")) {
123e0ebc46c0aa38ce4f35bd3b60c0fcb9204d4c35eJP Abgrall        const char *alertName = evt->findParam("ALERT_NAME");
124e0ebc46c0aa38ce4f35bd3b60c0fcb9204d4c35eJP Abgrall        const char *iface = evt->findParam("INTERFACE");
125e0ebc46c0aa38ce4f35bd3b60c0fcb9204d4c35eJP Abgrall        notifyQuotaLimitReached(alertName, iface);
126e07effe6f8e9340dbee9428b29672adfb647c413JP Abgrall
127fbe497fcd808e4317572ad48c42545105309a347Jeff Sharkey    } else if (!strcmp(subsys, "strict")) {
128fbe497fcd808e4317572ad48c42545105309a347Jeff Sharkey        const char *uid = evt->findParam("UID");
129fbe497fcd808e4317572ad48c42545105309a347Jeff Sharkey        const char *hex = evt->findParam("HEX");
130fbe497fcd808e4317572ad48c42545105309a347Jeff Sharkey        notifyStrictCleartext(uid, hex);
131fbe497fcd808e4317572ad48c42545105309a347Jeff Sharkey
132e07effe6f8e9340dbee9428b29672adfb647c413JP Abgrall    } else if (!strcmp(subsys, "xt_idletimer")) {
133c79bcc491f01b4d7956d7bd01f0e912e22307f41Ashish Sharma        const char *label = evt->findParam("INTERFACE");
134e07effe6f8e9340dbee9428b29672adfb647c413JP Abgrall        const char *state = evt->findParam("STATE");
13527ab7e10d7b8343f6354359b3d2c6900d6beed78Ruchi Kandoi        const char *timestamp = evt->findParam("TIME_NS");
13605c39f0a048abf6b8a44f17063f0c1f8c16285edRuchi Kandoi        const char *uid = evt->findParam("UID");
137e07effe6f8e9340dbee9428b29672adfb647c413JP Abgrall        if (state)
13805c39f0a048abf6b8a44f17063f0c1f8c16285edRuchi Kandoi            notifyInterfaceClassActivity(label, !strcmp("active", state),
13905c39f0a048abf6b8a44f17063f0c1f8c16285edRuchi Kandoi                                         timestamp, uid);
140e0ebc46c0aa38ce4f35bd3b60c0fcb9204d4c35eJP Abgrall
14140baed83f89e8d8f834cdfa94d0615076463c04bJP Abgrall#if !LOG_NDEBUG
14240baed83f89e8d8f834cdfa94d0615076463c04bJP Abgrall    } else if (strcmp(subsys, "platform") && strcmp(subsys, "backlight")) {
14340baed83f89e8d8f834cdfa94d0615076463c04bJP Abgrall        /* It is not a VSYNC or a backlight event */
14440baed83f89e8d8f834cdfa94d0615076463c04bJP Abgrall        ALOGV("unexpected event from subsystem %s", subsys);
14540baed83f89e8d8f834cdfa94d0615076463c04bJP Abgrall#endif
1466337b88ce4438d224819e9b381ddaf2873bbfddaAshish Sharma    }
147d18304287dbabc7835be771400b85d4ae8b63de6San Mehat}
14867c5753274ee828b56f96b5e9cdae64c8562ad52Robert Greenwalt
1490b454ea4abdc8a563af6da58fa37835729220acfLorenzo Colittivoid NetlinkHandler::notify(int code, const char *format, ...) {
1500b454ea4abdc8a563af6da58fa37835729220acfLorenzo Colitti    char *msg;
1510b454ea4abdc8a563af6da58fa37835729220acfLorenzo Colitti    va_list args;
1520b454ea4abdc8a563af6da58fa37835729220acfLorenzo Colitti    va_start(args, format);
1530b454ea4abdc8a563af6da58fa37835729220acfLorenzo Colitti    if (vasprintf(&msg, format, args) >= 0) {
1540b454ea4abdc8a563af6da58fa37835729220acfLorenzo Colitti        mNm->getBroadcaster()->sendBroadcast(code, msg, false);
1550b454ea4abdc8a563af6da58fa37835729220acfLorenzo Colitti        free(msg);
1560b454ea4abdc8a563af6da58fa37835729220acfLorenzo Colitti    } else {
1570b454ea4abdc8a563af6da58fa37835729220acfLorenzo Colitti        SLOGE("Failed to send notification: vasprintf: %s", strerror(errno));
1580b454ea4abdc8a563af6da58fa37835729220acfLorenzo Colitti    }
1590b454ea4abdc8a563af6da58fa37835729220acfLorenzo Colitti    va_end(args);
1600b454ea4abdc8a563af6da58fa37835729220acfLorenzo Colitti}
16167c5753274ee828b56f96b5e9cdae64c8562ad52Robert Greenwalt
1620b454ea4abdc8a563af6da58fa37835729220acfLorenzo Colittivoid NetlinkHandler::notifyInterfaceAdded(const char *name) {
1630b454ea4abdc8a563af6da58fa37835729220acfLorenzo Colitti    notify(ResponseCode::InterfaceChange, "Iface added %s", name);
16467c5753274ee828b56f96b5e9cdae64c8562ad52Robert Greenwalt}
16567c5753274ee828b56f96b5e9cdae64c8562ad52Robert Greenwalt
16667c5753274ee828b56f96b5e9cdae64c8562ad52Robert Greenwaltvoid NetlinkHandler::notifyInterfaceRemoved(const char *name) {
1670b454ea4abdc8a563af6da58fa37835729220acfLorenzo Colitti    notify(ResponseCode::InterfaceChange, "Iface removed %s", name);
16867c5753274ee828b56f96b5e9cdae64c8562ad52Robert Greenwalt}
16967c5753274ee828b56f96b5e9cdae64c8562ad52Robert Greenwalt
17067c5753274ee828b56f96b5e9cdae64c8562ad52Robert Greenwaltvoid NetlinkHandler::notifyInterfaceChanged(const char *name, bool isUp) {
1710b454ea4abdc8a563af6da58fa37835729220acfLorenzo Colitti    notify(ResponseCode::InterfaceChange,
1720b454ea4abdc8a563af6da58fa37835729220acfLorenzo Colitti           "Iface changed %s %s", name, (isUp ? "up" : "down"));
173564df4efc87f3d04c3570836d38134fd949c4cafMike J. Chen}
174564df4efc87f3d04c3570836d38134fd949c4cafMike J. Chen
175564df4efc87f3d04c3570836d38134fd949c4cafMike J. Chenvoid NetlinkHandler::notifyInterfaceLinkChanged(const char *name, bool isUp) {
1760b454ea4abdc8a563af6da58fa37835729220acfLorenzo Colitti    notify(ResponseCode::InterfaceChange,
1770b454ea4abdc8a563af6da58fa37835729220acfLorenzo Colitti           "Iface linkstate %s %s", name, (isUp ? "up" : "down"));
17867c5753274ee828b56f96b5e9cdae64c8562ad52Robert Greenwalt}
179e0ebc46c0aa38ce4f35bd3b60c0fcb9204d4c35eJP Abgrall
180e0ebc46c0aa38ce4f35bd3b60c0fcb9204d4c35eJP Abgrallvoid NetlinkHandler::notifyQuotaLimitReached(const char *name, const char *iface) {
1810b454ea4abdc8a563af6da58fa37835729220acfLorenzo Colitti    notify(ResponseCode::BandwidthControl, "limit alert %s %s", name, iface);
182e0ebc46c0aa38ce4f35bd3b60c0fcb9204d4c35eJP Abgrall}
1836337b88ce4438d224819e9b381ddaf2873bbfddaAshish Sharma
18498f65d32b1530b4da6050e38d52f955710577efbHaoyu Baivoid NetlinkHandler::notifyInterfaceClassActivity(const char *name,
18505c39f0a048abf6b8a44f17063f0c1f8c16285edRuchi Kandoi                                                  bool isActive,
18605c39f0a048abf6b8a44f17063f0c1f8c16285edRuchi Kandoi                                                  const char *timestamp,
18705c39f0a048abf6b8a44f17063f0c1f8c16285edRuchi Kandoi                                                  const char *uid) {
18827ab7e10d7b8343f6354359b3d2c6900d6beed78Ruchi Kandoi    if (timestamp == NULL)
18927ab7e10d7b8343f6354359b3d2c6900d6beed78Ruchi Kandoi        notify(ResponseCode::InterfaceClassActivity,
1900b454ea4abdc8a563af6da58fa37835729220acfLorenzo Colitti           "IfaceClass %s %s", isActive ? "active" : "idle", name);
19105c39f0a048abf6b8a44f17063f0c1f8c16285edRuchi Kandoi    else if (uid != NULL && isActive)
19205c39f0a048abf6b8a44f17063f0c1f8c16285edRuchi Kandoi        notify(ResponseCode::InterfaceClassActivity,
19305c39f0a048abf6b8a44f17063f0c1f8c16285edRuchi Kandoi           "IfaceClass active %s %s %s", name, timestamp, uid);
19427ab7e10d7b8343f6354359b3d2c6900d6beed78Ruchi Kandoi    else
19527ab7e10d7b8343f6354359b3d2c6900d6beed78Ruchi Kandoi        notify(ResponseCode::InterfaceClassActivity,
19627ab7e10d7b8343f6354359b3d2c6900d6beed78Ruchi Kandoi           "IfaceClass %s %s %s", isActive ? "active" : "idle", name, timestamp);
1976337b88ce4438d224819e9b381ddaf2873bbfddaAshish Sharma}
1989b3cd7635caf5948d7d4b11f8f588c9d2811d58eLorenzo Colitti
19932fa9ba006ce62737cdcc48b9df2b2f4a432d5e1Jeff Sharkeyvoid NetlinkHandler::notifyAddressChanged(NetlinkEvent::Action action, const char *addr,
2009b3cd7635caf5948d7d4b11f8f588c9d2811d58eLorenzo Colitti                                          const char *iface, const char *flags,
2019b3cd7635caf5948d7d4b11f8f588c9d2811d58eLorenzo Colitti                                          const char *scope) {
2020b454ea4abdc8a563af6da58fa37835729220acfLorenzo Colitti    notify(ResponseCode::InterfaceAddressChange,
2030b454ea4abdc8a563af6da58fa37835729220acfLorenzo Colitti           "Address %s %s %s %s %s",
20432fa9ba006ce62737cdcc48b9df2b2f4a432d5e1Jeff Sharkey           (action == NetlinkEvent::Action::kAddressUpdated) ? kUpdated : kRemoved,
205bd0f224f077264f21fa858b7a93062e3b8564006Lorenzo Colitti           addr, iface, flags, scope);
2069b3cd7635caf5948d7d4b11f8f588c9d2811d58eLorenzo Colitti}
20712acae8db9dee865a41f0fd11dacf01112115920Lorenzo Colitti
20812acae8db9dee865a41f0fd11dacf01112115920Lorenzo Colittivoid NetlinkHandler::notifyInterfaceDnsServers(const char *iface,
20912acae8db9dee865a41f0fd11dacf01112115920Lorenzo Colitti                                               const char *lifetime,
21012acae8db9dee865a41f0fd11dacf01112115920Lorenzo Colitti                                               const char *servers) {
21112acae8db9dee865a41f0fd11dacf01112115920Lorenzo Colitti    notify(ResponseCode::InterfaceDnsInfo, "DnsInfo servers %s %s %s",
21212acae8db9dee865a41f0fd11dacf01112115920Lorenzo Colitti           iface, lifetime, servers);
21312acae8db9dee865a41f0fd11dacf01112115920Lorenzo Colitti}
214bd0f224f077264f21fa858b7a93062e3b8564006Lorenzo Colitti
21532fa9ba006ce62737cdcc48b9df2b2f4a432d5e1Jeff Sharkeyvoid NetlinkHandler::notifyRouteChange(NetlinkEvent::Action action, const char *route,
216bd0f224f077264f21fa858b7a93062e3b8564006Lorenzo Colitti                                       const char *gateway, const char *iface) {
217bd0f224f077264f21fa858b7a93062e3b8564006Lorenzo Colitti    notify(ResponseCode::RouteChange,
218bd0f224f077264f21fa858b7a93062e3b8564006Lorenzo Colitti           "Route %s %s%s%s%s%s",
21932fa9ba006ce62737cdcc48b9df2b2f4a432d5e1Jeff Sharkey           (action == NetlinkEvent::Action::kRouteUpdated) ? kUpdated : kRemoved,
220bd0f224f077264f21fa858b7a93062e3b8564006Lorenzo Colitti           route,
22175c970f64ed55630b645a9f98261e445749c7063Manoj Gupta           (gateway && *gateway) ? " via " : "",
222bd0f224f077264f21fa858b7a93062e3b8564006Lorenzo Colitti           gateway,
22375c970f64ed55630b645a9f98261e445749c7063Manoj Gupta           (iface && *iface) ? " dev " : "",
224bd0f224f077264f21fa858b7a93062e3b8564006Lorenzo Colitti           iface);
225bd0f224f077264f21fa858b7a93062e3b8564006Lorenzo Colitti}
226fbe497fcd808e4317572ad48c42545105309a347Jeff Sharkey
227fbe497fcd808e4317572ad48c42545105309a347Jeff Sharkeyvoid NetlinkHandler::notifyStrictCleartext(const char* uid, const char* hex) {
228fbe497fcd808e4317572ad48c42545105309a347Jeff Sharkey    notify(ResponseCode::StrictCleartext, "%s %s", uid, hex);
229fbe497fcd808e4317572ad48c42545105309a347Jeff Sharkey}
2307035f228d17e925116b1b64a7c917b3196ab8818Lorenzo Colitti
2317035f228d17e925116b1b64a7c917b3196ab8818Lorenzo Colitti}  // namespace net
2327035f228d17e925116b1b64a7c917b3196ab8818Lorenzo Colitti}  // namespace android
233