aboutsummaryrefslogtreecommitdiffstats
path: root/common/resolver/resolver.go
diff options
context:
space:
mode:
authorzelig <viktor.tron@gmail.com>2015-03-31 08:57:17 +0800
committerzelig <viktor.tron@gmail.com>2015-04-20 03:57:48 +0800
commit97a602864a485bb3a79f460077052bd76cdbff99 (patch)
tree8c3e7de5e87cb40fe16e34b4e9075c22d6497890 /common/resolver/resolver.go
parent45676382b6cdf3720600647bdd76e4a89fa4495f (diff)
downloadgo-tangerine-97a602864a485bb3a79f460077052bd76cdbff99.tar
go-tangerine-97a602864a485bb3a79f460077052bd76cdbff99.tar.gz
go-tangerine-97a602864a485bb3a79f460077052bd76cdbff99.tar.bz2
go-tangerine-97a602864a485bb3a79f460077052bd76cdbff99.tar.lz
go-tangerine-97a602864a485bb3a79f460077052bd76cdbff99.tar.xz
go-tangerine-97a602864a485bb3a79f460077052bd76cdbff99.tar.zst
go-tangerine-97a602864a485bb3a79f460077052bd76cdbff99.zip
add common/resolver skeleton
Diffstat (limited to 'common/resolver/resolver.go')
-rw-r--r--common/resolver/resolver.go45
1 files changed, 45 insertions, 0 deletions
diff --git a/common/resolver/resolver.go b/common/resolver/resolver.go
new file mode 100644
index 000000000..aa54a689b
--- /dev/null
+++ b/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)
+}