Skip to content
82 changes: 82 additions & 0 deletions address/common.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,82 @@
package address

import (
"github.com/multiversx/mx-chain-core-go/core"
"github.com/multiversx/mx-chain-core-go/hashing/sha256"
"math"
)

var baseSeed = []byte(core.OneAddressPrefix + "PublicKey")

var sha256Hasher = sha256.NewSha256()

func enhanceBaseSeed(
sourceAddress []byte,
sourceIdentifier core.AddressIdentifier,
targetIdentifier core.AddressIdentifier,
) []byte {
seed := append(baseSeed, sourceAddress...)
seed = append(seed, sourceIdentifier.Spread()...)
return append(seed, targetIdentifier.Spread()...)
}

func generateOffCurvePublicKey(seed []byte, generator func([]byte) ([]byte, error)) ([]byte, error) {
for bump := math.MaxUint8; bump >= 0; bump-- {
bumpedSeed := append(seed, byte(bump))
publicKey, err := generator(bumpedSeed)
if err != nil {
continue
}

return publicKey, nil
}
return nil, ErrFailedToGenerateOffCurvePublicKey
}

func isSourceInvalid(sourceAddress []byte, sourceIdentifier core.AddressIdentifier) bool {
switch sourceIdentifier {
case core.MVXAddressIdentifier:
return isPseudoMultiversXAddress(sourceAddress)
case core.ETHAddressIdentifier:
return isPseudoEthereumAddress(sourceAddress)
default:
return true
}
}

func generatePseudoAddressForSeed(seed []byte, targetIdentifier core.AddressIdentifier) ([]byte, error) {
switch targetIdentifier {
case core.MVXAddressIdentifier:
return generatePseudoMultiversXAddress(seed)
case core.ETHAddressIdentifier:
return generatePseudoEthereumAddress(seed)
default:
return nil, ErrAddressIdentifierNotHandled
}
}

func GeneratePseudoAddress(
sourceAddress []byte,
sourceIdentifier core.AddressIdentifier,
targetIdentifier core.AddressIdentifier,
) ([]byte, error) {
if sourceIdentifier == targetIdentifier {
return nil, ErrSourceIdentifierMatchesTargetIdentifier
}
if isSourceInvalid(sourceAddress, sourceIdentifier) {
return nil, ErrSourceAddressIsGenerated
}
seed := enhanceBaseSeed(sourceAddress, sourceIdentifier, targetIdentifier)
return generatePseudoAddressForSeed(seed, targetIdentifier)
}

func ConvertAddressToPseudoAddress(sourceAddress []byte, sourceIdentifier core.AddressIdentifier) ([]byte, error) {
switch sourceIdentifier {
case core.MVXAddressIdentifier:
return convertMultiversXAddressToPseudoAddress(sourceAddress)
case core.ETHAddressIdentifier:
return convertEthereumAddressToPseudoAddress(sourceAddress)
default:
return nil, ErrAddressIdentifierNotHandled
}
}
15 changes: 15 additions & 0 deletions address/errors.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
package address

import "errors"

var ErrFailedToGenerateOffCurvePublicKey = errors.New("failed to generate off curve public key")

var ErrAddressIdentifierNotHandled = errors.New("address identifier not handled")

var ErrSourceAddressIsGenerated = errors.New("source address is generated")

var ErrSourceIdentifierMatchesTargetIdentifier = errors.New("source identifier matches target identifier")

var ErrInvalidAddressSizeForPseudoConversion = errors.New("invalid address size for pseudo conversion")

var ErrGeneratedAddressIsSmartContractAddress = errors.New("generated address is smart contract address")
30 changes: 30 additions & 0 deletions address/generateEthereumPseudoAddress.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
package address

import (
"bytes"
ethCommon "github.com/ethereum/go-ethereum/common"
)

var ethAddressSize = ethCommon.AddressLength

var ethereumPseudoAddressPrefix = []byte{'e', 't', 'h', '-', '-', 'o', 'n', 'e'}

