Documentation ¶
Index ¶
Constants ¶
const ( // ASCII is ASCII encoding ASCII = iota // BCD is "left-aligned" BCD BCD )
const ( // ErrInvalidEncoder is given when an invalid encoder is not supported ErrInvalidEncoder string = "invalid encoder" // ErrInvalidLengthEncoder is given when the length of an encoder is invalid ErrInvalidLengthEncoder string = "invalid length encoder" // ErrInvalidLengthHead is given when the length of the head is invalid ErrInvalidLengthHead string = "invalid length head" // ErrMissingLength is given when the length of a field is missing ErrMissingLength string = "missing length" // ErrValueTooLong is given when the length of the field is different from the length supplied ErrValueTooLong string = "length of value is longer than definition; type=%s, def_len=%d, len=%d" // ErrBadRaw is given when the raw data is malformed ErrBadRaw string = "bad raw data" // ErrParseLengthFailed is given when the length of the raw data is invalid ErrParseLengthFailed string = "parse length head failed" )
const ( // TagField defines the data field type TagField string = "field" // TagEncode defines the data encoding type TagEncode string = "encode" // TagLength defines the data encoding length TagLength string = "length" )
const Version = "v0.2.2"
Version number
Variables ¶
This section is empty.
Functions ¶
func UTF8ToWindows1252 ¶
UTF8ToWindows1252 converts text encoded in UTF-8 to Windows-1252 or CP-1252 encoding
Types ¶
type Alphanumeric ¶
type Alphanumeric struct {
Value string
}
An Alphanumeric contains alphanumeric value in fix length. The only supported encoder is ASCII. Length is required for marshaling and unmarshaling.
func NewAlphanumeric ¶
func NewAlphanumeric(val string) *Alphanumeric
NewAlphanumeric create new Alphanumeric field
func (*Alphanumeric) Bytes ¶
func (a *Alphanumeric) Bytes(encoder, lenEncoder, length int) ([]byte, error)
Bytes encode Alphanumeric field to bytes
func (*Alphanumeric) IsEmpty ¶
func (a *Alphanumeric) IsEmpty() bool
IsEmpty check Alphanumeric field for empty value
type Binary ¶
Binary contains binary value
type DataField ¶
type DataField interface { // Byte representation of current field. Bytes(encoder, lenEncoder, length int) ([]byte, error) // Load unmarshal byte value into DataField according to the // specific arguments. It returns the number of bytes actually read. Load(raw []byte, encoder, lenEncoder, length int) (int, error) // IsEmpty check is field empty IsEmpty() bool }
DataField interface for ISO 8583 fields
type L8var ¶
type L8var struct {
Value []byte
}
L8var contains bytes in non-fixed length field, first 8 symbols of field contains length
type Lllnumeric ¶
type Lllnumeric struct {
Value string
}
A Lllnumeric contains numeric value only in non-fix length, contains length in first 3 symbols. It holds numeric value as a string. Supportted encoder are ascii, bcd and rbcd. Length is required for marshaling and unmarshaling.
func NewLllnumeric ¶
func NewLllnumeric(val string) *Lllnumeric
NewLllnumeric create new Lllnumeric field
func (*Lllnumeric) Bytes ¶
func (l *Lllnumeric) Bytes(encoder, lenEncoder, length int) ([]byte, error)
Bytes encode Lllnumeric field to bytes
func (*Lllnumeric) IsEmpty ¶
func (l *Lllnumeric) IsEmpty() bool
IsEmpty check Lllnumeric field for empty value
type Lllvar ¶
type Lllvar struct {
Value []byte
}
Lllvar contains bytes in non-fixed length field, first 3 symbols of field contains length
type Llnumeric ¶
type Llnumeric struct {
Value string
}
A Llnumeric contains numeric value only in non-fix length, contains length in first 2 symbols. It holds numeric value as a string. Supportted encoder are ascii, bcd and rbcd. Length is required for marshaling and unmarshalling.
func NewLlnumeric ¶
NewLlnumeric create new Llnumeric field
type Llvar ¶
type Llvar struct {
Value []byte
}
Llvar contains bytes in non-fixed length field, first 2 symbols of field contains length
type Message ¶
type Message struct { // Mti is the Message Type Indicator Mti string MtiEncode int SecondBitmap bool ASCIIBitmap bool // Data elements are the individual fields carrying the transaction information Data interface{} }
Message is structure for ISO 8583 message encode and decode
func NewMessage ¶
NewMessage creates new Message structure
type Numeric ¶
type Numeric struct {
Value string
}
A Numeric contains numeric value only in fix length. It holds numeric value as a string. Supportted encoder are ascii, bcd and rbcd. Length is required for marshaling and unmarshaling.