From 2e4aaaaefdbfdf06515663986ed884fed1b2177e Mon Sep 17 00:00:00 2001 From: Gautam Botrel Date: Wed, 24 Jan 2024 12:29:27 -0600 Subject: [PATCH] feat: adds byteorder option in mimc `New` (#480) * feat: fix #479 adds byteorder option in mimc * fix: add missing files from previous commit --- ecc/bls12-377/fr/mimc/mimc.go | 11 ++-- ecc/bls12-377/fr/mimc/options.go | 50 +++++++++++++++++ ecc/bls12-378/fr/mimc/mimc.go | 11 ++-- ecc/bls12-378/fr/mimc/options.go | 50 +++++++++++++++++ ecc/bls12-381/fr/mimc/mimc.go | 11 ++-- ecc/bls12-381/fr/mimc/options.go | 50 +++++++++++++++++ ecc/bls24-315/fr/mimc/mimc.go | 11 ++-- ecc/bls24-315/fr/mimc/options.go | 50 +++++++++++++++++ ecc/bls24-317/fr/mimc/mimc.go | 11 ++-- ecc/bls24-317/fr/mimc/options.go | 50 +++++++++++++++++ ecc/bn254/fr/mimc/mimc.go | 11 ++-- ecc/bn254/fr/mimc/mimc_test.go | 55 +++++++++++++++++++ ecc/bn254/fr/mimc/options.go | 50 +++++++++++++++++ ecc/bw6-633/fr/mimc/mimc.go | 11 ++-- ecc/bw6-633/fr/mimc/options.go | 50 +++++++++++++++++ ecc/bw6-756/fr/mimc/mimc.go | 11 ++-- ecc/bw6-756/fr/mimc/options.go | 50 +++++++++++++++++ ecc/bw6-761/fr/mimc/mimc.go | 11 ++-- ecc/bw6-761/fr/mimc/options.go | 50 +++++++++++++++++ .../generator/crypto/hash/mimc/generate.go | 1 + .../crypto/hash/mimc/template/mimc.go.tmpl | 9 +-- .../crypto/hash/mimc/template/options.go.tmpl | 32 +++++++++++ 22 files changed, 606 insertions(+), 40 deletions(-) create mode 100644 ecc/bls12-377/fr/mimc/options.go create mode 100644 ecc/bls12-378/fr/mimc/options.go create mode 100644 ecc/bls12-381/fr/mimc/options.go create mode 100644 ecc/bls24-315/fr/mimc/options.go create mode 100644 ecc/bls24-317/fr/mimc/options.go create mode 100644 ecc/bn254/fr/mimc/options.go create mode 100644 ecc/bw6-633/fr/mimc/options.go create mode 100644 ecc/bw6-756/fr/mimc/options.go create mode 100644 ecc/bw6-761/fr/mimc/options.go create mode 100644 internal/generator/crypto/hash/mimc/template/options.go.tmpl diff --git a/ecc/bls12-377/fr/mimc/mimc.go b/ecc/bls12-377/fr/mimc/mimc.go index d393f0d742..ea08f11742 100644 --- a/ecc/bls12-377/fr/mimc/mimc.go +++ b/ecc/bls12-377/fr/mimc/mimc.go @@ -41,8 +41,9 @@ var ( // digest represents the partial evaluation of the checksum // along with the params of the mimc function type digest struct { - h fr.Element - data []fr.Element // data to hash + h fr.Element + data []fr.Element // data to hash + byteOrder fr.ByteOrder } // GetConstants exposed to be used in gnark @@ -56,9 +57,11 @@ func GetConstants() []big.Int { } // NewMiMC returns a MiMCImpl object, pure-go reference implementation -func NewMiMC() hash.Hash { +func NewMiMC(opts ...Option) hash.Hash { d := new(digest) d.Reset() + cfg := mimcOptions(opts...) + d.byteOrder = cfg.byteOrder return d } @@ -111,7 +114,7 @@ func (d *digest) Write(p []byte) (int, error) { var start int for start = 0; start < len(p); start += BlockSize { - if elem, err := fr.BigEndian.Element((*[BlockSize]byte)(p[start : start+BlockSize])); err == nil { + if elem, err := d.byteOrder.Element((*[BlockSize]byte)(p[start : start+BlockSize])); err == nil { d.data = append(d.data, elem) } else { return 0, err diff --git a/ecc/bls12-377/fr/mimc/options.go b/ecc/bls12-377/fr/mimc/options.go new file mode 100644 index 0000000000..be68e4b58f --- /dev/null +++ b/ecc/bls12-377/fr/mimc/options.go @@ -0,0 +1,50 @@ +// Copyright 2020 Consensys Software Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// Code generated by consensys/gnark-crypto DO NOT EDIT + +package mimc + +import ( + "github.com/consensys/gnark-crypto/ecc/bls12-377/fr" +) + +// Option defines option for altering the behavior of the MiMC hasher. +// See the descriptions of functions returning instances of this type for +// particular options. +type Option func(*mimcConfig) + +type mimcConfig struct { + byteOrder fr.ByteOrder +} + +// default options +func mimcOptions(opts ...Option) mimcConfig { + // apply options + opt := mimcConfig{ + byteOrder: fr.BigEndian, + } + for _, option := range opts { + option(&opt) + } + return opt +} + +// WithByteOrder sets the byte order used to decode the input +// in the Write method. Default is BigEndian. +func WithByteOrder(byteOrder fr.ByteOrder) Option { + return func(opt *mimcConfig) { + opt.byteOrder = byteOrder + } +} diff --git a/ecc/bls12-378/fr/mimc/mimc.go b/ecc/bls12-378/fr/mimc/mimc.go index 38cde39052..c351124ae4 100644 --- a/ecc/bls12-378/fr/mimc/mimc.go +++ b/ecc/bls12-378/fr/mimc/mimc.go @@ -41,8 +41,9 @@ var ( // digest represents the partial evaluation of the checksum // along with the params of the mimc function type digest struct { - h fr.Element - data []fr.Element // data to hash + h fr.Element + data []fr.Element // data to hash + byteOrder fr.ByteOrder } // GetConstants exposed to be used in gnark @@ -56,9 +57,11 @@ func GetConstants() []big.Int { } // NewMiMC returns a MiMCImpl object, pure-go reference implementation -func NewMiMC() hash.Hash { +func NewMiMC(opts ...Option) hash.Hash { d := new(digest) d.Reset() + cfg := mimcOptions(opts...) + d.byteOrder = cfg.byteOrder return d } @@ -111,7 +114,7 @@ func (d *digest) Write(p []byte) (int, error) { var start int for start = 0; start < len(p); start += BlockSize { - if elem, err := fr.BigEndian.Element((*[BlockSize]byte)(p[start : start+BlockSize])); err == nil { + if elem, err := d.byteOrder.Element((*[BlockSize]byte)(p[start : start+BlockSize])); err == nil { d.data = append(d.data, elem) } else { return 0, err diff --git a/ecc/bls12-378/fr/mimc/options.go b/ecc/bls12-378/fr/mimc/options.go new file mode 100644 index 0000000000..c5ae735e15 --- /dev/null +++ b/ecc/bls12-378/fr/mimc/options.go @@ -0,0 +1,50 @@ +// Copyright 2020 Consensys Software Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// Code generated by consensys/gnark-crypto DO NOT EDIT + +package mimc + +import ( + "github.com/consensys/gnark-crypto/ecc/bls12-378/fr" +) + +// Option defines option for altering the behavior of the MiMC hasher. +// See the descriptions of functions returning instances of this type for +// particular options. +type Option func(*mimcConfig) + +type mimcConfig struct { + byteOrder fr.ByteOrder +} + +// default options +func mimcOptions(opts ...Option) mimcConfig { + // apply options + opt := mimcConfig{ + byteOrder: fr.BigEndian, + } + for _, option := range opts { + option(&opt) + } + return opt +} + +// WithByteOrder sets the byte order used to decode the input +// in the Write method. Default is BigEndian. +func WithByteOrder(byteOrder fr.ByteOrder) Option { + return func(opt *mimcConfig) { + opt.byteOrder = byteOrder + } +} diff --git a/ecc/bls12-381/fr/mimc/mimc.go b/ecc/bls12-381/fr/mimc/mimc.go index 716a655b45..f492cadf96 100644 --- a/ecc/bls12-381/fr/mimc/mimc.go +++ b/ecc/bls12-381/fr/mimc/mimc.go @@ -41,8 +41,9 @@ var ( // digest represents the partial evaluation of the checksum // along with the params of the mimc function type digest struct { - h fr.Element - data []fr.Element // data to hash + h fr.Element + data []fr.Element // data to hash + byteOrder fr.ByteOrder } // GetConstants exposed to be used in gnark @@ -56,9 +57,11 @@ func GetConstants() []big.Int { } // NewMiMC returns a MiMCImpl object, pure-go reference implementation -func NewMiMC() hash.Hash { +func NewMiMC(opts ...Option) hash.Hash { d := new(digest) d.Reset() + cfg := mimcOptions(opts...) + d.byteOrder = cfg.byteOrder return d } @@ -111,7 +114,7 @@ func (d *digest) Write(p []byte) (int, error) { var start int for start = 0; start < len(p); start += BlockSize { - if elem, err := fr.BigEndian.Element((*[BlockSize]byte)(p[start : start+BlockSize])); err == nil { + if elem, err := d.byteOrder.Element((*[BlockSize]byte)(p[start : start+BlockSize])); err == nil { d.data = append(d.data, elem) } else { return 0, err diff --git a/ecc/bls12-381/fr/mimc/options.go b/ecc/bls12-381/fr/mimc/options.go new file mode 100644 index 0000000000..20d1dafba8 --- /dev/null +++ b/ecc/bls12-381/fr/mimc/options.go @@ -0,0 +1,50 @@ +// Copyright 2020 Consensys Software Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// Code generated by consensys/gnark-crypto DO NOT EDIT + +package mimc + +import ( + "github.com/consensys/gnark-crypto/ecc/bls12-381/fr" +) + +// Option defines option for altering the behavior of the MiMC hasher. +// See the descriptions of functions returning instances of this type for +// particular options. +type Option func(*mimcConfig) + +type mimcConfig struct { + byteOrder fr.ByteOrder +} + +// default options +func mimcOptions(opts ...Option) mimcConfig { + // apply options + opt := mimcConfig{ + byteOrder: fr.BigEndian, + } + for _, option := range opts { + option(&opt) + } + return opt +} + +// WithByteOrder sets the byte order used to decode the input +// in the Write method. Default is BigEndian. +func WithByteOrder(byteOrder fr.ByteOrder) Option { + return func(opt *mimcConfig) { + opt.byteOrder = byteOrder + } +} diff --git a/ecc/bls24-315/fr/mimc/mimc.go b/ecc/bls24-315/fr/mimc/mimc.go index 1912d66dfe..289944edc4 100644 --- a/ecc/bls24-315/fr/mimc/mimc.go +++ b/ecc/bls24-315/fr/mimc/mimc.go @@ -41,8 +41,9 @@ var ( // digest represents the partial evaluation of the checksum // along with the params of the mimc function type digest struct { - h fr.Element - data []fr.Element // data to hash + h fr.Element + data []fr.Element // data to hash + byteOrder fr.ByteOrder } // GetConstants exposed to be used in gnark @@ -56,9 +57,11 @@ func GetConstants() []big.Int { } // NewMiMC returns a MiMCImpl object, pure-go reference implementation -func NewMiMC() hash.Hash { +func NewMiMC(opts ...Option) hash.Hash { d := new(digest) d.Reset() + cfg := mimcOptions(opts...) + d.byteOrder = cfg.byteOrder return d } @@ -111,7 +114,7 @@ func (d *digest) Write(p []byte) (int, error) { var start int for start = 0; start < len(p); start += BlockSize { - if elem, err := fr.BigEndian.Element((*[BlockSize]byte)(p[start : start+BlockSize])); err == nil { + if elem, err := d.byteOrder.Element((*[BlockSize]byte)(p[start : start+BlockSize])); err == nil { d.data = append(d.data, elem) } else { return 0, err diff --git a/ecc/bls24-315/fr/mimc/options.go b/ecc/bls24-315/fr/mimc/options.go new file mode 100644 index 0000000000..e25f3cce22 --- /dev/null +++ b/ecc/bls24-315/fr/mimc/options.go @@ -0,0 +1,50 @@ +// Copyright 2020 Consensys Software Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// Code generated by consensys/gnark-crypto DO NOT EDIT + +package mimc + +import ( + "github.com/consensys/gnark-crypto/ecc/bls24-315/fr" +) + +// Option defines option for altering the behavior of the MiMC hasher. +// See the descriptions of functions returning instances of this type for +// particular options. +type Option func(*mimcConfig) + +type mimcConfig struct { + byteOrder fr.ByteOrder +} + +// default options +func mimcOptions(opts ...Option) mimcConfig { + // apply options + opt := mimcConfig{ + byteOrder: fr.BigEndian, + } + for _, option := range opts { + option(&opt) + } + return opt +} + +// WithByteOrder sets the byte order used to decode the input +// in the Write method. Default is BigEndian. +func WithByteOrder(byteOrder fr.ByteOrder) Option { + return func(opt *mimcConfig) { + opt.byteOrder = byteOrder + } +} diff --git a/ecc/bls24-317/fr/mimc/mimc.go b/ecc/bls24-317/fr/mimc/mimc.go index c0050e0568..b9024e7e5b 100644 --- a/ecc/bls24-317/fr/mimc/mimc.go +++ b/ecc/bls24-317/fr/mimc/mimc.go @@ -41,8 +41,9 @@ var ( // digest represents the partial evaluation of the checksum // along with the params of the mimc function type digest struct { - h fr.Element - data []fr.Element // data to hash + h fr.Element + data []fr.Element // data to hash + byteOrder fr.ByteOrder } // GetConstants exposed to be used in gnark @@ -56,9 +57,11 @@ func GetConstants() []big.Int { } // NewMiMC returns a MiMCImpl object, pure-go reference implementation -func NewMiMC() hash.Hash { +func NewMiMC(opts ...Option) hash.Hash { d := new(digest) d.Reset() + cfg := mimcOptions(opts...) + d.byteOrder = cfg.byteOrder return d } @@ -111,7 +114,7 @@ func (d *digest) Write(p []byte) (int, error) { var start int for start = 0; start < len(p); start += BlockSize { - if elem, err := fr.BigEndian.Element((*[BlockSize]byte)(p[start : start+BlockSize])); err == nil { + if elem, err := d.byteOrder.Element((*[BlockSize]byte)(p[start : start+BlockSize])); err == nil { d.data = append(d.data, elem) } else { return 0, err diff --git a/ecc/bls24-317/fr/mimc/options.go b/ecc/bls24-317/fr/mimc/options.go new file mode 100644 index 0000000000..2ef5de3f57 --- /dev/null +++ b/ecc/bls24-317/fr/mimc/options.go @@ -0,0 +1,50 @@ +// Copyright 2020 Consensys Software Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// Code generated by consensys/gnark-crypto DO NOT EDIT + +package mimc + +import ( + "github.com/consensys/gnark-crypto/ecc/bls24-317/fr" +) + +// Option defines option for altering the behavior of the MiMC hasher. +// See the descriptions of functions returning instances of this type for +// particular options. +type Option func(*mimcConfig) + +type mimcConfig struct { + byteOrder fr.ByteOrder +} + +// default options +func mimcOptions(opts ...Option) mimcConfig { + // apply options + opt := mimcConfig{ + byteOrder: fr.BigEndian, + } + for _, option := range opts { + option(&opt) + } + return opt +} + +// WithByteOrder sets the byte order used to decode the input +// in the Write method. Default is BigEndian. +func WithByteOrder(byteOrder fr.ByteOrder) Option { + return func(opt *mimcConfig) { + opt.byteOrder = byteOrder + } +} diff --git a/ecc/bn254/fr/mimc/mimc.go b/ecc/bn254/fr/mimc/mimc.go index 719ed4e8a9..c0158fc3a8 100644 --- a/ecc/bn254/fr/mimc/mimc.go +++ b/ecc/bn254/fr/mimc/mimc.go @@ -41,8 +41,9 @@ var ( // digest represents the partial evaluation of the checksum // along with the params of the mimc function type digest struct { - h fr.Element - data []fr.Element // data to hash + h fr.Element + data []fr.Element // data to hash + byteOrder fr.ByteOrder } // GetConstants exposed to be used in gnark @@ -56,9 +57,11 @@ func GetConstants() []big.Int { } // NewMiMC returns a MiMCImpl object, pure-go reference implementation -func NewMiMC() hash.Hash { +func NewMiMC(opts ...Option) hash.Hash { d := new(digest) d.Reset() + cfg := mimcOptions(opts...) + d.byteOrder = cfg.byteOrder return d } @@ -111,7 +114,7 @@ func (d *digest) Write(p []byte) (int, error) { var start int for start = 0; start < len(p); start += BlockSize { - if elem, err := fr.BigEndian.Element((*[BlockSize]byte)(p[start : start+BlockSize])); err == nil { + if elem, err := d.byteOrder.Element((*[BlockSize]byte)(p[start : start+BlockSize])); err == nil { d.data = append(d.data, elem) } else { return 0, err diff --git a/ecc/bn254/fr/mimc/mimc_test.go b/ecc/bn254/fr/mimc/mimc_test.go index dbd9740ad7..73042f6c31 100644 --- a/ecc/bn254/fr/mimc/mimc_test.go +++ b/ecc/bn254/fr/mimc/mimc_test.go @@ -3,9 +3,11 @@ package mimc_test import ( "testing" + "github.com/consensys/gnark-crypto/ecc/bn254/fr" "github.com/consensys/gnark-crypto/ecc/bn254/fr/mimc" fiatshamir "github.com/consensys/gnark-crypto/fiat-shamir" "github.com/stretchr/testify/assert" + "github.com/stretchr/testify/require" ) func TestMiMCFiatShamir(t *testing.T) { @@ -16,3 +18,56 @@ func TestMiMCFiatShamir(t *testing.T) { _, err = fs.ComputeChallenge("c0") assert.NoError(t, err) } + +func TestByteOrder(t *testing.T) { + assert := require.New(t) + + var buf [fr.Bytes]byte + // if the 31 first bytes are FF, it's a valid FF in little endian, but not in big endian + for i := 0; i < fr.Bytes-1; i++ { + buf[i] = 0xFF + } + _, err := fr.BigEndian.Element(&buf) + assert.Error(err) + _, err = fr.LittleEndian.Element(&buf) + assert.NoError(err) + + { + // hashing buf with big endian should fail + mimcHash := mimc.NewMiMC(mimc.WithByteOrder(fr.BigEndian)) + _, err := mimcHash.Write(buf[:]) + assert.Error(err) + } + + { + // hashing buf with little endian should succeed + mimcHash := mimc.NewMiMC(mimc.WithByteOrder(fr.LittleEndian)) + _, err := mimcHash.Write(buf[:]) + assert.NoError(err) + } + + buf = [fr.Bytes]byte{} + // if the 31 bytes are FF, it's a valid FF in big endian, but not in little endian + for i := 1; i < fr.Bytes; i++ { + buf[i] = 0xFF + } + _, err = fr.BigEndian.Element(&buf) + assert.NoError(err) + _, err = fr.LittleEndian.Element(&buf) + assert.Error(err) + + { + // hashing buf with big endian should succeed + mimcHash := mimc.NewMiMC(mimc.WithByteOrder(fr.BigEndian)) + _, err := mimcHash.Write(buf[:]) + assert.NoError(err) + } + + { + // hashing buf with little endian should fail + mimcHash := mimc.NewMiMC(mimc.WithByteOrder(fr.LittleEndian)) + _, err := mimcHash.Write(buf[:]) + assert.Error(err) + } + +} diff --git a/ecc/bn254/fr/mimc/options.go b/ecc/bn254/fr/mimc/options.go new file mode 100644 index 0000000000..ae82317a1a --- /dev/null +++ b/ecc/bn254/fr/mimc/options.go @@ -0,0 +1,50 @@ +// Copyright 2020 Consensys Software Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// Code generated by consensys/gnark-crypto DO NOT EDIT + +package mimc + +import ( + "github.com/consensys/gnark-crypto/ecc/bn254/fr" +) + +// Option defines option for altering the behavior of the MiMC hasher. +// See the descriptions of functions returning instances of this type for +// particular options. +type Option func(*mimcConfig) + +type mimcConfig struct { + byteOrder fr.ByteOrder +} + +// default options +func mimcOptions(opts ...Option) mimcConfig { + // apply options + opt := mimcConfig{ + byteOrder: fr.BigEndian, + } + for _, option := range opts { + option(&opt) + } + return opt +} + +// WithByteOrder sets the byte order used to decode the input +// in the Write method. Default is BigEndian. +func WithByteOrder(byteOrder fr.ByteOrder) Option { + return func(opt *mimcConfig) { + opt.byteOrder = byteOrder + } +} diff --git a/ecc/bw6-633/fr/mimc/mimc.go b/ecc/bw6-633/fr/mimc/mimc.go index 9cce55e360..bbf620172b 100644 --- a/ecc/bw6-633/fr/mimc/mimc.go +++ b/ecc/bw6-633/fr/mimc/mimc.go @@ -41,8 +41,9 @@ var ( // digest represents the partial evaluation of the checksum // along with the params of the mimc function type digest struct { - h fr.Element - data []fr.Element // data to hash + h fr.Element + data []fr.Element // data to hash + byteOrder fr.ByteOrder } // GetConstants exposed to be used in gnark @@ -56,9 +57,11 @@ func GetConstants() []big.Int { } // NewMiMC returns a MiMCImpl object, pure-go reference implementation -func NewMiMC() hash.Hash { +func NewMiMC(opts ...Option) hash.Hash { d := new(digest) d.Reset() + cfg := mimcOptions(opts...) + d.byteOrder = cfg.byteOrder return d } @@ -111,7 +114,7 @@ func (d *digest) Write(p []byte) (int, error) { var start int for start = 0; start < len(p); start += BlockSize { - if elem, err := fr.BigEndian.Element((*[BlockSize]byte)(p[start : start+BlockSize])); err == nil { + if elem, err := d.byteOrder.Element((*[BlockSize]byte)(p[start : start+BlockSize])); err == nil { d.data = append(d.data, elem) } else { return 0, err diff --git a/ecc/bw6-633/fr/mimc/options.go b/ecc/bw6-633/fr/mimc/options.go new file mode 100644 index 0000000000..420ddbd064 --- /dev/null +++ b/ecc/bw6-633/fr/mimc/options.go @@ -0,0 +1,50 @@ +// Copyright 2020 Consensys Software Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// Code generated by consensys/gnark-crypto DO NOT EDIT + +package mimc + +import ( + "github.com/consensys/gnark-crypto/ecc/bw6-633/fr" +) + +// Option defines option for altering the behavior of the MiMC hasher. +// See the descriptions of functions returning instances of this type for +// particular options. +type Option func(*mimcConfig) + +type mimcConfig struct { + byteOrder fr.ByteOrder +} + +// default options +func mimcOptions(opts ...Option) mimcConfig { + // apply options + opt := mimcConfig{ + byteOrder: fr.BigEndian, + } + for _, option := range opts { + option(&opt) + } + return opt +} + +// WithByteOrder sets the byte order used to decode the input +// in the Write method. Default is BigEndian. +func WithByteOrder(byteOrder fr.ByteOrder) Option { + return func(opt *mimcConfig) { + opt.byteOrder = byteOrder + } +} diff --git a/ecc/bw6-756/fr/mimc/mimc.go b/ecc/bw6-756/fr/mimc/mimc.go index 8078aa6c3e..d53a5b0b2d 100644 --- a/ecc/bw6-756/fr/mimc/mimc.go +++ b/ecc/bw6-756/fr/mimc/mimc.go @@ -41,8 +41,9 @@ var ( // digest represents the partial evaluation of the checksum // along with the params of the mimc function type digest struct { - h fr.Element - data []fr.Element // data to hash + h fr.Element + data []fr.Element // data to hash + byteOrder fr.ByteOrder } // GetConstants exposed to be used in gnark @@ -56,9 +57,11 @@ func GetConstants() []big.Int { } // NewMiMC returns a MiMCImpl object, pure-go reference implementation -func NewMiMC() hash.Hash { +func NewMiMC(opts ...Option) hash.Hash { d := new(digest) d.Reset() + cfg := mimcOptions(opts...) + d.byteOrder = cfg.byteOrder return d } @@ -111,7 +114,7 @@ func (d *digest) Write(p []byte) (int, error) { var start int for start = 0; start < len(p); start += BlockSize { - if elem, err := fr.BigEndian.Element((*[BlockSize]byte)(p[start : start+BlockSize])); err == nil { + if elem, err := d.byteOrder.Element((*[BlockSize]byte)(p[start : start+BlockSize])); err == nil { d.data = append(d.data, elem) } else { return 0, err diff --git a/ecc/bw6-756/fr/mimc/options.go b/ecc/bw6-756/fr/mimc/options.go new file mode 100644 index 0000000000..7fbe2e2e1b --- /dev/null +++ b/ecc/bw6-756/fr/mimc/options.go @@ -0,0 +1,50 @@ +// Copyright 2020 Consensys Software Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// Code generated by consensys/gnark-crypto DO NOT EDIT + +package mimc + +import ( + "github.com/consensys/gnark-crypto/ecc/bw6-756/fr" +) + +// Option defines option for altering the behavior of the MiMC hasher. +// See the descriptions of functions returning instances of this type for +// particular options. +type Option func(*mimcConfig) + +type mimcConfig struct { + byteOrder fr.ByteOrder +} + +// default options +func mimcOptions(opts ...Option) mimcConfig { + // apply options + opt := mimcConfig{ + byteOrder: fr.BigEndian, + } + for _, option := range opts { + option(&opt) + } + return opt +} + +// WithByteOrder sets the byte order used to decode the input +// in the Write method. Default is BigEndian. +func WithByteOrder(byteOrder fr.ByteOrder) Option { + return func(opt *mimcConfig) { + opt.byteOrder = byteOrder + } +} diff --git a/ecc/bw6-761/fr/mimc/mimc.go b/ecc/bw6-761/fr/mimc/mimc.go index d93fe32f29..b53d52abfb 100644 --- a/ecc/bw6-761/fr/mimc/mimc.go +++ b/ecc/bw6-761/fr/mimc/mimc.go @@ -41,8 +41,9 @@ var ( // digest represents the partial evaluation of the checksum // along with the params of the mimc function type digest struct { - h fr.Element - data []fr.Element // data to hash + h fr.Element + data []fr.Element // data to hash + byteOrder fr.ByteOrder } // GetConstants exposed to be used in gnark @@ -56,9 +57,11 @@ func GetConstants() []big.Int { } // NewMiMC returns a MiMCImpl object, pure-go reference implementation -func NewMiMC() hash.Hash { +func NewMiMC(opts ...Option) hash.Hash { d := new(digest) d.Reset() + cfg := mimcOptions(opts...) + d.byteOrder = cfg.byteOrder return d } @@ -111,7 +114,7 @@ func (d *digest) Write(p []byte) (int, error) { var start int for start = 0; start < len(p); start += BlockSize { - if elem, err := fr.BigEndian.Element((*[BlockSize]byte)(p[start : start+BlockSize])); err == nil { + if elem, err := d.byteOrder.Element((*[BlockSize]byte)(p[start : start+BlockSize])); err == nil { d.data = append(d.data, elem) } else { return 0, err diff --git a/ecc/bw6-761/fr/mimc/options.go b/ecc/bw6-761/fr/mimc/options.go new file mode 100644 index 0000000000..996bb8862e --- /dev/null +++ b/ecc/bw6-761/fr/mimc/options.go @@ -0,0 +1,50 @@ +// Copyright 2020 Consensys Software Inc. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +// Code generated by consensys/gnark-crypto DO NOT EDIT + +package mimc + +import ( + "github.com/consensys/gnark-crypto/ecc/bw6-761/fr" +) + +// Option defines option for altering the behavior of the MiMC hasher. +// See the descriptions of functions returning instances of this type for +// particular options. +type Option func(*mimcConfig) + +type mimcConfig struct { + byteOrder fr.ByteOrder +} + +// default options +func mimcOptions(opts ...Option) mimcConfig { + // apply options + opt := mimcConfig{ + byteOrder: fr.BigEndian, + } + for _, option := range opts { + option(&opt) + } + return opt +} + +// WithByteOrder sets the byte order used to decode the input +// in the Write method. Default is BigEndian. +func WithByteOrder(byteOrder fr.ByteOrder) Option { + return func(opt *mimcConfig) { + opt.byteOrder = byteOrder + } +} diff --git a/internal/generator/crypto/hash/mimc/generate.go b/internal/generator/crypto/hash/mimc/generate.go index 9780bb79e2..3783931ba0 100644 --- a/internal/generator/crypto/hash/mimc/generate.go +++ b/internal/generator/crypto/hash/mimc/generate.go @@ -14,6 +14,7 @@ func Generate(conf config.Curve, baseDir string, bgen *bavard.BatchGenerator) er entries := []bavard.Entry{ {File: filepath.Join(baseDir, "doc.go"), Templates: []string{"doc.go.tmpl"}}, {File: filepath.Join(baseDir, "mimc.go"), Templates: []string{"mimc.go.tmpl"}}, + {File: filepath.Join(baseDir, "options.go"), Templates: []string{"options.go.tmpl"}}, } os.Remove(filepath.Join(baseDir, "utils.go")) os.Remove(filepath.Join(baseDir, "utils_test.go")) diff --git a/internal/generator/crypto/hash/mimc/template/mimc.go.tmpl b/internal/generator/crypto/hash/mimc/template/mimc.go.tmpl index a752a3bcc5..ad1f77bdb3 100644 --- a/internal/generator/crypto/hash/mimc/template/mimc.go.tmpl +++ b/internal/generator/crypto/hash/mimc/template/mimc.go.tmpl @@ -8,8 +8,6 @@ import ( "sync" ) - - const ( {{ if eq .Name "bn254" }} mimcNbRounds = 110 @@ -43,6 +41,7 @@ var ( type digest struct { h fr.Element data []fr.Element // data to hash + byteOrder fr.ByteOrder } // GetConstants exposed to be used in gnark @@ -56,9 +55,11 @@ func GetConstants() []big.Int { } // NewMiMC returns a MiMCImpl object, pure-go reference implementation -func NewMiMC() hash.Hash { +func NewMiMC(opts ...Option) hash.Hash { d := new(digest) d.Reset() + cfg := mimcOptions(opts...) + d.byteOrder = cfg.byteOrder return d } @@ -111,7 +112,7 @@ func (d *digest) Write(p []byte) (int, error) { var start int for start = 0; start < len(p); start += BlockSize { - if elem, err := fr.BigEndian.Element((*[BlockSize]byte)(p[start:start+BlockSize])); err == nil { + if elem, err := d.byteOrder.Element((*[BlockSize]byte)(p[start:start+BlockSize])); err == nil { d.data = append(d.data, elem) } else { return 0, err diff --git a/internal/generator/crypto/hash/mimc/template/options.go.tmpl b/internal/generator/crypto/hash/mimc/template/options.go.tmpl new file mode 100644 index 0000000000..8194914cce --- /dev/null +++ b/internal/generator/crypto/hash/mimc/template/options.go.tmpl @@ -0,0 +1,32 @@ +import ( + "github.com/consensys/gnark-crypto/ecc/{{ .Name }}/fr" +) + +// Option defines option for altering the behavior of the MiMC hasher. +// See the descriptions of functions returning instances of this type for +// particular options. +type Option func(*mimcConfig) + +type mimcConfig struct { + byteOrder fr.ByteOrder +} + +// default options +func mimcOptions(opts ...Option) mimcConfig { + // apply options + opt := mimcConfig{ + byteOrder: fr.BigEndian, + } + for _, option := range opts { + option(&opt) + } + return opt +} + +// WithByteOrder sets the byte order used to decode the input +// in the Write method. Default is BigEndian. +func WithByteOrder(byteOrder fr.ByteOrder) Option { + return func(opt *mimcConfig) { + opt.byteOrder = byteOrder + } +}