public function post_create() { $messages = array('valid_uuid' => __('users::lang.Invalid UUID')->get(ADM_LANG), 'unique_avatar_name' => __('users::lang.This combination of avatar first name and avatar last name is already in use')->get(ADM_LANG)); Validator::register('valid_uuid', function ($attribute, $value, $parameters) { return (bool) preg_match('#^[a-z0-9]{8}-[a-z0-9]{4}-[a-z0-9]{4}-[a-z0-9]{4}-[a-z0-9]{12}$#', $value); }); Validator::register('unique_avatar_name', function ($attribute, $value, $parameters) { $user = Users\Model\User::where('avatar_first_name', '=', Input::get('avatar_first_name'))->where('avatar_last_name', '=', Input::get('avatar_last_name'))->first(); if (isset($user) and !empty($user)) { return false; } return true; }); $rules = array('uuid' => 'required|min:3|max:50|valid_uuid|unique:users', 'username' => 'required|min:3|max:50|alpha_dash|unique:users', 'avatar_first_name' => 'required|min:3|max:50', 'avatar_last_name' => 'required|min:3|max:50|unique_avatar_name', 'email' => 'required|email|unique:users', 'status' => 'required', 'password' => 'required|min:8'); $validation = Validator::make(Input::all(), $rules, $messages)->speaks(ADM_LANG); if ($validation->passes()) { $group_id = Input::get('group_id'); if (!isset($group_id) or empty($group_id)) { $group_id = 0; } $password = Users\Helper::hash_password(Input::get('password')); $new_user = new Users\Model\User(); $new_user->uuid = Input::get('uuid'); $new_user->username = Input::get('username'); $new_user->avatar_first_name = Input::get('avatar_first_name'); $new_user->avatar_last_name = Input::get('avatar_last_name'); $new_user->email = Input::get('email'); $new_user->status = Input::get('status'); $new_user->password = Hash::make(Input::get('password')); $new_user->hash = $password['hash']; $new_user->salt = $password['salt']; $new_user->group_id = $group_id; $new_user->save(); Event::fire('users.created', array($new_user)); if ($new_user->status == 'active') { Event::fire('users.activated', array($new_user)); } $this->data['message'] = __('users::lang.User was successfully created')->get(ADM_LANG); $this->data['message_type'] = 'success'; return Redirect::to(ADM_URI . '/users')->with($this->data); } else { return Redirect::to(ADM_URI . '/users/new')->with_errors($validation)->with_input(); } }
public function post_create() { $messages = array('unique_avatar_name' => 'This combination of avatar first name and avatar last name has already been taken.'); $rules = array('email' => 'required|email|unique:users', 'username' => 'required|unique:users|alpha_dash|max:30|min:3', 'avatar_first_name' => 'required|alpha_dash|max:30|min:3|unique_avatar_name', 'avatar_last_name' => 'required|alpha_dash|max:30|min:3', 'password' => 'required|min:8', 'password_confirmation' => 'required|same:password'); Validator::register('unique_avatar_name', function ($attribute, $value, $parameters) { $user = Users\Model\User::where('avatar_first_name', '=', Input::get('avatar_first_name'))->where('avatar_last_name', '=', Input::get('avatar_last_name'))->first(); if (isset($user) and !empty($user)) { return false; } return true; }); $validation = Validator::make(Input::all(), $rules, $messages); if ($validation->passes()) { $group_id = 0; if (Bundle::exists('groups')) { $users_group = Groups\Model\Group::where('slug', '=', 'users')->first(); if (isset($users_group->id) and ctype_digit($users_group->id)) { $group_id = $users_group->id; } } $new_user = new Users\Model\User(); $new_user->status = 'inactive'; $require_confirmation = Config::get('settings::core.registration_confirmation_required'); if ($require_confirmation == 'no') { $new_user->status = 'active'; } $password = Users\Helper::hash_password(Input::get('password')); $new_user->uuid = Mwi_Core::random_uuid(); $new_user->email = Input::get('email'); $new_user->username = Input::get('username'); $new_user->avatar_first_name = Input::get('avatar_first_name'); $new_user->avatar_last_name = Input::get('avatar_last_name'); $new_user->group_id = $group_id; $new_user->hash = $password['hash']; $new_user->salt = $password['salt']; $new_user->password = Hash::make(Input::get('password')); $new_user->save(); Event::fire('registration.user_signup', array($new_user)); //Event for Robust Event::fire('users.created', array($new_user)); if ($require_confirmation == 'no') { Auth::login($new_user->id); Event::fire('registration.user_activated', array($new_user)); //Event for Robust Event::fire('users.updated', array($new_user)); $site_name = Settings\Config::get('settings::core.site_name'); $this->data['message'] = Lang::line('registration::lang.welcome_signup', array('site_name' => $site_name))->get(APP_LANG); $this->data['message_type'] = 'success'; return Redirect::to('page/home')->with($this->data); } else { // save activation record on database $activation_record = new Registration\Model\Code(); $activation_record->user_id = $new_user->id; $activation_record->code = Mwi_Core::keygen(); $activation_record->save(); // new xblade to parse the email template $xblade = new Xblade(); $xblade->scopeGlue(':'); // data to be passed to email template $data['user'] = $new_user; $data['activation_code'] = $activation_record->code; $data['url']['base'] = URL::base(); $data['settings']['site_name'] = Config::get('settings::core.site_name'); $data['request']['ip'] = Request::ip(); $data['request']['user_agent'] = implode(', ', Request::header('user-agent')); $data['request']['languages'] = implode(', ', Request::languages()); // get email template based on settings $email_address = Config::get('settings::core.server_email'); $template_id = Config::get('settings::core.registration_email_template'); $email_data = Email\Model\Template::find($template_id); //send email to user Email\Message::to($new_user->email)->from($email_address)->subject($xblade->parse($email_data->subject, $data))->body($xblade->parse($email_data->body, $data))->html($email_data->type)->send(); $this->data['message'] = __('registration::lang.Thank you Please check your email to activate your new account')->get(APP_LANG); $this->data['message_type'] = 'success'; return Redirect::to('page/home')->with($this->data); } } return Redirect::to('signup')->with_errors($validation)->with_input(); }