verifyFeature( 'users_allow_register' ); if( $gBitUser->isRegistered() ) { $url = $gBitSystem->getDefaultPage(); header( 'Location: '.$url ); exit; } if( isset( $_REQUEST["register"] ) ) { $reg = $_REQUEST; // novalidation is set to yes if a user confirms his email is correct after tiki fails to validate it if( $gBitSystem->isFeatureActive( 'users_random_number_reg' ) ) { if( (empty( $reg['novalidation'] ) || $reg['novalidation'] != 'yes') && (!isset( $_SESSION['random_number'] ) || $_SESSION['random_number']!=$reg['regcode'])) { $errors['users_random_number_reg'] = "Wrong registration code"; } } // Check the mode if( $gBitSystem->isFeatureActive( 'users_register_passcode' ) ) { if( $reg["passcode"] != $gBitSystem->getConfig( "users_register_passcode",md5( $gBitUser->genPass() ) ) ) { $errors['passcode'] = 'Wrong passcode! You need to know the passcode to register at this site'; } } if( empty( $errors ) ) { $newUser = new BitPermUser(); if( $newUser->register( $reg ) ) { if ( !empty( $_REQUEST['group'] ) ) { $groupInfo = $gBitUser->getGroupInfo( $_REQUEST['group'] ); if ( empty($groupInfo) || $groupInfo['is_public'] != 'y' ) { $errors[] = "You can't use this group"; $gBitSmarty->assign_by_ref( 'errors', $errors ); } else { $userId = $newUser->getUserId(); $gBitUser->addUserToGroup( $userId, $_REQUEST['group'] ); $gBitUser->storeUserDefaultGroup( $userId, $_REQUEST['group'] ); $gBitUser->loadPermissions(); } } if( $gBitSystem->isFeatureActive( 'users_validate_user' ) ) { $gBitSmarty->assign('msg',tra('You will receive an email with information to login for the first time into this site')); $gBitSmarty->assign('showmsg','y'); } else { if( !empty( $_SESSION['loginfrom'] ) ) { unset( $_SESSION['loginfrom'] ); } $url = $newUser->login( $reg['login'], $reg['password'], FALSE, FALSE ); if ( !empty( $_REQUEST['group'] ) && !empty( $groupInfo['after_registration_page'] ) ) { if ( $newUser->verifyId( $groupInfo['after_registration_page'] ) ) { $url = BIT_ROOT_URL."index.php?content_id=".$groupInfo['after_registration_page']; } elseif( strpos( $groupInfo['after_registration_page'], '/' ) === FALSE ) { $url = BitPage::getDisplayUrl( $groupInfo['after_registration_page'] ); } else { $url = $groupInfo['after_registration_page']; } } header( 'Location: '.$url ); exit; } } else { $gBitSmarty->assign_by_ref( 'errors', $newUser->mErrors ); } } else { $gBitSmarty->assign_by_ref( 'errors', $errors ); } $gBitSmarty->assign_by_ref( 'reg', $reg ); } else { if( $gBitSystem->isFeatureActive( 'custom_user_fields' ) ) { $fields= explode( ',', $gBitSystem->getConfig( 'custom_user_fields' ) ); trim_array( $fields ); $gBitSmarty->assign('customFields', $fields); } } $languages = array(); $languages = $gBitLanguage->listLanguages(); $gBitSmarty->assign_by_ref('languages', $languages); $gBitSmarty->assign_by_ref('gBitLanguage', $gBitLanguage); // Get flags here $flags = array(); $h = opendir( USERS_PKG_PATH.'icons/flags/' ); while ($file = readdir($h)) { if (strstr($file, ".gif")) { $parts = explode('.', $file); $flags[] = $parts[0]; } } closedir ($h); sort ($flags); $gBitSmarty->assign('flags', $flags); $listHash = array( 'is_public'=>'y', 'sort_mode'=>array('is_default_asc' , 'group_desc_asc') ); $groupList = $gBitUser->getAllGroups( $listHash ); if ( $groupList['cant'] ) { $gBitSmarty->assign_by_ref( 'groupList', $groupList['data'] ); } $gBitSystem->display('bitpackage:users/register.tpl', 'Register' ); ?>