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