Question

Je suis en train de faire travailler des itinéraires personnalisés dans mon application Rails (Ruby 1.9.2 avec Rails 3).

Ceci est mon fichier config / routes.rb

match '/dashboard' => 'home#dashboard', :as => 'user_root'
devise_for :user do
   get "/login", :to => "devise/sessions#new" # Add a custom sign in route for user sign in
   get "/logout", :to => "devise/sessions#destroy" # Add a custom sing out route for user sign out
   get "/register", :to => "devise/registrations#new" # Add a Custom Route for Registrations
end

Mais en soumettant le formulaire de connexion / ou / registre va aux utilisateurs / sign_in et les utilisateurs / sign_up. Comment empêcher que cela se produise. Ou mieux encore assurez-vous que par défaut pour toutes les demandes etc utilisateurs / sign_in vont aux routes pertinentes et non les routes par défaut générés par legs.

Aussi comment puis-je faire la connexion sous forme d'une partie de l'inclure dans un contrôleur? Alors que je peux avoir la page de connexion sur la page d'accueil (accueil index #) et non sur les utilisateurs / sign_in?

J'utilise avec Rails 1.1.3 Devise 3 sur Ruby 1.9.2, sur Mac OS X Snow Leopard.

Merci!

Était-ce utile?

La solution

Avec ce qui suit 1.1.3 Devise devrait fonctionner

devise_for :user, :path => '', :path_names => { :sign_in => "login", :sign_out => "logout", :sign_up => "register" }

Les itinéraires qu'il crée ne sera pas ajouté avec « / user / ... » en raison du paramètre :path étant une chaîne vide. Le hachage :pathnames prendra soin de nommer les routes que vous le souhaitez. Utilisera ces legs routes en interne afin de soumettre à / connexion fonctionnera comme vous le souhaitez et non vous amène à / user / log_in

Pour ajouter un formulaire de connexion à votre page d'accueil, il y a d'infos sur le Wiki Devise: http: //github.com/plataformatec/devise/wiki/How-To:-Display-a-custom-sign_in-form-anywhere-in-your-app

Ou faire quelque chose comme ceci:

 <%= form_tag new_user_session_path do %>
  <%= text_field_tag 'user[email]' %>
  <%= password_field_tag 'user[password]' %>
 <%=  submit_tag 'Login' %>

Autres conseils

Le suivant a fonctionné pour moi:

  devise_for :users do
    get "/login" => "devise/sessions#new"
    get "/register" => "devise/registrations#new"
  end

Il vous suffit de ne pas mettre votre itinéraire spécial dans devise_for bloc

match '/dashboard' => 'home#dashboard', :as => 'user_root'
get "/login", :to => "devise/sessions#new" # Add a custom sign in route for user sign in
get "/logout", :to => "devise/sessions#destroy" # Add a custom sing out route for user sign out
get "/register", :to => "devise/registrations#new" # Add a Custom Route for Registrations
devise_for :user

/ login fonctionne. / Utilisateurs / sign_in aussi.

Config:

  devise_scope :user do
    get 'profile/edit'    => 'devise/registrations#edit',   :as => :edit_user_registration
    get 'profile/cancel'  => 'devise/registrations#cancel', :as => :cancel_user_registration
  end

  devise_for  :users,
              :path => '',
              :path_names => {  :sign_in =>       'login',
                                :sign_out =>      'logout',
                                :sign_up =>       '',
                                :registration =>  'register',
                                :edit =>          'edit',
                                :cancel =>        'cancel',
                                :confirmation =>  'verification'  }

Routes:

  edit_user_registration GET    /profile/edit(.:format)      devise/registrations#edit
cancel_user_registration GET    /profile/cancel(.:format)    devise/registrations#cancel
        new_user_session GET    /login(.:format)             devise/sessions#new
            user_session POST   /login(.:format)             devise/sessions#create
    destroy_user_session DELETE /logout(.:format)            devise/sessions#destroy
           user_password POST   /password(.:format)          devise/passwords#create
       new_user_password GET    /password/new(.:format)      devise/passwords#new
      edit_user_password GET    /password/edit(.:format)     devise/passwords#edit
                         PATCH  /password(.:format)          devise/passwords#update
                         PUT    /password(.:format)          devise/passwords#update
                         GET    /register/cancel(.:format)   registrations#cancel
       user_registration POST   /register(.:format)          registrations#create
   new_user_registration GET    /register(.:format)          registrations#new
                         GET    /register/edit(.:format)     registrations#edit
                         PATCH  /register(.:format)          registrations#update
                         PUT    /register(.:format)          registrations#update
                         DELETE /register(.:format)          registrations#destroy

J'ai créé mon propre contrôleur auth et contrôleur de sessions routé Concevoir à mon contrôleur

devise_for :users, 
:controllers => {
    :sessions => 'auth' },

:path => '/',

:path_names => {
    :sign_in  => 'login',
    :sign_out => 'logout' }

Ce code va ajouter / login et / fermeture de session urls.

En savoir plus sur ce que vous pouvez trouver dans le code source http : //github.com/plataformatec/devise/blob/master/lib/devise/rails/routes.rb

Utilisez ce en haut de votre fichier routes.rb

map.connect "users/:action", :controller => 'users', :action => /[a-z]+/i 

utiliser sur l'endroit où votre fichier d'index est. si elle est sur votre modèle de l'utilisateur, utilisez ce qui précède ou le changement en conséquence

Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top