macOS Dangerous Entitlements & TCC perms

htARTE (HackTricks AWS Red Team Expert)를 통해 **제로**부터 **히어로**까지 **AWS 해킹** 배우기!

HackTricks를 지원하는 다른 방법:

**com.apple**로 시작하는 entitlements는 서드파티에게 사용할 수 없으며, Apple만이 부여할 수 있음을 유의하세요.

High

com.apple.rootless.install.heritable

Entitlement **com.apple.rootless.install.heritable**은 SIP 우회를 허용합니다. 자세한 정보는 여기를 확인하세요.

com.apple.rootless.install

Entitlement **com.apple.rootless.install**은 SIP 우회를 허용합니다. 자세한 정보는 여기를 확인하세요.

com.apple.system-task-ports (이전에 task_for_pid-allow로 불렸음)

이 entitlement는 커널을 제외한 모든 프로세스의 작업 포트를 가져올 수 있게 합니다. 자세한 정보는 여기를 확인하세요.

com.apple.security.get-task-allow

이 entitlement는 다른 프로세스가 이 entitlement를 가진 이진 파일에 의해 실행된 프로세스의 작업 포트를 가져와 코드를 주입할 수 있도록 합니다. 자세한 정보는 여기를 확인하세요.

com.apple.security.cs.debugger

디버깅 도구 Entitlement를 가진 앱은 Get Task Allow entitlement가 true로 설정된 미사인 및 서드파티 앱에 대해 task_for_pid()를 호출하여 유효한 작업 포트를 검색할 수 있습니다. 그러나 디버깅 도구 entitlement가 있더라도 디버거는 Get Task Allow entitlement가 없는 프로세스의 작업 포트를 가져올 수 없으며, 따라서 시스템 무결성 보호로 보호되는 프로세스의 작업 포트를 가져올 수 없습니다. 자세한 정보는 여기를 확인하세요.

com.apple.security.cs.disable-library-validation

이 entitlement는 Apple에 의해 서명되지 않거나 주 실행 파일과 동일한 팀 ID로 서명되지 않은 프레임워크, 플러그인 또는 라이브러리를 로드할 수 있게 합니다. 따라서 공격자는 임의의 라이브러리 로드를 악용하여 코드를 주입할 수 있습니다. 자세한 정보는 여기를 확인하세요.

com.apple.private.security.clear-library-validation

이 entitlement는 **com.apple.security.cs.disable-library-validation**과 매우 유사하지만 라이브러리 유효성 검사를 직접 비활성화하는 대신 프로세스가 csops 시스템 호출을 통해 비활성화할 수 있게 합니다. 자세한 정보는 여기를 확인하세요.

com.apple.security.cs.allow-dyld-environment-variables

이 entitlement는 DYLD 환경 변수를 사용할 수 있게 하여 라이브러리와 코드를 주입할 수 있습니다. 자세한 정보는 여기를 확인하세요.

com.apple.private.tcc.manager 또는 com.apple.rootless.storage.TCC

이 블로그에 따르면 이 블로그에 따르면, 이러한 entitlements는 TCC 데이터베이스를 수정할 수 있게 합니다.

system.install.apple-softwaresystem.install.apple-software.standar-user

이러한 entitlements는 사용자에게 권한을 요청하지 않고 소프트웨어를 설치할 수 있게 합니다. 이는 권한 상승에 도움이 될 수 있습니다.

com.apple.private.security.kext-management

커널에게 커널 확장을 로드하도록 요청하는 entitlement입니다.

com.apple.private.icloud-account-access

Entitlement **com.apple.private.icloud-account-access**를 통해 com.apple.iCloudHelper XPC 서비스와 통신하여 iCloud 토큰을 제공할 수 있습니다.

iMovieGarageband에는 이 entitlement가 있었습니다.

해당 entitlement에서 icloud 토큰을 가져오는 exploit에 대한 자세한 정보는 다음 발표를 확인하세요: #OBTS v5.0: "What Happens on your Mac, Stays on Apple's iCloud?!" - Wojciech Regula

com.apple.private.tcc.manager.check-by-audit-token

TODO: 이것이 무엇을 할 수 있는지 모르겠습니다

com.apple.private.apfs.revert-to-snapshot

TODO: 이 보고서에서는 이것이 부팅 후 SSV로 보호된 콘텐츠를 업데이트하는 데 사용될 수 있다고 언급합니다. 알고 계시다면 PR을 보내주세요!

com.apple.private.apfs.create-sealed-snapshot

