Module: Hyrax::User

Extended by:
ActiveSupport::Concern
Defined in:
app/models/concerns/hyrax/user.rb

Defined Under Namespace

Modules: ClassMethods

Instance Method Summary collapse

Instance Method Details

#abilityObject



120
121
122
# File 'app/models/concerns/hyrax/user.rb', line 120

def ability
  @ability ||= ::Ability.new(self)
end

#all_user_activity(since = DateTime.current.to_i - 1.day) ⇒ Object



124
125
126
127
128
# File 'app/models/concerns/hyrax/user.rb', line 124

def all_user_activity(since = DateTime.current.to_i - 1.day)
  events = self.events.reverse.collect { |event| event if event[:timestamp].to_i > since }.compact
  profile_events = self.profile_events.reverse.collect { |event| event if event[:timestamp].to_i > since }.compact
  events.concat(profile_events).sort { |a, b| b[:timestamp].to_i <=> a[:timestamp].to_i }
end

#as_json(_opts = nil) ⇒ Object

Format the json for select2 which requires just an id and a field called text. If we need an alternate format we should probably look at a json template gem



95
96
97
# File 'app/models/concerns/hyrax/user.rb', line 95

def as_json(_opts = nil)
  { id: user_key, text: display_name ? "#{display_name} (#{user_key})" : user_key }
end

#log_profile_event(event_id) ⇒ Object



54
55
56
# File 'app/models/concerns/hyrax/user.rb', line 54

def log_profile_event(event_id)
  event_store.for(stream[:event][:profile]).push(event_id)
end

#mailboxer_email(_obj = nil) ⇒ Object

method needed for messaging



116
117
118
# File 'app/models/concerns/hyrax/user.rb', line 116

def mailboxer_email(_obj = nil)
  nil
end

#nameObject



103
104
105
106
107
# File 'app/models/concerns/hyrax/user.rb', line 103

def name
  display_name.titleize || raise
rescue
  user_key
end

#normalize_orcidObject

Coerce the ORCID into URL format



83
84
85
86
87
88
89
90
91
# File 'app/models/concerns/hyrax/user.rb', line 83

def normalize_orcid
  # Skip normalization if:
  #   1. validation has already flagged the ORCID as invalid
  #   2. the orcid field is blank
  #   3. the orcid is already in its normalized form
  return if errors[:orcid].first.present? || orcid.blank? || orcid.starts_with?('http://orcid.org/')
  bare_orcid = Hyrax::OrcidValidator.match(orcid).string
  self.orcid = "http://orcid.org/#{bare_orcid}"
end

#populate_attributesObject

Populate user instance with attributes from remote system (e.g., LDAP) There is no default implementation – override this in your application



101
# File 'app/models/concerns/hyrax/user.rb', line 101

def populate_attributes; end

#profile_events(size = -1)) ⇒ Object



50
51
52
# File 'app/models/concerns/hyrax/user.rb', line 50

def profile_events(size = -1)
  event_store.for(stream[:event][:profile]).fetch(size)
end

#set_arkivo_tokenObject



71
72
73
# File 'app/models/concerns/hyrax/user.rb', line 71

def set_arkivo_token
  self.arkivo_token ||= token_algorithm
end

#to_paramObject

Redefine this for more intuitive keys in Redis



110
111
112
113
# File 'app/models/concerns/hyrax/user.rb', line 110

def to_param
  # Rails doesn't like periods in urls
  user_key.gsub(/\./, '-dot-')
end

#to_sipity_agentObject



46
47
48
# File 'app/models/concerns/hyrax/user.rb', line 46

def to_sipity_agent
  sipity_agent || create_sipity_agent!
end

#token_algorithmObject



75
76
77
78
79
80
# File 'app/models/concerns/hyrax/user.rb', line 75

def token_algorithm
  loop do
    token = SecureRandom.base64(24)
    return token if User.find_by(arkivo_token: token).nil?
  end
end

#zotero_tokenObject



58
59
60
# File 'app/models/concerns/hyrax/user.rb', line 58

def zotero_token
  self[:zotero_token].blank? ? nil : Marshal.load(self[:zotero_token])
end

#zotero_token=(value) ⇒ Object



62
63
64
65
66
67
68
69
# File 'app/models/concerns/hyrax/user.rb', line 62

def zotero_token=(value)
  self[:zotero_token] = if value.blank?
                          # Resetting the token
                          value
                        else
                          Marshal.dump(value)
                        end
end