diff options
author | Jonathan Seitel <jon.seitel@gmail.com> | 2013-01-31 22:23:49 -0800 |
---|---|---|
committer | Jonathan Seitel <jon.seitel@gmail.com> | 2013-01-31 22:23:49 -0800 |
commit | 636383e630967c373d762ae2475f4f4e7e05f974 (patch) | |
tree | ebb5027be81e48f0f598981adbb1f5606bdf57c4 /lib | |
parent | fe6831de448276a7a8d9aa035c8dfed1e31d546c (diff) | |
download | refinerycms-blog-636383e630967c373d762ae2475f4f4e7e05f974.tar.gz refinerycms-blog-636383e630967c373d762ae2475f4f4e7e05f974.tar.bz2 refinerycms-blog-636383e630967c373d762ae2475f4f4e7e05f974.zip |
Committing user_class to master
Diffstat (limited to 'lib')
-rw-r--r-- | lib/generators/refinery/blog/templates/config/initializers/refinery/blog.rb.erb | 3 | ||||
-rw-r--r-- | lib/refinery/blog/configuration.rb | 23 |
2 files changed, 26 insertions, 0 deletions
diff --git a/lib/generators/refinery/blog/templates/config/initializers/refinery/blog.rb.erb b/lib/generators/refinery/blog/templates/config/initializers/refinery/blog.rb.erb index 294c258..4d61e5d 100644 --- a/lib/generators/refinery/blog/templates/config/initializers/refinery/blog.rb.erb +++ b/lib/generators/refinery/blog/templates/config/initializers/refinery/blog.rb.erb @@ -10,4 +10,7 @@ Refinery::Blog.configure do |config| # config.share_this_key = <%= Refinery::Blog.share_this_key.inspect %> # config.page_url = <%= Refinery::Blog.page_url.inspect %> + + # If you're grafting onto an existing app, change this to your User class + # Refinery::Blog.user_class = <%= Refinery::Blog.user_class.inspect %> end diff --git a/lib/refinery/blog/configuration.rb b/lib/refinery/blog/configuration.rb index b7598e8..6198cb2 100644 --- a/lib/refinery/blog/configuration.rb +++ b/lib/refinery/blog/configuration.rb @@ -11,5 +11,28 @@ module Refinery self.post_teaser_length = 250 self.share_this_key = "xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx" self.page_url = "/blog" + + # Refinery::User isn't available when this line gets hit, so we use static methods instead + @@user_class_name = nil + class << self + def user_class=(class_name) + if class_name.is_a?(Class) + raise TypeError, "You can't set user_class to be a class, e.g., User. Instead, please use a string like 'User'" + elsif class_name.is_a?(String) + @@user_class_name = class_name + else + raise TypeError, "Invalid type for user_class. Please use a string like 'User'" + end + end + + def user_class + class_name = @@user_class_name || 'Refinery::User' + begin + Object.const_get(class_name) + rescue NameError + class_name.constantize + end + end + end end end |