aboutsummaryrefslogtreecommitdiff
path: root/lib/mauve/people_list.rb
blob: 712424108b9a45510339a63c7ed73e49c56a0b77 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
# encoding: UTF-8
require 'log4r'
require 'mauve/calendar_interface'

module Mauve 

  # Stores a list of Mauve::Person
  #
  #
  class PeopleList 

    attr_reader :label, :list, :notifications

    # Create a new list
    #
    # @param [String] label The name of the list
    # @raise [ArgumentError] if the label is not a string
    #
    def initialize(label)
      raise ArgumentError, "people_list label must be a string #{label.inspect}" unless label.is_a?(String)
      @label = label
      @list  = []
      @notifications = []
    end

    alias username label

    #
    # A dummy XMPP method.
    #
    def xmpp; nil ; end

    # Append an Array or String to a list
    #
    # @param [Array or String] arr
    # @return [Mauve::PeopleList] self
    def +(arr)
      case arr
        when Array
          arr = arr.flatten
        when String
          arr = [arr]
        when Proc
          arr = [arr]
        else
          logger.warn "Not sure what to do with #{arr.inspect} -- converting to string, and continuing"
          arr = [arr.to_s]
      end

      arr.each do |person|
        if @list.include?(person)
          logger.warn "#{person} is already on the #{self.label} list"
        else
          @list << person
        end
      end

      self
    end

    alias add_to_list +

    # @return Log4r::Logger
    def logger
      @logger ||=  Log4r::Logger.new self.class.to_s
    end

    # Return the array of people
    #
    # @return [Array]
    def people(at = Time.now)
      l = list.collect do |name|
        name.is_a?(Proc) ? name.call(at) : name 
      end.flatten.compact.uniq.collect do |name|
        Configuration.current.people[name] 
      end.compact

      #
      # Hmm.. no-one in the list?!
      #
      logger.warn "No-one found in the people list for #{self.label}" if l.empty?

      l
    end

    def resolve_notifications(default_every=nil, default_during=nil, at = nil, lists_seen=[])
      #
      # Add our username to the list of lists seen.
      #
      lists_seen << self.username

      self.people(at).collect do |person_or_people_list|
        #
        # Make sure we don't parse the same people list twice
        #
        next if lists_seen.include?(person_or_people_list.username)
        
        if self.notifications.empty? 
          person_or_people_list.resolve_notifications(default_every, default_during, at, lists_seen)
        else
          self.notifications.collect do |notification|
            person_or_people_list.resolve_notifications(
              default_every || notification.every, 
              default_during || notification.during, 
              at, 
              lists_seen
            )
          end
        end
      end.flatten.compact
    end

  end

end