macOS XPC Connecting Process Check
XPC Connecting Process Check
XPC 서비스에 연결이 설정되면, 서버는 연결이 허용되는지 확인합니다. 일반적으로 수행하는 확인 사항은 다음과 같습니다:
연결하는 프로세스가 Apple 서명 인증서로 서명되었는지 확인합니다 (Apple에서만 발급).
이 확인이 이루어지지 않으면, 공격자는 가짜 인증서를 만들어 다른 확인 사항에 맞출 수 있습니다.
연결하는 프로세스가 조직의 인증서로 서명되었는지 확인합니다 (팀 ID 확인).
이 확인이 이루어지지 않으면, Apple의 모든 개발자 인증서를 사용하여 서명하고 서비스에 연결할 수 있습니다.
연결하는 프로세스가 적절한 번들 ID를 포함하는지 확인합니다.
이 확인이 이루어지지 않으면, 동일한 조직에서 서명된 도구를 사용하여 XPC 서비스와 상호작용할 수 있습니다.
(4 또는 5) 연결하는 프로세스가 적절한 소프트웨어 버전 번호를 가지고 있는지 확인합니다.
이 확인이 이루어지지 않으면, 오래된, 안전하지 않은 클라이언트가 프로세스 주입에 취약하여 다른 확인 사항이 있어도 XPC 서비스에 연결할 수 있습니다.
(4 또는 5) 연결하는 프로세스가 위험한 권한이 없는 강화된 런타임을 가지고 있는지 확인합니다 (임의의 라이브러리를 로드하거나 DYLD 환경 변수를 사용할 수 있는 권한과 같은).
이 확인이 이루어지지 않으면, 클라이언트는 코드 주입에 취약할 수 있습니다.
연결하는 프로세스가 서비스에 연결할 수 있는 권한을 가지고 있는지 확인합니다. 이는 Apple 바이너리에 적용됩니다.
검증은 연결하는 클라이언트의 감사 토큰을 기반으로 해야 하며, 프로세스 ID (PID) 대신 사용해야 합니다. 이는 후자가 PID 재사용 공격을 방지하기 때문입니다.
개발자는 감사 토큰 API 호출을 드물게 사용합니다. 이는 비공식적이므로 Apple이 언제든지 변경할 수 있습니다. 또한, 비공식 API 사용은 Mac App Store 앱에서 허용되지 않습니다.
processIdentifier
메서드가 사용되면 취약할 수 있습니다.**
xpc_dictionary_get_audit_token
**을xpc_connection_get_audit_token
대신 사용해야 하며, 후자는 특정 상황에서 취약할 수 있습니다.
Communication Attacks
PID 재사용 공격에 대한 자세한 내용은 다음을 확인하십시오:
macOS PID Reusexpc_connection_get_audit_token
공격에 대한 자세한 내용은 다음을 확인하십시오:
Trustcache - Downgrade Attacks Prevention
Trustcache는 Apple Silicon 기계에서 도입된 방어 방법으로, Apple 바이너리의 CDHSAH 데이터베이스를 저장하여 허용된 비수정 바이너리만 실행될 수 있도록 합니다. 이는 다운그레이드 버전의 실행을 방지합니다.
Code Examples
서버는 **shouldAcceptNewConnection
**이라는 함수에서 이 검증을 구현합니다.
객체 NSXPCConnection은 private 속성 auditToken
(사용해야 하지만 변경될 수 있는 것)과 public 속성 processIdentifier
(사용해서는 안 되는 것)을 가지고 있습니다.
연결된 프로세스는 다음과 같은 방법으로 확인할 수 있습니다:
개발자가 클라이언트의 버전을 확인하고 싶지 않다면, 적어도 클라이언트가 프로세스 주입에 취약하지 않은지 확인할 수 있습니다:
Last updated