enju_trunk_message 0.1.14.pre3
Sign up to get free protection for your applications and to get access to all the features.
- data/MIT-LICENSE +20 -0
- data/README.rdoc +3 -0
- data/Rakefile +46 -0
- data/app/controllers/message_requests_controller.rb +62 -0
- data/app/controllers/message_templates_controller.rb +17 -0
- data/app/controllers/messages_controller.rb +159 -0
- data/app/helpers/messages_helper.rb +2 -0
- data/app/models/message.rb +85 -0
- data/app/models/message_request.rb +97 -0
- data/app/models/message_template.rb +39 -0
- data/app/views/layouts/messages.html.erb +24 -0
- data/app/views/message_requests/edit.html.erb +40 -0
- data/app/views/message_requests/index.html.erb +58 -0
- data/app/views/message_requests/new.html.erb +40 -0
- data/app/views/message_requests/show.html.erb +55 -0
- data/app/views/message_templates/_form.html.erb +27 -0
- data/app/views/message_templates/edit.html.erb +13 -0
- data/app/views/message_templates/index.html.erb +44 -0
- data/app/views/message_templates/new.html.erb +12 -0
- data/app/views/message_templates/show.html.erb +33 -0
- data/app/views/messages/_form.html.erb +37 -0
- data/app/views/messages/edit.html.erb +42 -0
- data/app/views/messages/index.atom.builder +15 -0
- data/app/views/messages/index.html.erb +66 -0
- data/app/views/messages/index.rss.builder +41 -0
- data/app/views/messages/new.html.erb +43 -0
- data/app/views/messages/show.html.erb +48 -0
- data/app/views/notifier/message_notification.en.text.erb +14 -0
- data/app/views/notifier/message_notification.ja.text.erb +14 -0
- data/config/locales/translation_en.yml +51 -0
- data/config/locales/translation_ja.yml +51 -0
- data/config/routes.rb +9 -0
- data/db/fixtures/message_templates.yml +70 -0
- data/db/migrate/149_create_message_templates.rb +18 -0
- data/db/migrate/154_create_messages.rb +24 -0
- data/db/migrate/20080819181903_create_message_requests.rb +20 -0
- data/db/migrate/20110913115320_add_lft_and_rgt_to_message.rb +11 -0
- data/db/migrate/20120125050502_add_depth_to_message.rb +6 -0
- data/lib/enju_message.rb +7 -0
- data/lib/enju_message/engine.rb +10 -0
- data/lib/enju_message/user.rb +28 -0
- data/lib/enju_message/version.rb +3 -0
- data/lib/generators/enju_message/views_generator.rb +21 -0
- data/lib/tasks/enju_message_tasks.rake +5 -0
- data/spec/controllers/message_requests_controller_spec.rb +275 -0
- data/spec/controllers/message_templates_controller_spec.rb +439 -0
- data/spec/controllers/messages_controller_spec.rb +443 -0
- data/spec/dummy/Rakefile +7 -0
- data/spec/dummy/app/assets/javascripts/application.js +9 -0
- data/spec/dummy/app/assets/stylesheets/application.css +7 -0
- data/spec/dummy/app/controllers/application_controller.rb +52 -0
- data/spec/dummy/app/helpers/application_helper.rb +2 -0
- data/spec/dummy/app/mailers/notifier.rb +30 -0
- data/spec/dummy/app/models/ability.rb +30 -0
- data/spec/dummy/app/models/library_group.rb +86 -0
- data/spec/dummy/app/models/patron.rb +167 -0
- data/spec/dummy/app/models/patron_type.rb +19 -0
- data/spec/dummy/app/models/role.rb +8 -0
- data/spec/dummy/app/models/setting.rb +4 -0
- data/spec/dummy/app/models/user.rb +46 -0
- data/spec/dummy/app/models/user_group.rb +2 -0
- data/spec/dummy/app/models/user_has_role.rb +4 -0
- data/spec/dummy/app/views/layouts/application.html.erb +14 -0
- data/spec/dummy/app/views/page/403.html.erb +9 -0
- data/spec/dummy/app/views/page/403.mobile.erb +5 -0
- data/spec/dummy/app/views/page/403.xml.erb +4 -0
- data/spec/dummy/app/views/page/404.html.erb +9 -0
- data/spec/dummy/app/views/page/404.mobile.erb +5 -0
- data/spec/dummy/app/views/page/404.xml.erb +4 -0
- data/spec/dummy/config.ru +4 -0
- data/spec/dummy/config/application.rb +44 -0
- data/spec/dummy/config/application.yml +38 -0
- data/spec/dummy/config/boot.rb +10 -0
- data/spec/dummy/config/database.yml +25 -0
- data/spec/dummy/config/environment.rb +5 -0
- data/spec/dummy/config/environments/development.rb +30 -0
- data/spec/dummy/config/environments/production.rb +60 -0
- data/spec/dummy/config/environments/test.rb +39 -0
- data/spec/dummy/config/initializers/backtrace_silencers.rb +7 -0
- data/spec/dummy/config/initializers/devise.rb +205 -0
- data/spec/dummy/config/initializers/inflections.rb +10 -0
- data/spec/dummy/config/initializers/mime_types.rb +6 -0
- data/spec/dummy/config/initializers/resque_mailer.rb +1 -0
- data/spec/dummy/config/initializers/secret_token.rb +7 -0
- data/spec/dummy/config/initializers/session_store.rb +8 -0
- data/spec/dummy/config/initializers/wrap_parameters.rb +14 -0
- data/spec/dummy/config/locales/en.yml +5 -0
- data/spec/dummy/config/routes.rb +60 -0
- data/spec/dummy/db/migrate/001_create_patrons.rb +62 -0
- data/spec/dummy/db/migrate/080_create_library_groups.rb +25 -0
- data/spec/dummy/db/migrate/20080905191442_create_patron_types.rb +16 -0
- data/spec/dummy/db/migrate/20100211105551_add_admin_networks_to_library_group.rb +9 -0
- data/spec/dummy/db/migrate/20100222124420_add_allow_bookmark_external_url_to_library_group.rb +9 -0
- data/spec/dummy/db/migrate/20100527113752_create_delayed_jobs.rb +21 -0
- data/spec/dummy/db/migrate/20110115022329_add_position_to_library_group.rb +9 -0
- data/spec/dummy/db/migrate/20110222073537_add_url_to_library_group.rb +9 -0
- data/spec/dummy/db/migrate/20111020063828_remove_dsbl_from_library_group.rb +11 -0
- data/spec/dummy/db/migrate/20111201121636_create_languages.rb +16 -0
- data/spec/dummy/db/migrate/20111201121844_create_roles.rb +12 -0
- data/spec/dummy/db/migrate/20111201155456_create_users.rb +14 -0
- data/spec/dummy/db/migrate/20111201155513_add_devise_to_users.rb +52 -0
- data/spec/dummy/db/migrate/20111201163342_create_user_groups.rb +12 -0
- data/spec/dummy/db/migrate/20111201163718_create_user_has_roles.rb +10 -0
- data/spec/dummy/db/migrate/20120213092115_add_queue_to_delayed_jobs.rb +9 -0
- data/spec/dummy/db/schema.rb +236 -0
- data/spec/dummy/public/404.html +26 -0
- data/spec/dummy/public/422.html +26 -0
- data/spec/dummy/public/500.html +26 -0
- data/spec/dummy/public/favicon.ico +0 -0
- data/spec/dummy/script/delayed_job +5 -0
- data/spec/dummy/script/rails +6 -0
- data/spec/factories/message.rb +8 -0
- data/spec/factories/message_request.rb +8 -0
- data/spec/factories/message_template.rb +7 -0
- data/spec/factories/user.rb +34 -0
- data/spec/fixtures/library_groups.yml +34 -0
- data/spec/fixtures/message_requests.yml +30 -0
- data/spec/fixtures/message_templates.yml +85 -0
- data/spec/fixtures/messages.yml +62 -0
- data/spec/fixtures/patrons.yml +338 -0
- data/spec/fixtures/roles.yml +21 -0
- data/spec/fixtures/user_groups.yml +25 -0
- data/spec/fixtures/user_has_roles.yml +41 -0
- data/spec/fixtures/users.yml +71 -0
- data/spec/models/message_request_spec.rb +24 -0
- data/spec/models/message_spec.rb +59 -0
- data/spec/models/message_template_spec.rb +22 -0
- data/spec/spec_helper.rb +46 -0
- data/spec/support/controller_macros.rb +48 -0
- data/spec/support/devise.rb +4 -0
- metadata +440 -0
@@ -0,0 +1,9 @@
|
|
1
|
+
// This is a manifest file that'll be compiled into including all the files listed below.
|
2
|
+
// Add new JavaScript/Coffee code in separate files in this directory and they'll automatically
|
3
|
+
// be included in the compiled file accessible from http://example.com/assets/application.js
|
4
|
+
// It's not advisable to add code directly here, but if you do, it'll appear at the bottom of the
|
5
|
+
// the compiled file.
|
6
|
+
//
|
7
|
+
//= require jquery
|
8
|
+
//= require jquery_ujs
|
9
|
+
//= require_tree .
|
@@ -0,0 +1,7 @@
|
|
1
|
+
/*
|
2
|
+
* This is a manifest file that'll automatically include all the stylesheets available in this directory
|
3
|
+
* and any sub-directories. You're free to add application-wide styles to this file and they'll appear at
|
4
|
+
* the top of the compiled file, but it's generally better to create a new file per style scope.
|
5
|
+
*= require_self
|
6
|
+
*= require_tree .
|
7
|
+
*/
|
@@ -0,0 +1,52 @@
|
|
1
|
+
class ApplicationController < ActionController::Base
|
2
|
+
protect_from_forgery
|
3
|
+
|
4
|
+
rescue_from CanCan::AccessDenied, :with => :render_403
|
5
|
+
rescue_from ActiveRecord::RecordNotFound, :with => :render_404
|
6
|
+
|
7
|
+
private
|
8
|
+
def render_403
|
9
|
+
return if performed?
|
10
|
+
if user_signed_in?
|
11
|
+
respond_to do |format|
|
12
|
+
format.html {render :template => 'page/403', :status => 403}
|
13
|
+
format.mobile {render :template => 'page/403', :status => 403}
|
14
|
+
format.xml {render :template => 'page/403', :status => 403}
|
15
|
+
format.json
|
16
|
+
end
|
17
|
+
else
|
18
|
+
respond_to do |format|
|
19
|
+
format.html {redirect_to new_user_session_url}
|
20
|
+
format.mobile {redirect_to new_user_session_url}
|
21
|
+
format.xml {render :template => 'page/403', :status => 403}
|
22
|
+
format.json
|
23
|
+
end
|
24
|
+
end
|
25
|
+
end
|
26
|
+
|
27
|
+
def render_404
|
28
|
+
return if performed?
|
29
|
+
respond_to do |format|
|
30
|
+
format.html {render :template => 'page/404', :status => 404}
|
31
|
+
format.mobile {render :template => 'page/404', :status => 404}
|
32
|
+
format.xml {render :template => 'page/404', :status => 404}
|
33
|
+
format.json
|
34
|
+
end
|
35
|
+
end
|
36
|
+
|
37
|
+
def get_user
|
38
|
+
@user = User.where(:username => params[:user_id]).first if params[:user_id]
|
39
|
+
end
|
40
|
+
|
41
|
+
def solr_commit
|
42
|
+
Sunspot.commit
|
43
|
+
end
|
44
|
+
|
45
|
+
def move_position(resource, direction)
|
46
|
+
if ['higher', 'lower'].include?(direction)
|
47
|
+
resource.send("move_#{direction}")
|
48
|
+
redirect_to url_for(:controller => resource.class.to_s.pluralize.underscore)
|
49
|
+
return
|
50
|
+
end
|
51
|
+
end
|
52
|
+
end
|
@@ -0,0 +1,30 @@
|
|
1
|
+
class Notifier < ActionMailer::Base
|
2
|
+
include Resque::Mailer
|
3
|
+
if LibraryGroup.site_config.try(:url)
|
4
|
+
uri = Addressable::URI.parse(LibraryGroup.site_config.url)
|
5
|
+
default_url_options[:host] = uri.host
|
6
|
+
default_url_options[:port] = uri.port
|
7
|
+
else
|
8
|
+
default_url_options[:host] = 'library.example.jp'
|
9
|
+
default_url_options[:port] = 80
|
10
|
+
end
|
11
|
+
|
12
|
+
def message_notification(message_id)
|
13
|
+
message = Message.find(message_id)
|
14
|
+
I18n.locale = message.receiver.locale.try(:to_sym) || I18n.default_locale
|
15
|
+
from = "#{LibraryGroup.system_name(message.receiver.locale)} <#{LibraryGroup.site_config.email}>"
|
16
|
+
if message.subject
|
17
|
+
subject = message.subject
|
18
|
+
else
|
19
|
+
subject = I18n.t('message.new_message_from_library', :library => LibraryGroup.system_name(message.receiver.user.locale))
|
20
|
+
end
|
21
|
+
if message.sender
|
22
|
+
@sender_name = message.sender.full_name
|
23
|
+
else
|
24
|
+
@sender_name = LibraryGroup.system_name(message.receiver.locale)
|
25
|
+
end
|
26
|
+
@message = message
|
27
|
+
@locale = message.receiver.locale
|
28
|
+
mail(:from => from, :to => message.receiver.email, :subject => subject)
|
29
|
+
end
|
30
|
+
end
|
@@ -0,0 +1,30 @@
|
|
1
|
+
class Ability
|
2
|
+
include CanCan::Ability
|
3
|
+
|
4
|
+
def initialize(user)
|
5
|
+
case user.try(:role).try(:name)
|
6
|
+
when 'Administrator'
|
7
|
+
can :manage, Message
|
8
|
+
can [:read, :update, :destroy], MessageRequest
|
9
|
+
can [:read, :update], MessageTemplate
|
10
|
+
when 'Librarian'
|
11
|
+
can [:index, :create], Message
|
12
|
+
can [:update], Message do |message|
|
13
|
+
message.sender == user
|
14
|
+
end
|
15
|
+
can [:show, :destroy], Message do |message|
|
16
|
+
message.receiver == user
|
17
|
+
end
|
18
|
+
can [:read, :update, :destroy], MessageRequest
|
19
|
+
can :read, MessageTemplate
|
20
|
+
when 'User'
|
21
|
+
can [:read, :destroy], Message do |message|
|
22
|
+
message.receiver == user
|
23
|
+
end
|
24
|
+
can :index, Message
|
25
|
+
can :show, Message do |message|
|
26
|
+
message.receiver == user
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
@@ -0,0 +1,86 @@
|
|
1
|
+
# -*- encoding: utf-8 -*-
|
2
|
+
class LibraryGroup < ActiveRecord::Base
|
3
|
+
#include Singleton
|
4
|
+
#include Configurator
|
5
|
+
include MasterModel
|
6
|
+
|
7
|
+
has_many :libraries
|
8
|
+
has_many :search_engines
|
9
|
+
#has_many :news_feeds
|
10
|
+
belongs_to :country
|
11
|
+
|
12
|
+
validates :email, :format => {:with => /\A([\w\.%\+\-]+)@([\w\-]+\.)+([\w]{2,})\z/i}, :presence => true
|
13
|
+
validates :url, :presence => true, :url => true
|
14
|
+
after_save :clear_site_config_cache
|
15
|
+
|
16
|
+
def clear_site_config_cache
|
17
|
+
Rails.cache.delete('library_site_config')
|
18
|
+
end
|
19
|
+
|
20
|
+
def self.site_config
|
21
|
+
#if Rails.env == 'production'
|
22
|
+
# Rails.cache.fetch('library_site_config'){LibraryGroup.find(1)}
|
23
|
+
#else
|
24
|
+
LibraryGroup.find(1)
|
25
|
+
#end
|
26
|
+
rescue
|
27
|
+
nil
|
28
|
+
end
|
29
|
+
|
30
|
+
def self.system_name(locale = I18n.locale)
|
31
|
+
LibraryGroup.site_config.display_name.localize(locale)
|
32
|
+
end
|
33
|
+
|
34
|
+
def config?
|
35
|
+
true if self == LibraryGroup.site_config
|
36
|
+
end
|
37
|
+
|
38
|
+
def real_libraries
|
39
|
+
# 物理的な図書館 = IDが1以外
|
40
|
+
libraries.where('id != 1').all
|
41
|
+
end
|
42
|
+
|
43
|
+
def network_access_allowed?(ip_address, options = {})
|
44
|
+
options = {:network_type => :lan}.merge(options)
|
45
|
+
client_ip = IPAddr.new(ip_address)
|
46
|
+
case options[:network_type]
|
47
|
+
when :admin
|
48
|
+
allowed_networks = self.admin_networks.to_s.split
|
49
|
+
else
|
50
|
+
allowed_networks = self.my_networks.to_s.split
|
51
|
+
end
|
52
|
+
allowed_networks.each do |allowed_network|
|
53
|
+
begin
|
54
|
+
network = IPAddr.new(allowed_network)
|
55
|
+
return true if network.include?(client_ip)
|
56
|
+
rescue ArgumentError
|
57
|
+
nil
|
58
|
+
end
|
59
|
+
end
|
60
|
+
return false
|
61
|
+
end
|
62
|
+
end
|
63
|
+
|
64
|
+
|
65
|
+
# == Schema Information
|
66
|
+
#
|
67
|
+
# Table name: library_groups
|
68
|
+
#
|
69
|
+
# id :integer not null, primary key
|
70
|
+
# name :string(255) not null
|
71
|
+
# display_name :text
|
72
|
+
# short_name :string(255) not null
|
73
|
+
# email :string(255)
|
74
|
+
# my_networks :text
|
75
|
+
# login_banner :text
|
76
|
+
# note :text
|
77
|
+
# post_to_union_catalog :boolean default(FALSE), not null
|
78
|
+
# country_id :integer
|
79
|
+
# created_at :datetime
|
80
|
+
# updated_at :datetime
|
81
|
+
# admin_networks :text
|
82
|
+
# allow_bookmark_external_url :boolean default(FALSE), not null
|
83
|
+
# position :integer
|
84
|
+
# url :string(255) default("http://localhost:3000/")
|
85
|
+
#
|
86
|
+
|
@@ -0,0 +1,167 @@
|
|
1
|
+
# -*- encoding: utf-8 -*-
|
2
|
+
class Patron < ActiveRecord::Base
|
3
|
+
scope :readable_by, lambda{|user| {:conditions => ['required_role_id <= ?', user.try(:user_has_role).try(:role_id) || Role.where(:name => 'Guest').select(:id).first.id]}}
|
4
|
+
belongs_to :user
|
5
|
+
belongs_to :patron_type
|
6
|
+
belongs_to :required_role, :class_name => 'Role', :foreign_key => 'required_role_id', :validate => true
|
7
|
+
|
8
|
+
validates_presence_of :patron_type
|
9
|
+
validates_associated :patron_type
|
10
|
+
validates :full_name, :presence => true, :length => {:maximum => 255}
|
11
|
+
validates :user_id, :uniqueness => true, :allow_nil => true
|
12
|
+
validates :email, :format => {:with => /^([\w\.%\+\-]+)@([\w\-]+\.)+([\w]{2,})$/i}, :allow_blank => true
|
13
|
+
before_validation :set_role_and_name, :on => :create
|
14
|
+
|
15
|
+
#has_paper_trail
|
16
|
+
attr_accessor :user_username
|
17
|
+
#[:address_1, :address_2].each do |column|
|
18
|
+
# encrypt_with_public_key column,
|
19
|
+
# :key_pair => File.join(Rails.root.to_s,'config','keypair.pem'),
|
20
|
+
# :base64 => true
|
21
|
+
#end
|
22
|
+
|
23
|
+
searchable do
|
24
|
+
text :name, :place, :address_1, :address_2, :other_designation, :note
|
25
|
+
string :zip_code_1
|
26
|
+
string :zip_code_2
|
27
|
+
string :username do
|
28
|
+
user.username if user
|
29
|
+
end
|
30
|
+
time :created_at
|
31
|
+
time :updated_at
|
32
|
+
string :user
|
33
|
+
integer :work_ids, :multiple => true
|
34
|
+
integer :expression_ids, :multiple => true
|
35
|
+
integer :manifestation_ids, :multiple => true
|
36
|
+
integer :patron_merge_list_ids, :multiple => true if defined?(EnjuResourceMerge)
|
37
|
+
integer :original_patron_ids, :multiple => true
|
38
|
+
integer :required_role_id
|
39
|
+
integer :patron_type_id
|
40
|
+
end
|
41
|
+
|
42
|
+
def self.per_page
|
43
|
+
10
|
44
|
+
end
|
45
|
+
|
46
|
+
def full_name_without_space
|
47
|
+
full_name.gsub(/\s/, "")
|
48
|
+
end
|
49
|
+
|
50
|
+
def set_role_and_name
|
51
|
+
self.required_role = Role.where(:name => 'Librarian').first if self.required_role_id.nil?
|
52
|
+
set_full_name
|
53
|
+
end
|
54
|
+
|
55
|
+
def set_full_name
|
56
|
+
if self.full_name.blank?
|
57
|
+
if self.last_name.to_s.strip and self.first_name.to_s.strip and Setting.family_name_first == true
|
58
|
+
self.full_name = [last_name, middle_name, first_name].compact.join(" ").to_s.strip
|
59
|
+
else
|
60
|
+
self.full_name = [first_name, last_name, middle_name].compact.join(" ").to_s.strip
|
61
|
+
end
|
62
|
+
end
|
63
|
+
if self.full_name_transcription.blank?
|
64
|
+
self.full_name_transcription = [last_name_transcription, middle_name_transcription, first_name_transcription].join(" ").to_s.strip
|
65
|
+
end
|
66
|
+
[self.full_name, self.full_name_transcription]
|
67
|
+
end
|
68
|
+
|
69
|
+
def full_name_without_space
|
70
|
+
full_name.gsub(/\s/, "")
|
71
|
+
# # TODO: 日本人以外は?
|
72
|
+
# name = []
|
73
|
+
# name << self.last_name.to_s.strip
|
74
|
+
# name << self.middle_name.to_s.strip
|
75
|
+
# name << self.first_name.to_s.strip
|
76
|
+
# name << self.corporate_name.to_s.strip
|
77
|
+
# name.join("").strip
|
78
|
+
end
|
79
|
+
|
80
|
+
def full_name_transcription_without_space
|
81
|
+
full_name_transcription.to_s.gsub(/\s/, "")
|
82
|
+
end
|
83
|
+
|
84
|
+
def full_name_alternative_without_space
|
85
|
+
full_name_alternative.to_s.gsub(/\s/, "")
|
86
|
+
end
|
87
|
+
|
88
|
+
def name
|
89
|
+
name = []
|
90
|
+
name << full_name.to_s.strip
|
91
|
+
name << full_name_transcription.to_s.strip
|
92
|
+
name << full_name_alternative.to_s.strip
|
93
|
+
#name << full_name_without_space
|
94
|
+
#name << full_name_transcription_without_space
|
95
|
+
#name << full_name_alternative_without_space
|
96
|
+
#name << full_name.wakati rescue nil
|
97
|
+
#name << full_name_transcription.wakati rescue nil
|
98
|
+
#name << full_name_alternative.wakati rescue nil
|
99
|
+
name
|
100
|
+
end
|
101
|
+
|
102
|
+
def date
|
103
|
+
if date_of_birth
|
104
|
+
if date_of_death
|
105
|
+
"#{date_of_birth} - #{date_of_death}"
|
106
|
+
else
|
107
|
+
"#{date_of_birth} -"
|
108
|
+
end
|
109
|
+
end
|
110
|
+
end
|
111
|
+
|
112
|
+
def creator?(resource)
|
113
|
+
resource.creators.include?(self)
|
114
|
+
end
|
115
|
+
|
116
|
+
def publisher?(resource)
|
117
|
+
resource.publishers.include?(self)
|
118
|
+
end
|
119
|
+
|
120
|
+
def check_required_role(user)
|
121
|
+
return true if self.user.blank?
|
122
|
+
return true if self.user.required_role.name == 'Guest'
|
123
|
+
return true if user == self.user
|
124
|
+
return true if user.has_role?(self.user.required_role.name)
|
125
|
+
false
|
126
|
+
rescue NoMethodError
|
127
|
+
false
|
128
|
+
end
|
129
|
+
|
130
|
+
def created(work)
|
131
|
+
creates.where(:work_id => work.id).first
|
132
|
+
end
|
133
|
+
|
134
|
+
def realized(expression)
|
135
|
+
realizes.where(:expression_id => expression.id).first
|
136
|
+
end
|
137
|
+
|
138
|
+
def produced(manifestation)
|
139
|
+
produces.where(:manifestation_id => manifestation.id).first
|
140
|
+
end
|
141
|
+
|
142
|
+
def owned(item)
|
143
|
+
owns.where(:item_id => item.id)
|
144
|
+
end
|
145
|
+
|
146
|
+
def self.import_patrons(patron_lists)
|
147
|
+
list = []
|
148
|
+
patron_lists.each do |patron_list|
|
149
|
+
patron = Patron.where(:full_name => patron_list[:full_name]).first
|
150
|
+
unless patron
|
151
|
+
patron = Patron.new(
|
152
|
+
:full_name => patron_list[:full_name],
|
153
|
+
:full_name_transcription => patron_list[:full_name_transcription],
|
154
|
+
:language_id => 1
|
155
|
+
)
|
156
|
+
patron.required_role = Role.where(:name => 'Guest').first
|
157
|
+
patron.save
|
158
|
+
end
|
159
|
+
list << patron
|
160
|
+
end
|
161
|
+
list
|
162
|
+
end
|
163
|
+
|
164
|
+
def patrons
|
165
|
+
self.original_patrons + self.derived_patrons
|
166
|
+
end
|
167
|
+
end
|
@@ -0,0 +1,19 @@
|
|
1
|
+
class PatronType < ActiveRecord::Base
|
2
|
+
include MasterModel
|
3
|
+
default_scope :order => "patron_types.position"
|
4
|
+
has_many :patrons
|
5
|
+
end
|
6
|
+
|
7
|
+
# == Schema Information
|
8
|
+
#
|
9
|
+
# Table name: patron_types
|
10
|
+
#
|
11
|
+
# id :integer not null, primary key
|
12
|
+
# name :string(255) not null
|
13
|
+
# display_name :text
|
14
|
+
# note :text
|
15
|
+
# position :integer
|
16
|
+
# created_at :datetime
|
17
|
+
# updated_at :datetime
|
18
|
+
#
|
19
|
+
|
@@ -0,0 +1,46 @@
|
|
1
|
+
class User < ActiveRecord::Base
|
2
|
+
# Include default devise modules. Others available are:
|
3
|
+
# :token_authenticatable, :encryptable, :confirmable, :lockable, :timeoutable and :omniauthable
|
4
|
+
devise :database_authenticatable, :registerable,
|
5
|
+
:recoverable, :rememberable, :trackable, :validatable
|
6
|
+
|
7
|
+
# Setup accessible (or protected) attributes for your model
|
8
|
+
attr_accessible :email, :password, :password_confirmation, :remember_me
|
9
|
+
|
10
|
+
has_one :user_has_role
|
11
|
+
has_one :role, :through => :user_has_role
|
12
|
+
has_one :patron
|
13
|
+
belongs_to :user_group
|
14
|
+
belongs_to :required_role, :class_name => 'Role', :foreign_key => 'required_role_id'
|
15
|
+
before_create :set_role_and_patron
|
16
|
+
|
17
|
+
enju_message_user
|
18
|
+
|
19
|
+
extend FriendlyId
|
20
|
+
friendly_id :username
|
21
|
+
|
22
|
+
def set_role_and_patron
|
23
|
+
self.required_role = Role.where(:name => 'Librarian').first
|
24
|
+
self.locale = I18n.default_locale.to_s
|
25
|
+
unless self.patron
|
26
|
+
self.patron = Patron.create(:full_name => self.username) if self.username
|
27
|
+
end
|
28
|
+
end
|
29
|
+
|
30
|
+
def has_role?(role_in_question)
|
31
|
+
return false unless role
|
32
|
+
return true if role.name == role_in_question
|
33
|
+
case role.name
|
34
|
+
when 'Administrator'
|
35
|
+
return true
|
36
|
+
when 'Librarian'
|
37
|
+
return true if role_in_question == 'User'
|
38
|
+
else
|
39
|
+
false
|
40
|
+
end
|
41
|
+
end
|
42
|
+
|
43
|
+
def full_name
|
44
|
+
username
|
45
|
+
end
|
46
|
+
end
|