Файл: oc-includes/osclass/controller/register.php
Строк: 149
<?php if ( !defined('ABS_PATH') ) exit('ABS_PATH is not loaded. Direct access is not allowed.');
/*
* Copyright 2014 Osclass
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
class CWebRegister extends BaseModel
{
function __construct()
{
parent::__construct();
if( !osc_users_enabled() ) {
osc_add_flash_error_message( _m('Users not enabled') );
$this->redirectTo( osc_base_url() );
}
if( !osc_user_registration_enabled() ) {
osc_add_flash_error_message( _m('User registration is not enabled') );
$this->redirectTo( osc_base_url() );
}
if( osc_is_web_user_logged_in() ) {
$this->redirectTo( osc_base_url() );
}
}
function doModel()
{
switch( $this->action ) {
case('register'): //register user
$this->doView('user-register.php');
break;
case('register_post'): //register user
osc_csrf_check();
if( !osc_users_enabled() ) {
osc_add_flash_error_message( _m('Users are not enabled') );
$this->redirectTo( osc_base_url() );
}
osc_run_hook('before_user_register');
$banned = osc_is_banned(Params::getParam('s_email'));
if($banned==1) {
osc_add_flash_error_message( _m('Your current email is not allowed'));
$this->redirectTo(osc_register_account_url());
} else if($banned==2) {
osc_add_flash_error_message( _m('Your current IP is not allowed'));
$this->redirectTo(osc_register_account_url());
}
require_once LIB_PATH . 'osclass/UserActions.php';
$userActions = new UserActions(false);
$success = $userActions->add();
if($success==1) {
osc_add_flash_ok_message( _m('The user has been created. An activation email has been sent'));
$this->redirectTo(osc_base_url());
} else if($success==2) {
osc_add_flash_ok_message( _m('Your account has been created successfully'));
Params::setParam('action', 'login_post');
Params::setParam('email', Params::getParam('s_email'));
Params::setParam('password', Params::getParam('s_password', false, false));
require_once(osc_lib_path() . 'osclass/controller/login.php');
$do = new CWebLogin();
$do->doModel();
} else {
osc_add_flash_error_message($success);
$this->redirectTo(osc_register_account_url());
}
break;
case('validate'): //validate account
$id = intval( Params::getParam('id') );
$code = Params::getParam('code');
$userManager = new User();
$user = $userManager->findByIdSecret($id, $code);
if ( !$user ) {
osc_add_flash_error_message( _m('The link is not valid anymore. Sorry for the inconvenience!') );
$this->redirectTo( osc_base_url() );
}
if ( $user['b_active'] == 1 ) {
osc_add_flash_error_message( _m('Your account has already been validated'));
$this->redirectTo( osc_base_url() );
}
$userManager = new User();
$success = $userManager->update(
array('b_active' => '1')
,array('pk_i_id' => $id, 's_secret' => $code)
);
if($success) {
// Auto-login
Session::newInstance()->_set('userId', $user['pk_i_id']);
Session::newInstance()->_set('userName', $user['s_name']);
Session::newInstance()->_set('userEmail', $user['s_email']);
$phone = ($user['s_phone_mobile']) ? $user['s_phone_mobile'] : $user['s_phone_land'];
Session::newInstance()->_set('userPhone', $phone);
osc_run_hook('hook_email_user_registration', $user);
osc_run_hook('validate_user', $user);
osc_add_flash_ok_message( _m('Your account has been validated'));
} else {
osc_add_flash_ok_message( _m('Account validation failed'));
}
$this->redirectTo( osc_base_url() );
break;
}
}
function doView($file)
{
osc_run_hook( 'before_html' );
osc_current_web_theme_path( $file );
Session::newInstance()->_clearVariables();
osc_run_hook( 'after_html' );
}
}
/* file end: ./register.php */
?>