func generatePseudoEthereumAddress(seed []byte) ([]byte, error) {
baseAddress := sha256Hasher.Compute(string(seed))[:ethAddressSize]
return convertEthereumAddressToPseudoAddress(baseAddress)
}

func isPseudoEthereumAddress(address []byte) bool {
return bytes.HasPrefix(address, ethereumPseudoAddressPrefix)
}

func convertEthereumAddressToPseudoAddress(address []byte) ([]byte, error) {
if len(address) != ethAddressSize {
return nil, ErrInvalidAddressSizeForPseudoConversion
}

pseudoAddress := make([]byte, ethAddressSize)
copy(pseudoAddress, address)
copy(pseudoAddress, ethereumPseudoAddressPrefix)
return pseudoAddress, nil
}
12 changes: 12 additions & 0 deletions address/generateEthereumPseudoAddress_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
package address

import (
"github.com/multiversx/mx-chain-core-go/core"
"github.com/stretchr/testify/assert"
"testing"
)

func TestGeneratePseudoEthereumAddress(t *testing.T) {
_, err := GeneratePseudoAddress([]byte("multiversXAddress"), core.MVXAddressIdentifier, core.ETHAddressIdentifier)
assert.NoError(t, err)
}
51 changes: 51 additions & 0 deletions address/generateMultiversXPseudoAddress.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,51 @@
package address

import (
"bytes"
"filippo.io/edwards25519"
"github.com/multiversx/mx-chain-core-go/core"
)

var mvxAddressSize = len(core.SystemAccountAddress)

var multiversXPseudoAddressPrefix = []byte{'m', 'v', 'x', '-', '-', 'o', 'n', 'e'}

func generatePseudoMultiversXAddress(seed []byte) ([]byte, error) {
return generateOffCurvePublicKey(seed, func(bumpedSeed []byte) ([]byte, error) {
baseAddress := sha256Hasher.Compute(string(bumpedSeed))[:mvxAddressSize]
generatedAddress, err := convertMultiversXAddressToPseudoAddress(baseAddress)
if err != nil {
return nil, err
}
if core.IsSmartContractAddress(generatedAddress) {
return nil, ErrGeneratedAddressIsSmartContractAddress
}
if _, err = new(edwards25519.Point).SetBytes(generatedAddress); err != nil {
return nil, err
}

return generatedAddress, nil
})
}

func isPseudoMultiversXAddress(address []byte) bool {
return bytes.HasPrefix(referenceMultiversXPseudoAddressPrefix(address), multiversXPseudoAddressPrefix)
}

func convertMultiversXAddressToPseudoAddress(address []byte) ([]byte, error) {
if len(address) != mvxAddressSize {
return nil, ErrInvalidAddressSizeForPseudoConversion
}

pseudoAddress := make([]byte, mvxAddressSize)
copy(pseudoAddress, address)
copy(referenceMultiversXPseudoAddressPrefix(pseudoAddress), multiversXPseudoAddressPrefix)
return pseudoAddress, nil
}

func referenceMultiversXPseudoAddressPrefix(address []byte) []byte {
if core.IsSmartContractAddress(address) {
return address[core.NumInitCharactersForScAddress:]
}
return address
}
12 changes: 12 additions & 0 deletions address/generateMultiversXPseudoAddress_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
package address

import (
"github.com/multiversx/mx-chain-core-go/core"
"github.com/stretchr/testify/assert"
"testing"
)

func TestGeneratePseudoMultiversXAddress(t *testing.T) {
_, err := GeneratePseudoAddress([]byte("ethereumAddress"), core.ETHAddressIdentifier, core.MVXAddressIdentifier)
assert.NoError(t, err)
}
3 changes: 3 additions & 0 deletions errors.go
Original file line number Diff line number Diff line change
Expand Up @@ -93,3 +93,6 @@ var ErrNilLowLevelSigner = errors.New("nil low level signer")

// ErrFailedAuthentication is returned when a ciphertext could not be decrypted by a given private key
var ErrFailedAuthentication = errors.New("failed authentication for given ciphertext")

