acme-client 2.0.27 → 2.0.29

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: d41b8df6f16f62b2bd33a0fd960d7675c02e1d065fb3bf3466b58f59aad3a740
4
- data.tar.gz: 846346e6d27381ea63fa1cb82b9044bef0acc25e5ca38ebf332fb692c02b577e
3
+ metadata.gz: d03d332ce28ab051dc4b6c46eefed2da34bbe84b8cee56744099a4f1908a7823
4
+ data.tar.gz: '01019f67a1d5a5e0667476c5171d1a0a38160daa457cf119bed3ce9dbc8f5cca'
5
5
  SHA512:
6
- metadata.gz: 49cda221593c2902534457cd4b89e7c24fedc3ee33f52ae4af5e83df14e4baf0cd68e547ec95c54e4dffd2fa1aea2989e51f371f5abfb37cc0630e7e4176977f
7
- data.tar.gz: '059a4b9b2f260ab7dc8cb3f069120c74b3f76ec4ce5d6ff22f7eb625b75c6c032bfca3709795e247f82873d022a2f1e09ef939687e7c0f74589564cae41c9c94'
6
+ metadata.gz: 6f0d759792bcae8670e38bc97e1ac15ee6b9268acb6c37afaf9e619e519c247ad7cc38494a2dbb2c0aff0cc7b4ed6abc74f605a2c2de26824493bb2298976274
7
+ data.tar.gz: 75ede976566f9cf2f707f752cfcbf4b3f148d14d4d2f219e2020b31bd524941417b1f929c99993c482ddb0dd54b2f7a12ad6ecad36f7508bae0cb2f93f49a693
data/CHANGELOG.md CHANGED
@@ -1,3 +1,11 @@
1
+ ## `2.0.29`
2
+
3
+ * IP support to the CertificateRequest helper
4
+
5
+ ## `2.0.28`
6
+
7
+ * Make [Retry-After](https://datatracker.ietf.org/doc/html/rfc8555/#section-6.6) accessible from RateLimited#retry_after exceptions
8
+
1
9
  ## `2.0.27`
2
10
 
3
11
  * Add support for Renewal Information (ARI) (RFC 9773)
@@ -104,8 +104,15 @@ class Acme::Client::CertificateRequest
104
104
  end
105
105
 
106
106
  def add_extension(csr)
107
+ san = @names.map do |name|
108
+ if valid_ip_address?(name)
109
+ "IP:#{name}"
110
+ else
111
+ "DNS:#{name}"
112
+ end
113
+ end
107
114
  extension = OpenSSL::X509::ExtensionFactory.new.create_extension(
108
- 'subjectAltName', @names.map { |name| "DNS:#{name}" }.join(', '), false
115
+ 'subjectAltName', san.join(', '), false
109
116
  )
110
117
  csr.add_attribute(
111
118
  OpenSSL::X509::Attribute.new(
@@ -116,4 +123,14 @@ class Acme::Client::CertificateRequest
116
123
  end
117
124
  end
118
125
 
126
+ def valid_ip_address?(address)
127
+ require 'ipaddr'
128
+ begin
129
+ ip = IPAddr.new(address)
130
+ true
131
+ rescue IPAddr::InvalidAddressError, IPAddr::AddressFamilyError
132
+ false
133
+ end
134
+ end
135
+
119
136
  require 'acme/client/certificate_request/ec_key_patch'
@@ -0,0 +1,8 @@
1
+ class Acme::Client::Error::RateLimited < Acme::Client::Error::ServerError
2
+ attr_reader :retry_after
3
+
4
+ def initialize(message, retry_after = 10)
5
+ super(message)
6
+ @retry_after = retry_after.nil? ? 10 : retry_after.to_i
7
+ end
8
+ end
@@ -101,6 +101,9 @@ module Acme::Client::HTTPClient
101
101
  end
102
102
 
103
103
  def raise_on_error!
104
+ if error_class == Acme::Client::Error::RateLimited
105
+ raise error_class.new(error_message, env.response_headers['Retry-After'])
106
+ end
104
107
  raise error_class, error_message
105
108
  end
106
109
 
@@ -2,6 +2,6 @@
2
2
 
3
3
  module Acme
4
4
  class Client
5
- VERSION = '2.0.27'.freeze
5
+ VERSION = '2.0.29'.freeze
6
6
  end
7
7
  end
data/lib/acme/client.rb CHANGED
@@ -20,6 +20,7 @@ require 'acme/client/self_sign_certificate'
20
20
  require 'acme/client/resources'
21
21
  require 'acme/client/jwk'
22
22
  require 'acme/client/error'
23
+ require 'acme/client/error/rate_limited'
23
24
  require 'acme/client/util'
24
25
  require 'acme/client/chain_identifier'
25
26
 
metadata CHANGED
@@ -1,13 +1,13 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: acme-client
3
3
  version: !ruby/object:Gem::Version
4
- version: 2.0.27
4
+ version: 2.0.29
5
5
  platform: ruby
6
6
  authors:
7
7
  - Charles Barbier
8
8
  bindir: bin
9
9
  cert_chain: []
10
- date: 2025-11-12 00:00:00.000000000 Z
10
+ date: 2025-12-12 00:00:00.000000000 Z
11
11
  dependencies:
12
12
  - !ruby/object:Gem::Dependency
13
13
  name: rake
@@ -155,6 +155,7 @@ files:
155
155
  - lib/acme/client/certificate_request/ec_key_patch.rb
156
156
  - lib/acme/client/chain_identifier.rb
157
157
  - lib/acme/client/error.rb
158
+ - lib/acme/client/error/rate_limited.rb
158
159
  - lib/acme/client/http_client.rb
159
160
  - lib/acme/client/jwk.rb
160
161
  - lib/acme/client/jwk/base.rb