]> Cypherpunks.ru repositories - gogost.git/blob - news.texi
Download link for 4.2.2 release
[gogost.git] / news.texi
1 @node News
2 @unnumbered News
3
4 @table @strong
5
6 @anchor{Release 4.2.2}
7 @item 4.2.2
8     More 34.10-2012 test vectors.
9
10 @anchor{Release 4.2.1}
11 @item 4.2.1
12     Dummy release. More nicer tarballs.
13
14 @anchor{Release 4.2.0}
15 @item 4.2.0
16     @itemize
17     @item @code{PRF_IPSEC_PRFPLUS_GOSTR3411_2012_@{256,512@}} implementation
18     @item Generic @code{prf+} function (taken from IKEv2
19         (@url{https://tools.ietf.org/html/rfc5831.html, RFC 7296}))
20     @end itemize
21
22 @anchor{Release 4.1.0}
23 @item 4.1.0
24     @itemize
25     @item @code{ESPTREE}/@code{IKETREE} implementation
26     @item @code{CurveIdtc26gost34102012256paramSetB},
27         @code{CurveIdtc26gost34102012256paramSetC},
28         @code{CurveIdtc26gost34102012256paramSetD} curve aliases
29     @item Forbid any later GNU GPL version autousage
30         (project's licence now is GNU GPLv3 only)
31     @item Project now is @command{go get}-able and uses
32         @code{go.cypherpunks.ru} namespace:
33         @command{go get go.cypherpunks.ru/gogost},
34         @command{go get go.cypherpunks.ru/gogost/cmd/streebog@{256,512@}}
35     @end itemize
36
37 @anchor{Release 4.0}
38 @item 4.0
39     @itemize
40     @item Backward incompatible change: all keys passing to encryption
41         functions are slices now, not the fixed arrays. That heavily
42         simplifies the library usage
43     @item Fix bug with overwriting IVs memory in @code{gost28147.CFB*crypter}
44     @item @code{TLSTREE}, used in TLS 1.[23], implementation
45     @item @code{gost3410.KEK2012*} can be used with any curves, not only 512-bit ones
46     @item @code{gost3410.PrivateKey} satisfies @code{crypto.Signer} interface
47     @item @code{gost34112012*} hashes satisfy @code{encoding.Binary(Un)Marshaler}
48     @item Streebog256 HKDF test vectors
49     @end itemize
50
51 @anchor{Release 3.0}
52 @item 3.0
53     @itemize
54     @item Multilinear Galois Mode (MGM) block cipher mode for
55       64 and 128 bit ciphers
56     @item @code{KDF_GOSTR3411_2012_256} KDF
57     @item 34.12-2015 64-bit block cipher Магма (Magma)
58     @item Additional EAC 28147-89 Sbox
59     @item 34.10-2012 TC26 twisted Edwards curve related parameters
60     @item Coordinates conversion from twisted Edwards to Weierstrass
61       form and vice versa
62     @item Fixed @code{gost3410.PrivateKey}'s length validation
63     @item Backward incompatible change: @code{gost3410.NewCurve} takes
64       @code{big.Int}, instead of encoded integers
65     @item Backward incompatible Sbox and curves parameters renaming, to
66       comply with OIDs identifying them:
67 @verbatim
68 Gost2814789_TestParamSet       -> SboxIdGost2814789TestParamSet
69 Gost28147_CryptoProParamSetA   -> SboxIdGost2814789CryptoProAParamSet
70 Gost28147_CryptoProParamSetB   -> SboxIdGost2814789CryptoProBParamSet
71 Gost28147_CryptoProParamSetC   -> SboxIdGost2814789CryptoProCParamSet
72 Gost28147_CryptoProParamSetD   -> SboxIdGost2814789CryptoProDParamSet
73 GostR3411_94_TestParamSet      -> SboxIdGostR341194TestParamSet
74 Gost28147_tc26_ParamZ          -> SboxIdtc26gost28147paramZ
75 GostR3411_94_CryptoProParamSet -> SboxIdGostR341194CryptoProParamSet
76 EACParamSet                    -> SboxEACParamSet
77
78 CurveParamsGostR34102001cc            -> CurveGostR34102001ParamSetcc
79 CurveParamsGostR34102001Test          -> CurveIdGostR34102001TestParamSet
80 CurveParamsGostR34102001CryptoProA    -> CurveIdGostR34102001CryptoProAParamSet
81 CurveParamsGostR34102001CryptoProB    -> CurveIdGostR34102001CryptoProBParamSet
82 CurveParamsGostR34102001CryptoProC    -> CurveIdGostR34102001CryptoProCParamSet
83 CurveParamsGostR34102001CryptoProXchA -> CurveIdGostR34102001CryptoProXchAParamSet
84 CurveParamsGostR34102001CryptoProXchB -> CurveIdGostR34102001CryptoProXchBParamSet
85 CurveParamsGostR34102012TC26ParamSetA -> CurveIdtc26gost341012512paramSetA
86 CurveParamsGostR34102012TC26ParamSetB -> CurveIdtc26gost341012512paramSetB
87 @end verbatim
88     @item Various additional test vectors
89     @item go modules friendliness
90     @end itemize
91
92 @anchor{Release 2.0}
93 @item 2.0
94     @itemize
95     @item 34.11-2012 is split on two different modules:
96         @code{gost34112012256} and @code{gost34112012512}
97     @item 34.11-94's digest is reversed. Now it is compatible with TC26's
98       HMAC and PBKDF2 test vectors
99     @item @code{gogost-streebog} is split to @code{streebog256} and
100         @code{streebog512} correspondingly by analogy with sha* utilities
101     @item added VKO 34.10-2012 support with corresponding test vectors
102     @item @code{gost3410.DigestSizeX} is renamed to
103         @code{gost3410.ModeX} because it is not related to digest size,
104         but parameters and key sizes
105     @item KEK functions take @code{big.Int} UKM value. Use @code{NewUKM}
106         to unmarshal raw binary UKM
107     @end itemize
108
109 @anchor{Release 1.1}
110 @item 1.1
111     @itemize
112     @item gogost-streebog is able to use either 256 or 512 bits digest size
113     @item 34.13-2015 padding methods
114     @item 28147-89 CBC mode of operation
115     @end itemize
116
117 @end table