TODO: 이 보고서에서는 이것이 부팅 후 SSV로 보호된 콘텐츠를 업데이트하는 데 사용될 수 있다고 언급합니다. 알고 계시다면 PR을 보내주세요!

keychain-access-groups

이 entitlement은 애플리케이션이 액세스할 수 있는 키체인 그룹 목록을 나열합니다:

<key>keychain-access-groups</key>
<array>
<string>ichat</string>
<string>apple</string>
<string>appleaccount</string>
<string>InternetAccounts</string>
<string>IMCore</string>
</array>

kTCCServiceSystemPolicyAllFiles

전체 디스크 액세스 권한을 부여하며, 가질 수 있는 TCC에서 가장 높은 권한 중 하나입니다.

kTCCServiceAppleEvents

앱이 작업 자동화에 일반적으로 사용되는 다른 애플리케이션에 이벤트를 보낼 수 있게 합니다. 다른 앱을 제어하여 이러한 다른 앱에 부여된 권한을 남용할 수 있습니다.

사용자에게 비밀번호를 요청하도록 만드는 것과 같은 작업을 수행할 수 있습니다:

osascript -e 'tell app "App Store" to activate' -e 'tell app "App Store" to activate' -e 'tell app "App Store" to display dialog "App Store requires your password to continue." & return & return default answer "" with icon 1 with hidden answer with title "App Store Alert"'

또는 임의의 작업을 수행하도록 만듭니다.

kTCCServiceEndpointSecurityClient

다른 권한 중 하나로 사용자 TCC 데이터베이스를 쓸 수 있게 합니다.

kTCCServiceSystemPolicySysAdminFiles

사용자의 홈 폴더 경로를 변경하는 사용자의 NFSHomeDirectory 속성을 변경할 수 있게 합니다. 따라서 TCC를 우회할 수 있습니다.

kTCCServiceSystemPolicyAppBundles

기본적으로 허용되지 않는 앱 번들(앱 내부의 app.app 내) 내 파일을 수정할 수 있습니다.

이 권한을 가진 사용자를 확인할 수 있습니다. 시스템 환경설정 > 개인정보 및 보안 > 앱 관리.

kTCCServiceAccessibility

프로세스는 macOS 접근성 기능을 남용할 수 있게 됩니다. 이는 예를 들어 키 입력을 누를 수 있게 됨을 의미합니다. 따라서 Finder와 같은 앱을 제어하고 이 권한으로 대화 상자를 승인할 수 있습니다.

중간

com.apple.security.cs.allow-jit

이 권한은 mmap() 시스템 함수에 MAP_JIT 플래그를 전달하여 쓰기 및 실행 가능한 메모리를 생성할 수 있게 합니다. 자세한 정보는 여기를 참조하세요.

com.apple.security.cs.allow-unsigned-executable-memory

이 권한은 C 코드를 오버라이드하거나 패치하거나 오래된 NSCreateObjectFileImageFromMemory (기본적으로 보안에 취약함)를 사용하거나 DVDPlayback 프레임워크를 사용할 수 있게 합니다. 자세한 정보는 여기를 참조하세요.

이 권한을 포함하면 앱이 메모리 안전하지 않은 코드 언어의 일반적인 취약점에 노출됩니다. 앱이 이 예외를 필요로 하는지 신중히 고려하세요.

com.apple.security.cs.disable-executable-page-protection

이 권한은 디스크의 자체 실행 파일 섹션을 수정하여 강제로 종료할 수 있게 합니다. 자세한 정보는 여기를 참조하세요.

실행 파일 페이지 보호 비활성화 권한은 앱에서 기본 보안 보호를 제거하는 극단적인 권한이며, 앱의 실행 코드를 감지하지 않고 공격자가 앱의 실행 코드를 재작성할 수 있게 합니다. 가능하면 더 좁은 권한을 선호하세요.

com.apple.security.cs.allow-relative-library-loads

TODO

com.apple.private.nullfs_allow

이 권한은 기본적으로 금지된 nullfs 파일 시스템을 마운트할 수 있게 합니다. 도구: mount_nullfs.

kTCCServiceAll

이 블로그 게시물에 따르면, 이 TCC 권한은 일반적으로 다음 형식으로 발견됩니다:

[Key] com.apple.private.tcc.allow-prompting
[Value]
[Array]
[String] kTCCServiceAll

프로세스가 모든 TCC 권한을 요청하도록 허용합니다.

kTCCServicePostEvent

제로부터 영웅이 될 때까지 AWS 해킹을 배우세요 htARTE (HackTricks AWS Red Team Expert)!

HackTricks를 지원하는 다른 방법:

Last updated