2021-10-27 07:41:05 +00:00
|
|
|
package version
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
"github.com/nspcc-dev/neofs-api-go/v2/refs"
|
|
|
|
)
|
|
|
|
|
2022-03-23 15:35:44 +00:00
|
|
|
// Version represents revision number in SemVer scheme.
|
2021-10-27 07:41:05 +00:00
|
|
|
//
|
2022-03-23 15:35:44 +00:00
|
|
|
// Version is mutually compatible with github.com/nspcc-dev/neofs-api-go/v2/refs.Version
|
|
|
|
// message. See ReadFromV2 / WriteToV2 methods.
|
2021-10-27 07:41:05 +00:00
|
|
|
//
|
2022-03-23 15:35:44 +00:00
|
|
|
// Instances can be created using built-in var declaration.
|
|
|
|
//
|
|
|
|
// Note that direct typecast is not safe and may result in loss of compatibility:
|
2022-08-24 14:17:40 +00:00
|
|
|
//
|
|
|
|
// _ = Version(refs.Version{}) // not recommended
|
2022-03-23 15:35:44 +00:00
|
|
|
type Version refs.Version
|
2021-10-27 07:41:05 +00:00
|
|
|
|
2022-07-06 07:39:38 +00:00
|
|
|
const sdkMjr, sdkMnr = 2, 13
|
2022-03-23 15:35:44 +00:00
|
|
|
|
|
|
|
// Current returns Version instance that initialized to the
|
|
|
|
// latest supported NeoFS API revision number in SDK.
|
|
|
|
func Current() (v Version) {
|
2021-10-27 07:41:05 +00:00
|
|
|
v.SetMajor(sdkMjr)
|
|
|
|
v.SetMinor(sdkMnr)
|
|
|
|
return v
|
|
|
|
}
|
|
|
|
|
|
|
|
// Major returns major number of the revision.
|
|
|
|
func (v *Version) Major() uint32 {
|
|
|
|
return (*refs.Version)(v).GetMajor()
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetMajor sets major number of the revision.
|
|
|
|
func (v *Version) SetMajor(val uint32) {
|
|
|
|
(*refs.Version)(v).SetMajor(val)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Minor returns minor number of the revision.
|
|
|
|
func (v *Version) Minor() uint32 {
|
|
|
|
return (*refs.Version)(v).GetMinor()
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetMinor sets minor number of the revision.
|
|
|
|
func (v *Version) SetMinor(val uint32) {
|
|
|
|
(*refs.Version)(v).SetMinor(val)
|
|
|
|
}
|
|
|
|
|
2022-03-23 15:35:44 +00:00
|
|
|
// WriteToV2 writes Version to the refs.Version message.
|
|
|
|
// The message must not be nil.
|
2021-10-27 07:41:05 +00:00
|
|
|
//
|
2022-03-23 15:35:44 +00:00
|
|
|
// See also ReadFromV2.
|
|
|
|
func (v Version) WriteToV2(m *refs.Version) {
|
|
|
|
*m = (refs.Version)(v)
|
2021-10-27 07:41:05 +00:00
|
|
|
}
|
|
|
|
|
2022-07-07 10:51:05 +00:00
|
|
|
// ReadFromV2 reads Version from the refs.Version message. Checks if the message
|
|
|
|
// conforms to NeoFS API V2 protocol.
|
2022-03-23 15:35:44 +00:00
|
|
|
//
|
|
|
|
// See also WriteToV2.
|
2022-07-07 10:51:05 +00:00
|
|
|
func (v *Version) ReadFromV2(m refs.Version) error {
|
2022-03-23 15:35:44 +00:00
|
|
|
*v = Version(m)
|
2022-07-07 10:51:05 +00:00
|
|
|
return nil
|
2021-10-27 07:41:05 +00:00
|
|
|
}
|
|
|
|
|
2022-04-12 08:43:34 +00:00
|
|
|
// String implements fmt.Stringer.
|
|
|
|
//
|
|
|
|
// String is designed to be human-readable, and its format MAY differ between
|
|
|
|
// SDK versions.
|
2022-03-23 15:35:44 +00:00
|
|
|
func (v Version) String() string {
|
2022-04-12 08:43:34 +00:00
|
|
|
return EncodeToString(v)
|
|
|
|
}
|
|
|
|
|
|
|
|
// EncodeToString encodes version according to format from specification:
|
|
|
|
// semver formatted value without patch and with v prefix, e.g. 'v2.1'.
|
|
|
|
func EncodeToString(v Version) string {
|
2022-03-23 15:35:44 +00:00
|
|
|
return fmt.Sprintf("v%d.%d", v.Major(), v.Minor())
|
2021-10-27 07:41:05 +00:00
|
|
|
}
|
2022-03-28 08:15:52 +00:00
|
|
|
|
|
|
|
// Equal returns true if versions are identical.
|
|
|
|
func (v Version) Equal(v2 Version) bool {
|
|
|
|
return v.Major() == v2.Major() &&
|
|
|
|
v.Minor() == v2.Minor()
|
|
|
|
}
|
2023-01-31 08:18:45 +00:00
|
|
|
|
|
|
|
// MarshalJSON encodes Version into a JSON format of the NeoFS API
|
|
|
|
// protocol (Protocol Buffers JSON).
|
|
|
|
//
|
|
|
|
// See also UnmarshalJSON.
|
|
|
|
func (v Version) MarshalJSON() ([]byte, error) {
|
|
|
|
var m refs.Version
|
|
|
|
v.WriteToV2(&m)
|
|
|
|
|
|
|
|
return m.MarshalJSON()
|
|
|
|
}
|
|
|
|
|
|
|
|
// UnmarshalJSON decodes NeoFS API protocol JSON format into the Version
|
|
|
|
// (Protocol Buffers JSON). Returns an error describing a format violation.
|
|
|
|
//
|
|
|
|
// See also MarshalJSON.
|
|
|
|
func (v *Version) UnmarshalJSON(data []byte) error {
|
|
|
|
var m refs.Version
|
|
|
|
|
|
|
|
err := m.UnmarshalJSON(data)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
return v.ReadFromV2(m)
|
|
|
|
}
|