Files
Go_I2p/lib/common/router_identity/router_identity.go

52 lines
1.3 KiB
Go
Raw Normal View History

package router_identity
2016-02-15 00:34:29 -08:00
/*
I2P RouterIdentity
2016-06-16 23:17:21 -07:00
https://geti2p.net/spec/common-structures#routeridentity
2016-02-15 00:34:29 -08:00
Accurate for version 0.9.24
Identical to KeysAndCert
*/
import (
. "github.com/go-i2p/go-i2p/lib/common/certificate"
. "github.com/go-i2p/go-i2p/lib/common/keys_and_cert"
"github.com/go-i2p/go-i2p/lib/crypto"
)
2016-02-15 00:34:29 -08:00
//
// A RouterIdentity is identical to KeysAndCert.
//
type RouterIdentity struct {
KeysAndCert *KeysAndCert
}
//[]byte
func (router_identity *RouterIdentity) PublicKey() crypto.PublicKey {
return router_identity.KeysAndCert.PublicKey()
}
func (router_identity *RouterIdentity) SigningPublicKey() crypto.SigningPublicKey {
return router_identity.KeysAndCert.SigningPublicKey()
}
func (router_identity *RouterIdentity) Certificate() *Certificate {
return router_identity.KeysAndCert.Certificate()
}
2016-02-15 00:34:29 -08:00
func ReadRouterIdentity(data []byte) (router_identity RouterIdentity, remainder []byte, err error) {
keys_and_cert, remainder, err := NewKeysAndCert(data)
router_identity = RouterIdentity{
KeysAndCert: keys_and_cert,
} //(keys_and_cert)
return
}
func NewRouterIdentity(data []byte) (router_identity *RouterIdentity, remainder []byte, err error) {
objrouter_identity, remainder, err := ReadRouterIdentity(data)
router_identity = &objrouter_identity
2016-02-15 00:34:29 -08:00
return
}