Spamworldpro Mini Shell
Spamworldpro


Server : Apache
System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64
User : corals ( 1002)
PHP Version : 7.4.33
Disable Function : exec,passthru,shell_exec,system
Directory :  /home/corals/mautic.corals.io/app/bundles/ApiBundle/EventListener/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home/corals/mautic.corals.io/app/bundles/ApiBundle/EventListener/ApiSubscriber.php
<?php

namespace Mautic\ApiBundle\EventListener;

use Mautic\ApiBundle\Helper\RequestHelper;
use Mautic\CoreBundle\Helper\CoreParametersHelper;
use Mautic\CoreBundle\Translation\Translator;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
use Symfony\Component\HttpFoundation\JsonResponse;
use Symfony\Component\HttpKernel\Event\RequestEvent;
use Symfony\Component\HttpKernel\Event\ResponseEvent;
use Symfony\Component\HttpKernel\Exception\AccessDeniedHttpException;
use Symfony\Component\HttpKernel\KernelEvents;

class ApiSubscriber implements EventSubscriberInterface
{
    public function __construct(
        private CoreParametersHelper $coreParametersHelper,
        private Translator $translator
    ) {
    }

    public static function getSubscribedEvents(): array
    {
        return [
            KernelEvents::REQUEST  => ['onKernelRequest', 255],
            KernelEvents::RESPONSE => ['onKernelResponse', 0],
        ];
    }

    /**
     * Check for API requests and throw denied access if API is disabled.
     *
     * @throws AccessDeniedHttpException
     */
    public function onKernelRequest(RequestEvent $event): void
    {
        if (!$event->isMainRequest()) {
            return;
        }

        $request = $event->getRequest();

        // Ignore if not an API request
        if (!RequestHelper::isApiRequest($request)) {
            return;
        }

        // Prevent access to API if disabled
        $apiEnabled = $this->coreParametersHelper->get('api_enabled');
        if (!$apiEnabled) {
            $response   = new JsonResponse(
                [
                    'errors' => [
                        [
                            'message' => $this->translator->trans('mautic.api.error.api.disabled'),
                            'code'    => 403,
                            'type'    => 'api_disabled',
                        ],
                    ],
                ],
                403
            );

            $event->setResponse($response);

            return;
        }

        // Prevent access via basic auth if it is disabled
        $hasBasicAuth     = RequestHelper::hasBasicAuth($request);
        $basicAuthEnabled = $this->coreParametersHelper->get('api_enable_basic_auth');

        if ($hasBasicAuth && !$basicAuthEnabled) {
            $response   = new JsonResponse(
                [
                    'errors' => [
                        [
                            'message' => $this->translator->trans('mautic.api.error.basic.auth.disabled'),
                            'code'    => 403,
                            'type'    => 'access_denied',
                        ],
                    ],
                ],
                403
            );

            $event->setResponse($response);
        }
    }

    public function onKernelResponse(ResponseEvent $event): void
    {
        $request      = $event->getRequest();
        $isApiRequest = RequestHelper::isApiRequest($request);
        $hasBasicAuth = RequestHelper::hasBasicAuth($event->getRequest());

        // Ignore if this is not an API request
        if (!$isApiRequest) {
            return;
        }

        // Ignore if this does not contain an error response
        $response = $event->getResponse();
        $content  = $response->getContent();
        if (!str_contains($content, 'error')) {
            return;
        }

        // Ignore if content is not json
        if (!$data = json_decode($content, true)) {
            return;
        }

        // Ignore if an error was not found in the JSON response
        if (!isset($data['error'])) {
            return;
        }

        // Override api messages with something useful
        $type  = null;
        $error = $data['error'];
        if (is_array($error)) {
            if (!isset($error['message'])) {
                return;
            }

            // Catch useless oauth errors
            $error = $error['message'];
        }

        switch ($error) {
            case 'access_denied':
                $type    = $error;
                $message = $this->translator->trans('mautic.api.auth.error.accessdenied');

                if ($hasBasicAuth) {
                    if ($this->coreParametersHelper->get('api_enable_basic_auth')) {
                        $message = $this->translator->trans('mautic.api.error.basic.auth.invalid.credentials');
                    } else {
                        $message = $this->translator->trans('mautic.api.error.basic.auth.disabled');
                    }
                }

                break;
            default:
                if (isset($data['error_description'])) {
                    $message = $data['error_description'];
                    $type    = $error;
                } elseif ($this->translator->hasId('mautic.api.auth.error.'.$error)) {
                    $message = $this->translator->trans('mautic.api.auth.error.'.$error);
                    $type    = $error;
                }
        }

        // Message was not overriden so leave as is
        if (!isset($message)) {
            return;
        }

        $statusCode = $response->getStatusCode();
        $response   = new JsonResponse(
            [
                'errors' => [
                    [
                        'message' => $message,
                        'code'    => $response->getStatusCode(),
                        'type'    => $type,
                    ],
                ],
            ],
            $statusCode
        );

        $event->setResponse($response);
    }
}

Spamworldpro Mini