Thibault GUILLAUME a83a78a462 fix contactform
2016-03-02 12:36:13 +01:00

182 lines
6.6 KiB
PHP

<?php
class Process
{
private $data;
private $mail_dir;
private $to_provider = [];
private $to_press = [];
public function __construct()
{
$this->mail_dir = dirname(__FILE__);
$_to = Db::getInstance()->ExecuteS('SELECT `email`, `type` FROM `'._DB_PREFIX_.'contactform_email`');
foreach ($_to as $k => $email) {
if ($email['type'] == Contactform::TYPE_PROVIDER) {
$this->to_provider[] = $email['email'];
}
if ($email['type'] == Contactform::TYPE_PRESS) {
$this->to_press[] = $email['email'];
}
}
}
public function addProvider($post)
{
global $cookie;
$this->data = $post;
$errors = [];
$isCorrect = $this->validate(Contactform::TYPE_PROVIDER);
if (!$isCorrect) {
$errors[] = Tools::displayError('Tous les champs ne sont pas remplis');
} else {
if (!Validate::isEmail($this->data['email1'])) {
$errors[] = Tools::displayError('Certains champs ne sont pas valide');
} else {
$query = Db::getInstance()->autoExecute(_DB_PREFIX_.'contactform', [
'brand' => pSQL($this->data['brand']),
'compagny' => pSQL($this->data['compagny']),
'lastname' => pSQL($this->data['lastname']),
'firstname' => pSQL($this->data['firstname']),
'function' => pSQL($this->data['function']),
'email1' => pSQL($this->data['email1']),
'email2' => pSQL($this->data['email2']),
'phone1' => pSQL($this->data['phone1']),
'phone2' => pSQL($this->data['phone2']),
'purpose' => pSQL($this->data['purpose']),
'content' => pSQL($this->data['content']),
'type' => Contactform::TYPE_PROVIDER
], 'INSERT');
if (!$query) {
$errors[] = Tools::displayError('Une erreur s\'est produite. Votre message n\'a pas été envoyé');
} else {
$this->data = array();
foreach ($post as $key => $data) {
$this->data['{'.$key.'}'] = $data;
}
$sended = Mail::Send(
(int)$cookie->id_lang,
'provider',
'Contact fournisseur',
$this->data,
$this->to_provider
);
if (!$sended) {
$errors[] = Tools::displayError('Une erreur s\'est produite. Votre message n\'a pas été envoyé');
}
}
}
}
if (!empty($errors)) {
return $errors;
}
$this->emptyForm();
return true;
}
public function addPress($post)
{
global $cookie;
$this->data = $post;
$errors = [];
$isCorrect = $this->validate(Contactform::TYPE_PRESS);
if (!$isCorrect) {
$errors[] = Tools::displayError('Tous les champs ne sont pas remplis');
} else {
if (!Validate::isEmail($this->data['email1'])) {
$errors[] = Tools::displayError('Certains champs ne sont pas valide');
} else {
$query = Db::getInstance()->autoExecute(_DB_PREFIX_.'contactform', [
'compagny' => pSQL($this->data['compagny']),
'lastname' => pSQL($this->data['lastname']),
'firstname' => pSQL($this->data['firstname']),
'function' => pSQL($this->data['function']),
'email1' => pSQL($this->data['email1']),
'email2' => pSQL($this->data['email2']),
'phone1' => pSQL($this->data['phone1']),
'phone2' => pSQL($this->data['phone2']),
'content' => pSQL($this->data['content']),
'type' => Contactform::TYPE_PRESS
], 'INSERT');
if (!$query) {
$errors[] = Tools::displayError('Une erreur s\'est produite. Votre message n\'a pas été envoyé');
} else {
$this->data = array();
foreach ($post as $key => $data) {
$this->data['{'.$key.'}'] = $data;
}
$sended = Mail::Send(
intval($cookie->id_lang),
'press',
'Contact presse',
$this->data,
$this->to_press
);
if (!$sended) {
$errors[] = Tools::displayError('Une erreur s\'est produite. Votre message n\'a pas été envoyé');
}
}
}
}
if (!empty($errors)) {
return $errors;
}
$this->emptyForm();
return true;
}
private function validate($type)
{
switch ($type) {
case Contactform::TYPE_PROVIDER:
return (!empty($this->data['brand'])
&& !empty($this->data['compagny'])
&& !empty($this->data['lastname'])
&& !empty($this->data['firstname'])
&& !empty($this->data['function'])
&& !empty($this->data['email1'])
&& !empty($this->data['phone1'])
&& !empty($this->data['purpose'])
&& !empty($this->data['content']));
break;
case Contactform::TYPE_PRESS:
return (!empty($this->data['compagny'])
&& !empty($this->data['lastname'])
&& !empty($this->data['firstname'])
&& !empty($this->data['function'])
&& !empty($this->data['email1'])
&& !empty($this->data['phone1'])
&& !empty($this->data['content']));
break;
default:
return false;
break;
}
}
private function emptyForm() {
$_POST['brand'] = '';
$_POST['compagny'] = '';
$_POST['function'] = '';
$_POST['lastname'] = '';
$_POST['firstname'] = '';
$_POST['email1'] = '';
$_POST['email2'] = '';
$_POST['phone1'] = '';
$_POST['phone2'] = '';
$_POST['purpose'] = '';
$_POST['content'] = '';
}
}