Skip to content

Releases: moov-io/iso8583

Release v0.13.0

26 Sep 11:44
c45c72b
Compare
Choose a tag to compare

Changelog

BREAKING CHANGE

  • remove Value field from String, Numeric, Binary fields and add Value() method instead (PR). This change makes code safer and addresses #195

Thank you @adamdecaf for your contributions!

Release v0.12.2

26 Sep 11:21
986a81f
Compare
Choose a tag to compare

Changelog

  • Fix variable length HEX prefix (#198)

Thank you @svz-ya, for the contributions!

v0.12.1

03 Aug 11:48
11ed597
Compare
Choose a tag to compare

Changelog

  • Add EBCDIC 1047 encoder & prefixer #190

Kudos to @Dakinola892 for the contributions!

Release v0.12.0

21 Jul 14:16
151e28e
Compare
Choose a tag to compare

Changelog

  • Introduce a SafeError type which is used to wrap around external errors, preventing the returned error message from displaying sensitive information, while still allowing errors to be matched (#185)
  • Use SafeError type to wrap external errors in the field and encoding packages, as these operate on the potentially sensitive data. Errors from prefix and network packages were not changed since these only operate on the length part of the data, exposing their details should be okay. (#185)

Kudos to @cheukwing for the contributions!

Release v0.11.2

13 Jul 13:48
92f3b34
Compare
Choose a tag to compare

Changelog

  • Return error when packing fields with zero length (#180)

Release v0.11.1

01 Mar 14:50
d04444b
Compare
Choose a tag to compare

Changelog

  • index tag of the field has priority over the field name when (un)marshal message data using go structs #168

Release v0.11.0

21 Feb 13:47
43d0fdb
Compare
Choose a tag to compare

Changelog

  • move describe.Message(out, mesage) into iso8583.Describe(message, out)
  • accept value (not only pointer) in message.Marshal(data) - it will make it easier to migrate from SetData as similar behavior was supported in it.

Release v0.10.0

15 Feb 20:28
7bead25
Compare
Choose a tag to compare

Changelog

  • added message.Marshal(data) which sets values of message fields using values provided in the data struct.
  • added support of index tag for both message.Marshal() and message.Unmarshal(). Now you can name your fields as you want and use index tag to specify the field index matching the ISO8583 specification. Examples are here and here.
  • removed iso8583.Unmarshal. Please, use message.Unmarshal instead.
  • removed message.Data()
  • deprecated message.SetData(data). Use message.Marshal() instead.
  • deprecated field.SetData(data). Use field.Marshal(data) instead.
  • changed current behavior of message.SetData(data). Before it could be used to get values into a struct after calling message.Unpack() like this:
data := &ISOMessage{}
mesage.SetData(data)
message.Unpack(rawMessage)

data.F1.Value //  in previous versions, values were populated during unpacking, but now they are not

Now message.SetData(data) only sets field values and you can't get values back to the struct using it. In order to get values into the struct you have to use message.Unmarshal(data) like this:

message.Unpack(rawMessage)
data := &ISOMessage{}
mesage.Unmarshall(data)

data.F1.Value //  now you can get the value

Migration Guide

Two main changes that you may need to do in your code:

  1. Replace message.SetData(data) with message.Marshal(data). Latter simply sets field values with values provided in the data struct. Without any side effects.
  2. Replace message.Data()(*YouMessageTypehere) with message.Unmarshal(data). It sets data struct values with message field values. No side-effects.
  3. If you used SetData() with Unpack to get access to message field values, then you have to replace it with just message.Unmarshal(data).

You have to change your code from this

type ISO87Data struct {
	F0 *field.String
	F2 *field.String
	F4 *field.String
}

message := NewMessage(spec)
data := &ISO87Data{}
err := message.SetData(data) // you "link" data internally
err = message.Unpack(rawMsg) // here values are populated into linked data struct. it will not work anymore.

// access field values
data.F0.Value
data.F2.Value
data.F4.Value

to this:

type ISO87Data struct {
	F0 *field.String
	F2 *field.String
	F4 *field.String
}

message := NewMessage(spec)
err := message.Unpack(rawMsg)

data := &ISO87Data{}
err = message.Unmarshal(data)

// access field values
data.F0.Value
data.F2.Value
data.F4.Value

If you have any questions, please, submit an issue or ask in our community Slack channel.

Release v0.10.0-beta

14 Feb 14:33
Compare
Choose a tag to compare
Release v0.10.0-beta Pre-release
Pre-release

Changes in this PR are not backward compatible! Few things have changed. Hopefully, migration will not be painful for you. If you have any questions, please, let us know here or in our community Slack channel.

Changes:

  • added message.Marshal(data) which sets values of message fields using values provided in data struct.
  • added support of index tag for both message.Marshal() and message.Unmarshal(). Now you can name your fields as you want and used index tag to specify field index in the ISO8583 specification. Examples are here and here.
  • removed iso8583.Unmarshal. Please, use message.Unmarshal instead.
  • removed message.Data()
  • deprecated message.SetData(data). Use message.Marshal() instead.
  • deprecated field.SetData(data). Use field.Marshal(data) instead.
  • changed current behavior of message.SetData(data). Before it could be used to get values into a struct after calling message.Unpack() like this:
data := &ISOMessage{}
mesage.SetData(data)
message.Unpack(rawMessage)

data.F1.Value //  if previous versions values were populated during unpacking, but now they are not

Now message.SetData(data) only sets field values. No way to get values back to the struct. In order to get values into struct you have to use message.Unmarshal(data) like this:

message.Unpack(rawMessage)
data := &ISOMessage{}
mesage.Unmarshall(data)

data.F1.Value //  now you can get the value

Migration Guide

Two main changes that you may need to do in your code:

  1. Replace message.SetData(data) with message.Marshal(data). Latter, simply sets field values with values provided in the data struct. Without any side-effects.
  2. Replce message.Data()(*YouMessageTypehere) with message.Unmarshal(data). It sets data` struct values with message field values. No side-effects.
  3. If you used SetData() and call Unpack to get access to message field values, replace it with message.Unmarshal(data).

You have to change your code from this

type ISO87Data struct {
	F0 *field.String
	F2 *field.String
	F4 *field.String
}

message := NewMessage(spec)
data := &ISO87Data{}
err := message.SetData(data) // you "link" data internally
err = message.Unpack(rawMsg) // here values are populated into linked data struct. no more.

// now you access you
data.F0.Value
data.F2.Value
data.F4.Value

to this:

type ISO87Data struct {
	F0 *field.String
	F2 *field.String
	F4 *field.String
}

message := NewMessage(spec)
err := message.Unpack(rawMsg)

data := &ISO87Data{}
err = message.Unmarshal(data)

// now you access fields in data
data.F0.Value
data.F2.Value
data.F4.Value

Release v0.9.0

09 Feb 18:03
07d52aa
Compare
Choose a tag to compare

Changelog

  • Fix panic on message.Unpack(nil) or empty/smaller than expected input slice length (#161)
  • Implement iso8583.Unmarshal method to populate data struct with message field values (#157)
  • Deprecated: message.Data() will be removed in the next release. Please, use iso8583.Unmarshal instead (see the example here).