forked from cerc-io/plugeth
add common/resolver skeleton
This commit is contained in:
parent
45676382b6
commit
97a602864a
45
common/resolver/resolver.go
Normal file
45
common/resolver/resolver.go
Normal file
@ -0,0 +1,45 @@
|
||||
package resolver
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"net/url"
|
||||
|
||||
"github.com/ethereum/go-ethereum/common"
|
||||
"github.com/ethereum/go-ethereum/xeth"
|
||||
)
|
||||
|
||||
/*
|
||||
Resolver implements the Ethereum DNS mapping
|
||||
NameReg : Domain Name (or Code hash of Contract) -> Content Hash
|
||||
UrlHint : Content Hash -> Url Hint
|
||||
*/
|
||||
const (
|
||||
urlHintContractAddress = "urlhint"
|
||||
nameRegContractAddress = "nameReg"
|
||||
)
|
||||
|
||||
type Resolver struct {
|
||||
xeth *xeth.XEth
|
||||
}
|
||||
|
||||
func (self *Resolver) NameToContentHash(name string) (hash common.Hash, err error) {
|
||||
// look up in nameReg
|
||||
copy(hash[:], []byte(name)[:32])
|
||||
return
|
||||
}
|
||||
|
||||
func (self *Resolver) ContentHashToUrl(hash common.Hash) (uri *url.URL, err error) {
|
||||
// look up in nameReg
|
||||
rawurl := fmt.Sprintf("bzz://%x/my/path/mycontract.sud", hash[:])
|
||||
// mime type?
|
||||
return url.Parse(rawurl)
|
||||
}
|
||||
|
||||
func (self *Resolver) NameToUrl(name string) (uri *url.URL, err error) {
|
||||
// look up in urlHint
|
||||
hash, err := self.NameToContentHash(name)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
return self.ContentHashToUrl(hash)
|
||||
}
|
17
common/resolver/resolver_test.go
Normal file
17
common/resolver/resolver_test.go
Normal file
@ -0,0 +1,17 @@
|
||||
package resolver
|
||||
|
||||
import (
|
||||
"testing"
|
||||
)
|
||||
|
||||
func TestNameToContentHash(t *testing.T) {
|
||||
|
||||
}
|
||||
|
||||
func TestContentHashToUrl(t *testing.T) {
|
||||
|
||||
}
|
||||
|
||||
func TestNameToUrl(t *testing.T) {
|
||||
|
||||
}
|
Loading…
Reference in New Issue
Block a user