⚝
One Hat Cyber Team
⚝
Your IP:
216.73.216.72
Server IP:
41.128.143.86
Server:
Linux host.raqmix.cloud 6.8.0-1025-azure #30~22.04.1-Ubuntu SMP Wed Mar 12 15:28:20 UTC 2025 x86_64
Server Software:
Apache
PHP Version:
8.3.23
Buat File
|
Buat Folder
Eksekusi
Dir :
~
/
usr
/
share
/
psa-horde
/
services
/
Edit File: ajax.php
<?php /** * Processes an AJAX request and returns a JSON encoded result. * * Path Info: * ---------- * http://example.com/horde/services/ajax.php/APP/ACTION[?OPTIONS] * - ACTION: (string) The AJAX action identifier. * - APP: (string) The application name. * - OPTIONS: Additional URL options * - jsonhtml: (boolean) On error, return in text/html format instead of * application/json * * Copyright 2010-2017 Horde LLC (http://www.horde.org/) * * See the enclosed file COPYING for license information (LGPL-2). If you * did not receive this file, see http://www.horde.org/licenses/lgpl. * * @author Michael Slusarz <slusarz@horde.org> * @category Horde * @license http://www.horde.org/licenses/lgpl LGPL-2 * @package Horde */ require_once __DIR__ . '/../lib/Application.php'; list($app, $action) = explode('/', trim(Horde_Util::getPathInfo(), '/')); if (empty($action)) { // This is the only case where we really don't return anything, since // the frontend can be presumed not to make this request on purpose. // Other missing data cases we return a response of boolean false. exit; } try { Horde_Registry::appInit($app, array( 'authentication' => 'fallback' )); } catch (Exception $e) { // Uncaught exception. Sending backtrace info back via AJAX is just a // waste of time. exit; } // Open an output buffer to ensure that we catch errors that might break JSON // encoding. Horde::startBuffer(); // Token checking occurs in constructor. $vars = $injector->getInstance('Horde_Variables'); try { $ajax = $injector->getInstance('Horde_Core_Factory_Ajax')->create($app, $vars, $action, $vars->token); } catch (Horde_Exception $e) { /* Treat a token error as a session timeout. */ $response = new Horde_Core_Ajax_Response_HordeCore_SessionTimeout($app); $response->jsonhtml = $vars->jsonhtml; $response->sendAndExit(); } try { $ajax->doAction(); // Clear the output buffer that we started above, and log any unexpected // output at a DEBUG level. if ($out = Horde::endBuffer()) { Horde::log('Unexpected output when creating AJAX reponse: ' . $out, 'DEBUG'); } // Send the final result. $ajax->send(); } catch (Horde_Exception_AuthenticationFailure $e) { // If we reach this, authentication to Horde was successful, but // authentication to some underlying backend failed. Best to logout // immediately, since no way of knowing if error is transient. $response = new Horde_Core_Ajax_Response_HordeCore_NoAuth($app, $e->getCode()); $response->jsonhtml = $vars->jsonhtml; $response->sendAndExit(); } catch (Exception $e) { $notification->push($e->getMessage(), 'horde.error'); $response = new Horde_Core_Ajax_Response_HordeCore(); $response->jsonhtml = $vars->jsonhtml; $response->sendAndExit(); }
Simpan