본문으로 건너뛰기
피드

백악관 공식 앱을 디컴파일해봤더니 — GDPR 배너 강제 제거, GPS 추적, 개인 GitHub에서 코드 로드

security 약 6분
vote
0
댓글
북마크

백악관 공식 Android 앱을 디컴파일한 결과, 인앱 브라우저에서 쿠키 동의/페이월을 강제 제거하는 JS 주입, 완전히 컴파일된 GPS 추적 파이프라인, 개인 GitHub Pages에서 코드 로드, 프로덕션 빌드에 개발 잔재가 남아있는 것을 발견.

  • 1

    WebView에서 GDPR 배너/페이월 강제 제거 JS 주입

  • 2

    OneSignal 통한 4.5분/9.5분 간격 GPS 추적 파이프라인 내장

  • 3

    YouTube 임베드를 개인 GitHub Pages에서 로드

  • 4

    개발 서버 URL/IP가 프로덕션 빌드에 잔존

앱 기본 구조

  • 백악관이 공식 앱을 출시했는데, 누군가가 APK를 뜯어봤음 — React Native + Expo SDK 54, Hermes JS 엔진, 백엔드는 WordPress
    • "forty-five-press"라는 업체가 만들었고, 5.5MB Hermes 바이트코드 번들에 68개 이상 라이브러리 포함
    • WordPress REST API(whitehouse/v1)로 뉴스, 라이브 스트림, 갤러리, 정책 이슈 등을 제공하는 콘텐츠 포털
    • 하드코딩된 문자열 중에 "Greatest President Ever!" (ㅋㅋ), ICE 신고 폼 링크도 있음

인앱 브라우저의 동의 배너 강제 제거

  • 앱 내 WebView에서 외부 링크를 열 때마다 JavaScript를 주입해서 다음을 숨김:
    • 쿠키 배너, GDPR 동의 다이얼로그, OneTrust 팝업, 프라이버시 배너
    • 로그인 월, 회원가입 월, 업셀 프롬프트, 페이월까지
    • MutationObserver로 동적으로 추가되는 동의 요소도 계속 제거
    • body { overflow: auto !important }로 스크롤 잠금도 해제

⚠️주의

> 미국 정부 공식 앱이 서드파티 웹사이트에 CSS/JS를 주입해서 쿠키 동의, GDPR 배너, 페이월을 강제로 제거하고 있음.

GPS 추적 파이프라인

  • OneSignal SDK의 위치 추적 코드가 APK에 완전히 컴파일되어 있음
    • 포그라운드 4.5분, 백그라운드 9.5분 간격으로 GPS 폴링
    • 위도, 경도, 정확도, 타임스탬프, 포그라운드/백그라운드 여부, fine/coarse 구분까지 전부 OneSignal 서버로 동기화
    • 백그라운드 서비스로 앱이 비활성 상태에서도 위치 수집 가능
  • 활성화 조건이 3가지 있음: _isShared 플래그(JS에서 토글 가능), 런타임 위치 권한, 위치 제공자 존재
    • withNoLocation이라는 Expo 플러그인이 위치 코드를 제거했어야 하는데 실제로는 아무것도 제거하지 않음
    • JS 번들에 setLocationSharedisLocationShared 참조가 존재 — setLocationShared(true) 한 줄이면 전체 파이프라인 가동

서드파티 의존성 문제

  • YouTube 임베드에 lonelycpp.github.io라는 개인 GitHub Pages 사이트에서 HTML을 로드함
    • 이 계정이 탈취되면 앱 WebView 안에서 임의 코드 실행 가능 — 정부 앱이 랜덤 개인의 GitHub Pages에서 코드를 불러오는 상황
  • Elfsight(상용 SaaS 위젯)의 JS를 샌드박싱 없이 로드, Mailchimp로 이메일 수집, Uploadcare에서 이미지 호스팅, Truth Social 임베드 하드코딩
    • 이 중 어느 것도 정부 통제 인프라가 아님
  • SSL 인증서 피닝 없음 — 표준 Android TrustManager만 사용
    • 기업 프록시나 공용 WiFi에서 MITM 가능

