JEMBOT MAWOT Bypass Shell

Current Path : /home/cinepatreb/billetterie/modules/psgdpr/controllers/front/
Upload File :
Current File : /home/cinepatreb/billetterie/modules/psgdpr/controllers/front/ExportDataToCsv.php

<?php
/**
 * Copyright since 2007 PrestaShop SA and Contributors
 * PrestaShop is an International Registered Trademark & Property of PrestaShop SA
 *
 * NOTICE OF LICENSE
 *
 * This source file is subject to the Academic Free License 3.0 (AFL-3.0)
 * that is bundled with this package in the file LICENSE.md.
 * It is also available through the world-wide-web at this URL:
 * https://opensource.org/licenses/AFL-3.0
 * If you did not receive a copy of the license and are unable to
 * obtain it through the world-wide-web, please send an email
 * to license@prestashop.com so we can send you a copy immediately.
 *
 * @author    PrestaShop SA <contact@prestashop.com>
 * @copyright Since 2007 PrestaShop SA and Contributors
 * @license   https://opensource.org/licenses/AFL-3.0 Academic Free License 3.0 (AFL-3.0)
 */
class psgdprExportDataToCsvModuleFrontController extends ModuleFrontController
{
    /**
     * @var Psgdpr
     */
    public $module;

    /**
     * @throws PrestaShopDatabaseException
     */
    public function initContent()
    {
        $customer = Context::getContext()->customer;
        $secure_key = sha1($customer->secure_key);
        $token = Tools::getValue('psgdpr_token');

        if ($customer->isLogged() === false || !isset($token) || $token != $secure_key) {
            exit('bad token');
        }

        GDPRLog::addLog($customer->id, 'exportCsv', 0);
        $this->exportDataToCsv($customer->id);
    }

