Packages

class BerDerDecoder extends AnyRef

Decodes ASN.1 BER/DER encoded messages into Spark InternalRow values.

Decoding is schema-driven: the expected Asn1Type controls how each TLV element is interpreted and converted to its Spark SQL value.

Under AUTOMATIC / IMPLICIT TAGS modules each SEQUENCE component carries a context-specific tag [n]. The decoder inspects these tags to correctly align present elements with their schema components even when OPTIONAL fields are absent.

Source
BerDerDecoder.scala
Linear Supertypes
AnyRef, Any
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. BerDerDecoder
  2. AnyRef
  3. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. Protected

Instance Constructors

  1. new BerDerDecoder(registry: SchemaRegistry, moduleName: String, enumeratedAsInt: Boolean = false)

Value Members

  1. final def !=(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  2. final def ##: Int
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean
    Definition Classes
    AnyRef → Any
  4. final def asInstanceOf[T0]: T0
    Definition Classes
    Any
  5. def clone(): AnyRef
    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.CloneNotSupportedException]) @native()
  6. def decodeBytes(bytes: Array[Byte], schema: Asn1Type): InternalRow

    Decode a raw DER/BER byte array against schema.

    Decode a raw DER/BER byte array against schema. REAL elements (tag 9) are masked as OCTET STRING before BouncyCastle parsing.

  7. def decodeNext(is: InputStream, schema: Asn1Type, requiredSchema: Option[StructType] = None): Option[InternalRow]

    Read the next complete ASN.1 object from the stream and decode it against schema.

    Read the next complete ASN.1 object from the stream and decode it against schema. Returns None when the stream is exhausted.

    Reads one raw TLV frame before handing bytes to BouncyCastle so that REAL elements (tag 9, unknown to BC 1.80) can be masked in-place before parsing.

  8. def decodeValue(obj: ASN1Primitive, schema: Asn1Type): Any

    Decode one ASN.1 primitive to a Spark-internal value (not a Row).

  9. final def eq(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  10. def equals(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef → Any
  11. final def getClass(): Class[_ <: AnyRef]
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  12. def hashCode(): Int
    Definition Classes
    AnyRef → Any
    Annotations
    @native()
  13. final def isInstanceOf[T0]: Boolean
    Definition Classes
    Any
  14. final def ne(arg0: AnyRef): Boolean
    Definition Classes
    AnyRef
  15. final def notify(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  16. final def notifyAll(): Unit
    Definition Classes
    AnyRef
    Annotations
    @native()
  17. def openParser(is: InputStream): InputStream

    Return the InputStream to use for streaming.

    Return the InputStream to use for streaming. Retained for API symmetry with decodeNext; the caller passes this value back to decodeNext each time.

  18. final def synchronized[T0](arg0: => T0): T0
    Definition Classes
    AnyRef
  19. def toString(): String
    Definition Classes
    AnyRef → Any
  20. final def wait(): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException])
  21. final def wait(arg0: Long, arg1: Int): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException])
  22. final def wait(arg0: Long): Unit
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.InterruptedException]) @native()

Deprecated Value Members

  1. def finalize(): Unit
    Attributes
    protected[lang]
    Definition Classes
    AnyRef
    Annotations
    @throws(classOf[java.lang.Throwable]) @Deprecated
    Deprecated

    (Since version 9)

Inherited from AnyRef

Inherited from Any

Ungrouped