aboutsummaryrefslogtreecommitdiffstats
path: root/common/registrar
diff options
context:
space:
mode:
authorzelig <viktor.tron@gmail.com>2015-07-07 13:00:58 +0800
committerJeffrey Wilcke <geffobscura@gmail.com>2015-07-07 17:30:55 +0800
commitc5cb6e8e70339b6641b7ce46cda04b83936213b3 (patch)
tree6ab24e55a8b4bd14b3a9c25917d440c03b875bfc /common/registrar
parent3791831081eb2d6e0dbfb3aa96f181dbb645c394 (diff)
downloadgo-tangerine-c5cb6e8e70339b6641b7ce46cda04b83936213b3.tar
go-tangerine-c5cb6e8e70339b6641b7ce46cda04b83936213b3.tar.gz
go-tangerine-c5cb6e8e70339b6641b7ce46cda04b83936213b3.tar.bz2
go-tangerine-c5cb6e8e70339b6641b7ce46cda04b83936213b3.tar.lz
go-tangerine-c5cb6e8e70339b6641b7ce46cda04b83936213b3.tar.xz
go-tangerine-c5cb6e8e70339b6641b7ce46cda04b83936213b3.tar.zst
go-tangerine-c5cb6e8e70339b6641b7ce46cda04b83936213b3.zip
fix/skip tests, adapt registrar to no contract address
registry initialisers now return the txhash which caller can use to retrieve receipt
Diffstat (limited to 'common/registrar')
-rw-r--r--common/registrar/registrar.go25
-rw-r--r--common/registrar/registrar_test.go2
2 files changed, 10 insertions, 17 deletions
diff --git a/common/registrar/registrar.go b/common/registrar/registrar.go
index 262231762..b70c7227b 100644
--- a/common/registrar/registrar.go
+++ b/common/registrar/registrar.go
@@ -92,7 +92,7 @@ func New(b Backend) (res *Registrar) {
return
}
-func (self *Registrar) SetGlobalRegistrar(namereg string, addr common.Address) (err error) {
+func (self *Registrar) SetGlobalRegistrar(namereg string, addr common.Address) (txhash string, err error) {
if namereg != "" {
GlobalRegistrarAddr = namereg
return
@@ -102,7 +102,7 @@ func (self *Registrar) SetGlobalRegistrar(namereg string, addr common.Address) (
err = fmt.Errorf("GlobalRegistrar address not found and sender for creation not given")
return
} else {
- GlobalRegistrarAddr, err = self.backend.Transact(addr.Hex(), "", "", "", "800000", "", GlobalRegistrarCode)
+ txhash, err = self.backend.Transact(addr.Hex(), "", "", "", "800000", "", GlobalRegistrarCode)
if err != nil {
err = fmt.Errorf("GlobalRegistrar address not found and sender for creation failed: %v", err)
return
@@ -112,7 +112,7 @@ func (self *Registrar) SetGlobalRegistrar(namereg string, addr common.Address) (
return
}
-func (self *Registrar) SetHashReg(hashreg string, addr common.Address) (err error) {
+func (self *Registrar) SetHashReg(hashreg string, addr common.Address) (txhash string, err error) {
if hashreg != "" {
HashRegAddr = hashreg
} else {
@@ -133,25 +133,21 @@ func (self *Registrar) SetHashReg(hashreg string, addr common.Address) (err erro
return
}
- HashRegAddr, err = self.backend.Transact(addr.Hex(), "", "", "", "", "", HashRegCode)
+ txhash, err = self.backend.Transact(addr.Hex(), "", "", "", "", "", HashRegCode)
if err != nil {
err = fmt.Errorf("HashReg address not found and sender for creation failed: %v", err)
}
- glog.V(logger.Detail).Infof("created HashRegAddr @ %v\n", HashRegAddr)
+ glog.V(logger.Detail).Infof("created HashRegAddr @ txhash %v\n", txhash)
} else {
glog.V(logger.Detail).Infof("HashRegAddr found at @ %v\n", HashRegAddr)
return
}
}
- // register as HashReg
- self.ReserveName(addr, HashRegName)
- self.SetAddressToName(addr, HashRegName, common.HexToAddress(HashRegAddr))
-
return
}
-func (self *Registrar) SetUrlHint(urlhint string, addr common.Address) (err error) {
+func (self *Registrar) SetUrlHint(urlhint string, addr common.Address) (txhash string, err error) {
if urlhint != "" {
UrlHintAddr = urlhint
} else {
@@ -171,21 +167,17 @@ func (self *Registrar) SetUrlHint(urlhint string, addr common.Address) (err erro
err = fmt.Errorf("UrlHint address not found and sender for creation not given")
return
}
- UrlHintAddr, err = self.backend.Transact(addr.Hex(), "", "", "", "210000", "", UrlHintCode)
+ txhash, err = self.backend.Transact(addr.Hex(), "", "", "", "210000", "", UrlHintCode)
if err != nil {
err = fmt.Errorf("UrlHint address not found and sender for creation failed: %v", err)
}
- glog.V(logger.Detail).Infof("created UrlHint @ %v\n", HashRegAddr)
+ glog.V(logger.Detail).Infof("created UrlHint @ txhash %v\n", txhash)
} else {
glog.V(logger.Detail).Infof("UrlHint found @ %v\n", HashRegAddr)
return
}
}
- // register as UrlHint
- self.ReserveName(addr, UrlHintName)
- self.SetAddressToName(addr, UrlHintName, common.HexToAddress(UrlHintAddr))
-
return
}
@@ -348,6 +340,7 @@ func (self *Registrar) HashToUrl(chash common.Hash) (uri string, err error) {
uri = uri + str
idx++
}
+
if len(uri) == 0 {
err = fmt.Errorf("GetURLhint: URL hint not found for '%v'", chash.Hex())
}
diff --git a/common/registrar/registrar_test.go b/common/registrar/registrar_test.go
index 5612e691c..7561e424e 100644
--- a/common/registrar/registrar_test.go
+++ b/common/registrar/registrar_test.go
@@ -59,7 +59,7 @@ func (self *testBackend) Call(fromStr, toStr, valueStr, gasStr, gasPriceStr, cod
func TestSetGlobalRegistrar(t *testing.T) {
b := NewTestBackend()
res := New(b)
- err := res.SetGlobalRegistrar("addresshex", common.BigToAddress(common.Big1))
+ _, err := res.SetGlobalRegistrar("addresshex", common.BigToAddress(common.Big1))
if err != nil {
t.Errorf("unexpected error: %v'", err)
}