summaryrefslogtreecommitdiffstats
path: root/vendor/go.mau.fi/libsignal/ecc/DjbECPublicKey.go
blob: 11757fb4eaa2dade2dbfef9f12a6c784c1504b33 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
package ecc

// NewDjbECPublicKey creates a new Curve25519 public key with the given bytes.
func NewDjbECPublicKey(publicKey [32]byte) *DjbECPublicKey {
	key := DjbECPublicKey{
		publicKey: publicKey,
	}
	return &key
}

// DjbECPublicKey implements the ECPublicKey interface and uses Curve25519.
type DjbECPublicKey struct {
	publicKey [32]byte
}

// PublicKey returns the EC public key as a byte array.
func (d *DjbECPublicKey) PublicKey() [32]byte {
	return d.publicKey
}

// Serialize returns the public key prepended by the DjbType value.
func (d *DjbECPublicKey) Serialize() []byte {
	return append([]byte{DjbType}, d.publicKey[:]...)
}

// Type returns the DjbType value.
func (d *DjbECPublicKey) Type() int {
	return DjbType
}