improve functionanility in register
- validate post request according to bussiness rules besides redundant validation on front-end. - validate captcha againts google service - register every error in flash message service - build json response for errors on submit - add google/recaptcha to project and implements it, make settings for secret-key, put test re-captcha in register.html and secret-test in settings. - add flash message service and register against container. - add twig extension to read flash message service - remove api folder from public, conflicts in routes.
This commit is contained in:
parent
61d954d5fc
commit
507ea9a7ac
@ -3,7 +3,7 @@
|
|||||||
"description": "Groups Geometry and Dynamics, ICM2018 Satellite, Web Project",
|
"description": "Groups Geometry and Dynamics, ICM2018 Satellite, Web Project",
|
||||||
"keywords": ["ICM2018", "GGDWorkshop", "Montevideo","Math","Groups","Geometry"],
|
"keywords": ["ICM2018", "GGDWorkshop", "Montevideo","Math","Groups","Geometry"],
|
||||||
"homepage": "https://ggdworkshop.cmat.edu.uy",
|
"homepage": "https://ggdworkshop.cmat.edu.uy",
|
||||||
"license": "GPLv3",
|
"license": "GPLv2",
|
||||||
"authors": [
|
"authors": [
|
||||||
{
|
{
|
||||||
"name": "Germán Correa",
|
"name": "Germán Correa",
|
||||||
@ -16,7 +16,8 @@
|
|||||||
"slim/slim": "^3.1",
|
"slim/slim": "^3.1",
|
||||||
"monolog/monolog": "^1.17",
|
"monolog/monolog": "^1.17",
|
||||||
"slim/twig-view": "^2.3",
|
"slim/twig-view": "^2.3",
|
||||||
"google/recaptcha": "^1.1"
|
"google/recaptcha": "^1.1",
|
||||||
|
"kanellov/slim-twig-flash": "^0.2.0"
|
||||||
},
|
},
|
||||||
"require-dev": {
|
"require-dev": {
|
||||||
"phpunit/phpunit": ">=4.8 < 6.0"
|
"phpunit/phpunit": ">=4.8 < 6.0"
|
||||||
|
105
composer.lock
generated
105
composer.lock
generated
@ -4,7 +4,7 @@
|
|||||||
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file",
|
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file",
|
||||||
"This file is @generated automatically"
|
"This file is @generated automatically"
|
||||||
],
|
],
|
||||||
"content-hash": "f85f941c60254a0fb9e6426933aeac77",
|
"content-hash": "9a62d6d00b747b3976c6fb52bdeaeab3",
|
||||||
"packages": [
|
"packages": [
|
||||||
{
|
{
|
||||||
"name": "container-interop/container-interop",
|
"name": "container-interop/container-interop",
|
||||||
@ -82,6 +82,61 @@
|
|||||||
],
|
],
|
||||||
"time": "2017-03-09T18:44:34+00:00"
|
"time": "2017-03-09T18:44:34+00:00"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "kanellov/slim-twig-flash",
|
||||||
|
"version": "0.2.0",
|
||||||
|
"source": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://github.com/kanellov/slim-twig-flash.git",
|
||||||
|
"reference": "14a96919cfb116aa528b6ce9a611f544ac6d6a01"
|
||||||
|
},
|
||||||
|
"dist": {
|
||||||
|
"type": "zip",
|
||||||
|
"url": "https://api.github.com/repos/kanellov/slim-twig-flash/zipball/14a96919cfb116aa528b6ce9a611f544ac6d6a01",
|
||||||
|
"reference": "14a96919cfb116aa528b6ce9a611f544ac6d6a01",
|
||||||
|
"shasum": ""
|
||||||
|
},
|
||||||
|
"require": {
|
||||||
|
"php": ">=5.5.0",
|
||||||
|
"slim/flash": ">=0.1.0",
|
||||||
|
"twig/twig": ">=1.18"
|
||||||
|
},
|
||||||
|
"require-dev": {
|
||||||
|
"friendsofphp/php-cs-fixer": "1.*",
|
||||||
|
"phpunit/phpcov": "2.*",
|
||||||
|
"phpunit/phpunit": "4.8.0",
|
||||||
|
"satooshi/php-coveralls": "dev-master"
|
||||||
|
},
|
||||||
|
"type": "library",
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": {
|
||||||
|
"Knlv\\Slim\\Views\\": "src"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"notification-url": "https://packagist.org/downloads/",
|
||||||
|
"license": [
|
||||||
|
"GNU GPLv3"
|
||||||
|
],
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "Vassilis Kanellopoulos",
|
||||||
|
"email": "contact@kanellov.com",
|
||||||
|
"homepage": "http://kanellov.com"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"description": "A Twig extension to access Slim Flash messages in templates",
|
||||||
|
"keywords": [
|
||||||
|
"extension",
|
||||||
|
"flash",
|
||||||
|
"framework",
|
||||||
|
"message",
|
||||||
|
"provider",
|
||||||
|
"slim",
|
||||||
|
"twig",
|
||||||
|
"view"
|
||||||
|
],
|
||||||
|
"time": "2016-12-29T22:07:19+00:00"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "monolog/monolog",
|
"name": "monolog/monolog",
|
||||||
"version": "1.23.0",
|
"version": "1.23.0",
|
||||||
@ -399,6 +454,54 @@
|
|||||||
],
|
],
|
||||||
"time": "2016-10-10T12:19:37+00:00"
|
"time": "2016-10-10T12:19:37+00:00"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "slim/flash",
|
||||||
|
"version": "0.4.0",
|
||||||
|
"source": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "https://github.com/slimphp/Slim-Flash.git",
|
||||||
|
"reference": "9aaff5fded3b54f4e519ec3d4ac74d3d1f2cbbbc"
|
||||||
|
},
|
||||||
|
"dist": {
|
||||||
|
"type": "zip",
|
||||||
|
"url": "https://api.github.com/repos/slimphp/Slim-Flash/zipball/9aaff5fded3b54f4e519ec3d4ac74d3d1f2cbbbc",
|
||||||
|
"reference": "9aaff5fded3b54f4e519ec3d4ac74d3d1f2cbbbc",
|
||||||
|
"shasum": ""
|
||||||
|
},
|
||||||
|
"require": {
|
||||||
|
"php": ">=5.5.0"
|
||||||
|
},
|
||||||
|
"require-dev": {
|
||||||
|
"phpunit/phpunit": "^4.0"
|
||||||
|
},
|
||||||
|
"type": "library",
|
||||||
|
"autoload": {
|
||||||
|
"psr-4": {
|
||||||
|
"Slim\\Flash\\": "src"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"notification-url": "https://packagist.org/downloads/",
|
||||||
|
"license": [
|
||||||
|
"MIT"
|
||||||
|
],
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "Josh Lockhart",
|
||||||
|
"email": "hello@joshlockhart.com",
|
||||||
|
"homepage": "http://joshlockhart.com"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"description": "Slim Framework Flash message service provider",
|
||||||
|
"homepage": "http://slimframework.com",
|
||||||
|
"keywords": [
|
||||||
|
"flash",
|
||||||
|
"framework",
|
||||||
|
"message",
|
||||||
|
"provider",
|
||||||
|
"slim"
|
||||||
|
],
|
||||||
|
"time": "2017-10-22T10:35:05+00:00"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "slim/slim",
|
"name": "slim/slim",
|
||||||
"version": "3.9.2",
|
"version": "3.9.2",
|
||||||
|
@ -1,76 +0,0 @@
|
|||||||
<?php
|
|
||||||
function verifyCaptcha(){
|
|
||||||
$url = 'https://www.google.com/recaptcha/api/siteverify';
|
|
||||||
$data = array(
|
|
||||||
'secret' => '6LeLxy4UAAAAABClplWLJUjZ1_nhX_-SI7CuNcm8',
|
|
||||||
'response' => $_POST["g-recaptcha-response"]
|
|
||||||
);
|
|
||||||
$options = array(
|
|
||||||
'http' => array (
|
|
||||||
'header' => 'Content-Type: application/x-www-form-urlencoded\r\n',
|
|
||||||
'method' => 'POST',
|
|
||||||
'content' => http_build_query($data)
|
|
||||||
)
|
|
||||||
);
|
|
||||||
$context = stream_context_create($options);
|
|
||||||
$verify = file_get_contents($url, false, $context);
|
|
||||||
$captcha_success=json_decode($verify);
|
|
||||||
return $captcha_success;
|
|
||||||
}
|
|
||||||
// process.php
|
|
||||||
|
|
||||||
$errors = array(); // array to hold validation errors
|
|
||||||
$data = array(); // array to pass back data
|
|
||||||
|
|
||||||
// validate the variables ======================================================
|
|
||||||
// if any of these variables don't exist, add an error to our $errors array
|
|
||||||
|
|
||||||
if (empty($_POST['nombre']))
|
|
||||||
$errors['nombre'] = 'Name is required.';
|
|
||||||
|
|
||||||
if (empty($_POST['email']))
|
|
||||||
$errors['email'] = 'Email is required.';
|
|
||||||
|
|
||||||
if (empty($_POST['mensage']))
|
|
||||||
$errors['mensage'] = 'Mensaje is required.';
|
|
||||||
|
|
||||||
if(empty($_POST['g-recaptcha-response'])){
|
|
||||||
$errors['recaptcha'] = 'Debe validar el captcha';
|
|
||||||
}
|
|
||||||
else if(!verifyCaptcha()){
|
|
||||||
$errors['recaptcha'] = 'Error en la validación de ReCaptcha';
|
|
||||||
}
|
|
||||||
|
|
||||||
// return a response ===========================================================
|
|
||||||
|
|
||||||
// if there are any errors in our errors array, return a success boolean of false
|
|
||||||
if ( ! empty($errors)) {
|
|
||||||
|
|
||||||
// if there are items in our errors array, return those errors
|
|
||||||
$data['success'] = false;
|
|
||||||
$data['errors'] = $errors;
|
|
||||||
} else {
|
|
||||||
|
|
||||||
// if there are no errors process our form, then return a message
|
|
||||||
|
|
||||||
// DO ALL YOUR FORM PROCESSING HERE
|
|
||||||
// THIS CAN BE WHATEVER YOU WANT TO DO (LOGIN, SAVE, UPDATE, WHATEVER)
|
|
||||||
|
|
||||||
// show a message of success and provide a true success variable
|
|
||||||
$nombre = $_POST['nombre'];
|
|
||||||
$mail = $_POST['email'];
|
|
||||||
$msg = $_POST['mensage'];
|
|
||||||
$headers = 'From: ' . $mail . "\r\n" .
|
|
||||||
'Reply-To: ' . $mail . "\r\n" .
|
|
||||||
'X-Mailer: PHP/' . phpversion();
|
|
||||||
mail('6coloquio@cmat.edu.uy', 'Contacto de ' . $nombre, $msg, $headers);
|
|
||||||
|
|
||||||
$data['success'] = true;
|
|
||||||
$data['message'] = 'Mensaje enviado,<br/>A la brevedad el comite organizador se pondrá en contacto con usted.';
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
// return all our data to an AJAX call
|
|
||||||
echo json_encode($data);
|
|
||||||
|
|
||||||
?>
|
|
@ -1,135 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
$root = realpath($_SERVER["DOCUMENT_ROOT"]);
|
|
||||||
include_once $root.'/db/db.php';
|
|
||||||
|
|
||||||
function verifyCaptcha(){
|
|
||||||
$url = 'https://www.google.com/recaptcha/api/siteverify';
|
|
||||||
$data = array(
|
|
||||||
'secret' => '6LesRDsUAAAAAA6t3UgL4U4Foc9njmXX-8HIiLj_',
|
|
||||||
'response' => $_POST["g-recaptcha-response"]
|
|
||||||
);
|
|
||||||
$options = array(
|
|
||||||
'http' => array (
|
|
||||||
'header' => 'Content-Type: application/x-www-form-urlencoded\r\n',
|
|
||||||
'method' => 'POST',
|
|
||||||
'content' => http_build_query($data)
|
|
||||||
)
|
|
||||||
);
|
|
||||||
$context = stream_context_create($options);
|
|
||||||
$verify = file_get_contents($url, false, $context);
|
|
||||||
$captcha_success=json_decode($verify);
|
|
||||||
return $captcha_success;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*function verifyExistance($doc,$mail){
|
|
||||||
$fp = fopen("2021y22.csv", 'r');
|
|
||||||
fclose($fp);
|
|
||||||
}*/
|
|
||||||
|
|
||||||
/*function setheaders() {
|
|
||||||
$fp = fopen("2021y22.csv", 'w');
|
|
||||||
$cabezal = array('Nombre', 'Apellido','TipoDoc','Documento',
|
|
||||||
'Direccion','Pais','Ciudad', 'Telefono', 'Email',
|
|
||||||
'Profesión','Trabaja en','Financiación','Detalle Financiación');
|
|
||||||
if($fp){
|
|
||||||
fputcsv($fp,$cabezal);
|
|
||||||
fclose($fp);
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
die("unable to open file");
|
|
||||||
}
|
|
||||||
}*/
|
|
||||||
|
|
||||||
/*function registrar($fila) {
|
|
||||||
$fp = fopen("2021y22.csv", 'a');
|
|
||||||
if($fp){
|
|
||||||
fputcsv($fp,$fila);
|
|
||||||
fclose($fp);
|
|
||||||
|
|
||||||
}
|
|
||||||
else{
|
|
||||||
die("unable to open file");
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
function bkpregister(){
|
|
||||||
$fecha = date("d-m-H:i:s");
|
|
||||||
$filebkp = "bkp/registro-".$fecha.".bak.csv";
|
|
||||||
copy("2021y22.csv",$filebkp);
|
|
||||||
}*/
|
|
||||||
|
|
||||||
$errors = array(); // array to hold validation errors
|
|
||||||
$data = array(); // array to pass back data
|
|
||||||
|
|
||||||
|
|
||||||
// validate the variables ======================================================
|
|
||||||
$data['nombre'] = $_POST['nombre'];
|
|
||||||
$data['apellido'] = $_POST['apellido'];
|
|
||||||
$data['titulo'] = $_POST['titulo'];
|
|
||||||
$data['afiliacion'] = $_POST['afiliacion'];
|
|
||||||
$data['ciudad'] = $_POST['ciudad'];
|
|
||||||
$data['pais'] = $_POST['pais'];
|
|
||||||
$data['email'] = $_POST['email'];
|
|
||||||
$data['fechaLlegada'] = $_POST['bda'];
|
|
||||||
$data['fechaPartida'] = $_POST['eda'];
|
|
||||||
$data['financiacion'] = $_POST['financiacion'];
|
|
||||||
$data['invitado'] = $_POST['invited'];
|
|
||||||
$data['cartaInvitacion'] = $_POST['letterinvited'];
|
|
||||||
$data['roomingPref'] = $_POST['roomtype'];
|
|
||||||
$data['roommate'] = $_POST['roomate'];
|
|
||||||
$data['fechaRegistro'] = date("Y-m-d H:i:s");
|
|
||||||
$fila = $data;
|
|
||||||
|
|
||||||
if (empty($_POST['nombre']))
|
|
||||||
$errors['nombre'] = 'Nombre is required.';
|
|
||||||
|
|
||||||
if (empty($_POST['apellido']))
|
|
||||||
$errors['apellido'] = 'Apellido is required.';
|
|
||||||
|
|
||||||
if (empty($_POST['email']))
|
|
||||||
$errors['email'] = 'E-Mail de contacto vacio o incorrecto';
|
|
||||||
|
|
||||||
if(empty($_POST['g-recaptcha-response'])){
|
|
||||||
$errors['recaptcha'] = 'Debe validar el captcha';
|
|
||||||
}
|
|
||||||
else if(!verifyCaptcha()){
|
|
||||||
$errors['recaptcha'] = 'Error en la validación de ReCaptcha';
|
|
||||||
}
|
|
||||||
|
|
||||||
/*GUAMBIA ACAAA!!!!*/
|
|
||||||
$errors=array();
|
|
||||||
/* NO GILEAR!!!!!*/
|
|
||||||
|
|
||||||
if ( !empty($errors)) {
|
|
||||||
|
|
||||||
// if there are items in our errors array, return those errors
|
|
||||||
$data['success'] = false;
|
|
||||||
$data['errors'] = $errors;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
$data['success'] = true;
|
|
||||||
$db->insert($fila);
|
|
||||||
/*
|
|
||||||
$mail = $data["email"];
|
|
||||||
$nombre = $data["nombre"] . " " . $data["apellido"];
|
|
||||||
$msg = "Hi ". $data["nombre"] ."!\n\n".
|
|
||||||
"You have been Successfully registered to the workshop on Groups, Geometry and Dynamics!\n\n".
|
|
||||||
"For any question, write us to: ggdworkshop@cmat.edu.uy\n\n".
|
|
||||||
"Regards,\n\n".
|
|
||||||
"Organizing Commite, GGD Workshop.";
|
|
||||||
$headers = 'From: ' . "ggdworkshop@cmat.edu.uy" . "\r\n" .
|
|
||||||
'Reply-To: ' . "ggdworkshop@cmat.edu.uy" . "\r\n" .
|
|
||||||
'Content-Type: ' . "text/plain; charset=UTF-8". "\r\n" .
|
|
||||||
'X-Mailer: PHP/' . phpversion();
|
|
||||||
mail($mail, 'Registration confirmation for GGDWorkshop', $msg, $headers);
|
|
||||||
*/
|
|
||||||
$data['message'] = "Registration Successfully!";
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
// return all our data to an AJAX call
|
|
||||||
echo json_encode($data);
|
|
||||||
|
|
||||||
?>
|
|
@ -3,14 +3,24 @@
|
|||||||
|
|
||||||
$container = $app->getContainer();
|
$container = $app->getContainer();
|
||||||
|
|
||||||
|
$container['flash'] = function($c){
|
||||||
|
return new \Slim\Flash\Messages();
|
||||||
|
};
|
||||||
|
|
||||||
$container['renderer'] = function ($c) {
|
$container['renderer'] = function ($c) {
|
||||||
$settings = $c->get('settings')['renderer'];
|
$settings = $c->get('settings')['renderer'];
|
||||||
return new Slim\Views\Twig($settings['template_path'],[
|
|
||||||
|
$view = new Slim\Views\Twig($settings['template_path'],[
|
||||||
'cache' => $settings['cache_path'],
|
'cache' => $settings['cache_path'],
|
||||||
|
|
||||||
]);
|
]);
|
||||||
|
|
||||||
|
$view->addExtension(new Knlv\Slim\Views\TwigMessages(
|
||||||
|
$c->get('flash')
|
||||||
|
));
|
||||||
|
return $view;
|
||||||
};
|
};
|
||||||
|
|
||||||
$container['db'] = function ($c) {
|
$container['db'] = function ($c) {
|
||||||
$db = $c->get('settings')['db'];
|
$db = $c->get('settings')['db'];
|
||||||
try{
|
try{
|
||||||
|
@ -39,6 +39,7 @@ $app->get('/committess', function (Request $request, Response $response, array $
|
|||||||
$this->logger->info("GDDWorkshop '/committess' route");
|
$this->logger->info("GDDWorkshop '/committess' route");
|
||||||
|
|
||||||
// Render index view
|
// Render index view
|
||||||
|
//$this->flash->addMessage("lele","mensaje de lele");
|
||||||
return $this->renderer->render($response, 'committess.html', $args);
|
return $this->renderer->render($response, 'committess.html', $args);
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -65,17 +66,48 @@ $app->group('/api', function($app){
|
|||||||
//$this->logger->debug(var_dump($request->getParsedBody()));
|
//$this->logger->debug(var_dump($request->getParsedBody()));
|
||||||
$db = new DB($this->db);
|
$db = new DB($this->db);
|
||||||
$data = $request->getParsedBody();
|
$data = $request->getParsedBody();
|
||||||
|
$messages = $this->flash;
|
||||||
|
if(!isset($data['nombre']))
|
||||||
|
$messages->addMessageNow("submit-register-err", "First Name could not be empty");
|
||||||
|
if(!isset($data['apellido']))
|
||||||
|
$messages->addMessageNow("submit-register-err", "Last Name could not be empty");
|
||||||
|
if(!isset($data['email']))
|
||||||
|
$messages->addMessageNow("submit-register-err", "E-mail could not be empty");
|
||||||
|
if(!isset($data['financiacion']))
|
||||||
|
$messages->addMessageNow("submit-register-err", "Question about financial support must have a selected answer");
|
||||||
|
if(!isset($data['invited']))
|
||||||
|
$messages->addMessageNow("submit-register-err", "Question about 'invited to participate in this conference' must have a selected answer");
|
||||||
|
if(!isset($data['letterinvited']))
|
||||||
|
$messages->addMessageNow("submit-register-err", "Question about needing a letter of invitation must have a selected answer");
|
||||||
|
if(!isset($data['g-recaptcha-response'])){
|
||||||
|
$messages->addMessageNow("submit-register-err", "Please validate captcha!");
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$recaptcha = new ReCaptcha\ReCaptcha($this->settings['recaptcha']['secret-test']);
|
||||||
|
//get remote ip from request header TODO
|
||||||
|
$resp = $recaptcha->verify($data['g-recaptcha-response'], $_SERVER['REMOTE_ADDR']);
|
||||||
|
if(!$resp->isSuccess()){
|
||||||
|
$messages->addMessageNow("submit-register-err", "ReCaptcha validation error " . implode($resp->getErrorCodes()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
try{
|
if($messages->hasMessage("submit-register-err")){
|
||||||
$db->insert($data);
|
|
||||||
}
|
|
||||||
catch (Exception $e){
|
|
||||||
$this->logger->debug($e->getMessage());
|
|
||||||
return $e->getMessage();
|
|
||||||
}
|
|
||||||
|
|
||||||
$newresponse = $response->withJson($data);
|
$arrayresponse = array("success" => false, "errors"=>$messages->getMessage("submit-register-err"), "data"=>$data);
|
||||||
return $newresponse;
|
$newres = $response->withJson($arrayresponse);
|
||||||
|
return $newres;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
|
||||||
|
/*try{
|
||||||
|
$db->insert($data);
|
||||||
|
}
|
||||||
|
catch (Exception $e){
|
||||||
|
$this->logger->debug($e->getMessage());
|
||||||
|
return $e->getMessage();
|
||||||
|
}*/
|
||||||
|
echo "todo ok";
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
@ -21,7 +21,11 @@ return [
|
|||||||
'level' => \Monolog\Logger::DEBUG,
|
'level' => \Monolog\Logger::DEBUG,
|
||||||
],
|
],
|
||||||
'db' => [
|
'db' => [
|
||||||
'path' => __DIR__."/../db/ggdworkshop.db"
|
'path' => __DIR__."/../db/ggdworkshop.db",
|
||||||
|
],
|
||||||
|
'recaptcha' => [
|
||||||
|
'secret' => "6LesRDsUAAAAAA6t3UgL4U4Foc9njmXX-8HIiLj_",
|
||||||
|
'secret-test' => "6LeIxAcTAAAAAGG-vFI1TnRWxMZNFuojJ4WifJWe",
|
||||||
],
|
],
|
||||||
],
|
],
|
||||||
];
|
];
|
||||||
|
@ -163,7 +163,8 @@
|
|||||||
<!--Captcha -->
|
<!--Captcha -->
|
||||||
<div class="row">
|
<div class="row">
|
||||||
<div class="form-group col-xs-12">
|
<div class="form-group col-xs-12">
|
||||||
<div class="g-recaptcha" data-sitekey="6LesRDsUAAAAAJvyoODvjiza9u75qEGJmbKHEV6s"></div>
|
<div id="testing" class="g-recaptcha" data-sitekey="6LeIxAcTAAAAAJcZVRqyHh71UMIEGNQ_MXjiZKhI"></div>
|
||||||
|
<!--<div class="g-recaptcha" data-sitekey="6LesRDsUAAAAAJvyoODvjiza9u75qEGJmbKHEV6s"></div>-->
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@ -175,13 +176,19 @@
|
|||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
|
|
||||||
<div id="statusmsg" class="alert alert-success">
|
|
||||||
<strong>Success!</strong> Indicates a successful or positive action.
|
<!--{% if flash("submit-register-err") %}-->
|
||||||
</div>
|
<div id="statusmsg" class="alert alert-error">
|
||||||
|
<strong>Error!</strong>
|
||||||
|
{% for msg in flash("submit-register-err") %}
|
||||||
|
<kbd>{{ msg }}.</kdb>
|
||||||
|
{% endfor %}
|
||||||
|
</div>
|
||||||
|
<!-- {% endif %}-->
|
||||||
<!--<div id="myModal" class="modal fade" role="dialog">
|
<!--<div id="myModal" class="modal fade" role="dialog">
|
||||||
<div class="modal-dialog">
|
<div class="modal-dialog">
|
||||||
<!-- Modal content-->
|
|
||||||
<!--<div class="modal-content">
|
<div class="modal-content">
|
||||||
<div class="modal-header">
|
<div class="modal-header">
|
||||||
<button type="button" class="close" data-dismiss="modal">×</button>
|
<button type="button" class="close" data-dismiss="modal">×</button>
|
||||||
<h4 class="modal-title">Revise sus datos cuidadosamente y confirme</h4>
|
<h4 class="modal-title">Revise sus datos cuidadosamente y confirme</h4>
|
||||||
|
Loading…
Reference in New Issue
Block a user