2023-04-02 18:13:10 +02:00

44 lines
902 B
Go

package accountdata
import (
"crypto/rand"
"github.com/anytypeio/any-sync/util/crypto"
)
type AccountKeys struct {
PeerKey crypto.PrivKey
SignKey crypto.PrivKey
MasterKey crypto.PrivKey
PeerId string
}
func New(peerKey, signKey, masterKey crypto.PrivKey) *AccountKeys {
return &AccountKeys{
PeerKey: peerKey,
SignKey: signKey,
MasterKey: masterKey,
PeerId: peerKey.GetPublic().PeerId(),
}
}
func NewRandom() (*AccountKeys, error) {
peerKey, _, err := crypto.GenerateEd25519Key(rand.Reader)
if err != nil {
return nil, err
}
signKey, _, err := crypto.GenerateEd25519Key(rand.Reader)
if err != nil {
return nil, err
}
masterKey, _, err := crypto.GenerateEd25519Key(rand.Reader)
if err != nil {
return nil, err
}
return &AccountKeys{
PeerKey: peerKey,
SignKey: signKey,
MasterKey: masterKey,
PeerId: peerKey.GetPublic().PeerId(),
}, nil
}