// ErrImplementationNotDefinedForSelector is returned when an implementation was not defined for a selector
var ErrImplementationNotDefinedForSelector = errors.New("implementation not defined for selector")
19 changes: 13 additions & 6 deletions go.mod
Original file line number Diff line number Diff line change
@@ -1,26 +1,33 @@
module github.com/multiversx/mx-chain-crypto-go

go 1.23
go 1.23.0

toolchain go1.24.9

replace github.com/multiversx/mx-chain-core-go => github.com/multiversx/mx-chain-core-sovereign-go v1.2.25-0.20251016085427-f3e9cd4fff15

require (
filippo.io/edwards25519 v1.0.0
github.com/decred/dcrd/dcrec/secp256k1/v4 v4.0.1
github.com/ethereum/go-ethereum v1.13.15
github.com/herumi/bls-go-binary v1.28.2
github.com/multiversx/mx-chain-core-go v1.4.0
github.com/multiversx/mx-chain-logger-go v1.1.0
github.com/stretchr/testify v1.8.0
golang.org/x/crypto v0.3.0
github.com/stretchr/testify v1.8.4
golang.org/x/crypto v0.33.0
)

require (
github.com/btcsuite/btcd/btcec/v2 v2.2.0 // indirect
github.com/davecgh/go-spew v1.1.1 // indirect
github.com/denisbrodbeck/machineid v1.0.1 // indirect
github.com/gogo/protobuf v1.3.2 // indirect
github.com/golang/protobuf v1.5.2 // indirect
github.com/golang/protobuf v1.5.4 // indirect
github.com/holiman/uint256 v1.2.4 // indirect
github.com/mr-tron/base58 v1.2.0 // indirect
github.com/pelletier/go-toml v1.9.3 // indirect
github.com/pmezard/go-difflib v1.0.0 // indirect
golang.org/x/sys v0.2.0 // indirect
google.golang.org/protobuf v1.26.0 // indirect
golang.org/x/sys v0.30.0 // indirect
google.golang.org/protobuf v1.36.5 // indirect
gopkg.in/yaml.v3 v3.0.1 // indirect
)
64 changes: 42 additions & 22 deletions go.sum
Original file line number Diff line number Diff line change
@@ -1,6 +1,17 @@
filippo.io/edwards25519 v1.0.0 h1:0wAIcmJUqRdI8IJ/3eGi5/HwXZWPujYXXlkrQogz0Ek=
filippo.io/edwards25519 v1.0.0/go.mod h1:N1IkdkCkiLB6tki+MYJoSx2JTY9NUlxZE7eHn5EwJns=
github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
github.com/bits-and-blooms/bitset v1.10.0 h1:ePXTeiPEazB5+opbv5fr8umg2R/1NlzgDsyepwsSr88=
github.com/bits-and-blooms/bitset v1.10.0/go.mod h1:7hO7Gc7Pp1vODcmWvKMRA9BNmbv6a/7QIWpPxHddWR8=
github.com/btcsuite/btcd/btcec/v2 v2.2.0 h1:fzn1qaOt32TuLjFlkzYSsBC35Q3KUjT1SwPxiMSCF5k=
github.com/btcsuite/btcd/btcec/v2 v2.2.0/go.mod h1:U7MHm051Al6XmscBQ0BoNydpOTsFAn707034b5nY8zU=
github.com/btcsuite/btcd/chaincfg/chainhash v1.0.1 h1:q0rUy8C/TYNBQS1+CGKw68tLOFYSNEs0TFnxxnS9+4U=
github.com/btcsuite/btcd/chaincfg/chainhash v1.0.1/go.mod h1:7SFka0XMvUgj3hfZtydOrQY2mwhPclbT2snogU7SQQc=
github.com/consensys/bavard v0.1.13 h1:oLhMLOFGTLdlda/kma4VOJazblc7IM5y5QPd2A/YjhQ=
github.com/consensys/bavard v0.1.13/go.mod h1:9ItSMtA/dXMAiL7BG6bqW2m3NdSEObYWoH223nGHukI=
github.com/consensys/gnark-crypto v0.12.1 h1:lHH39WuuFgVHONRl3J0LRBtuYdQTumFSDtJF7HpyG8M=
github.com/consensys/gnark-crypto v0.12.1/go.mod h1:v2Gy7L/4ZRosZ7Ivs+9SfUDr0f5UlG+EM5t7MPHiLuY=
github.com/crate-crypto/go-kzg-4844 v0.7.0 h1:C0vgZRk4q4EZ/JgPfzuSoxdCq3C3mOZMBShovmncxvA=
github.com/crate-crypto/go-kzg-4844 v0.7.0/go.mod h1:1kMhvPgI0Ky3yIa+9lFySEBUBXkYxeOi8ZF1sYioxhc=
github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c=
github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38=
github.com/decred/dcrd/crypto/blake256 v1.0.0 h1:/8DMNYp9SGi5f0w7uCm6d6M4OU2rGFK09Y2A4Xv7EE0=
Expand All @@ -9,39 +20,47 @@ github.com/decred/dcrd/dcrec/secp256k1/v4 v4.0.1 h1:YLtO71vCjJRCBcrPMtQ9nqBsqpA1
github.com/decred/dcrd/dcrec/secp256k1/v4 v4.0.1/go.mod h1:hyedUtir6IdtD/7lIxGeCxkaw7y45JueMRL4DIyJDKs=
github.com/denisbrodbeck/machineid v1.0.1 h1:geKr9qtkB876mXguW2X6TU4ZynleN6ezuMSRhl4D7AQ=
github.com/denisbrodbeck/machineid v1.0.1/go.mod h1:dJUwb7PTidGDeYyUBmXZ2GphQBbjJCrnectwCyxcUSI=
github.com/ethereum/c-kzg-4844 v0.4.0 h1:3MS1s4JtA868KpJxroZoepdV0ZKBp3u/O5HcZ7R3nlY=
github.com/ethereum/c-kzg-4844 v0.4.0/go.mod h1:VewdlzQmpT5QSrVhbBuGoCdFJkpaJlO1aQputP83wc0=
github.com/ethereum/go-ethereum v1.13.15 h1:U7sSGYGo4SPjP6iNIifNoyIAiNjrmQkz6EwQG+/EZWo=
github.com/ethereum/go-ethereum v1.13.15/go.mod h1:TN8ZiHrdJwSe8Cb6x+p0hs5CxhJZPbqB7hHkaUXcmIU=
github.com/gogo/protobuf v1.3.2 h1:Ov1cvc58UF3b5XjBnZv7+opcTcQFZebYjWzi34vdm4Q=
github.com/gogo/protobuf v1.3.2/go.mod h1:P1XiOD3dCwIKUDQYPy72D8LYyHL2YPYrpS2s69NZV8Q=
github.com/golang/protobuf v1.5.0/go.mod h1:FsONVRAS9T7sI+LIUmWTfcYkHO4aIWwzhcaSAoJOfIk=
github.com/golang/protobuf v1.5.2 h1:ROPKBNFfQgOUMifHyP+KYbvpjbdoFNs+aK7DXlji0Tw=
github.com/golang/protobuf v1.5.2/go.mod h1:XVQd3VNwM+JqD3oG2Ue2ip4fOMUkwXdXDdiuN0vRsmY=
github.com/google/go-cmp v0.5.5 h1:Khx7svrCpmxxtHBq5j2mp/xVjsi8hQMfNLvJFAlrGgU=
github.com/google/go-cmp v0.5.5/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE=
github.com/golang/protobuf v1.5.4 h1:i7eJL8qZTpSEXOPTxNKhASYpMn+8e5Q6AdndVa1dWek=
github.com/golang/protobuf v1.5.4/go.mod h1:lnTiLA8Wa4RWRcIUkrtSVa5nRhsEGBg48fD6rSs7xps=
github.com/google/go-cmp v0.5.9 h1:O2Tfq5qg4qc4AmwVlvv0oLiVAGB7enBSJ2x2DqQFi38=
github.com/google/go-cmp v0.5.9/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY=
github.com/herumi/bls-go-binary v1.28.2 h1:F0AezsC0M1a9aZjk7g0l2hMb1F56Xtpfku97pDndNZE=
github.com/herumi/bls-go-binary v1.28.2/go.mod h1:O4Vp1AfR4raRGwFeQpr9X/PQtncEicMoOe6BQt1oX0Y=
github.com/holiman/uint256 v1.2.4 h1:jUc4Nk8fm9jZabQuqr2JzednajVmBpC+oiTiXZJEApU=
github.com/holiman/uint256 v1.2.4/go.mod h1:EOMSn4q6Nyt9P6efbI3bueV4e1b3dGlUCXeiRV4ng7E=
github.com/kisielk/errcheck v1.5.0/go.mod h1:pFxgyoBC7bSaBwPgfKdkLd5X25qrDl4LWUI2bnpBCr8=
github.com/kisielk/gotool v1.0.0/go.mod h1:XhKaO+MFFWcvkIS/tQcRk01m1F5IRFswLeQ+oQHNcck=
github.com/mmcloughlin/addchain v0.4.0 h1:SobOdjm2xLj1KkXN5/n0xTIWyZA2+s99UCY1iPfkHRY=
github.com/mmcloughlin/addchain v0.4.0/go.mod h1:A86O+tHqZLMNO4w6ZZ4FlVQEadcoqkyU72HC5wJ4RlU=
github.com/mr-tron/base58 v1.2.0 h1:T/HDJBh4ZCPbU39/+c3rRvE0uKBQlU27+QI8LJ4t64o=
github.com/mr-tron/base58 v1.2.0/go.mod h1:BinMc/sQntlIE1frQmRFPUoPA1Zkr8VRgBdjWI2mNwc=
github.com/multiversx/mx-chain-core-go v1.4.0 h1:p6FbfCzvMXF54kpS0B5mrjNWYpq4SEQqo0UvrMF7YVY=
github.com/multiversx/mx-chain-core-go v1.4.0/go.mod h1:IO+vspNan+gT0WOHnJ95uvWygiziHZvfXpff6KnxV7g=
github.com/multiversx/mx-chain-core-sovereign-go v1.2.25-0.20251016085427-f3e9cd4fff15 h1:DVjnbVio7v+4nIJ/sO32iNG+GxouPNj6rd5ixdERqCM=
github.com/multiversx/mx-chain-core-sovereign-go v1.2.25-0.20251016085427-f3e9cd4fff15/go.mod h1:PsKbRg77qscWGVpOqH85sh3+q+wKny14Wmlziz2XXlM=
github.com/multiversx/mx-chain-logger-go v1.1.0 h1:97x84A6L4RfCa6YOx1HpAFxZp1cf/WI0Qh112whgZNM=
github.com/multiversx/mx-chain-logger-go v1.1.0/go.mod h1:K9XgiohLwOsNACETMNL0LItJMREuEvTH6NsoXWXWg7g=
github.com/pelletier/go-toml v1.9.3 h1:zeC5b1GviRUyKYd6OJPvBU/mcVDVoL1OhT17FCt5dSQ=
github.com/pelletier/go-toml v1.9.3/go.mod h1:u1nR/EPcESfeI/szUZKdtJ0xRNbUoANCkoOuaOx1Y+c=
github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM=
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME=
github.com/stretchr/objx v0.4.0/go.mod h1:YvHI0jy2hoMjB+UWwv71VJQ9isScKT/TqJzVSSt89Yw=
github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg=
github.com/stretchr/testify v1.8.0 h1:pSgiaMZlXftHpm5L7V1+rVB+AZJydKsMxsQBIJw4PKk=
github.com/stretchr/testify v1.8.0/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU=
github.com/stretchr/testify v1.8.4 h1:CcVxjf3Q8PM0mHUKJCdn+eZZtm5yQwehR5yeSVQQcUk=
github.com/stretchr/testify v1.8.4/go.mod h1:sz/lmYIOXD/1dqDmKjjqLyZ2RngseejIcXlSw2iwfAo=
github.com/supranational/blst v0.3.11 h1:LyU6FolezeWAhvQk0k6O/d49jqgO52MSDDfYgbeoEm4=
github.com/supranational/blst v0.3.11/go.mod h1:jZJtfjgudtNl4en1tzwPIV3KjUnQUvG3/j+w+fVonLw=
github.com/yuin/goldmark v1.1.27/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
github.com/yuin/goldmark v1.2.1/go.mod h1:3hX8gzYuyVAZsxl0MRgGTJEmQBFcNTphYh9decYSb74=
golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w=
golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI=
golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto=
golang.org/x/crypto v0.3.0 h1:a06MkbcxBrEFc0w0QIZWXrH/9cCX6KJyWbBOIwAn+7A=
golang.org/x/crypto v0.3.0/go.mod h1:hebNnKkNXi2UzZN1eVRvBB7co0a+JxK6XbPiWVs/3J4=
golang.org/x/crypto v0.33.0 h1:IOBPskki6Lysi0lo9qQvbxiQ+FvsCC/YWOecCHAixus=
golang.org/x/crypto v0.33.0/go.mod h1:bVdXmD7IV/4GdElGPozy6U7lWdRXA4qyRVGJV57uQ5M=
golang.org/x/exp v0.0.0-20231110203233-9a3e6036ecaa h1:FRnLl4eNAQl8hwxVVC17teOw8kdjVDVAiFMtgUdTSRQ=
golang.org/x/exp v0.0.0-20231110203233-9a3e6036ecaa/go.mod h1:zk2irFbV9DP96SEBUUAy67IdHUaZuSnrz1n472HUCLE=
golang.org/x/mod v0.2.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
golang.org/x/mod v0.3.0/go.mod h1:s0Qsj1ACt9ePp/hMypM3fl4fZqREWJwdYDEqhRiZZUA=
golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg=
Expand All @@ -51,11 +70,13 @@ golang.org/x/net v0.0.0-20201021035429-f5854403a974/go.mod h1:sp8m0HH+o8qH0wwXwY
golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
golang.org/x/sync v0.11.0 h1:GGz8+XQP4FvTTrjZPzNKTMFtSXH80RAzG+5ghFPgK9w=
golang.org/x/sync v0.11.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk=
golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
golang.org/x/sys v0.2.0 h1:ljd4t30dBnAvMZaQCevtY0xLLD0A+bRZXbgLMLU1F/A=
golang.org/x/sys v0.2.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
golang.org/x/sys v0.30.0 h1:QjkSwP/36a20jFYWkSue1YwXzLmsV5Gfq7Eiy72C1uc=
golang.org/x/sys v0.30.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA=
golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ=
golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ=
Expand All @@ -65,13 +86,12 @@ golang.org/x/tools v0.0.0-20210106214847-113979e3529a/go.mod h1:emZCQorbCU4vsT4f
golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1 h1:go1bK/D/BFZV2I8cIQd1NKEZ+0owSTG1fDTci4IqFcE=
golang.org/x/xerrors v0.0.0-20200804184101-5ec99f83aff1/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
google.golang.org/protobuf v1.26.0-rc.1/go.mod h1:jlhhOSvTdKEhbULTjvd4ARK9grFBp09yW+WbY/TyQbw=
google.golang.org/protobuf v1.26.0 h1:bxAC2xTBsZGibn2RTntX0oH50xLsqy1OxA9tTL3p/lk=
google.golang.org/protobuf v1.26.0/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc=
google.golang.org/protobuf v1.36.5 h1:tPhr+woSbjfYvY6/GPufUoYizxw1cF/yFoxJ2fmpwlM=
google.golang.org/protobuf v1.36.5/go.mod h1:9fA7Ob0pmnwhb644+1+CVWFRbNajQ6iRojtC/QF5bRE=
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405 h1:yhCVgyC4o1eVCa2tZl7eS0r+SDo693bJlVdllGtEeKM=
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA=
gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=
rsc.io/tmplfunc v0.0.3 h1:53XFQh69AfOa8Tw0Jm7t+GV7KZhOi6jzsCzTtKbMvzU=
rsc.io/tmplfunc v0.0.3/go.mod h1:AG3sTPzElb1Io3Yg4voV9AGZJuleGAwaVRxL9M49PhA=
Loading
Loading