Class: Fhcap::Tasks::Misc::CreateSslCert
- Defined in:
- lib/fhcap/tasks/misc/create_ssl_cert.rb
Instance Attribute Summary
Attributes inherited from TaskBase
#config, #options, #thor, #verbose
Instance Method Summary collapse
-
#initialize(options) ⇒ CreateSslCert
constructor
A new instance of CreateSslCert.
- #run ⇒ Object
Methods inherited from TaskBase
#ask_config, #color_pad, #exit_with_error, #set_color, #suppress_stdout, #table_header, #table_row, #with_progress
Methods included from KnifeHelper
#chef_server_config_for, #chef_server_config_hash_for, #chef_server_names, #delete_chef_object, #knife_config, #knife_config_dir, #knife_config_file_for, #knife_data_bag_delete, #knife_download, #knife_environment_delete, #knife_upload, #local_chef_server?, #with_chef_server, #with_local_chef_server
Methods included from ProvidersHelper
#provider_availability_zones, #provider_config, #provider_credentials, #provider_for, #provider_names, #provider_names_for, #provider_regions, #provider_type, #providers_config
Methods included from ReposHelper
#find_cluster, #find_cluster_pwds, #find_cluster_pwds_with_repo, #find_cluster_with_repo, #find_data_bag, #find_data_bag_item, #find_environment, #find_repo_item, #find_role, #get_cookbook_deps, #get_cookbook_meta, #get_cookbook_versions, #get_cookbooks, #get_entry_dependencies, #get_modified_cookbooks, #git_diff, #is_dirty?, #modified?, #repo_cfg, #repo_clusters_dir, #repo_cookbook_paths, #repo_dir, #repo_names, #repo_paths, #repos_config, #repos_dir, #run_inside_repo_dir
Methods included from FhcapHelper
Constructor Details
#initialize(options) ⇒ CreateSslCert
Returns a new instance of CreateSslCert.
9 10 11 12 13 14 15 |
# File 'lib/fhcap/tasks/misc/create_ssl_cert.rb', line 9 def initialize() super @domain = [:domain] @name = [:name] @directory = [:directory] @format = [:format] end |
Instance Method Details
#run ⇒ Object
17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 |
# File 'lib/fhcap/tasks/misc/create_ssl_cert.rb', line 17 def run case @format when 'pem' certificate_file = File.join(@directory, "#{@name}-certificate.pem") private_key_file = File.join(@directory, "#{@name}-private-key.pem") if File.exists?(certificate_file) && File.exists?(private_key_file) thor.say_status 'exists', certificate_file, :green thor.say_status 'exists', private_key_file, :green else key, cert = generate_cert(@domain) thor.create_file(private_key_file, key.to_pem) thor.create_file(certificate_file, cert.to_pem) end when 'json' certificate_file = File.join(@directory, "#{@name}.json") if File.exists?(certificate_file) thor.say_status 'exists', certificate_file, :green else key, cert = generate_cert(@domain) cert_conf = { id: @name, cert: cert.to_pem.split(/\n/), key: key.to_pem.split(/\n/) } thor.create_file(certificate_file, JSON.pretty_generate(cert_conf)) end else exit_with_error("Unsupported format #{@format}") end end |