Class: Certman::Client
- Inherits:
-
Object
- Object
- Certman::Client
- Includes:
- Resource::ACM, Resource::Route53, Resource::S3, Resource::SES, Resource::STS
- Defined in:
- lib/certman/client.rb
Constant Summary
Constants included from Resource::SES
Resource::SES::REGIONS, Resource::SES::RULE_SET_NAME_BY_CERTMAN
Instance Method Summary collapse
- #check_resource(check_acm: true) ⇒ Object
- #delete ⇒ Object
-
#initialize(domain, options) ⇒ Client
constructor
A new instance of Client.
- #request ⇒ Object
- #restore_resources ⇒ Object
- #rollback ⇒ Object
Methods included from Resource::ACM
#acm, #certificate_exist?, #delete_certificate, #request_certificate, #resend_validation_email
Methods included from Resource::Route53
#cname_rset_exist?, #create_mx_rset, #create_txt_rset, #delete_mx_rset, #delete_txt_rset, #hosted_zone_exist?, #mx_rset_exist?, #route53, #txt_rset_exist?
Methods included from Resource::SES
#active_rule_set_exist?, #check_domain_identity_verified, #create_and_active_rule_set, #create_domain_identity, #create_rule, #delete_domain_identity, #delete_rule, #delete_rule_set, #region_by_hash, #rule_exist?, #ses
Methods included from Resource::S3
#check_approval_mail, #create_bucket, #delete_bucket, #s3
Methods included from Resource::STS
Constructor Details
#initialize(domain, options) ⇒ Client
Returns a new instance of Client.
9 10 11 12 13 14 15 16 17 18 19 |
# File 'lib/certman/client.rb', line 9 def initialize(domain, ) @do_rollback = false @cname_exists = false @domain = domain @subject_alternative_names = [:subject_alternative_names] @cert_arn = nil @savepoint = [] @remain_resources = [:remain_resources] @hosted_zone_domain = [:hosted_zone] @hosted_zone_domain.sub(/\.\z/, '') if @hosted_zone_domain end |
Instance Method Details
#check_resource(check_acm: true) ⇒ Object
122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 |
# File 'lib/certman/client.rb', line 122 def check_resource(check_acm: true) pastel = Pastel.new if check_acm s = spinner('[ACM] Check Certificate') if certificate_exist? s.error puts pastel.yellow("\nCertificate already exists!\n") puts "certificate_arn: #{pastel.cyan(@cert_arn)}" exit end s.success end s = spinner('[Route53] Check Hosted Zone') unless hosted_zone_exist? s.error puts pastel.red("\nHosted Zone #{hosted_zone_domain} does not exist") exit end s.success s = spinner('[Route53] Check TXT Record') if txt_rset_exist? s.error puts pastel.red("\n_amazonses.#{email_domain} TXT already exists") exit end s.success enforce_region_by_hash do s = spinner('[Route53] Check MX Record') if mx_rset_exist? s.error puts pastel.red("\n#{email_domain} MX already exist") exit end if cname_rset_exist? puts pastel.cyan("\n#{email_domain} CNAME already exists. Use #{hosted_zone_domain}") @cname_exists = true check_resource end s.success s = spinner('[SES] Check Active Rule Set') if active_rule_set_exist? puts pastel.cyan("\nActive Rule Set already exist. Use #{@current_active_rule_set_name}") end s.success end true end |
#delete ⇒ Object
111 112 113 114 115 116 117 118 119 120 |
# File 'lib/certman/client.rb', line 111 def delete s = spinner('[ACM] Delete Certificate') unless certificate_exist? s.error puts pastel.yellow("\nNo certificate to delete!\n") exit end delete_certificate s.success end |
#request ⇒ Object
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 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 |
# File 'lib/certman/client.rb', line 21 def request check_resource enforce_region_by_hash do step('[S3] Create Bucket for SES inbound', :s3_bucket) do create_bucket end step('[SES] Create Domain Identity', :ses_domain_identity) do create_domain_identity end end step('[Route53] Create TXT Record Set to verify Domain Identity', :route53_txt) do create_txt_rset end enforce_region_by_hash do step('[SES] Check Domain Identity Status *verified*', nil) do check_domain_identity_verified end step('[Route53] Create MX Record Set', :route53_mx) do create_mx_rset end unless active_rule_set_exist? step('[SES] Create and Active Receipt Rule Set', :ses_rule_set) do create_and_active_rule_set end end step('[SES] Create Receipt Rule', :ses_rule) do create_rule end end step('[ACM] Request Certificate', :acm_certificate) do request_certificate end enforce_region_by_hash do step('[S3] Check for approval mail (can take up to 30 min)', nil) do check_approval_mail end end cleanup_resources if !@remain_resources || @do_rollback @cert_arn end |
#restore_resources ⇒ Object
72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 |
# File 'lib/certman/client.rb', line 72 def restore_resources check_resource(check_acm: false) enforce_region_by_hash do step('[S3] Create Bucket for SES inbound', :s3_bucket) do create_bucket end step('[SES] Create Domain Identity', :ses_domain_identity) do create_domain_identity end end step('[Route53] Create TXT Record Set to verify Domain Identity', :route53_txt) do create_txt_rset end enforce_region_by_hash do step('[SES] Check Domain Identity Status *verified*', nil) do check_domain_identity_verified end step('[Route53] Create MX Record Set', :route53_mx) do create_mx_rset end unless active_rule_set_exist? step('[SES] Create and Active Receipt Rule Set', :ses_rule_set) do create_and_active_rule_set end end step('[SES] Create Receipt Rule', :ses_rule) do create_rule end end cleanup_resources if @do_rollback end |
#rollback ⇒ Object
176 177 178 |
# File 'lib/certman/client.rb', line 176 def rollback @do_rollback = true end |