diff options
author | elijah <elijah@riseup.net> | 2013-01-28 02:45:36 -0800 |
---|---|---|
committer | elijah <elijah@riseup.net> | 2013-01-28 02:45:36 -0800 |
commit | 89da880dc2ae9aff184d81a5edc702a5c0f1cd87 (patch) | |
tree | 9697b28a47c169aade816ec9220ae6874e22723b /lib | |
parent | d30e9067a94e0d236df65d37b81809ddd6a4f153 (diff) |
remove old secrets from secrets.json if they are not defined anywhere.
Diffstat (limited to 'lib')
-rw-r--r-- | lib/leap_cli.rb | 1 | ||||
-rw-r--r-- | lib/leap_cli/config/manager.rb | 2 | ||||
-rw-r--r-- | lib/leap_cli/config/object.rb | 2 | ||||
-rw-r--r-- | lib/leap_cli/config/secrets.rb | 33 |
4 files changed, 36 insertions, 2 deletions
diff --git a/lib/leap_cli.rb b/lib/leap_cli.rb index 31a9d8f..384a5f2 100644 --- a/lib/leap_cli.rb +++ b/lib/leap_cli.rb @@ -20,6 +20,7 @@ require 'leap_cli/ssh_key' require 'leap_cli/config/object' require 'leap_cli/config/node' require 'leap_cli/config/tag' +require 'leap_cli/config/secrets' require 'leap_cli/config/object_list' require 'leap_cli/config/manager' diff --git a/lib/leap_cli/config/manager.rb b/lib/leap_cli/config/manager.rb index c860b5c..5fc4499 100644 --- a/lib/leap_cli/config/manager.rb +++ b/lib/leap_cli/config/manager.rb @@ -35,7 +35,7 @@ module LeapCli @nodes = load_all_json(Path.named_path([:node_config, '*'], @provider_dir), Config::Node) @common = load_json(common_path, Config::Object) @provider = load_json(provider_path, Config::Object) - @secrets = load_json(Path.named_path(:secrets_config, @provider_dir), Config::Object) + @secrets = load_json(Path.named_path(:secrets_config, @provider_dir), Config::Secrets) # inherit @services.inherit_from! base_services diff --git a/lib/leap_cli/config/object.rb b/lib/leap_cli/config/object.rb index ef5133f..e039660 100644 --- a/lib/leap_cli/config/object.rb +++ b/lib/leap_cli/config/object.rb @@ -270,7 +270,7 @@ module LeapCli # manager.export_secrets should be called later to capture any newly generated secrets. # def secret(name, length=32) - @manager.secrets[name.to_s] ||= Util::Secret.generate(length) + @manager.secrets.set(name, Util::Secret.generate(length)) end # diff --git a/lib/leap_cli/config/secrets.rb b/lib/leap_cli/config/secrets.rb new file mode 100644 index 0000000..00d0cd6 --- /dev/null +++ b/lib/leap_cli/config/secrets.rb @@ -0,0 +1,33 @@ +# +# +# A class for the secrets.json file +# +# + +module LeapCli; module Config + + class Secrets < Object + attr_reader :node_list + + def initialize(manager=nil) + super(manager) + @discovered_keys = {} + end + + def set(key, value) + key = key.to_s + @discovered_keys[key] = true + self[key] ||= value + end + + def dump_json + self.each_key do |key| + unless @discovered_keys[key] + self.delete(key) + end + end + super + end + end + +end; end |