浏览代码

add common/resolver skeleton

zelig 10 年之前
父节点
当前提交
97a602864a
共有 2 个文件被更改,包括 62 次插入0 次删除
  1. 45 0
      common/resolver/resolver.go
  2. 17 0
      common/resolver/resolver_test.go

+ 45 - 0
common/resolver/resolver.go

@@ -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 - 0
common/resolver/resolver_test.go

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