public function check_usernameAction() { $request = $this->getRequest(); $username = trim($request->getPost('raw')); if (strlen($username) < 3) { $this->view->error = $this->translate('Please use at least 3 characters'); } else { $validate = new Helper_Validate(); $validate->_set_rules($username, $this->translate('Username'), 'not_empty;min_length[3];max_length[100];username'); if ($validate->_valid_form()) { if (Model_Users::isExistUsername($username)) { $validate->_set_form_errors($this->translate('This username is already used')); $validate->_set_valid_form(false); } } if ($validate->_valid_form()) { $this->view->success = $this->translate('Available'); } else { $this->view->error = $validate->_get_error_messages(); } } echo $this->renderScript('json'); }
public function createAction() { if (!WM_Users::allow('create', $this->getRequest()->getController())) { $this->forward('error', 'noPermission'); } $this->setViewChange('form'); $request = $this->getRequest(); if ($request->isPost()) { if (trim($request->getPost('password')) and !Model_Users::isExistEmail($request->getPost('email')) and !Model_Users::isExistUsername($request->getPost('username'))) { Model_Users::createUser($request->getParams()); $this->session->set('successfu_edite', true); $this->redirect($this->getRequest()->getBaseUrl() . $this->getRequest()->getModule() . '/users/'); } } $this->view->new = true; $this->getForm(); }
public function profileAction() { $request = $this->getRequest(); $method = $request->getSegment(2); if (method_exists($this, strtolower($method) . 'Action')) { $this->forward('users', $method); } else { if ($method) { if (Model_Users::isExistUsername($method)) { $this->redirect($request->getBaseUrl() . $method); } } } $page = (int) $request->getRequest('page'); if ($page < 1) { $page = 1; } $user_data = $this->profileHelp(); $this->view->active = 'boards'; $this->view->enable_sort = JO_Session::get('user[user_id]') && JO_Session::get('user[user_id]') == $user_data['user_id']; $this->view->has_edit_boards = true; $this->view->enable_sort = true; $this->view->current_page = $page; if (JO_Session::get('user[user_id]') && $user_data['user_id'] == JO_Session::get('user[user_id]')) { $has_invates = new Model_Boards_TotalInvates(array('filter_user_id' => JO_Session::get('user[user_id]'))); $this->view->get_invate_boards = $has_invates->total; } /*//get pins data if($request->isXmlHttpRequest()) { $this->forward('users', 'getBoards', $user_data); }*/ ///// get pins $page = (int) $request->getRequest('page'); if ($page < 1) { $page = 1; } $this->view->result_data = ''; if (!Helper_Config::get('config_disable_js')) { //get pins data if ($request->isXmlHttpRequest()) { $this->forward('users', 'getBoards', $user_data); } } else { if ($page > 1 && $request->isXmlHttpRequest()) { $this->forward('users', 'getBoards', $user_data); } $pins = (array) $this->getBoardsAction($user_data, true); foreach ($pins as $pin) { $template = new Helper_Tmpl($pin['template'], $pin); $this->view->result_data .= $template->render($pin['template']); } } $this->view->children = array('header_part' => 'layout/header_part', 'footer_part' => 'layout/footer_part'); }
public function checkAvaibilityAction() { $request = $this->getRequest(); $username = trim($request->getPost('username')); if (empty($username)) { die('$("#username_check").removeClass("box-succeess").addClass("box-error").html("<p>' . $this->translate('Please type username') . '</p>");'); } if (!preg_match('/^[a-zA-Z0-9_]+$/i', $username)) { die('$("#username_check").removeClass("box-succeess").addClass("box-error").html("<p>' . $this->translate('The username you have typed is not valid') . '</p>");'); } $methodNames = array(); if (version_compare(PHP_VERSION, '5.2.6') === -1) { $class = new ReflectionObject($this); $classMethods = $class->getMethods(); foreach ($classMethods as $method) { $methodNames[] = $method->getName(); } } else { $methodNames = get_class_methods($this); } $temp_methodNames = array(); foreach ($methodNames as $methodName) { if (preg_match('/^([\\w]{1,})Action$/i', $methodName, $match)) { $temp_methodNames[] = $match[1]; } } $temp_methodNames = array_change_key_case($temp_methodNames, CASE_LOWER); if (in_array(strtolower($request->getPost('username')), $temp_methodNames)) { die('$("#username_check").removeClass("box-succeess").addClass("box-error").html("<p>' . $this->translate('This username can not be registered') . '</p>");'); } if (Model_Users::isExistUsername($request->getPost('username'))) { die('$("#username_check").removeClass("box-succeess").addClass("box-error").html("<p>' . $this->translate('There is already registration with that username') . '</p>");'); } die('$("#username_check").removeClass("box-error").addClass("box-success").html("<p>' . $this->translate('That username is free') . '</p>");'); }
public function registerfbAction() { $this->noViewRenderer(true); $request = $this->getRequest(); $response = $this->getResponse(); $page = (int) $request->getRequest('page'); if ($page < 1) { $page = 1; } $callback = $request->getRequest('callback'); if (!preg_match('/^([a-z0-9_.]{1,})$/', $callback)) { $callback = false; } $return = array(); $shared_content = Model_Users::checkSharedContent($request->getParam('key'), $request->getParam('user_id')); //self::loginInit($fbData['id'], $session); $ph = new WM_Facebook_Photo(); $image = $ph->getRealUrl('http://graph.facebook.com/' . $request->getPost('facebook_id') . '/picture?type=large'); if (!@getimagesize($image)) { $image = ''; } $this->view->error = false; if ($request->isPost()) { $session = $request->getPost('facebook_id'); //error_log("facebook id " . $session . " " . $request->getPost('username') . " " . $request->getPost('firstname')." ". $request->getPost('lastname')); $validate = new Helper_Validate(); $validate->_set_rules($request->getPost('username'), $this->translate('Username'), 'not_empty;min_length[3];max_length[100];username'); // $validate->_set_rules($request->getPost('firstname'), $this->translate('First name'), 'not_empty;min_length[3];max_length[100]'); // $validate->_set_rules($request->getPost('lastname'), $this->translate('Last name'), 'not_empty;min_length[3];max_length[100]'); $validate->_set_rules($request->getPost('email'), $this->translate('Email'), 'not_empty;min_length[5];max_length[100];email'); $validate->_set_rules($request->getPost('password'), $this->translate('Password'), 'not_empty;min_length[4];max_length[30]'); // $validate->_set_rules($request->getPost('password2'), $this->translate('Confirm password'), 'not_empty;min_length[4];max_length[30]'); if ($validate->_valid_form()) { if (md5($request->getPost('password')) != md5($request->getPost('password2'))) { $validate->_set_form_errors($this->translate('Password and Confirm Password should be the same')); $validate->_set_valid_form(false); //error_log("ERROR PASSS ". $request->getPost('password') . " " . $request->getPost('password2') ); } if (Model_Users::isExistEmail($request->getPost('email'))) { $validate->_set_form_errors($this->translate('This e-mail address is already used')); $validate->_set_valid_form(false); //error_log("ERROR MAIL ". $request->getPost('email')); } if (Model_Users::isExistUsername($request->getPost('username'))) { $validate->_set_form_errors($this->translate('This username is already used')); $validate->_set_valid_form(false); //error_log("ERROR USER ". $request->getPost('username')); } } if ($validate->_valid_form()) { $reg_key = sha1($request->getPost('email') . $request->getPost('username')); $result = Model_Users::create(array('facebook_id' => $request->getPost('facebook_id'), 'gender' => $request->getPost('gender'), 'avatar' => $image ? $image : '', 'location' => $request->getPost('location'), 'website' => $request->getPost('website'), 'username' => $request->getPost('username'), 'firstname' => $request->getPost('firstname'), 'lastname' => $request->getPost('lastname'), 'email' => $request->getPost('email'), 'password' => $request->getPost('password'), 'delete_email' => $request->getPost('email'), 'facebook_session' => $session, 'delete_code' => isset($shared_content['if_id']) ? $shared_content['if_id'] : '', 'following_user' => isset($shared_content['user_id']) ? $shared_content['user_id'] : '', 'facebook_connect' => 1, 'confirmed' => '0', 'regkey' => $reg_key)); if ($result) { if (self::sendMail($result)) { //self::loginInit($result); } $return = array('id' => $result); //['user_id']); //error_log("SIN ERROR ". $result); } else { $return = array('error' => 3, 'description' => $this->translate('There was a problem with the record. Please try again!')); //error_log("ERROR 3 "); } } else { $return = array('error' => 4, 'description' => str_replace("<br />", ". ", $validate->_get_error_messages())); //error_log("ERROR 4 " . str_replace("<br />", ". ", $validate->_get_error_messages())); } } $this->view->user_id_fb = $request->getPost('facebook_id'); $this->view->baseUrl = $request->getBaseUrl(); if ($request->issetPost('email')) { $this->view->email = $request->getPost('email'); } else { $this->view->email = ''; } if ($request->issetPost('firstname')) { $this->view->firstname = $request->getPost('firstname'); } else { $this->view->firstname = ''; } // // if($request->issetPost('lastname')) { // $this->view->lastname = $request->getPost('lastname'); // } else { // if(isset($fbData['last_name'])) { // $this->view->lastname = $fbData['last_name']; // } else { // $this->view->lastname = ''; // } // } if ($request->issetPost('username')) { $this->view->username = $request->getPost('username'); } else { $this->view->username = ''; } $this->view->password = $request->getPost('password'); // $this->view->password2 = $request->getPost('password2'); if ($callback) { $return = $callback . '(' . JO_Json::encode($return) . ')'; } else { $response->addHeader('Cache-Control: no-cache, must-revalidate'); $response->addHeader('Expires: Mon, 26 Jul 1997 05:00:00 GMT'); $response->addHeader('Content-type: application/json; charset=utf-8'); $return = JO_Json::encode($return); error_log("2RETURN " . $return); } $response->appendBody($return); }
public function registerAction() { $request = $this->getRequest(); $_SESSION["deportes_url"] = WM_Router::create($request->getBaseUrl() . '?controller=users&action=register'); $this->view->deportes = WM_Router::create($request->getBaseUrl() . '?controller=users&action=deportes'); //////////// Categories //////////// $this->view->categories = array(); $categories = Model_Categories::getCategories(array('filter_status' => 1)); foreach ($categories as $category) { $category['subcategories'] = Model_Categories::getSubcategories($category['category_id']); $this->view->categories[] = $category; } //////////// User Type //////////// $this->view->user_types = array(); $user_types = Model_Users::getUserType(array('filter_status' => 1)); foreach ($user_types as $user_type) { $user_type['subuser_types'] = Model_Users::getSubUserType($user_type['user_type_id']); $this->view->user_types[] = $user_type; } $this->view->user_sports = array(); $users_sports = Model_Users::getUserSports(0); $i = 0; foreach ($users_sports as $user_sports) { if ($user_sports['sport_category'] != 1) { if (!Model_Boards::isCategoryParent($user_sports['sport_category'])) { $this->view->user_sports[] = Model_Boards::getCategoryTitle($user_sports['sport_category']); $i++; } } } //$this->view->sportcounter = $i; if (JO_Session::get('user[user_id]')) { $this->redirect(WM_Router::create($request->getBaseUrl() . '?controller=users&action=profile&user_id=' . JO_Session::get('user[user_id]'))); } $shared_content = Model_Users::checkSharedContent($request->getParam('key'), $request->getParam('user_id')); if (!JO_Registry::get('enable_free_registration')) { if (!$shared_content) { $this->redirect(WM_Router::create($request->getBaseUrl() . '?controller=landing')); } } else { $this->view->fb_register = null; $fb_ses = JO_Registry::get('facebookapi'); $session = $fb_ses->getUser(); if (JO_Registry::get('oauth_fb_key') && JO_Registry::get('oauth_fb_secret')) { $this->view->fb_register = $this->facebook->getLoginUrl(array('redirect_uri' => WM_Router::create($request->getBaseUrl() . '?controller=facebook&action=login'), 'req_perms' => 'email,user_birthday,status_update,user_videos,user_status,user_photos,offline_access,read_friendlists')); } } if (JO_Registry::get('oauth_in_key')) { $this->view->instagram_register = WM_Router::create($this->getRequest()->getBaseUrl() . '?controller=instagram&action=register&next=' . urlencode(WM_Router::create($request->getBaseUrl() . '?controller=instagram&action=register'))); } $this->view->error = false; if ($request->isPost()) { $validate = new Helper_Validate(); $validate->_set_rules($request->getPost('username'), $this->translate('Username'), 'not_empty;min_length[3];max_length[100];username'); $validate->_set_rules($request->getPost('firstname'), $this->translate('First name'), 'not_empty;min_length[3];max_length[100]'); //$validate->_set_rules($request->getPost('lastname'), $this->translate('Last name'), 'not_empty;min_length[3];max_length[100]'); $validate->_set_rules($request->getPost('email'), $this->translate('Email'), 'not_empty;min_length[5];max_length[100];email'); $validate->_set_rules($request->getPost('password'), $this->translate('Password'), 'not_empty;min_length[4];max_length[30]'); $validate->_set_rules($request->getPost('password2'), $this->translate('Confirm password'), 'not_empty;min_length[4];max_length[30]'); if (!isset($_SESSION['token'])) { if ($request->issetPost('type_user')) { if ($request->getPost('type_user') != 1 && $request->getPost('type_user') != 5 && $request->getPost('type_user') != 12) { $validate->_set_rules($request->getPost('location'), $this->translate('Location'), 'not_empty;min_length[3];max_length[100]'); } } //is_nan() sino /* if($request->getPost('sport_category_1') == "" && $request->getPost('sport_category_2') == "" && $request->getPost('sport_category_3') == "") { $validate->_set_rules($request->getPost('sport_category'), $this->translate('Category_id'), 'not_empty;min_length[3];max_length[100]'); } */ $validate->_set_rules($request->getPost('sports'), $this->translate('Category_id1'), 'not_empty;min_length[3];max_length[100]'); //$validate->_set_rules($request->getPost('sport_category_2'), $this->translate('Category_id2'), 'not_empty;min_length[3];max_length[100]'); //$validate->_set_rules($request->getPost('sport_category_3'), $this->translate('Category_id3'), 'not_empty;min_length[3];max_length[100]'); $validate->_set_rules($request->getPost('type_user'), $this->translate('User_type_id'), 'not_empty;min_length[1];max_length[100]'); } if ($validate->_valid_form()) { if (md5($request->getPost('password')) != md5($request->getPost('password2'))) { $validate->_set_form_errors($this->translate('Password and Confirm Password should be the same')); $validate->_set_valid_form(false); } if (Model_Users::isExistEmail($request->getPost('email'))) { $validate->_set_form_errors($this->translate('This e-mail address is already used')); $validate->_set_valid_form(false); } if (Model_Users::isExistUsername($request->getPost('username'))) { $validate->_set_form_errors($this->translate('This username is already used')); $validate->_set_valid_form(false); } } if ($validate->_valid_form()) { $reg_key = sha1($request->getPost('email') . $request->getPost('username')); $lat = $request->getPost('lat'); $len = $request->getPost('len'); /* while (Model_Users::getUsersLatLen($lat, $len)) { $posLat = strpos($lat, "."); $longLat = strlen(substr((string) $lat, $posLat)); $cantLat = 0; for ($i = 0; $i < ($longLat - 4); $i++) { if ($i == 0) { $cantLat .= ".0"; } else { $cantLat .= "0"; } } $cantLat .= "1"; $lat = $lat + $cantLat; $posLen = strpos($len, "."); $longLen = strlen(substr((string) $len, $posLen)); $cantLen = 0; for ($i = 0; $i < ($longLen - 4); $i++) { if ($i == 0) { $cantLen .= ".0"; } else { $cantLen .= "0"; } } $cantLen .= "1"; $len = $len + $cantLen; } */ $result = Model_Users::create(array('username' => $request->getPost('username'), 'firstname' => $request->getPost('firstname'), 'lastname' => $request->getPost('lastname'), 'email' => $request->getPost('email'), 'password' => $request->getPost('password'), 'delete_email' => isset($shared_content['email']) ? $shared_content['email'] : '', 'delete_code' => isset($shared_content['if_id']) ? $shared_content['if_id'] : '', 'following_user' => isset($shared_content['user_id']) ? $shared_content['user_id'] : '', 'facebook_id' => isset($shared_content['facebook_id']) ? $shared_content['facebook_id'] : 0, 'location' => $request->getPost('location') != "Introduce una ubicaciĆ³n" ? $request->getPost('location') : "", 'sport_category_1' => $request->getPost('sport_category_1'), 'sport_category_2' => $request->getPost('sport_category_2'), 'sport_category_3' => $request->getPost('sport_category_3'), 'type_user' => $request->getPost('type_user'), 'lat' => $lat, 'len' => $len, 'confirmed' => '0', 'regkey' => $reg_key)); if ($result) { for ($i = 0; $i <= $request->getPost('locationcounter'); $i++) { $location = 'location' . $i; $lat = 'lat' . $i; $len = 'len' . $i; if ($request->issetPost($location)) { if ($request->getPost($location) != "") { $lat = $request->getPost($lat); $len = $request->getPost($len); /* while (Model_Users::getLocationUsersLatLen($lat, $len)) { $posLat = strpos($lat, "."); $longLat = strlen(substr((string) $lat, $posLat)); $cantLat = 0; for ($x = 0; $x < ($longLat - 4); $x++) { if ($x == 0) { $cantLat .= ".0"; } else { $cantLat .= "0"; } } $cantLat .= "1"; $lat = $lat + $cantLat; $posLen = strpos($len, "."); $longLen = strlen(substr((string) $len, $posLen)); $cantLen = 0; for ($y = 0; $y < ($longLen - 4); $y++) { if ($y == 0) { $cantLen .= ".0"; } else { $cantLen .= "0"; } } $cantLen .= "1"; $len = $len + $cantLen; } */ if (Model_Users::createUsersLocation($result, $request->getPost($location), $lat, $len)) { } } } } if (Model_Users::editUserSports($result)) { } if (self::sendMail($result)) { self::loginInit($result); } } else { $this->view->error = $this->translate('There was a problem with the record. Please try again!'); } } else { $this->view->error = $validate->_get_error_messages(); } } $this->view->baseUrl = $request->getBaseUrl(); if ($request->issetPost('email')) { $this->view->email = $request->getPost('email'); } else { if (isset($shared_content['email'])) { $this->view->email = $shared_content['email']; } else { $this->view->email = ''; } } if ($request->issetPost('firstname')) { $this->view->firstname = $request->getPost('firstname'); } else { $this->view->firstname = ''; } if ($request->issetPost('lastname')) { $this->view->lastname = $request->getPost('lastname'); } else { $this->view->lastname = ''; } if ($request->issetPost('username')) { $this->view->username = $request->getPost('username'); } else { $this->view->username = ''; } $this->view->password = $request->getPost('password'); $this->view->password2 = $request->getPost('password2'); $this->view->location = ''; if ($request->issetPost('location')) { $this->view->location = $request->getPost('location'); } else { $this->view->location = ''; } //lat $this->view->lat = ''; if ($request->issetPost('lat')) { $this->view->lat = $request->getPost('lat'); } else { $this->view->lat = ''; } //len $this->view->len = ''; if ($request->issetPost('len')) { $this->view->len = $request->getPost('len'); } else { $this->view->len = ''; } $this->view->cat_title1 = ''; $this->view->sport_category_1 = ''; if ($request->issetPost('sport_category_1')) { $this->view->sport_category_1 = $request->getPost('sport_category_1'); if ($request->getPost('sport_category_1') != "") { if ($request->getPost('sport_category_1') == 1) { $this->view->cat_title1 = "Todo"; } else { $this->view->cat_title1 = Model_Boards::getCategoryTitle($request->getPost('sport_category_1')); } } } else { $this->view->sport_category_1 = ''; } $this->view->cat_title2 = ''; $this->view->sport_category_2 = ''; if ($request->issetPost('sport_category_2')) { $this->view->sport_category_2 = $request->getPost('sport_category_2'); if ($request->getPost('sport_category_2') != "") { if ($request->getPost('sport_category_2') == 1) { $this->view->cat_title2 = "Todo"; } else { $this->view->cat_title2 = Model_Boards::getCategoryTitle($request->getPost('sport_category_2')); } } } else { $this->view->sport_category_2 = ''; } $this->view->cat_title3 = ''; $this->view->sport_category_3 = ''; if ($request->issetPost('sport_category_3')) { $this->view->sport_category_3 = $request->getPost('sport_category_3'); if ($request->getPost('sport_category_3') != "") { if ($request->getPost('sport_category_3') == 1) { $this->view->cat_title3 = "Todo"; } else { $this->view->cat_title3 = Model_Boards::getCategoryTitle($request->getPost('sport_category_3')); } } } else { $this->view->sport_category_3 = ''; } $this->view->usertype_title = ''; $this->view->type_user = ''; if ($request->issetPost('type_user')) { $this->view->type_user = $request->getPost('type_user'); if ($request->getPost('type_user') != "") { $this->view->usertype_title = Model_Users::getUserTypeTitle($request->getPost('type_user')); } } else { $this->view->type_user = ''; } //////////// User location //////////// $this->view->user_location = array(); $this->view->locationcounter = 0; if ($request->issetPost('location1')) { $user_location = array(); for ($i = 1; $i <= $request->getPost('locationcounter'); $i++) { $location = 'location' . $i; $lat = 'lat' . $i; $len = 'len' . $i; if ($request->issetPost($location)) { if ($request->getPost($location) != "") { $user_location[] = $request->getPost($location); } } } $this->view->user_location = $user_location; $this->view->locationcounter = $request->getPost('locationcounter'); } else { $this->view->locationcounter = 0; } // si llama a los deportes if (isset($_SESSION["email"])) { $this->view->email = $_SESSION["email"]; $_SESSION["email"] = null; } if (isset($_SESSION["firstname"])) { $this->view->firstname = $_SESSION["firstname"]; $_SESSION["firstname"] = null; } if (isset($_SESSION["username"])) { $this->view->username = $_SESSION["username"]; $_SESSION["username"] = null; } if (isset($_SESSION["password"])) { $this->view->password = $_SESSION["password"]; $_SESSION["password"] = null; } if (isset($_SESSION["password2"])) { $this->view->password2 = $_SESSION["password2"]; $_SESSION["password2"] = null; } if (isset($_SESSION["location"])) { $this->view->location = $_SESSION["location"]; $_SESSION["location"] = null; } if (isset($_SESSION["lat"])) { $this->view->lat = $_SESSION["lat"]; $_SESSION["lat"] = null; } if (isset($_SESSION["len"])) { $this->view->len = $_SESSION["len"]; $_SESSION["len"] = null; } if (isset($_SESSION["type_user"])) { if ($_SESSION["type_user"] != "") { $this->view->type_user = $_SESSION["type_user"]; $this->view->usertype_title = Model_Users::getUserTypeTitle($_SESSION["type_user"]); } $_SESSION["type_user"] = null; } if (isset($_SESSION["location1"])) { $user_location = array(); for ($i = 1; $i <= $_SESSION['locationcounter']; $i++) { $location = 'location' . $i; $lat = 'lat' . $i; $len = 'len' . $i; if (isset($_SESSION[$location])) { if ($_SESSION[$location] != "") { $user_location[] = $_SESSION[$location]; $_SESSION[$location] = null; } } } $this->view->user_location = $user_location; $this->view->locationcounter = $_SESSION['locationcounter']; $_SESSION['locationcounter'] = null; } $this->view->children = array('header_part' => 'layout/header_part', 'footer_part' => 'layout/footer_part'); }