Class: Sessions::Generators::MadminGenerator
- Inherits:
-
Rails::Generators::Base
- Object
- Rails::Generators::Base
- Sessions::Generators::MadminGenerator
- Defined in:
- lib/generators/sessions/madmin_generator.rb
Overview
‘rails generate sessions:madmin` — drop-in admin surfaces for github.com/excid3/madmin: the live session registry (with a per-row Revoke action) and the login trail with its triage scopes.
The generated files use only STOCK Madmin APIs, so they work on any Madmin install and are yours to restyle (swap in your custom fields, add member actions). Two Madmin footguns are pre-solved in the generated code: the trail’s namespaced model needs an explicit ‘resource_class_name` on its flat controller, and the events routes must be drawn BEFORE `resources :sessions` (or /sessions/events gets captured as a session id).
Instance Method Summary collapse
- #check_for_madmin! ⇒ Object
- #create_controllers ⇒ Object
- #create_resources ⇒ Object
- #display_post_install_message ⇒ Object
Instance Method Details
#check_for_madmin! ⇒ Object
23 24 25 26 27 28 29 30 31 32 33 34 |
# File 'lib/generators/sessions/madmin_generator.rb', line 23 def check_for_madmin! return if madmin_available? raise Thor::Error, <<~MSG ❌ Madmin isn't loaded in this app (gem "madmin"). This generator produces Madmin resources for the session registry and the login trail. For other admin frameworks, build on the same primitives it uses: Session.active / session.revoke! / Sessions::Event scopes (failed_logins, last_24_hours, …). MSG end |
#create_controllers ⇒ Object
41 42 43 44 |
# File 'lib/generators/sessions/madmin_generator.rb', line 41 def create_controllers template "sessions_controller.rb", "app/controllers/madmin/sessions_controller.rb" template "session_events_controller.rb", "app/controllers/madmin/session_events_controller.rb" end |
#create_resources ⇒ Object
36 37 38 39 |
# File 'lib/generators/sessions/madmin_generator.rb', line 36 def create_resources template "session_resource.rb", "app/madmin/resources/session_resource.rb" template "event_resource.rb", "app/madmin/resources/sessions/event_resource.rb" end |
#display_post_install_message ⇒ Object
46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 |
# File 'lib/generators/sessions/madmin_generator.rb', line 46 def say "\n🔐 Madmin resources for sessions installed.", :green say "\nTo complete the setup:" say " 1. Add the routes where you draw your Madmin routes" say " (config/routes/madmin.rb in most apps):" say "" say " # Login trail — drawn BEFORE `resources :sessions`, or" say " # /sessions/events would match as a session id." say " namespace :sessions do" say " resources :events, only: [ :index, :show ], controller: \"/madmin/session_events\"" say " end" say "" say " resources :sessions, only: [ :index, :show ] do" say " member do" say " post :revoke" say " end" say " end" say "\n 2. (Optional) Group them in the sidebar — both resources declare" say " `parent: \"Security\"`; pre-seed its position in an initializer:" say "" say " Madmin.menu.before_render do" say " add label: \"Security\", position: 91" say " end" say "\n 3. (Optional) For a per-user panel (devices + trail on the user's" say " show page), add a member action to your users controller that" say " loads `user.sessions.by_recency` and `user.session_history.recent`" say " — the README's Admin section has the full recipe." say "\nRevoking from the index destroys the row: that device is signed out" say "on its very next request, and the revocation lands in the trail with" say "admin attribution. 🔐\n", :green end |