    /**
     * @param int $id_customer
     */
    public function exportDataToCsv($id_customer)
    {
        $data = $this->module->getCustomerData('customer', $id_customer);

        $customerInfo = $data['data']['prestashopData']['customerInfo'];
        $addresses = $data['data']['prestashopData']['addresses'];
        $orders = $data['data']['prestashopData']['orders'];
        $carts = $data['data']['prestashopData']['carts'];
        $messages = $data['data']['prestashopData']['messages'];
        $connections = $data['data']['prestashopData']['connections'];
        $modules = $data['data']['modulesData'];

        // Open the output stream
        $fh = fopen('php://output', 'w');
        $delimiter = "\t";

        // Start output buffering (to capture stream contents)
        ob_start();

        // GENERAL INFO
        $line = [Tools::strtoupper($this->module->l('General info', 'ExportDataToCsv'))];
        fputcsv($fh, $line, $delimiter);

        $line = [
            $this->module->l('Gender', 'ExportDataToCsv'),
            $this->module->l('Name', 'ExportDataToCsv'),
            $this->module->l('Birth date', 'ExportDataToCsv'),
            $this->module->l('Age', 'ExportDataToCsv'),
            $this->module->l('Email', 'ExportDataToCsv'),
            $this->module->l('Language', 'ExportDataToCsv'),
            $this->module->l('Creation account data', 'ExportDataToCsv'),
            $this->module->l('Last visit', 'ExportDataToCsv'),
            $this->module->l('Siret', 'ExportDataToCsv'),
            $this->module->l('Ape', 'ExportDataToCsv'),
            $this->module->l('Company', 'ExportDataToCsv'),
            $this->module->l('Website', 'ExportDataToCsv'),
        ];
        fputcsv($fh, $line, $delimiter);
        unset($line);

        $line = [
            $customerInfo['gender'],
            $customerInfo['firstname'] . ' ' . $customerInfo['lastname'],
            $customerInfo['birthday'],
            $customerInfo['age'],
            $customerInfo['email'],
            $customerInfo['language'],
            $customerInfo['date_add'],
            $customerInfo['last_visit'],
            $customerInfo['siret'],
            $customerInfo['ape'],
            $customerInfo['company'],
            $customerInfo['website'],
        ];
        fputcsv($fh, $line, $delimiter);
        unset($line);
        // GENERAL INFO

        // empty line
        $line = [];
        fputcsv($fh, $line, $delimiter);

        // ADDRESSES
        $line = [Tools::strtoupper($this->module->l('Addresses', 'ExportDataToCsv'))];
        fputcsv($fh, $line, $delimiter);

        $line = [
            $this->module->l('Alias', 'ExportDataToCsv'),
            $this->module->l('Company', 'ExportDataToCsv'),
            $this->module->l('Name', 'ExportDataToCsv'),
            $this->module->l('Address', 'ExportDataToCsv'),
            $this->module->l('Phone(s)', 'ExportDataToCsv'),
            $this->module->l('Country', 'ExportDataToCsv'),
            $this->module->l('Date', 'ExportDataToCsv'),
        ];
        fputcsv($fh, $line, $delimiter);
        unset($line);

        if (count($addresses) >= 1) {
            foreach ($addresses as $address) {
                $line = [
                    $address['alias'],
                    $address['company'],
                    $address['firstname'] . ' ' . $address['lastname'],
                    $address['address1'] . ' ' . $address['address2'],
                    $address['phone'] . ' ' . $address['phone_mobile'],
                    $address['country'],
                    $address['date_add'],
                ];
                fputcsv($fh, $line, $delimiter);
                unset($line);
            }
        } else {
            $line = [$this->module->l('No addresses', 'ExportDataToCsv')];
            fputcsv($fh, $line, $delimiter);
            unset($line);
        }
        // ADDRESSES

        // empty line
        $line = [];
        fputcsv($fh, $line, $delimiter);

        // ORDERS
        $line = [Tools::strtoupper($this->module->l('Orders', 'ExportDataToCsv'))];
        fputcsv($fh, $line, $delimiter);

        $line = [
            $this->module->l('Reference', 'ExportDataToCsv'),
            $this->module->l('Payment', 'ExportDataToCsv'),
            $this->module->l('Order state', 'ExportDataToCsv'),
            $this->module->l('Total paid', 'ExportDataToCsv'),
            $this->module->l('Date', 'ExportDataToCsv'),
        ];
        fputcsv($fh, $line, $delimiter);
        unset($line);

        if (count($orders) >= 1) {
            foreach ($orders as $order) {
                $line = [
                    $order['reference'],
                    $order['payment'],
                    $order['order_state'],
                    $order['total_paid_tax_incl'],
                    $order['date_add'],
                ];
                fputcsv($fh, $line, $delimiter);
                unset($line);
            }
        } else {
            $line = [$this->module->l('No orders', 'ExportDataToCsv')];
            fputcsv($fh, $line, $delimiter);
            unset($line);
        }
        // ORDERS

        // empty line
        $line = [];
        fputcsv($fh, $line, $delimiter);

        // PRODUCTS IN ORDER
        if (count($orders) >= 1) {
            $line = [Tools::strtoupper($this->module->l('Products bought', 'ExportDataToCsv'))];
            fputcsv($fh, $line, $delimiter);

            $line = [
                $this->module->l('Order ref', 'ExportDataToCsv'),
                $this->module->l('Product ref', 'ExportDataToCsv'),
                $this->module->l('Name', 'ExportDataToCsv'),
                $this->module->l('Quantity', 'ExportDataToCsv'),
            ];
            fputcsv($fh, $line, $delimiter);
            unset($line);

            foreach ($orders as $order) {
                $products = $order['products'];
                foreach ($products as $product) {
                    $line = [
                        $order['reference'],
                        $product['product_reference'],
                        $product['product_name'],
                        $product['product_quantity'],
                    ];
                    fputcsv($fh, $line, $delimiter);
                    unset($line);
                }
            }
        }
        // PRODUCTS IN ORDER

        // empty line
        $line = [];
        fputcsv($fh, $line, $delimiter);

        // CARTS
        $line = [Tools::strtoupper($this->module->l('Carts', 'ExportDataToCsv'))];
        fputcsv($fh, $line, $delimiter);

        $line = [
            $this->module->l('Id', 'ExportDataToCsv'),
            $this->module->l('Total products', 'ExportDataToCsv'),
            $this->module->l('Date', 'ExportDataToCsv'),
        ];
        fputcsv($fh, $line, $delimiter);
        unset($line);

        if (count($carts) >= 1) {
            foreach ($carts as $cart) {
                $line = [
                    '#' . $cart['id_cart'],
                    $cart['nb_products'],
                    $cart['date_add'],
                ];
                fputcsv($fh, $line, $delimiter);
                unset($line);
            }
        } else {
            $line = [$this->module->l('No carts', 'ExportDataToCsv')];
            fputcsv($fh, $line, $delimiter);
            unset($line);
        }
        // CARTS

        // empty line
        $line = [];
        fputcsv($fh, $line, $delimiter);

        // PRODUCTS IN CART
        $line = [Tools::strtoupper($this->module->l('Product(s) still in cart', 'ExportDataToCsv'))];
        fputcsv($fh, $line, $delimiter);

        $line = [
            $this->module->l('Cart ID', 'ExportDataToCsv'),
            $this->module->l('Product reference', 'ExportDataToCsv'),
            $this->module->l('Name', 'ExportDataToCsv'),
            $this->module->l('Quantity', 'ExportDataToCsv'),
        ];
        fputcsv($fh, $line, $delimiter);
        unset($line);

        if (count($carts) >= 1) {
            foreach ($carts as $cart) {
                $products = $cart['products'];
                if (count($products) >= 1) {
                    foreach ($products as $product) {
                        $line = [
                            '#' . $cart['id_cart'],
                            $product['product_reference'],
                            $product['product_name'],
                            $product['product_quantity'],
                        ];
                        fputcsv($fh, $line, $delimiter);
                        unset($line);
                    }
                } else {
                    $line = [$this->module->l('No products', 'ExportDataToCsv')];
                    fputcsv($fh, $line, $delimiter);
                    unset($line);
                }
            }
        } else {
            $line = [$this->module->l('No carts', 'ExportDataToCsv')];
            fputcsv($fh, $line, $delimiter);
            unset($line);
        }
        // PRODUCTS IN CART

        // empty line
        $line = [];
        fputcsv($fh, $line, $delimiter);

        // MESSSAGES
        $line = [Tools::strtoupper($this->module->l('Messages', 'ExportDataToCsv'))];
        fputcsv($fh, $line, $delimiter);

        $line = [
            $this->module->l('IP', 'ExportDataToCsv'),
            $this->module->l('Message', 'ExportDataToCsv'),
            $this->module->l('Date', 'ExportDataToCsv'),
        ];
        fputcsv($fh, $line, $delimiter);
        unset($line);

        if (count($messages) >= 1) {
            foreach ($messages as $message) {
                $line = [
                    $message['ip'],
                    $message['message'],
                    $message['date_add'],
                ];
                fputcsv($fh, $line, $delimiter);
                unset($line);
            }
        } else {
            $line = [$this->module->l('No messages', 'ExportDataToCsv')];
            fputcsv($fh, $line, $delimiter);
            unset($line);
        }
        // MESSAGES

        // empty line
        $line = [];
        fputcsv($fh, $line, $delimiter);

        // CONNECTIONS
        $line = [Tools::strtoupper($this->module->l('Last connections', 'ExportDataToCsv'))];
        fputcsv($fh, $line, $delimiter);

        $line = [
            $this->module->l('Origin request', 'ExportDataToCsv'),
            $this->module->l('Page viewed', 'ExportDataToCsv'),
            $this->module->l('Time on the page', 'ExportDataToCsv'),
            $this->module->l('IP address', 'ExportDataToCsv'),
            $this->module->l('Date', 'ExportDataToCsv'),
            $this->module->l('Country', 'ExportDataToCsv'),
            $this->module->l('Date', 'ExportDataToCsv'),
        ];
        fputcsv($fh, $line, $delimiter);
        unset($line);

        if (count($connections) >= 1) {
            foreach ($connections as $connection) {
                $line = [
                    $connection['http_referer'],
                    $connection['pages'],
                    $connection['time'],
                    $connection['ipaddress'],
                    $connection['date_add'],
                ];
                fputcsv($fh, $line, $delimiter);
                unset($line);
            }
        } else {
            $line = [$this->module->l('No connections', 'ExportDataToCsv')];
            fputcsv($fh, $line, $delimiter);
            unset($line);
        }
        // CONNECTIONS

        // empty line
        $line = [];
        fputcsv($fh, $line, $delimiter);

        // MODULES
        if (count($modules) >= 1) {
            foreach ($modules as $index => $module) {
                $line = [Tools::strtoupper('Module : ' . $index)];
                fputcsv($fh, $line, $delimiter);
                $line = [];
                if (is_array($module)) {
                    foreach ($module as $table) {
                        foreach ($table as $key => $value) {
                            $line[] = $key;
                        }
                        fputcsv($fh, $line, $delimiter);
                        $line = [];
                        foreach ($table as $key => $value) {
                            $line[] = $value;
                        }
                        fputcsv($fh, $line, $delimiter);
                        $line = [];
                    }
                } else {
                    $line[] = $module;
                    fputcsv($fh, $line, $delimiter);
                }
                // empty line
                $line = [];
                fputcsv($fh, $line, $delimiter);
            }
        }
        // MODULES

        // Get the contents of the output buffer
        $csv = ob_get_clean();

        // Set the filename of the download
        $filename = 'personalData-' . date('Y-m-d');

        // Output CSV-specific headers
        header('Content-Description: File Transfer');
        //header('Content-Type: application/octet-stream');
        header('Content-Type: application/vnd.ms-excel;');
        header('Content-Type: application/x-msexcel;');
        header('Content-Disposition: attachment; filename="' . $filename . '.csv";');
        header('Content-Transfer-Encoding: binary');
        header('Expires: 0');
        header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
        header('Pragma: public');

        $csv = chr(255) . chr(254) . iconv('UTF-8', 'UTF-16LE', $csv);

        exit($csv);
    }
}

xxxxx1.0, XXX xxxx