#!/usr/bin/env ruby
###########################################################################
# AWS Elastic Beanstalk Command Line Client
# Copyright 2011 Amazon.com, Inc. or its affiliates. All Rights Reserved.
# 
# Licensed under the Apache License, Version 2.0 (the “License”). You
# may not use this file except in compliance with the License. A copy of
# the License is located at
#
#    http://aws.amazon.com/apache2.0/
#
# or in the “license” file accompanying this file. This file is
# distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF
# ANY KIND, either express or implied. See the License for the specific
# language governing permissions and limitations under the License.
#

require File.join(File.dirname(__FILE__), 'setup.rb')
require 'aws/elasticbeanstalk/cli/optionsettings'

AWS::ElasticBeanstalk::OptionSettingsCLI.new do |client|
  client.service_call = lambda { |params| @elasticbeanstalk.create_configuration_template(params) }
  client.result_key = 'ConfigurationSettings'
  client.empty_response = 'No template created.'

  client.option('-a', '--application-name NAME', 'Name of the application') do |app_name|
    client.service_param('ApplicationName', app_name)
  end
  
  client.option('-t', '--template-name NAME', 'Name of the template') do |template_name|
    client.service_param('TemplateName', template_name)
  end

  client.option('-E', '--environment-id ID', 'Environment ID') do |env_id|
    client.service_param('EnvironmentId', env_id)
  end

  client.option('-d', '--description DESC', 'Description') do |description|
    client.service_param('Description', description)
  end

  client.option('-s', '--solution-stack STACK', 'Solution stack name') do |solution_stack|
    client.service_param('SolutionStackName', solution_stack)
  end
  
  client.option('-f', '--options-file FILENAME', 'File containing JSON-formatted option settings') do |options_file|
    client.parse_options_file('OptionSettings', options_file)
  end

  client.option('-A', '--source-application-name NAME', 'Name of the application to use as the source') do |source_app_name|
    client.service_param('SourceConfiguration.ApplicationName', source_app_name)
  end

  client.option('-T', '--source-template-name NAME', 'Name of the template to use as the source') do |source_template_name|
    client.service_param('SourceConfiguration.TemplateName', source_template_name)
  end
end.run(ARGV)
