Analysis
1. 개요
CVE-2024-52427은 Event Tickets with Ticket Scanner(이하, Event Tickets) WordPress 플러그인 2.3.11 버전 이하에서 발견된 Server Side Include(SSI) Injection 취약점입니다. 이 취약점은 해당 플러그인에서 사용하는 Twig 템플릿 엔진의 특수 요소를 적절히 필터링하지 않아 발생하며, 글 쓰기 권한이 있는 사용자(Author 권한 이상)가 악의적인 코드를 삽입해 서버에 시스템 명령어를 실행할 수 있습니다.
2. 플러그인 설명
Event Tickets은 WordPress 웹사이트에서 이벤트 티켓을 생성하고 관리할 수 있는 플러그인입니다.
예를 들어, 콘서트 입장권 판매 시 상품 등록 단계에서 입장권 정보를 입력하면 상품을 구매한 고객에게 상품 정보가 포함된 티켓이 자동으로 부여됩니다.
상품 등록 시 티켓 정보 입력
상품 주문 완료 화면 내 티켓 정보
위 상품 주문 완료 화면 내 티켓 정보를 클릭할 경우 상품 구매 정보와 QR 코드가 담긴 티켓을 발급받을 수 있습니다.
또한 QR 코드를 통한 티켓 스캔 기능을 제공하며, 티켓 템플릿 커스터마이징, 이벤트 관리, 결제 처리 등 다양한 기능을 제공합니다.
티켓 스캐너 1
티켓 스캐너 2
3. 취약점 분석
Event Tickets 플러그인은 템플릿 커스터마이징 기능을 통해 티켓 페이지를 꾸밀 수 있습니다. 해당 커스터마이징 기능은 Event Tickets 설정 메뉴(/wp-admin/admin.php?page=event-tickets-with-ticket-scanner)의 ‘Options’ 내 티켓 템플릿 설정에서 확인할 수 있습니다.
Event Tickets 설정 메뉴
Event Tickets 설정 메뉴 내 티켓 페이지 템플릿 설정
이 설정에서는 HTML 과 Twig 템플릿 문법을 사용하여 티켓의 디자인과 내용을 자유롭게 수정할 수 있도록 허용하고 있습니다.
하지만 Event Tickets 플러그인은 사용자가 입력한 Twig 템플릿 코드를 적절히 검증하지 않아 악의적인 코드가 실행될 수 있는 취약점이 있습니다. 또한, 해당 플러그인의 설정 메뉴는 글쓴이(Author) 수준의 낮은 접근 권한으로도 이용할 수 있으므로 취약점 악용의 위험성이 높습니다.
글쓴이(’Author’) 권한을 가진 사용자 Event Tickets 설정 메뉴 접근 화면(티켓 페이지 템플릿 설정)
따라서, WordPress의 글쓴이(Author) 권한은 일반적으로 콘텐츠 작성과 편집만 가능하지만, Event Tickets 플러그인 설정 메뉴에 접근할 수 있어 템플릿 코드에 악의적인 코드를 삽입하여 시스템 명령어를 실행할 수 있습니다.
PoC
1. PoC 환경 셋팅
CVE-2024-52427 취약점을 PoC 하기 위해서는 우선, WordPress의WooCommerce 플러그인 설치를 통해 스토어를 개설해야 합니다.
WooCommerce 플러그인 설치를 완료한 뒤, 스토어 설정을 통해 WordPress 사이트의 스토어를 활성화 합니다.
이후 event-tickets-with-ticket-scanner 플러그인 2.3.11 버전을 설치합니다. 그 다음 어드민 페이지에서 플러그인 설정 페이지(/wp-admin/admin.php?page=event-tickets-with-ticket-scanner)로 이동합니다.
해당 플러그인 파일은 plugins/event-tickets-with-ticket-scanner.2.3.11.zip 경로에 있습니다.
만약, event-tickets-with-ticket-scanner 플러그인 설정 페이지 접근 시 아래의 경고창이 나타날 경우 고유주소를 설정합니다.
고유주소 설정은 아래와 같이 설정합니다.
2. 트리거 준비
접근 권한이 글쓴이(Author)인 계정으로 로그인을 수행한 후 Event Tickets 설정 메뉴(/wp-admin/admin.php?page=event-tickets-with-ticket-scanner)로 이동하여 티켓 템플릿 설정 영역으로 이동 합니다.
현재 위와 같이 설정된 템플릿 내용은 아래의 형식으로 티켓 페이지를 출력하고 있습니다.
이후 템플릿 내용을 아래의 코드로 작성합니다. 해당 코드는 WordPress 서버의 시스템에 cat /etc/passwd 명령어를 실행하는 코드입니다.
{{['cat /etc/passwd'] | filter('system')}}
Plain Text
복사
3. 취약점 발생
그 다음 티켓 페이지를 요청 할 경우 다음과 같이 명령어 cat /etc/passwd 의 결과를 출력하는 것을 확인할 수 있습니다.
티켓 페이지의 요청은 ‘ Analysis > 2. 플러그인 설명’ 에서 확인할 수 있습니다.
PoC 코드 구현 및 실행
1. 환경 셋팅
아래의 명령어를 입력하여 poc 폴더로 이동한 뒤, python의 가상환경(venv)을 생성 및 실행하고 필요한 모듈을 설치합니다.
$ cd poc
$ python3 -m venv venv
$ source venv/bin/activate
(venv) $ pip install -r requirements.txt
Bash
복사
2. poc.py 코드 수정
poc.py 파일을 열어 코드 하단에 WordPress 주소와 관리자 계정을 입력합니다.
3. PoC 수행
이후 아래의 명령어를 입력하여 PoC를 수행합니다.
(venv) $ python poc.py
Bash
복사
또한, 위 출력된 로그 중 Ticket URL에 접속할 경우 아래와 같이 명령어 cat /etc/passwd 의 결과를 확인하실 수도 있습니다.
패치확인
본 내용은 CVE-2024-52427 제보자의 원본 PoC 코드를 직접 확인할 수 없어, CVE 제보 내용을 바탕으로 재현한 결과를 정리한 것입니다.
CVE-2024-52427 정보에 따르면 해당 취약점은 Event Tickets 플러그인 2.3.11 이하 버전에서 영향을 받으며, 2.3.12 이후 버전에서는 영향을 받지 않는다고 나와있습니다.
그러나 플러그인 개발 기록을 확인하고 해당 취약점에 영향을 받지 않는 버전의 상위 버전인 2.4.0 을 대상으로 PoC를 수행한 결과, 패치는 2.4.1 버전부터 이루어진 것을 확인하였습니다.
/wp-content/plugins/event-tickets-with-ticket-scanner/sasoEventtickets_Options.php
위 코드 내용은 Event Tickets 플러그인의 설정 메뉴 중 아래 접근과 관련된 설정입니다.
즉, Event Tickets 플러그인의 설정 메뉴의 접근 권한을 관리자(Administrator) 또는 접근 설정에 선택된 역할에만 할당하는 것을 기본 값(Default)으로 설정하고 있습니다.
따라서, 해당 취약점은 Event Tickets 플러그인 설정 메뉴의 기본 접근 권한의 변경을 통해 패치 되었습니다.