add common/resolver skeleton

This commit is contained in:
zelig 2015-03-31 01:57:17 +01:00
parent 45676382b6
commit 97a602864a
2 changed files with 62 additions and 0 deletions

View 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)
}

View File

@ -0,0 +1,17 @@
package resolver
import (
"testing"
)
func TestNameToContentHash(t *testing.T) {
}
func TestContentHashToUrl(t *testing.T) {
}
func TestNameToUrl(t *testing.T) {
}