diff options
author | Jeff Brown <jeffbrown@google.com> | 2013-08-16 20:19:26 -0700 |
---|---|---|
committer | Jeff Brown <jeffbrown@google.com> | 2013-08-16 20:21:07 -0700 |
commit | 893a5642871114fca3b2a00c6ff8e5699ce3e3ed (patch) | |
tree | d34721dfd133e8a79a4ff32ee8e8d2d83ef24031 /services/audioflinger/ServiceUtilities.cpp | |
parent | 7fb865653293e665f48b31e791ca124e98c7d257 (diff) | |
download | frameworks_av-893a5642871114fca3b2a00c6ff8e5699ce3e3ed.zip frameworks_av-893a5642871114fca3b2a00c6ff8e5699ce3e3ed.tar.gz frameworks_av-893a5642871114fca3b2a00c6ff8e5699ce3e3ed.tar.bz2 |
Enforce permission for recording from remote submix.
Bug: 10265163
Change-Id: I2395036bac6e10baeaf6ea4bc3093bd9dd98742d
Diffstat (limited to 'services/audioflinger/ServiceUtilities.cpp')
-rw-r--r-- | services/audioflinger/ServiceUtilities.cpp | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/services/audioflinger/ServiceUtilities.cpp b/services/audioflinger/ServiceUtilities.cpp index d15bd04..9ee513b 100644 --- a/services/audioflinger/ServiceUtilities.cpp +++ b/services/audioflinger/ServiceUtilities.cpp @@ -34,6 +34,15 @@ bool recordingAllowed() { return ok; } +bool captureAudioOutputAllowed() { + if (getpid_cached == IPCThreadState::self()->getCallingPid()) return true; + static const String16 sCaptureAudioOutput("android.permission.CAPTURE_AUDIO_OUTPUT"); + // don't use PermissionCache; this is not a system permission + bool ok = checkCallingPermission(sCaptureAudioOutput); + if (!ok) ALOGE("Request requires android.permission.CAPTURE_AUDIO_OUTPUT"); + return ok; +} + bool settingsAllowed() { if (getpid_cached == IPCThreadState::self()->getCallingPid()) return true; static const String16 sAudioSettings("android.permission.MODIFY_AUDIO_SETTINGS"); |