mirror of https://github.com/status-im/op-geth.git
Merge
This commit is contained in:
parent
3274e0a249
commit
8ea7e21f64
|
@ -6,7 +6,7 @@ Ethereum
|
||||||
Ethereum Go Development package (C) Jeffrey Wilcke
|
Ethereum Go Development package (C) Jeffrey Wilcke
|
||||||
|
|
||||||
Ethereum is currently in its testing phase. The current state is "Proof
|
Ethereum is currently in its testing phase. The current state is "Proof
|
||||||
of Concept 2". For build instructions see the [Wiki](https://github.com/ethereum/go-ethereum/wiki/Building-Edge).
|
of Concept 3". For build instructions see the [Wiki](https://github.com/ethereum/go-ethereum/wiki/Building-Ethereum(Go)).
|
||||||
|
|
||||||
Ethereum Go is split up in several sub packages Please refer to each
|
Ethereum Go is split up in several sub packages Please refer to each
|
||||||
individual package for more information.
|
individual package for more information.
|
||||||
|
@ -35,7 +35,7 @@ get a node and connectivity going.
|
||||||
Build
|
Build
|
||||||
=======
|
=======
|
||||||
|
|
||||||
This is the Developer package. For the development client please see
|
This is the Developer package. For the Ethereal client please see
|
||||||
[Ethereum(G)](https://github.com/ethereum/go-ethereum).
|
[Ethereum(G)](https://github.com/ethereum/go-ethereum).
|
||||||
|
|
||||||
`go get -u github.com/ethereum/eth-go`
|
`go get -u github.com/ethereum/eth-go`
|
||||||
|
|
|
@ -11,7 +11,7 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
type PoW interface {
|
type PoW interface {
|
||||||
Search(block *Block, breakChan chan bool) []byte
|
Search(block *Block, minerChan chan ethutil.React) []byte
|
||||||
Verify(hash []byte, diff *big.Int, nonce []byte) bool
|
Verify(hash []byte, diff *big.Int, nonce []byte) bool
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -19,19 +19,32 @@ type EasyPow struct {
|
||||||
hash *big.Int
|
hash *big.Int
|
||||||
}
|
}
|
||||||
|
|
||||||
func (pow *EasyPow) Search(block *Block, breakChan chan bool) []byte {
|
func (pow *EasyPow) Search(block *Block, minerChan chan ethutil.React) []byte {
|
||||||
r := rand.New(rand.NewSource(time.Now().UnixNano()))
|
r := rand.New(rand.NewSource(time.Now().UnixNano()))
|
||||||
hash := block.HashNoNonce()
|
hash := block.HashNoNonce()
|
||||||
diff := block.Difficulty
|
diff := block.Difficulty
|
||||||
|
i := int64(0)
|
||||||
|
start := time.Now().UnixNano()
|
||||||
|
|
||||||
for {
|
for {
|
||||||
select {
|
select {
|
||||||
case shouldbreak := <-breakChan:
|
case chanMessage := <-minerChan:
|
||||||
if shouldbreak {
|
if _, ok := chanMessage.Resource.(*Block); ok {
|
||||||
log.Println("Got signal: Breaking out mining.")
|
log.Println("BREAKING OUT: BLOCK")
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
if _, ok := chanMessage.Resource.(*Transaction); ok {
|
||||||
|
log.Println("BREAKING OUT: TX")
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
|
i++
|
||||||
|
if i%1234567 == 0 {
|
||||||
|
elapsed := time.Now().UnixNano() - start
|
||||||
|
hashes := ((float64(1e9) / float64(elapsed)) * float64(i)) / 1000
|
||||||
|
log.Println("Hashing @", int64(hashes), "khash")
|
||||||
|
}
|
||||||
|
|
||||||
sha := ethutil.Sha3Bin(big.NewInt(r.Int63()).Bytes())
|
sha := ethutil.Sha3Bin(big.NewInt(r.Int63()).Bytes())
|
||||||
if pow.Verify(hash, diff, sha) {
|
if pow.Verify(hash, diff, sha) {
|
||||||
return sha
|
return sha
|
||||||
|
|
|
@ -0,0 +1,74 @@
|
||||||
|
package ethchain
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/ethereum/eth-go/ethutil"
|
||||||
|
"math/big"
|
||||||
|
)
|
||||||
|
|
||||||
|
type KeyPair struct {
|
||||||
|
PrivateKey []byte
|
||||||
|
PublicKey []byte
|
||||||
|
|
||||||
|
// The associated account
|
||||||
|
account *Account
|
||||||
|
state *State
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewKeyPairFromValue(val *ethutil.Value) *KeyPair {
|
||||||
|
keyPair := &KeyPair{PrivateKey: val.Get(0).Bytes(), PublicKey: val.Get(1).Bytes()}
|
||||||
|
|
||||||
|
return keyPair
|
||||||
|
}
|
||||||
|
|
||||||
|
func (k *KeyPair) Address() []byte {
|
||||||
|
return ethutil.Sha3Bin(k.PublicKey[1:])[12:]
|
||||||
|
}
|
||||||
|
|
||||||
|
func (k *KeyPair) Account() *Account {
|
||||||
|
if k.account == nil {
|
||||||
|
k.account = k.state.GetAccount(k.Address())
|
||||||
|
}
|
||||||
|
|
||||||
|
return k.account
|
||||||
|
}
|
||||||
|
|
||||||
|
// Create transaction, creates a new and signed transaction, ready for processing
|
||||||
|
func (k *KeyPair) CreateTx(receiver []byte, value *big.Int, data []string) *Transaction {
|
||||||
|
tx := NewTransaction(receiver, value, data)
|
||||||
|
tx.Nonce = k.account.Nonce
|
||||||
|
|
||||||
|
// Sign the transaction with the private key in this key chain
|
||||||
|
tx.Sign(k.PrivateKey)
|
||||||
|
|
||||||
|
return tx
|
||||||
|
}
|
||||||
|
|
||||||
|
func (k *KeyPair) RlpEncode() []byte {
|
||||||
|
return ethutil.EmptyValue().Append(k.PrivateKey).Append(k.PublicKey).Encode()
|
||||||
|
}
|
||||||
|
|
||||||
|
type KeyRing struct {
|
||||||
|
keys []*KeyPair
|
||||||
|
}
|
||||||
|
|
||||||
|
func (k *KeyRing) Add(pair *KeyPair) {
|
||||||
|
k.keys = append(k.keys, pair)
|
||||||
|
}
|
||||||
|
|
||||||
|
// The public "singleton" keyring
|
||||||
|
var keyRing *KeyRing
|
||||||
|
|
||||||
|
func GetKeyRing(state *State) *KeyRing {
|
||||||
|
if keyRing == nil {
|
||||||
|
keyRing = &KeyRing{}
|
||||||
|
|
||||||
|
data, _ := ethutil.Config.Db.Get([]byte("KeyRing"))
|
||||||
|
it := ethutil.NewValueFromBytes(data).NewIterator()
|
||||||
|
for it.Next() {
|
||||||
|
v := it.Value()
|
||||||
|
keyRing.Add(NewKeyPairFromValue(v))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return keyRing
|
||||||
|
}
|
|
@ -22,7 +22,6 @@ type EthManager interface {
|
||||||
Reactor() *ethutil.ReactorEngine
|
Reactor() *ethutil.ReactorEngine
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO rename to state manager
|
|
||||||
type StateManager struct {
|
type StateManager struct {
|
||||||
// Mutex for locking the block processor. Blocks can only be handled one at a time
|
// Mutex for locking the block processor. Blocks can only be handled one at a time
|
||||||
mutex sync.Mutex
|
mutex sync.Mutex
|
||||||
|
|
29
ethereum.go
29
ethereum.go
|
@ -271,8 +271,32 @@ func (s *Ethereum) Start() {
|
||||||
|
|
||||||
if ethutil.Config.Seed {
|
if ethutil.Config.Seed {
|
||||||
ethutil.Config.Log.Debugln("Seeding")
|
ethutil.Config.Log.Debugln("Seeding")
|
||||||
// Testnet seed bootstrapping
|
// DNS Bootstrapping
|
||||||
resp, err := http.Get("https://www.ethereum.org/servers.poc3.txt")
|
_, nodes, err := net.LookupSRV("eth", "tcp", "ethereum.org")
|
||||||
|
if err == nil {
|
||||||
|
peers := []string{}
|
||||||
|
// Iterate SRV nodes
|
||||||
|
for _, n := range nodes {
|
||||||
|
target := n.Target
|
||||||
|
port := strconv.Itoa(int(n.Port))
|
||||||
|
// Resolve target to ip (Go returns list, so may resolve to multiple ips?)
|
||||||
|
addr, err := net.LookupHost(target)
|
||||||
|
if err == nil {
|
||||||
|
for _, a := range addr {
|
||||||
|
// Build string out of SRV port and Resolved IP
|
||||||
|
peer := net.JoinHostPort(a, port)
|
||||||
|
log.Println("Found DNS Bootstrap Peer:", peer)
|
||||||
|
peers = append(peers, peer)
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
log.Println("Couldn't resolve :", target)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// Connect to Peer list
|
||||||
|
s.ProcessPeerList(peers)
|
||||||
|
} else {
|
||||||
|
// Fallback to servers.poc3.txt
|
||||||
|
resp, err := http.Get("http://www.ethereum.org/servers.poc3.txt")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Println("Fetching seed failed:", err)
|
log.Println("Fetching seed failed:", err)
|
||||||
return
|
return
|
||||||
|
@ -286,6 +310,7 @@ func (s *Ethereum) Start() {
|
||||||
|
|
||||||
s.ConnectToPeer(string(body))
|
s.ConnectToPeer(string(body))
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Ethereum) peerHandler(listener net.Listener) {
|
func (s *Ethereum) peerHandler(listener net.Listener) {
|
||||||
|
|
|
@ -219,18 +219,6 @@ func (t *Trie) UpdateState(node interface{}, key []int, value string) interface{
|
||||||
}
|
}
|
||||||
|
|
||||||
func (t *Trie) Put(node interface{}) interface{} {
|
func (t *Trie) Put(node interface{}) interface{} {
|
||||||
/*
|
|
||||||
enc := Encode(node)
|
|
||||||
if len(enc) >= 32 {
|
|
||||||
var sha []byte
|
|
||||||
sha = Sha3Bin(enc)
|
|
||||||
//t.db.Put([]byte(sha), enc)
|
|
||||||
|
|
||||||
return sha
|
|
||||||
}
|
|
||||||
return node
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
TODO?
|
TODO?
|
||||||
c := Conv(t.Root)
|
c := Conv(t.Root)
|
||||||
|
|
Loading…
Reference in New Issue