Module: Studio
- Defined in:
- lib/studio.rb,
lib/studio/s3.rb,
lib/studio/engine.rb,
lib/studio/version.rb,
lib/studio/color_scale.rb,
lib/studio/image_cache.rb,
lib/studio/theme_resolver.rb,
lib/studio/username_generator.rb,
app/controllers/concerns/studio/error_handling.rb
Defined Under Namespace
Modules: ColorScale, ErrorHandling, ImageCache, S3 Classes: Engine, S3ConfigError, ThemeResolver, UserContractError, UsernameGenerator
Constant Summary collapse
- REQUIRED_USER_INSTANCE_METHODS =
Only methods that consumers must explicitly define are checked here. Column accessors (#email, #name, #role) are NOT validated because ActiveRecord defines them lazily — they don’t appear on ‘.instance_methods` until the schema is introspected (typically first record access). Missing columns are caught by the User table schema, not by this validator.
%i[authenticate admin? display_name].freeze
- REQUIRED_USER_CLASS_METHODS =
%i[find_by].freeze
- VERSION =
"0.4.3"
Class Method Summary collapse
- .configure {|_self| ... } ⇒ Object
-
.logo_for(title) ⇒ Object
Find a logo from theme_logos by title, with fallback chain: 1.
- .routes(router) ⇒ Object
- .theme_config ⇒ Object
-
.validate_user_contract!(user_class) ⇒ Object
Verifies that the host app’s User model satisfies the engine’s expected contract.
Class Method Details
.configure {|_self| ... } ⇒ Object
54 55 56 |
# File 'lib/studio.rb', line 54 def self.configure yield self end |
.logo_for(title) ⇒ Object
Find a logo from theme_logos by title, with fallback chain:
-
Exact title match
-
“Navbar Logo” fallback
-
First logo in the list
106 107 108 109 110 111 112 |
# File 'lib/studio.rb', line 106 def self.logo_for(title) logos = theme_logos.map { |l| l.is_a?(Hash) ? l : { file: l, title: l } } entry = logos.find { |l| l[:title] == title } entry ||= logos.find { |l| l[:title] == "Navbar Logo" } entry ||= logos.first entry ? "/#{entry[:file]}" : nil end |
.routes(router) ⇒ Object
114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 |
# File 'lib/studio.rb', line 114 def self.routes(router) router.instance_exec do get "login", to: "sessions#new" post "login", to: "sessions#create" post "sso_continue", to: "sessions#sso_continue" get "sso_login", to: "sessions#sso_login" get "logout", to: "sessions#destroy" get "signup", to: "registrations#new" post "signup", to: "registrations#create" get "auth/:provider/callback", to: "omniauth_callbacks#create" get "auth/failure", to: "omniauth_callbacks#failure" resources :error_logs, only: [:index, :show] # Admin get "admin/theme", to: "theme_settings#edit", as: :admin_theme patch "admin/theme", to: "theme_settings#update", as: :admin_theme_update post "admin/theme/regenerate", to: "theme_settings#regenerate", as: :admin_theme_regenerate get "admin/schema", to: "schema#index", as: :admin_schema end end |
.theme_config ⇒ Object
90 91 92 93 94 95 96 97 98 99 100 |
# File 'lib/studio.rb', line 90 def self.theme_config { primary: theme_primary, dark: theme_dark, light: theme_light, success: theme_success, warning: theme_warning, danger: theme_danger, accent: theme_accent }.compact end |
.validate_user_contract!(user_class) ⇒ Object
Verifies that the host app’s User model satisfies the engine’s expected contract. Raises Studio::UserContractError with a clear pointer to docs/USER_CONTRACT.md if anything required is missing. Called from Engine#after_initialize. Opt out via Studio.validate_user_contract = false.
62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 |
# File 'lib/studio.rb', line 62 def self.validate_user_contract!(user_class) return unless validate_user_contract return unless user_class.is_a?(Class) missing = [] REQUIRED_USER_CLASS_METHODS.each do |m| missing << "User.#{m}" unless user_class.respond_to?(m) end REQUIRED_USER_INSTANCE_METHODS.each do |m| missing << "User##{m}" unless user_class.instance_methods.include?(m) end return if missing.empty? raise UserContractError, <<~MSG The studio-engine gem's expected User model contract is not satisfied. Missing: #{missing.join(", ")} See the USER_CONTRACT.md doc in the studio-engine repo for the full contract + a minimal compliant example: https://github.com/amcritchie/studio-engine/blob/main/docs/USER_CONTRACT.md To bypass this check temporarily, set Studio.validate_user_contract = false in config/initializers/studio.rb. MSG end |