Sha256: 804f5f52680b665038c5cbe713c0178a080621bea40c0190a3d26593d812cce2

Contents?: true

Size: 1.99 KB

Versions: 7

Compression:

Stored size: 1.99 KB

Contents

module JSON
  class JWK
    module JWKizable
      module RSA
        def to_jwk(ex_params = {})
          params = {
            kty: :RSA,
            e: UrlSafeBase64.encode64(e.to_s(2)),
            n: UrlSafeBase64.encode64(n.to_s(2))
          }.merge ex_params
          if private?
            params.merge!(
              d: UrlSafeBase64.encode64(d.to_s(2)),
              p: UrlSafeBase64.encode64(p.to_s(2)),
              q: UrlSafeBase64.encode64(q.to_s(2)),
              dp: UrlSafeBase64.encode64(dmp1.to_s(2)),
              dq: UrlSafeBase64.encode64(dmq1.to_s(2)),
              qi: UrlSafeBase64.encode64(iqmp.to_s(2)),
            )
          end
          JWK.new params
        end
      end

      module EC
        def to_jwk(ex_params = {})
          params = {
            kty: :EC,
            crv: curve_name,
            x: UrlSafeBase64.encode64([coordinates[:x]].pack('H*')),
            y: UrlSafeBase64.encode64([coordinates[:y]].pack('H*'))
          }.merge ex_params
          params[:d] = UrlSafeBase64.encode64([coordinates[:d]].pack('H*')) if private_key?
          JWK.new params
        end

        private

        def curve_name
          case group.curve_name
          when 'prime256v1'
            :'P-256'
          when 'secp384r1'
            :'P-384'
          when 'secp521r1'
            :'P-521'
          else
            raise UnknownAlgorithm.new('Unknown EC Curve')
          end
        end

        def coordinates
          unless @coordinates
            hex = public_key.to_bn.to_s(16)
            data_len = hex.length - 2
            hex_x = hex[2, data_len / 2]
            hex_y = hex[2 + data_len / 2, data_len / 2]
            @coordinates = {
              x: hex_x,
              y: hex_y
            }
            @coordinates[:d] = private_key.to_s(16) if private_key?
          end
          @coordinates
        end
      end
    end
  end
end

OpenSSL::PKey::RSA.send :include, JSON::JWK::JWKizable::RSA
OpenSSL::PKey::EC.send :include, JSON::JWK::JWKizable::EC

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
json-jwt-1.9.2 lib/json/jwk/jwkizable.rb
json-jwt-1.9.1 lib/json/jwk/jwkizable.rb
json-jwt-1.9.0 lib/json/jwk/jwkizable.rb
json-jwt-1.8.3 lib/json/jwk/jwkizable.rb
json-jwt-1.8.2 lib/json/jwk/jwkizable.rb
json-jwt-1.8.1 lib/json/jwk/jwkizable.rb
json-jwt-1.8.1.pre lib/json/jwk/jwkizable.rb