File "LeadsAjaxController.php"

Full path: C:/Inetpub/vhosts/drshti.com/httpdocs/wp-content/plugins/depicter/app/src/Controllers/Ajax/LeadsAjaxController.php
File size: 8.12 B (8.12 KB bytes)
MIME-type: text/x-php
Charset: utf-8

Download   Open   Edit   Advanced Editor &nnbsp; Back

<?php

namespace Depicter\Controllers\Ajax;

use Depicter\Utility\Sanitize;
use WPEmerge\Requests\RequestInterface;

class LeadsAjaxController
{
    public function index(RequestInterface $request, $view)
    {
        $args = [
            's'         => Sanitize::sql($request->query('s', '')),
            'sources'   => Sanitize::textfield($request->query('sources', '')),
            'dateStart' => Sanitize::textfield($request->query('dateStart', '')),
            'dateEnd'   => Sanitize::textfield($request->query('dateEnd', '')),
            'order'     => Sanitize::textfield($request->query('order', 'DESC')),
            'orderBy'   => Sanitize::textfield($request->query('orderBy', 'id')),
            'page'      => Sanitize::int($request->query('page', 1)),
            'perPage'   => Sanitize::int($request->query('perpage', 10))
        ];

        $response   = \Depicter::lead()->get($args);
        $statusCode = isset($response['errors']) ? 400 : 200;

        return \Depicter::json($response)->withStatus($statusCode);
    }

    /**
     * @throws \Exception
     */
    public function list(RequestInterface $request, $view)
    {
        $args = [
            's'                => Sanitize::sql($request->query('s', '')),
            'ids'              => Sanitize::textfield($request->query('ids', '')),
            'sources'          => Sanitize::textfield($request->query('sources', '')),
            'dateStart'        => Sanitize::textfield($request->query('dateStart', '')),
            'dateEnd'          => Sanitize::textfield($request->query('dateEnd', '')),
            'order'            => Sanitize::textfield($request->query('order', 'DESC')),
            'orderBy'          => Sanitize::textfield($request->query('orderBy', 'id')),
            'page'             => Sanitize::int($request->query('page', 1)),
            'perPage'          => Sanitize::int($request->query('perpage', 10)),
            'columns'          => Sanitize::textfield($request->query('columns', '')),
            'includeFields'    => Sanitize::textfield($request->query('includeFields', false)),
            'skipCustomFields' => Sanitize::textfield($request->query('skipCustomFields', false))
        ];

        $response = \Depicter::leadRepository()->getResults($args);

        return \Depicter::json($response);
    }

    public function submit(RequestInterface $request, $view)
    {
        $sourceId  = Sanitize::textfield($request->body('_sourceId', ''));
        $contentId = Sanitize::textfield($request->body('_contentId', ''));
        $csrfToken = Sanitize::textfield($request->body('_csrfToken', ''));

        $clientKey = \Depicter::options()->get('google_recaptcha_client_key', false);
        $secretKey = \Depicter::options()->get('google_recaptcha_secret_key', false);

        if ($clientKey && $secretKey) {

            $token = Sanitize::textfield($request->body('_g_recaptcha_token', ''));

            if (empty($token)) {
                return \Depicter::json([
                    'errors' => [__('Not a valid or authorized token. Please try later.', 'depicter')]
                ])->withStatus(400);
            }

            $isValid = \Depicter::recaptcha()->verify($token);
            if (!$isValid['success']) {
                return \Depicter::json([
                    'errors' => [$isValid['message']],
                    'data'   => $isValid['data']
                ])->withStatus(400);
            }
        }

        if (empty($sourceId) || empty($contentId)) {
            return \Depicter::json([
                'errors' => [__('Source ID or content ID is missing.', 'depicter')]
            ])->withStatus(400);
        }
        if (empty($csrfToken) || !wp_verify_nonce($csrfToken, 'depicter-csrf-lead-' . $sourceId)) {
            return \Depicter::json([
                'errors' => [__('Invalid or missing CSRF token. The request could not be completed.', 'depicter')]
            ])->withStatus(400);
        }

        try {
            $result = \Depicter::lead()->add($sourceId, $contentId, $request);
            if ($result['success']) {
                return \Depicter::json($result)->withStatus(200);
            }

            return \Depicter::json($result)->withStatus(400);

        } catch (\Exception $e) {
            return \Depicter::json(['errors' => [$e->getMessage()]])->withStatus(400);
        }
    }

