diff options
author | ytti <saku@ytti.fi> | 2017-01-25 00:02:56 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-01-25 00:02:56 +0200 |
commit | 2a69179c7765455ad9b468f33c8df78188e7dec5 (patch) | |
tree | d66e7664953eca981ea1eb885304c1ee26dcb256 /lib/oxidized | |
parent | 8375aa0ad364e4cb274ba96be1ddfb312c148e38 (diff) | |
parent | 07b4d0c52ce7b5c2377a4547686b95b7ddb62986 (diff) |
Merge pull request #674 from bulletproofnetworks/master
Add GPG support for reading router.db
Diffstat (limited to 'lib/oxidized')
-rw-r--r-- | lib/oxidized/source/csv.rb | 11 |
1 files changed, 10 insertions, 1 deletions
diff --git a/lib/oxidized/source/csv.rb b/lib/oxidized/source/csv.rb index d498e0b..c1e310a 100644 --- a/lib/oxidized/source/csv.rb +++ b/lib/oxidized/source/csv.rb @@ -11,14 +11,23 @@ class CSV < Source Oxidized.asetus.user.source.csv.delimiter = /:/ Oxidized.asetus.user.source.csv.map.name = 0 Oxidized.asetus.user.source.csv.map.model = 1 + Oxidized.asetus.user.source.csv.gpg = false Oxidized.asetus.save :user raise NoConfig, 'no source csv config, edit ~/.config/oxidized/config' end + require 'gpgme' if @cfg.gpg? end def load nodes = [] - open(File.expand_path @cfg.file).each_line do |line| + file = File.expand_path(@cfg.file) + file = if @cfg.gpg? + crypto = GPGME::Crypto.new password: @cfg.gpg_password + crypto.decrypt(file).to_s + else + open(file) + end + file.each_line do |line| next if line.match(/^\s*#/) data = line.chomp.split(@cfg.delimiter, -1) next if data.empty? |