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
|
# 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
# 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
|