프로덕션 빌드에 남은 개발 잔재

  • localhost:8081 URL(Metro 번들러 개발 서버)이 프로덕션 Hermes 번들에 포함
  • 개발자 로컬 IP 10.4.4.109가 문자열 리소스에 하드코딩
  • Expo 개발 클라이언트와 Compose PreviewActivity가 릴리스 빌드에 export됨
  • OneSignal을 통한 광범위한 사용자 프로파일링: 태그, SMS 번호, 크로스 디바이스 식별, 행동 추적, 알림 상호작용 로깅, 인앱 메시지 클릭 추적

기술 맥락

  • React Native 앱의 WebView injectedJavaScript는 원래 자사 웹 콘텐츠를 커스터마이징할 때 쓰는 기능인데, 이걸 서드파티 사이트에 적용하면 사실상 브라우저 확장 프로그램 수준의 페이지 조작이 돼요. GDPR 동의 배너를 제거하는 건 EU 법률 위반 소지가 있거든요
  • Expo의 config plugin 시스템(withNoLocation, withStripPermissions)은 빌드 타임에 네이티브 코드를 수정하는 방식인데, OneSignal 같은 SDK가 자체 네이티브 모듈로 위치 코드를 주입하면 Expo 플러그인이 이를 인식하지 못할 수 있어요. 이건 Expo 생태계에서 서드파티 SDK와의 충돌이 흔한 문제
  • 개인 GitHub Pages에서 코드를 로드하는 건 react-native-youtube-iframe 라이브러리의 기본 동작이에요. 이 라이브러리가 YouTube IFrame API를 감싸는 HTML을 자체 호스팅하는 건데, 정부 앱처럼 보안 요구사항이 높은 환경에서는 이런 외부 의존성을 자체 CDN으로 가져와야 했어요

React Native + Expo 기반 정부 앱의 보안 실태를 적나라하게 보여주는 리버스 엔지니어링. 특히 서드파티 의존성 관리와 빌드 위생 문제는 모든 모바일 개발팀이 점검해볼 만함.

댓글

댓글

댓글을 불러오는 중...

security

한양대 에리카와 네이버클라우드, 클라우드·보안·AI 인재 키우는 산학협력 체결

한양대 에리카가 네이버클라우드와 첨단 분야 지역인재 양성과 글로벌 산학협력을 위한 업무협약을 맺었다. 협력 범위는 클라우드, 사이버보안, 블록체인, 개인정보보호, 인공지능(AI), 디지털 전환(DX) 교육·연구 기반 구축까지 포함된다.

security

악성 npm 패키지가 AI 개발도구의 지침 파일과 MCP까지 노리기 시작함

이스트시큐리티가 웹과 탈중앙화금융 개발자를 겨냥한 악성 npm 패키지 캠페인을 포착했어. 공격자는 유명 웹3 도구를 사칭하는 데서 그치지 않고, AI 에이전트가 읽는 프로젝트 지침 파일과 MCP 기반 외부 도구 호출까지 공격 경로로 삼으려 했어.

security

금융권, 앤트로픽 미토스가 찾은 오픈소스 취약점에 긴급 점검 들어감

앤트로픽의 AI 모델 클로드 미토스가 1000개 넘는 오픈소스에서 대량의 취약점 후보를 찾아냈고, 그중 일부가 실제 취약점으로 검증돼 공개됐어. 금융당국은 nginx, wolfSSL, FreeRDP, Ghost 같은 널리 쓰이는 구성요소를 중심으로 금융권에 긴급 자산 점검과 패치 적용을 권고했어.

security

애플이 양자 내성 암호화 검증 코드를 공개했다, 핵심은 수학적 증명

애플이 corecrypto 라이브러리의 포스트 양자 암호화 구현과 검증 코드를 GitHub에 공개했다. ML-KEM, ML-DSA 구현과 형식 검증 접근을 공개해 보안 연구자들이 직접 검토할 수 있게 했고, 이 기술은 25억 대 이상 활성 기기에서 쓰이는 암호화 기반과 연결된다.

security

라라벨 번역 패키지 태그가 통째로 바뀌었다, 개발자 비밀값 털리는 공급망 공격

전 세계 라라벨 개발자가 쓰는 Laravel-Lang 패키지가 공격을 받아 Git 태그가 악성 버전을 가리키도록 바뀌었다. 5월 22일 약 90분 동안 4개 저장소의 태그가 교체됐고, 감염된 패키지는 AWS 키, GitHub 토큰, Stripe 시크릿, 암호화폐 지갑 복구 구문, SSH 개인키 등을 노렸다.