1/* 2 * Copyright (C) 2022 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 17syntax = "proto2"; 18 19package com.android.app.motiontool; 20 21import "view_capture.proto"; 22 23option java_multiple_files = true; 24 25message MotionToolsRequest { 26 oneof type { 27 HandshakeRequest handshake = 1; 28 BeginTraceRequest begin_trace = 2; 29 EndTraceRequest end_trace = 3; 30 PollTraceRequest poll_trace = 4; 31 } 32} 33 34// RPC response messages. 35// 36// Returns the result from the corresponding request. 37message MotionToolsResponse { 38 oneof type { 39 // Contains error information whenever the request failed. 40 ErrorResponse error = 1; 41 42 HandshakeResponse handshake = 2; 43 BeginTraceResponse begin_trace = 3; 44 EndTraceResponse end_trace = 4; 45 PollTraceResponse poll_trace = 5; 46 } 47} 48 49message ErrorResponse { 50 enum Code { 51 UNKNOWN = 0; 52 INVALID_REQUEST = 1; 53 UNKNOWN_TRACE_ID = 2; 54 WINDOW_NOT_FOUND = 3; 55 } 56 57 optional Code code = 1; 58 // Human readable error message. 59 optional string message = 2; 60} 61 62// Identifies the window, in which context the motion tools are executed 63message WindowIdentifier { 64 // An identifier for the root view, as accepted by 65 // WindowManagerGlobal#getRootView. This is formatted as 66 // `windowName/rootViewClassName@rootViewIdentityHashCode`, 67 // for example `NotificationShade/android.view.ViewRootImpl@bab6a53`. 68 optional string root_window = 1; 69} 70 71// Verifies the motion tools are available for the specified window. 72message HandshakeRequest { 73 optional WindowIdentifier window = 1; 74 optional int32 client_version = 2; 75} 76 77message HandshakeResponse { 78 enum Status { 79 OK = 1; 80 WINDOW_NOT_FOUND = 2; 81 } 82 optional Status status = 1; 83 optional int32 server_version = 2; 84} 85 86// Enables motion tracing for the specified window 87message BeginTraceRequest { 88 optional WindowIdentifier window = 1; 89} 90 91message BeginTraceResponse { 92 optional int32 trace_id = 1; 93} 94 95// Disabled motion tracing for the specified window 96message EndTraceRequest { 97 optional int32 trace_id = 1; 98} 99 100message EndTraceResponse { 101 optional com.android.app.viewcapture.data.MotionWindowData data = 1; 102} 103 104// Polls collected motion trace data collected since the last PollTraceRequest (or the 105// BeginTraceRequest) 106message PollTraceRequest { 107 optional int32 trace_id = 1; 108} 109 110message PollTraceResponse { 111 optional com.android.app.viewcapture.data.MotionWindowData data = 1; 112} 113 114