1754d744a7
There are a few major pieces here: incidentd --------- This daemon (started by init) runs and accepts incoming requests to take incident reports. When prompted, it calls into various system services and fills in an IncidentProto data structure, and then writes the report into dropbox. The next steps for incidentd: - Security review of SELinux policies. These will be a subset of the dumpstate permissions. Until this is done, incidentd is not started at boot time. incident -------- This shell command calls into incidentd, and can initiate an incident report and either capture the output or leave for dropbox. incident_report --------------- This host side tool can call adb shell with the correct parameters and also format the incident report as text. This formatting code was left of the device on purpose. Right now it's pretty small, but as the number of fields increases, the metadata and code to do the formatting will start to grow. The incident_report command also contains a workaround to let it work before incidentd is turned on by default. Right now, it is implemented to call adb shell dumpsys <service> --proto directly, whereas in the future it will go through the full incidentd flow. incident_section_gen -------------------- A build-time tool that generates a stripped down set of information about the fields that are available. libincident ----------- This library contains the code to connect to incidentd, and the meta proto definitions that are used by the framework protos. The basics are here now, but they are not fully fleshed out yet. The privacy.proto file contains annotations that can go in the proto file that we will later use to filter which fields are uploaded, and which are used by local sources. For example, a device in a test lab is safe to upload much much more information than a real user. These will share the same mechanism, but the user's output will be filtered according to these annotations. frameworks/core/proto --------------------- These .proto files contain the definitions of the system's output. There is one master android.os.IncidentProto file that is the top level of an incident report, but some other services (notification, fingerprint, batterystats, etc) will have others that are used directly by the logging mechanism. Other files which are shared by several of the services also go here, such as ComponentName, Locale, Configuration, etc. There will be many more. There is also a first iplementation of a dump method handling --proto in the fingerprint service. IncidentManager --------------- The java API to trigger an incident report. Test: Not written yet Change-Id: I59568b115ac7fcf73af70c946c95752bf33ae67f
90 lines
2.5 KiB
C++
90 lines
2.5 KiB
C++
/*
|
|
* Copyright (C) 2016 The Android Open Source Project
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
#include "proto_format.h"
|
|
|
|
#include <string.h>
|
|
|
|
extern int const PROTO_FORMAT_STRING_POOL_SIZE;
|
|
extern int const PROTO_FORMAT_ENUM_LABELS_LENGTH;
|
|
extern int const PROTO_FORMAT_MESSAGES_LENGTH;
|
|
extern int const PROTO_FORMAT_FIELDS_LENGTH;
|
|
|
|
extern char const PROTO_FORMAT_STRING_POOL[];
|
|
extern ProtoFieldFormat const PROTO_FORMAT_FIELDS[];
|
|
extern ProtoEnumLabel const PROTO_FORMAT_ENUM_LABELS[];
|
|
extern ProtoMessageFormat const PROTO_FORMAT_MESSAGES[];
|
|
|
|
static const char*
|
|
get_string(int index)
|
|
{
|
|
if (index >= 0 && index < PROTO_FORMAT_STRING_POOL_SIZE) {
|
|
return PROTO_FORMAT_STRING_POOL + index;
|
|
} else {
|
|
// These indices all come from within the generated table, so just crash now.
|
|
*(int*)NULL = 42;
|
|
return NULL;
|
|
}
|
|
}
|
|
|
|
static ProtoMessageFormat const*
|
|
get_message(int index)
|
|
{
|
|
if (index >= 0 && index < PROTO_FORMAT_MESSAGES_LENGTH) {
|
|
return PROTO_FORMAT_MESSAGES + index;
|
|
} else {
|
|
// These indices all come from within the generated table, so just crash now.
|
|
*(int*)NULL = 42;
|
|
return NULL;
|
|
}
|
|
}
|
|
|
|
static int
|
|
compare_name(const char* full, const char* package, const char* clazz)
|
|
{
|
|
int const packageLen = strlen(package);
|
|
int cmp = strncmp(full, package, packageLen);
|
|
if (cmp == 0) {
|
|
cmp = full[packageLen] - '.';
|
|
if (cmp == 0) {
|
|
return strcmp(full + packageLen, clazz);
|
|
}
|
|
}
|
|
return cmp;
|
|
}
|
|
|
|
int
|
|
find_message_index(const char* name)
|
|
{
|
|
size_t low = 0;
|
|
size_t high = PROTO_FORMAT_FIELDS_LENGTH - 1;
|
|
|
|
while (low <= high) {
|
|
size_t mid = (low + high) >> 1;
|
|
ProtoMessageFormat const* msg = get_message(mid);
|
|
|
|
int cmp = compare_name(name, get_string(msg->package_name), get_string(msg->package_name));
|
|
if (cmp < 0) {
|
|
low = mid + 1;
|
|
} else if (cmp > 0) {
|
|
high = mid - 1;
|
|
} else {
|
|
return mid;
|
|
}
|
|
}
|
|
return -1;
|
|
}
|