LookupDomain method to uilib
This commit is contained in:
parent
9f4886839f
commit
203c4b99a0
|
@ -103,7 +103,7 @@ ApplicationWindow {
|
||||||
uri.replace(reg, function(match, pre, domain, path) {
|
uri.replace(reg, function(match, pre, domain, path) {
|
||||||
uri = pre;
|
uri = pre;
|
||||||
|
|
||||||
var lookup = eth.lookupDomain(domain.substring(0, domain.length - 4));
|
var lookup = ui.lookupDomain(domain.substring(0, domain.length - 4));
|
||||||
var ip = [];
|
var ip = [];
|
||||||
for(var i = 0, l = lookup.length; i < l; i++) {
|
for(var i = 0, l = lookup.length; i < l; i++) {
|
||||||
ip.push(lookup.charCodeAt(i))
|
ip.push(lookup.charCodeAt(i))
|
||||||
|
|
|
@ -12,7 +12,7 @@ import (
|
||||||
|
|
||||||
const (
|
const (
|
||||||
ClientIdentifier = "Ethereal"
|
ClientIdentifier = "Ethereal"
|
||||||
Version = "0.6.1"
|
Version = "0.6.2"
|
||||||
)
|
)
|
||||||
|
|
||||||
var ethereum *eth.Ethereum
|
var ethereum *eth.Ethereum
|
||||||
|
|
|
@ -1,11 +1,15 @@
|
||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"bytes"
|
||||||
"fmt"
|
"fmt"
|
||||||
"path"
|
"path"
|
||||||
|
"strconv"
|
||||||
|
"strings"
|
||||||
|
|
||||||
"github.com/ethereum/eth-go"
|
"github.com/ethereum/eth-go"
|
||||||
"github.com/ethereum/eth-go/ethchain"
|
"github.com/ethereum/eth-go/ethchain"
|
||||||
|
"github.com/ethereum/eth-go/ethcrypto"
|
||||||
"github.com/ethereum/eth-go/ethpipe"
|
"github.com/ethereum/eth-go/ethpipe"
|
||||||
"github.com/ethereum/eth-go/ethutil"
|
"github.com/ethereum/eth-go/ethutil"
|
||||||
"github.com/ethereum/go-ethereum/javascript"
|
"github.com/ethereum/go-ethereum/javascript"
|
||||||
|
@ -36,6 +40,30 @@ func NewUiLib(engine *qml.Engine, eth *eth.Ethereum, assetPath string) *UiLib {
|
||||||
return &UiLib{JSPipe: ethpipe.NewJSPipe(eth), engine: engine, eth: eth, assetPath: assetPath, jsEngine: javascript.NewJSRE(eth)}
|
return &UiLib{JSPipe: ethpipe.NewJSPipe(eth), engine: engine, eth: eth, assetPath: assetPath, jsEngine: javascript.NewJSRE(eth)}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (self *UiLib) LookupDomain(domain string) string {
|
||||||
|
world := self.World()
|
||||||
|
|
||||||
|
if len(domain) > 32 {
|
||||||
|
domain = string(ethcrypto.Sha3Bin([]byte(domain)))
|
||||||
|
}
|
||||||
|
data := world.Config().Get("DnsReg").StorageString(domain).Bytes()
|
||||||
|
|
||||||
|
// Left padded = A record, Right padded = CNAME
|
||||||
|
if data[0] == 0 {
|
||||||
|
data = bytes.TrimLeft(data, "\x00")
|
||||||
|
var ipSlice []string
|
||||||
|
for _, d := range data {
|
||||||
|
ipSlice = append(ipSlice, strconv.Itoa(int(d)))
|
||||||
|
}
|
||||||
|
|
||||||
|
return strings.Join(ipSlice, ".")
|
||||||
|
} else {
|
||||||
|
data = bytes.TrimRight(data, "\x00")
|
||||||
|
|
||||||
|
return string(data)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func (self *UiLib) ImportTx(rlpTx string) {
|
func (self *UiLib) ImportTx(rlpTx string) {
|
||||||
tx := ethchain.NewTransactionFromBytes(ethutil.Hex2Bytes(rlpTx))
|
tx := ethchain.NewTransactionFromBytes(ethutil.Hex2Bytes(rlpTx))
|
||||||
self.eth.TxPool().QueueTransaction(tx)
|
self.eth.TxPool().QueueTransaction(tx)
|
||||||
|
|
|
@ -13,7 +13,7 @@ import (
|
||||||
|
|
||||||
const (
|
const (
|
||||||
ClientIdentifier = "Ethereum(G)"
|
ClientIdentifier = "Ethereum(G)"
|
||||||
Version = "0.6.1"
|
Version = "0.6.2"
|
||||||
)
|
)
|
||||||
|
|
||||||
var logger = ethlog.NewLogger("CLI")
|
var logger = ethlog.NewLogger("CLI")
|
||||||
|
|
Loading…
Reference in New Issue