diff options
| author | elijah <elijah@riseup.net> | 2012-10-23 03:53:06 -0700 | 
|---|---|---|
| committer | elijah <elijah@riseup.net> | 2012-10-23 03:53:06 -0700 | 
| commit | 628165fd0a4e03bb7bbef3a464447924195e10b8 (patch) | |
| tree | 746280b6f4d6d488fcece4fff41b4addfb77d0c1 /lib/leap_cli/config | |
| parent | 4f38e99c629f60d9524d1cf23efa7ab927ac9cf4 (diff) | |
added a bunch of new commands, including init-node and deploy
Diffstat (limited to 'lib/leap_cli/config')
| -rw-r--r-- | lib/leap_cli/config/manager.rb | 28 | 
1 files changed, 20 insertions, 8 deletions
| diff --git a/lib/leap_cli/config/manager.rb b/lib/leap_cli/config/manager.rb index 432ba0b..79ae5b8 100644 --- a/lib/leap_cli/config/manager.rb +++ b/lib/leap_cli/config/manager.rb @@ -18,12 +18,16 @@ module LeapCli        #        # load .json configuration files        # -      def load(dir) -        @services = load_all_json("#{dir}/services/*.json") -        @tags     = load_all_json("#{dir}/tags/*.json") -        @common   = load_all_json("#{dir}/common.json")['common'] -        @provider = load_all_json("#{dir}/provider.json")['provider'] -        @nodes    = load_all_json("#{dir}/nodes/*.json") +      def load(provider_dir=Path.provider) +        @services = load_all_json(Path.named_path( [:service_config, '*'], provider_dir )) +        @tags     = load_all_json(Path.named_path( [:tag_config, '*'],     provider_dir )) +        @common   = load_all_json(Path.named_path( :common_config,         provider_dir ))['common'] +        @provider = load_all_json(Path.named_path( :provider_config,       provider_dir ))['provider'] +        @nodes    = load_all_json(Path.named_path( [:node_config, '*'],    provider_dir )) + +        Util::assert!(@provider, "Failed to load provider.json") +        Util::assert!(@common, "Failed to load common.json") +          @nodes.each do |name, node|            @nodes[name] = apply_inheritance(node)          end @@ -32,11 +36,10 @@ module LeapCli        #        # save compiled hiera .yaml files        # -      def export(dir) +      def export(dir=Path.named_path(:hiera_dir))          existing_files = Dir.glob(dir + '/*.yaml')          updated_files = []          @nodes.each do |name, node| -          # not sure if people will approve of this change:            filepath = "#{dir}/#{name}.yaml"            updated_files << filepath            Util::write_file!(filepath, node.to_yaml) @@ -86,6 +89,15 @@ module LeapCli        end        # +      # same as filter(), but exits if there is no matching nodes +      # +      def filter!(filters) +        node_list = filter(filters) +        Util::assert! node_list.any?, "Could not match any nodes from '#{filters}'" +        return node_list +      end + +      #        # returns a single Config::Object that corresponds to a Node.        #        def node(name) | 
