blob: eab2b1d44c2eb2cab9b19d1b8772d5a2dbbf6180 (
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
|
module Oxidized
require 'oxidized/node'
class Oxidized::NotSupported < StandardError; end
class Oxidized::NodeNotFound < StandardError; end
class Nodes < Array
attr_accessor :source
alias :put :unshift
def load
with_lock do
new = []
@source = CFG.source[:default]
Oxidized.mgr.add_source @source
Oxidized.mgr.source[@source].new.load.each do |node|
begin
_node = Node.new node
new.push _node
rescue ModelNotFound => err
Log.error "node %s raised %s with message %s" % [node, err.class, err.message]
end
end
replace new
end
end
def list
with_lock do
map { |e| e.serialize }
end
end
def show node
with_lock do
i = find_node_index node
self[i].serialize
end
end
def fetch node, group
with_lock do
i = find_node_index node
output = self[i].output.new
raise Oxidized::NotSupported unless output.respond_to? :fetch
output.fetch node, group
end
end
# @param node [String] name of the node moved into the head of array
def next node, opt={}
with_lock do
n = del node
if n
n.user = opt['user']
n.msg = opt['msg']
n.from = opt['from']
# set last job to nil so that the node is picked for immediate update
n.last = nil
put n
end
end
end
alias :top :next
# @return [String] node from the head of the array
def get
with_lock do
(self << shift).last
end
end
private
def initialize *args
super
@mutex= Mutex.new # we compete for the nodes with webapi thread
load if args.empty?
end
def with_lock &block
@mutex.synchronize(&block)
end
def find_index node
index { |e| e.name == node }
end
def find_node_index node
find_index node or raise Oxidized::NodeNotFound, "unable to find '#{node}'"
end
def del node
delete_at find_node_index(node)
end
end
end
|