    public function update(RequestInterface $request, $view)
    {
        $id     = Sanitize::int($request->body('id', 0));
        $fields = [];

        if (false !== $sourceId = $request->body('source_id', false)) {
            $fields['source_id'] = Sanitize::textfield($sourceId);
        }

        if (false !== $sourceType = $request->body('source_type', false)) {
            $fields['source_type'] = Sanitize::textfield($sourceType);
        }

        if (empty($id) || empty($fields)) {
            return \Depicter::json([
                'errors' => [__('Both lead id and lead data are required.', 'depicter')]
            ])->withStatus(400);
        }

        try {
            if (\Depicter::leadRepository()->update($id, $fields)) {
                return \Depicter::json(['success' => true])->withStatus(200);
            }
        } catch (\Exception $e) {
            return \Depicter::json(['errors' => [$e->getMessage()]])->withStatus(400);
        }

        return \Depicter::json(['errors' => [__('Error while updating the lead', 'depicter')]])->withStatus(400);

    }

    public function delete(RequestInterface $request, $view)
    {
        $id = Sanitize::textfield($request->body('ID', 0));
        if (empty($id)) {
            return \Depicter::json([
                'errors' => [__('Lead id is required.', 'depicter')]
            ])->withStatus(400);
        }

        try {
            if (\Depicter::leadRepository()->delete($id)) {
                return \Depicter::json(['success' => true])->withStatus(200);
            }
        } catch (\Exception $e) {
            return \Depicter::json(['errors' => [$e->getMessage()]])->withStatus(400);
        }

        return \Depicter::json(['errors' => [__('Error while deleting the lead.', 'depicter')]])->withStatus(400);
    }

    /**
     * Exports leads in a csv file
     *
     * @throws \Exception
     */
    public function export(RequestInterface $request, $view)
    {
        $args = [
            's'                => Sanitize::sql($request->query('s', '')),
            'ids'              => Sanitize::textfield($request->query('ids', '')),
            'sources'          => Sanitize::textfield($request->query('sources', '')),
            'dateStart'        => Sanitize::textfield($request->query('dateStart', '')),
            'dateEnd'          => Sanitize::textfield($request->query('dateEnd', '')),
            'order'            => Sanitize::textfield($request->query('order', 'DESC')),
            'orderBy'          => Sanitize::textfield($request->query('orderBy', 'id')),
            'page'             => Sanitize::int($request->query('page', 1)),
            'perPage'          => 10000000,
            'columns'          => Sanitize::textfield($request->query('columns', '')),
            'includeFields'    => Sanitize::textfield($request->query('includeFields', true)),
            'skipCustomFields' => Sanitize::textfield($request->query('skipCustomFields', false))
        ];

        $response = \Depicter::leadRepository()->getResults($args);

        if (!empty($response)) {

            $output = fopen('php://output', 'w');
            $now    = gmdate('y-m-d_H-i');

            header('Content-Description: File Transfer');
            header('Content-Type: text/csv; charset=utf-8');
            header("Content-Disposition: attachment; filename=leads-{$now}.csv");
            header('Expires: 0');
            header('Cache-Control: must-revalidate');
            header('Pragma: public');

            fputcsv($output, array_keys($response[0]));

            foreach ($response as $entry) {
                fputcsv($output, array_values($entry));
            }

            fclose($output);
            exit;
        }

        return \Depicter::json([
            'errors' => [__('error occurred during the export process', 'depicter')]
        ])->withStatus(400);
    }
}