plugeth/javascript/types.go

139 lines
3.4 KiB
Go
Raw Normal View History

package javascript
2014-05-20 10:48:34 +00:00
import (
"fmt"
"github.com/ethereum/eth-go"
"github.com/ethereum/eth-go/ethchain"
2014-08-15 23:38:24 +00:00
"github.com/ethereum/eth-go/ethpipe"
"github.com/ethereum/eth-go/ethstate"
"github.com/ethereum/eth-go/ethutil"
"github.com/obscuren/otto"
2014-05-20 10:48:34 +00:00
)
2014-07-15 18:34:25 +00:00
type JSStateObject struct {
2014-08-15 23:38:24 +00:00
*ethpipe.JSObject
2014-07-15 18:34:25 +00:00
eth *JSEthereum
2014-05-20 10:48:34 +00:00
}
2014-07-15 18:34:25 +00:00
func (self *JSStateObject) EachStorage(call otto.FunctionCall) otto.Value {
cb := call.Argument(0)
2014-08-15 23:38:24 +00:00
self.JSObject.EachStorage(func(key string, value *ethutil.Value) {
2014-07-15 18:34:25 +00:00
value.Decode()
2014-05-20 10:48:34 +00:00
2014-07-15 18:34:25 +00:00
cb.Call(self.eth.toVal(self), self.eth.toVal(key), self.eth.toVal(ethutil.Bytes2Hex(value.Bytes())))
})
2014-05-20 10:48:34 +00:00
2014-07-15 18:34:25 +00:00
return otto.UndefinedValue()
2014-05-20 10:48:34 +00:00
}
// The JSEthereum object attempts to wrap the PEthereum object and returns
// meaningful javascript objects
type JSBlock struct {
2014-08-15 23:38:24 +00:00
*ethpipe.JSBlock
eth *JSEthereum
}
func (self *JSBlock) GetTransaction(hash string) otto.Value {
2014-08-15 23:38:24 +00:00
return self.eth.toVal(self.JSBlock.GetTransaction(hash))
}
type JSMessage struct {
2014-08-14 15:01:21 +00:00
To string `json:"to"`
From string `json:"from"`
Input string `json:"input"`
Output string `json:"output"`
Path int `json:"path"`
Origin string `json:"origin"`
Timestamp int32 `json:"timestamp"`
Coinbase string `json:"coinbase"`
Block string `json:"block"`
Number int32 `json:"number"`
}
func NewJSMessage(message *ethstate.Message) JSMessage {
return JSMessage{
To: ethutil.Bytes2Hex(message.To),
From: ethutil.Bytes2Hex(message.From),
Input: ethutil.Bytes2Hex(message.Input),
Output: ethutil.Bytes2Hex(message.Output),
Path: message.Path,
Origin: ethutil.Bytes2Hex(message.Origin),
Timestamp: int32(message.Timestamp),
Coinbase: ethutil.Bytes2Hex(message.Origin),
Block: ethutil.Bytes2Hex(message.Block),
Number: int32(message.Number.Int64()),
}
}
2014-05-20 10:48:34 +00:00
type JSEthereum struct {
2014-08-15 23:38:24 +00:00
*ethpipe.JSPipe
vm *otto.Otto
ethereum *eth.Ethereum
2014-05-20 10:48:34 +00:00
}
2014-05-21 10:14:39 +00:00
func (self *JSEthereum) GetBlock(hash string) otto.Value {
2014-08-17 23:35:42 +00:00
return self.toVal(&JSBlock{self.JSPipe.BlockByHash(hash), self})
2014-05-21 10:14:39 +00:00
}
2014-06-02 13:16:37 +00:00
func (self *JSEthereum) GetPeers() otto.Value {
2014-08-17 23:35:42 +00:00
return self.toVal(self.JSPipe.Peers())
2014-06-02 13:16:37 +00:00
}
2014-05-20 10:48:34 +00:00
func (self *JSEthereum) GetKey() otto.Value {
2014-08-17 23:35:42 +00:00
return self.toVal(self.JSPipe.Key())
2014-05-20 10:48:34 +00:00
}
func (self *JSEthereum) GetStateObject(addr string) otto.Value {
2014-08-15 23:38:24 +00:00
return self.toVal(&JSStateObject{ethpipe.NewJSObject(self.JSPipe.World().SafeGet(ethutil.Hex2Bytes(addr))), self})
}
2014-05-20 10:48:34 +00:00
func (self *JSEthereum) Transact(key, recipient, valueStr, gasStr, gasPriceStr, dataStr string) otto.Value {
2014-08-15 23:38:24 +00:00
r, err := self.JSPipe.Transact(key, recipient, valueStr, gasStr, gasPriceStr, dataStr)
2014-05-20 10:48:34 +00:00
if err != nil {
fmt.Println(err)
return otto.UndefinedValue()
}
return self.toVal(r)
}
func (self *JSEthereum) Create(key, valueStr, gasStr, gasPriceStr, scriptStr string) otto.Value {
2014-08-15 23:38:24 +00:00
r, err := self.JSPipe.Transact(key, "", valueStr, gasStr, gasPriceStr, scriptStr)
2014-05-20 10:48:34 +00:00
if err != nil {
fmt.Println(err)
return otto.UndefinedValue()
}
return self.toVal(r)
}
func (self *JSEthereum) toVal(v interface{}) otto.Value {
result, err := self.vm.ToValue(v)
if err != nil {
fmt.Println("Value unknown:", err)
2014-05-20 10:48:34 +00:00
return otto.UndefinedValue()
}
return result
}
func (self *JSEthereum) Messages(object map[string]interface{}) otto.Value {
2014-08-15 11:16:07 +00:00
filter := ethchain.NewFilterFromMap(object, self.ethereum)
messages := filter.Find()
var msgs []JSMessage
for _, m := range messages {
msgs = append(msgs, NewJSMessage(m))
}
v, _ := self.vm.ToValue(msgs)
return v
}