blob: f84a7a8d6c403386f9c30aa84ca3520f716b7f2e (
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
|
module Oxidized
class SQL < Source
require 'sequel'
def initialize
super
@cfg = CFG.source.sql
end
def setup
if @cfg.empty?
CFGS.user.source.sql.adapter = 'sqlite'
CFGS.user.source.sql.file = File.join(Config::Root, 'sqlite.db')
CFGS.user.source.sql.table = 'devices'
CFGS.user.source.sql.map.name = 'name'
CFGS.user.source.sql.map.model = 'rancid'
CFGS.save :user
raise NoConfig, 'no source sql config, edit ~/.config/oxidized/config'
end
end
def load
nodes = []
db = case @cfg.adapter
when 'sqlite'
require 'sqlite3'
Sequel.sqlite @cfg.file
end
db[@cfg.table.to_sym].each do |node|
keys = {}
@cfg.map.each { |key, sql_column| keys[key.to_sym] = node[sql_column.to_sym] }
keys[:model] = map_model keys[:model] if keys.key? :model
nodes << keys
end
nodes
end
end
end
|