Вход Регистрация
Файл: 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->redirectToosc_base_url() );
            }

            if( !
osc_user_registration_enabled() ) {
                
osc_add_flash_error_message_m('User registration is not enabled') );
                
$this->redirectToosc_base_url() );
            }

            if( 
osc_is_web_user_logged_in() ) {
                
$this->redirectToosc_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->redirectToosc_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'falsefalse));
                                            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          intvalParams::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->redirectToosc_base_url() );
                                        }

                                        if ( 
$user['b_active'] == ) {
                                            
osc_add_flash_error_message_m('Your account has already been validated'));
                                            
$this->redirectToosc_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->redirectToosc_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 */
?>
Онлайн: 1
Реклама