| Junyu Lai | eb6f4be | 2022-01-17 11:52:57 +0000 | [diff] [blame] | 1 | /* | 
|  | 2 | * Copyright (C) 2017 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 | syntax = "proto2"; | 
|  | 18 | package android.service; | 
|  | 19 |  | 
|  | 20 | option java_multiple_files = true; | 
|  | 21 | option java_outer_classname = "NetworkStatsServiceProto"; | 
|  | 22 |  | 
|  | 23 | // Represents dumpsys from NetworkStatsService (netstats). | 
|  | 24 | message NetworkStatsServiceDumpProto { | 
|  | 25 | repeated NetworkInterfaceProto active_interfaces = 1; | 
|  | 26 |  | 
|  | 27 | repeated NetworkInterfaceProto active_uid_interfaces = 2; | 
|  | 28 |  | 
|  | 29 | // Device level network stats, which may include non-IP layer traffic. | 
|  | 30 | optional NetworkStatsRecorderProto dev_stats = 3; | 
|  | 31 |  | 
|  | 32 | // IP-layer traffic stats. | 
|  | 33 | optional NetworkStatsRecorderProto xt_stats = 4; | 
|  | 34 |  | 
|  | 35 | // Per-UID network stats. | 
|  | 36 | optional NetworkStatsRecorderProto uid_stats = 5; | 
|  | 37 |  | 
|  | 38 | // Per-UID, per-tag network stats, excluding the default tag (i.e. tag=0). | 
|  | 39 | optional NetworkStatsRecorderProto uid_tag_stats = 6; | 
|  | 40 | } | 
|  | 41 |  | 
|  | 42 | // Corresponds to NetworkStatsService.mActiveIfaces/mActiveUidIfaces. | 
|  | 43 | message NetworkInterfaceProto { | 
|  | 44 | // Name of the network interface (eg: wlan). | 
|  | 45 | optional string interface = 1; | 
|  | 46 |  | 
|  | 47 | optional NetworkIdentitySetProto identities = 2; | 
|  | 48 | } | 
|  | 49 |  | 
|  | 50 | // Corresponds to NetworkIdentitySet. | 
|  | 51 | message NetworkIdentitySetProto { | 
|  | 52 | repeated NetworkIdentityProto identities = 1; | 
|  | 53 | } | 
|  | 54 |  | 
|  | 55 | // Corresponds to NetworkIdentity. | 
|  | 56 | message NetworkIdentityProto { | 
|  | 57 | // Constants from ConnectivityManager.TYPE_*. | 
|  | 58 | optional int32 type = 1; | 
|  | 59 |  | 
|  | 60 | optional bool roaming = 4; | 
|  | 61 |  | 
|  | 62 | optional bool metered = 5; | 
|  | 63 |  | 
|  | 64 | optional bool default_network = 6; | 
|  | 65 |  | 
|  | 66 | optional int32 oem_managed_network = 7; | 
|  | 67 | } | 
|  | 68 |  | 
|  | 69 | // Corresponds to NetworkStatsRecorder. | 
|  | 70 | message NetworkStatsRecorderProto { | 
|  | 71 | optional int64 pending_total_bytes = 1; | 
|  | 72 |  | 
|  | 73 | optional NetworkStatsCollectionProto complete_history = 2; | 
|  | 74 | } | 
|  | 75 |  | 
|  | 76 | // Corresponds to NetworkStatsCollection. | 
|  | 77 | message NetworkStatsCollectionProto { | 
|  | 78 | repeated NetworkStatsCollectionStatsProto stats = 1; | 
|  | 79 | } | 
|  | 80 |  | 
|  | 81 | // Corresponds to NetworkStatsCollection.mStats. | 
|  | 82 | message NetworkStatsCollectionStatsProto { | 
|  | 83 | optional NetworkStatsCollectionKeyProto key = 1; | 
|  | 84 |  | 
|  | 85 | optional NetworkStatsHistoryProto history = 2; | 
|  | 86 | } | 
|  | 87 |  | 
|  | 88 | // Corresponds to NetworkStatsCollection.Key. | 
|  | 89 | message NetworkStatsCollectionKeyProto { | 
|  | 90 | optional NetworkIdentitySetProto identity = 1; | 
|  | 91 |  | 
|  | 92 | optional int32 uid = 2; | 
|  | 93 |  | 
|  | 94 | optional int32 set = 3; | 
|  | 95 |  | 
|  | 96 | optional int32 tag = 4; | 
|  | 97 | } | 
|  | 98 |  | 
|  | 99 | // Corresponds to NetworkStatsHistory. | 
|  | 100 | message NetworkStatsHistoryProto { | 
|  | 101 | // Duration for this bucket in milliseconds. | 
|  | 102 | optional int64 bucket_duration_ms = 1; | 
|  | 103 |  | 
|  | 104 | repeated NetworkStatsHistoryBucketProto buckets = 2; | 
|  | 105 | } | 
|  | 106 |  | 
|  | 107 | // Corresponds to each bucket in NetworkStatsHistory. | 
|  | 108 | message NetworkStatsHistoryBucketProto { | 
|  | 109 | // Bucket start time in milliseconds since epoch. | 
|  | 110 | optional int64 bucket_start_ms = 1; | 
|  | 111 |  | 
|  | 112 | optional int64 rx_bytes = 2; | 
|  | 113 |  | 
|  | 114 | optional int64 rx_packets = 3; | 
|  | 115 |  | 
|  | 116 | optional int64 tx_bytes = 4; | 
|  | 117 |  | 
|  | 118 | optional int64 tx_packets = 5; | 
|  | 119 |  | 
|  | 120 | optional int64 operations = 6; | 
|  | 121 | } |