Skip to content

Commit

Permalink
Drop use of base64 gem and warn about invalid base64 input
Browse files Browse the repository at this point in the history
  • Loading branch information
anakinj committed Dec 28, 2023
1 parent 965ca2b commit 6dfc74f
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 6 deletions.
2 changes: 2 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,8 @@

- Fix signature has expired error if payload is a string [#555](https://github.com/jwt/ruby-jwt/pull/555) - [@GobinathAL](https://github.com/GobinathAL).
- Fix key base equality and spaceship operators [#569](https://github.com/jwt/ruby-jwt/pull/569) - [@magneland](https://github.com/magneland).
- Drop dependency to base64 gem [#578](https://github.com/jwt/ruby-jwt/pull/578) - [@anakinj](https://github.com/anakinj).
- Deprecation warning for decoding content not compliant with RFC 4648 [#578](https://github.com/jwt/ruby-jwt/pull/578) - [@anakinj](https://github.com/anakinj).
- Your contribution here

## [v2.7.1](https://github.com/jwt/ruby-jwt/tree/v2.8.0) (2023-06-09)
Expand Down
26 changes: 20 additions & 6 deletions lib/jwt/base64.rb
Original file line number Diff line number Diff line change
@@ -1,18 +1,32 @@
# frozen_string_literal: true

require 'base64'

module JWT
# Base64 helpers
# Base64 encoding and decoding
class Base64
class << self
# Encode a string with URL-safe Base64 complying with RFC 4648 (not padded).
def url_encode(str)
::Base64.encode64(str).tr('+/', '-_').gsub(/[\n=]/, '')
encoded = [str].pack('m0')
encoded.chomp!('==') || encoded.chomp!('=')
encoded.tr!('+/', '-_')
encoded
end

# Decode a string with URL-safe Base64 complying with RFC 4648.
# Deprecated support for RFC 2045 remains for now. ("All line breaks or other characters not found in Table 1 must be ignored by decoding software")
def url_decode(str)
str += '=' * (4 - str.length.modulo(4))
::Base64.decode64(str.tr('-_', '+/'))
if !str.end_with?('=') && str.length % 4 != 0
str = str.ljust((str.length + 3) & ~3, '=')
str.tr!('-_', '+/')
else
str = str.tr('-_', '+/')
end
str.unpack1('m0')
rescue ArgumentError => e
raise unless e.message == 'invalid base64'

warn('[DEPRECATION] Invalid base64 input detected, could be because of invalid padding, trailing whitespaces or newline chars. Graceful handling of invalid input will be dropped in the next major version of ruby-jwt')
str.unpack1('m')
end
end
end
Expand Down

0 comments on commit 6dfc74f

Please sign in to comment.