crypto

package
v2.1.4 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 26, 2024 License: MIT Imports: 13 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func FlattenECPoints

func FlattenECPoints(in []*ECPoint) ([]*big.Int, error)

func GenerateNTildei

func GenerateNTildei(rand io.Reader, safePrimes [2]*big.Int) (NTildei, h1i, h2i *big.Int, err error)

Types

type ECPoint

type ECPoint struct {
	// contains filtered or unexported fields
}

ECPoint convenience helper

func NewECPoint

func NewECPoint(curve elliptic.Curve, X, Y *big.Int) (*ECPoint, error)

Creates a new ECPoint and checks that the given coordinates are on the elliptic curve.

func NewECPointNoCurveCheck

func NewECPointNoCurveCheck(curve elliptic.Curve, X, Y *big.Int) *ECPoint

Creates a new ECPoint without checking that the coordinates are on the elliptic curve. Only use this function when you are completely sure that the point is already on the curve.

func ScalarBaseMult

func ScalarBaseMult(curve elliptic.Curve, k *big.Int) *ECPoint

func UnFlattenECPoints

func UnFlattenECPoints(curve elliptic.Curve, in []*big.Int, noCurveCheck ...bool) ([]*ECPoint, error)

func (*ECPoint) Add

func (p *ECPoint) Add(p1 *ECPoint) (*ECPoint, error)

func (*ECPoint) Curve

func (p *ECPoint) Curve() elliptic.Curve

func (*ECPoint) EightInvEight

func (p *ECPoint) EightInvEight() *ECPoint

func (*ECPoint) Equals

func (p *ECPoint) Equals(p2 *ECPoint) bool

func (*ECPoint) GobDecode

func (p *ECPoint) GobDecode(buf []byte) error

func (*ECPoint) GobEncode

func (p *ECPoint) GobEncode() ([]byte, error)

func (*ECPoint) IsOnCurve

func (p *ECPoint) IsOnCurve() bool

func (*ECPoint) MarshalJSON

func (p *ECPoint) MarshalJSON() ([]byte, error)

crypto.ECPoint is not inherently json marshal-able

func (*ECPoint) ScalarMult

func (p *ECPoint) ScalarMult(k *big.Int) *ECPoint

func (*ECPoint) SetCurve

func (p *ECPoint) SetCurve(curve elliptic.Curve) *ECPoint

func (*ECPoint) ToECDSAPubKey

func (p *ECPoint) ToECDSAPubKey() *ecdsa.PublicKey

func (*ECPoint) ToEd25519PubKey added in v2.1.4

func (p *ECPoint) ToEd25519PubKey() *edwards25519.PublicKey

ToEd25519PubKey returns a github.com/ModChain/edwards25519.PublicKey object for this public key or nil if this is not a ed25519 key.

func (*ECPoint) ToSecp256k1PubKey added in v2.1.1

func (p *ECPoint) ToSecp256k1PubKey() *secp256k1.PublicKey

ToSecp256k1PubKey returns a github.com/ModChain/secp256k1.PublicKey object for this public key or nil if this is not a secp256k1 key.

func (*ECPoint) UnmarshalJSON

func (p *ECPoint) UnmarshalJSON(payload []byte) error

func (*ECPoint) ValidateBasic

func (p *ECPoint) ValidateBasic() bool

func (*ECPoint) X

func (p *ECPoint) X() *big.Int

func (*ECPoint) Y

func (p *ECPoint) Y() *big.Int

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL