Class: Caboose::RegisterController
- Inherits:
-
ApplicationController
- Object
- ActionController::Base
- ApplicationController
- Caboose::RegisterController
- Defined in:
- app/controllers/caboose/register_controller.rb
Instance Method Summary collapse
-
#index ⇒ Object
GET /register.
-
#register ⇒ Object
POST /register.
Methods inherited from ApplicationController
#admin_add, #admin_bulk_add, #admin_bulk_delete, #admin_bulk_update, #admin_delete, #admin_edit, #admin_index, #admin_json, #admin_json_single, #admin_update, #before_action, #before_before_action, #hashify_query_string, #init_cart, #logged_in?, #logged_in_user, #login_user, #logout_user, #parse_url_params, #reject_param, #user_is_allowed, #user_is_allowed_to, #validate_cookie, #validate_token, #var, #verify_logged_in
Instance Method Details
#index ⇒ Object
GET /register
6 7 8 9 10 11 |
# File 'app/controllers/caboose/register_controller.rb', line 6 def index @return_url = params[:return_url].nil? ? "/" : params[:return_url]; @modal = params[:modal].nil? ? false : params[:modal] redirect_to @return_url if logged_in? render :layout => Caboose::register_layout end |
#register ⇒ Object
POST /register
14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 |
# File 'app/controllers/caboose/register_controller.rb', line 14 def register resp = StdClass.new('error' => '', 'redirect' => '') return_url = params[:return_url].nil? ? "/" : params[:return_url]; if (logged_in?) resp.error = "Already logged in" else first_name = params[:first_name] last_name = params[:last_name] email = params[:email] phone = params[:phone] pass1 = params[:pass1] pass2 = params[:pass2] if first_name.nil? || first_name.strip.length == 0 then resp.error = "Your first name is required." elsif last_name.nil? || last_name.strip.length == 0 then resp.error = "Your last name is required." elsif email.nil? || email.strip.length == 0 then resp.error = "Your email address is required." elsif User.where(:email => email.strip.downcase).exists? then resp.error = "A user with that email address already exists." elsif phone.nil? || phone.strip.length < 10 then resp.error = "Your phone number is required. Please include your area code." elsif pass1.nil? || pass1.strip.length < 8 then resp.error = "Your password must be at least 8 characters." elsif pass2.nil? || pass1 != pass2 then resp.error = "Your passwords don't match." else u = Caboose::User.new u.first_name = first_name u.last_name = last_name u.email = email.strip.downcase u.phone = phone u.password = Digest::SHA1.hexdigest(Caboose::salt + pass1) u.date_created = DateTime.now u.save # Go ahead and log the user in u = Caboose::User.find(u.id) login_user(u, true) resp.redirect = "/login?return_url=#{return_url}" end end render json: resp end |