summaryrefslogtreecommitdiff
path: root/libs/androidfw/StringPool.cpp
diff options
context:
space:
mode:
author Robert Carr <racarr@google.com> 2022-01-22 16:49:31 -0800
committer Rob Carr <racarr@google.com> 2022-02-08 03:39:17 +0000
commit20303e05bf73796124ab70a279cf849b61b97905 (patch)
tree02fe6672fddb07ce9e2959cdf7690f3e15ca7678 /libs/androidfw/StringPool.cpp
parent0a771d1712c49b1d5bb2058def38a4a6b6d5dc2c (diff)
DO NOT MERGE: WM: Call Transaction#sanitize
Various elements of the Transaction interface require a permission in order to apply. In particular the setTrustedOverlay and setInputWindowInfo fields. These permission checks are implemented by checking the PID and the UID of the process which sent the transaction. Unfortunately widespread use of transaction merging makes this inadequate. At the moment IWindowSession#finishDrawing seems to be the only boundary on which transactions move from client to system processes, and so we expose a sanitize method and use it from there to resolve the situation in an easily backportable way. Moving forward it likely make sense to move security sensitive interfaces off of Transaction. Most of the things behind permissions currently are not truly security sensitive, more of just a request not to use them. It was also considered to sanitize transactions at all process boundaries through writeToParcel, however this could be disruptive as previously permissioned processes (WM and SysUI) could freely exchange transactions. As the change needs to be backportable the lowest risk option was chosen. Bug: 213644870 Test: Existing tests pass Change-Id: I8d4a0ebe0cdfaed7ff1ad862724d49a14ed04478 (cherry picked from commit cdf139841567a625608b94339fa49cb895f6a69f)
Diffstat (limited to 'libs/androidfw/StringPool.cpp')
0 files changed, 0 insertions, 0 deletions