aboutsummaryrefslogblamecommitdiffstats
path: root/src/process-request.php
blob: bbc1e4b5b1319c8f4781cf46b3384c56a2af25ba (plain) (tree)
1
2
3
4
5
6
7
8
9
     





                                                       

                                  






                                                                
         










                                                   

  


                                                                                               

                                                                 





                                         
                                                                                                

                                                     
 
                                 
<?php

// SPDX-FileCopyrightText: 2024 Eilertsens Kodeknekkeri
// SPDX-FileCopyrightText: 2024 Harald Eilertsen
//
// SPDX-License-Identifier: AGPL-3.0-or-later

use VolseNet\Webtrap\XmlRpcMethod;

function save_credentials(string $user, string $pass): void
{
    $file_name = dirname(__DIR__) . '/payloads/credentials.txt';
    $file = new SplFileObject($file_name, 'a');
    $file->fwrite("{$user}: {$pass}\n");
}

$data = [
    'SERVER_NAME' => $_SERVER['SERVER_NAME'],
    'REMOTE_ADDR' => $_SERVER['REMOTE_ADDR'],
    'REMOTE_PORT' => $_SERVER['REMOTE_PORT'],
    'REQUEST_METHOD' => $_SERVER['REQUEST_METHOD'],
    'REQUEST_URI' => $_SERVER['REQUEST_URI'],
    'QUERY_STRING' => $_SERVER['QUERY_STRING'],
    'REQUEST_TIME' => $_SERVER['REQUEST_TIME'],
    'REQUEST_HEADERS' => getallheaders(),
    'POST' => $_POST,
    'COOKIES' => $_COOKIE,
    'BODY' => file_get_contents('php://input'),
];

if (preg_match('/xmlrpc\.php/i', $data['REQUEST_URI']) && $data['REQUEST_METHOD'] === 'POST') {
    $method = XmlRpcMethod::parse($data['BODY']);
    if ($method->name === 'wp.getUsersBlogs') {
        save_credentials($method->params[0], $method->params[1]);
        error_log("Trapped XML-RPC request: saved credentials");

        header("HTTP/1.1 404 Not Found");
        die();
    }
}

$file_name = dirname(__DIR__) . "/payloads/{$data['REQUEST_TIME']}-{$data['SERVER_NAME']}.json";
error_log("Trapped request, saving to {$file_name}");
file_put_contents($file_name, json_encode($data));

header("HTTP/1.1 404 Not Found");