Commit 144f7493 authored by kingwang's avatar kingwang Committed by 33cn

update 01/25

parent 3f366492
......@@ -277,7 +277,7 @@ func (acc *DB) loadAccountsHistory(api client.QueueProtocolAPI, addrs []string,
// GetBalance 获取某个状态下账户余额
func (acc *DB) GetBalance(api client.QueueProtocolAPI, in *types.ReqBalance) ([]*types.Account, error) {
// load account
if in.AssetExec == in.Execer || "" == in.Execer {
if in.AssetExec == string(types.GetParaExec([]byte(in.Execer))) || "" == in.Execer {
addrs := in.GetAddresses()
var exaddrs []string
for _, addr := range addrs {
......
......@@ -355,7 +355,7 @@ func TestReplace(t *testing.T) {
dir, ldb, kvdb := util.CreateTestDB()
defer util.CloseTestDB(dir, ldb)
opt := &Option{
Prefix: "prefix",
Prefix: "prefix-hello",
Name: "name",
Primary: "Hash",
Index: []string{"From", "To"},
......
......@@ -51,10 +51,13 @@ func NewStateDB(client queue.Client, stateHash []byte, localdb db.KVDB, opt *Sta
return db
}
func (s *StateDB) enableMVCC() {
func (s *StateDB) enableMVCC(hash []byte) {
opt := s.opt
if opt.EnableMVCC {
v, err := s.local.GetVersion(s.stateHash)
if hash == nil {
hash = s.stateHash
}
v, err := s.local.GetVersion(hash)
if err == nil && v >= 0 {
s.version = v
} else if s.height > 0 {
......
......@@ -66,8 +66,8 @@ func newExecutor(ctx *executorCtx, exec *Executor, txs []*types.Transaction, rec
return e
}
func (e *executor) enableMVCC() {
e.stateDB.(*StateDB).enableMVCC()
func (e *executor) enableMVCC(hash []byte) {
e.stateDB.(*StateDB).enableMVCC(hash)
}
// AddMVCC convert key value to mvcc kv data
......
......@@ -147,7 +147,7 @@ func (exec *Executor) procExecQuery(msg queue.Message) {
opt := &StateDBOption{EnableMVCC: exec.pluginEnable["mvcc"], Height: header.GetHeight()}
db := NewStateDB(exec.client, data.StateHash, localdb, opt)
db.(*StateDB).enableMVCC()
db.(*StateDB).enableMVCC(nil)
driver.SetStateDB(db)
driver.SetAPI(exec.qclient)
driver.SetExecutorAPI(exec.qclient, exec.grpccli)
......@@ -174,7 +174,7 @@ func (exec *Executor) procExecCheckTx(msg queue.Message) {
parentHash: datas.ParentHash,
}
execute := newExecutor(ctx, exec, datas.Txs, nil)
execute.enableMVCC()
execute.enableMVCC(nil)
//返回一个列表表示成功还是失败
result := &types.ReceiptCheckTxList{}
for i := 0; i < len(datas.Txs); i++ {
......@@ -205,7 +205,7 @@ func (exec *Executor) procExecTxList(msg queue.Message) {
parentHash: datas.ParentHash,
}
execute := newExecutor(ctx, exec, datas.Txs, nil)
execute.enableMVCC()
execute.enableMVCC(nil)
var receipts []*types.Receipt
index := 0
for i := 0; i < len(datas.Txs); i++ {
......@@ -274,7 +274,8 @@ func (exec *Executor) procExecAddBlock(msg queue.Message) {
parentHash: b.ParentHash,
}
execute := newExecutor(ctx, exec, b.Txs, datas.Receipts)
execute.enableMVCC()
//因为mvcc 还没有写入,所以目前的mvcc版本是前一个区块的版本
execute.enableMVCC(datas.PrevStatusHash)
var kvset types.LocalDBSet
for _, kv := range datas.KV {
execute.stateDB.Set(kv.Key, kv.Value)
......@@ -297,6 +298,9 @@ func (exec *Executor) procExecAddBlock(msg queue.Message) {
}
if len(kvs) > 0 {
kvset.KV = append(kvset.KV, kvs...)
for _, kv := range kvs {
execute.localDB.Set(kv.Key, kv.Value)
}
}
}
for i := 0; i < len(b.Txs); i++ {
......@@ -316,6 +320,9 @@ func (exec *Executor) procExecAddBlock(msg queue.Message) {
return
}
kvset.KV = append(kvset.KV, kv.KV...)
for _, kv := range kv.KV {
execute.localDB.Set(kv.Key, kv.Value)
}
}
}
msg.Reply(exec.client.NewMessage("", types.EventAddBlock, &kvset))
......@@ -334,7 +341,7 @@ func (exec *Executor) procExecDelBlock(msg queue.Message) {
parentHash: b.ParentHash,
}
execute := newExecutor(ctx, exec, b.Txs, nil)
execute.enableMVCC()
execute.enableMVCC(nil)
var kvset types.LocalDBSet
for _, kv := range datas.KV {
execute.stateDB.Set(kv.Key, kv.Value)
......
......@@ -15,7 +15,7 @@ func init() {
}
type addrindexPlugin struct {
*pluginBase
pluginBase
}
func (p *addrindexPlugin) CheckEnable(executor *executor, enable bool) (kvs []*types.KeyValue, ok bool, err error) {
......
......@@ -11,7 +11,7 @@ func init() {
}
type feePlugin struct {
*pluginBase
pluginBase
fee types.TotalFee
}
......
......@@ -4,14 +4,16 @@
package executor
import "github.com/33cn/chain33/types"
import (
"github.com/33cn/chain33/types"
)
func init() {
RegisterPlugin("mvcc", &mvccPlugin{})
}
type mvccPlugin struct {
*pluginBase
pluginBase
}
func (p *mvccPlugin) CheckEnable(executor *executor, enable bool) (kvs []*types.KeyValue, ok bool, err error) {
......@@ -24,9 +26,6 @@ func (p *mvccPlugin) CheckEnable(executor *executor, enable bool) (kvs []*types.
func (p *mvccPlugin) ExecLocal(executor *executor, data *types.BlockDetail) (kvs []*types.KeyValue, err error) {
kvs = AddMVCC(executor.localDB, data)
for _, kv := range kvs {
executor.localDB.Set(kv.Key, kv.Value)
}
return kvs, nil
}
......
......@@ -13,7 +13,7 @@ func init() {
}
type statPlugin struct {
*pluginBase
pluginBase
}
func (p *statPlugin) CheckEnable(executor *executor, enable bool) (kvs []*types.KeyValue, ok bool, err error) {
......@@ -39,8 +39,10 @@ func countInfo(ex *executor, b *types.BlockDetail) ([]*types.KeyValue, error) {
if err != nil {
return nil, err
}
kvset.KV = append(kvset.KV, ticketkv.KV...)
if ticketkv == nil {
return nil, nil
}
kvset.KV = ticketkv.KV
return kvset.KV, nil
}
......@@ -51,8 +53,10 @@ func delCountInfo(ex *executor, b *types.BlockDetail) ([]*types.KeyValue, error)
if err != nil {
return nil, err
}
kvset.KV = append(kvset.KV, ticketkv.KV...)
if ticketkv == nil {
return nil, nil
}
kvset.KV = ticketkv.KV
return kvset.KV, nil
}
......
......@@ -16,7 +16,7 @@ func init() {
}
type txindexPlugin struct {
*pluginBase
pluginBase
}
func (p *txindexPlugin) CheckEnable(executor *executor, enable bool) (kvs []*types.KeyValue, ok bool, err error) {
......
......@@ -63,9 +63,6 @@ func (c *channelClient) ReWriteRawTx(param *types.ReWriteRawTx) ([]byte, error)
if err != nil {
return nil, err
}
if param.Execer != nil {
tx.Execer = param.Execer
}
if param.To != "" {
tx.To = param.To
}
......
......@@ -1051,7 +1051,6 @@ func TestReWriteRawTx(t *testing.T) {
txHex1 := "0a05636f696e73122c18010a281080c2d72f222131477444795771577233553637656a7663776d333867396e7a6e7a434b58434b7120a08d0630a696c0b3f78dd9ec083a2131477444795771577233553637656a7663776d333867396e7a6e7a434b58434b71"
in := &types.ReWriteRawTx{
Tx: txHex1,
Execer: []byte("paracross"),
Fee: 29977777777,
Expire: "130s",
To: "aabbccdd",
......@@ -1066,7 +1065,6 @@ func TestReWriteRawTx(t *testing.T) {
tx := &types.Transaction{}
err = types.Decode(data.Data, tx)
assert.Nil(t, err)
assert.Equal(t, tx.Execer, []byte(in.Execer))
assert.Equal(t, tx.Fee, in.Fee)
assert.Equal(t, int64(130000000000), tx.Expire)
assert.Equal(t, in.To, tx.To)
......
......@@ -48,7 +48,6 @@ func (c *Chain33) CreateRawTransaction(in *rpctypes.CreateTx, result *interface{
func (c *Chain33) ReWriteRawTx(in *rpctypes.ReWriteRawTx, result *interface{}) error {
inpb := &types.ReWriteRawTx{
Tx: in.Tx,
Execer: []byte(in.Execer),
To: in.To,
Fee: in.Fee,
Expire: in.Expire,
......@@ -874,6 +873,9 @@ func (c *Chain33) IsNtpClockSync(in *types.ReqNil, result *interface{}) error {
// QueryTotalFee query total fee
func (c *Chain33) QueryTotalFee(in *types.LocalDBGet, result *interface{}) error {
if in == nil || len(in.Keys) > 1 {
return types.ErrInvalidParam
}
reply, err := c.cli.LocalGet(in)
if err != nil {
return err
......@@ -925,58 +927,6 @@ func (c *Chain33) GetFatalFailure(in *types.ReqNil, result *interface{}) error {
}
// QueryTicketStat quert stat of ticket
func (c *Chain33) QueryTicketStat(in *types.LocalDBGet, result *interface{}) error {
reply, err := c.cli.LocalGet(in)
if err != nil {
return err
}
var ticketStat types.TicketStatistic
err = types.Decode(reply.Values[0], &ticketStat)
if err != nil {
return err
}
*result = ticketStat
return nil
}
// QueryTicketInfo query ticket information
func (c *Chain33) QueryTicketInfo(in *types.LocalDBGet, result *interface{}) error {
reply, err := c.cli.LocalGet(in)
if err != nil {
return err
}
var ticketInfo types.TicketMinerInfo
err = types.Decode(reply.Values[0], &ticketInfo)
if err != nil {
return err
}
*result = ticketInfo
return nil
}
// QueryTicketInfoList query ticket list information
func (c *Chain33) QueryTicketInfoList(in *types.LocalDBList, result *interface{}) error {
reply, err := c.cli.LocalList(in)
if err != nil {
return err
}
var ticketInfo types.TicketMinerInfo
var ticketList []types.TicketMinerInfo
for _, v := range reply.Values {
err = types.Decode(v, &ticketInfo)
if err != nil {
return err
}
ticketList = append(ticketList, ticketInfo)
}
*result = ticketList
return nil
}
// DecodeRawTransaction decode rawtransaction
func (c *Chain33) DecodeRawTransaction(in *types.ReqDecodeRawTransaction, result *interface{}) error {
reply, err := c.cli.DecodeRawTransaction(in)
......@@ -1152,6 +1102,10 @@ func convertBlockDetails(details []*types.BlockDetail, retDetails *rpctypes.Bloc
for _, item := range details {
var bdtl rpctypes.BlockDetail
var block rpctypes.Block
if item == nil {
retDetails.Items = append(retDetails.Items, nil)
continue
}
block.BlockTime = item.Block.GetBlockTime()
block.Height = item.Block.GetHeight()
block.Version = item.Block.GetVersion()
......
......@@ -413,7 +413,6 @@ func TestChain33_ReWriteRawTx(t *testing.T) {
reTx := &rpctypes.ReWriteRawTx{
Tx: txHex1,
Execer: "paracross",
Fee: 29977777777,
Expire: "130s",
To: "aabbccdd",
......@@ -428,7 +427,6 @@ func TestChain33_ReWriteRawTx(t *testing.T) {
tx := &types.Transaction{}
err = types.Decode(txData, tx)
assert.Nil(t, err)
assert.Equal(t, tx.Execer, []byte(reTx.Execer))
assert.Equal(t, tx.Fee, reTx.Fee)
assert.Equal(t, int64(130000000000), tx.Expire)
assert.Equal(t, reTx.To, tx.To)
......
......@@ -104,11 +104,6 @@ func TestJSONClient_Call(t *testing.T) {
err = jsonClient.Call("Chain33.QueryTotalFee", &types.ReqSignRawTx{}, &fee)
assert.NotNil(t, err)
var ticket []types.TicketMinerInfo
api.On("LocalList", mock.Anything).Return(nil, errors.New("error value"))
err = jsonClient.Call("Chain33.QueryTicketInfoList", &types.ReqSignRawTx{}, &ticket)
assert.NotNil(t, err)
var retNtp bool
api.On("IsNtpClockSync", mock.Anything).Return(&types.Reply{IsOk: true, Msg: []byte("yes")}, nil)
err = jsonClient.Call("Chain33.IsNtpClockSync", &types.ReqNil{}, &retNtp)
......
......@@ -377,7 +377,6 @@ type CreateTx struct {
// ReWriteRawTx parameter
type ReWriteRawTx struct {
Tx string `json:"tx"`
Execer string `json:"execer"`
To string `json:"to"`
Fee int64 `json:"fee"`
Expire string `json:"expire"`
......
......@@ -288,7 +288,8 @@ func addBlockByHashsFlags(cmd *cobra.Command) {
func getblockbyhashs(cmd *cobra.Command, args []string) {
rpcLaddr, _ := cmd.Flags().GetString("rpc_laddr")
hashes, _ := cmd.Flags().GetString("hashes")
hashesArr := strings.Split(hashes, " ")
hashesArr := strings.Fields(hashes)
params := rpctypes.ReqHashes{
Hashes: hashesArr,
}
......
......@@ -320,7 +320,6 @@ func addReWriteRawTxFlags(cmd *cobra.Command) {
cmd.Flags().StringP("tx", "s", "", "transaction hex")
cmd.MarkFlagRequired("tx")
cmd.Flags().StringP("execer", "x", "", "transaction execer (optional)")
cmd.Flags().StringP("to", "t", "", "to addr (optional)")
cmd.Flags().Float64P("fee", "f", 0, "transaction fee (optional)")
cmd.Flags().StringP("expire", "e", "120s", "expire time (optional)")
......@@ -329,7 +328,6 @@ func addReWriteRawTxFlags(cmd *cobra.Command) {
func reWriteRawTx(cmd *cobra.Command, args []string) {
rpcLaddr, _ := cmd.Flags().GetString("rpc_laddr")
txHash, _ := cmd.Flags().GetString("tx")
execer, _ := cmd.Flags().GetString("execer")
to, _ := cmd.Flags().GetString("to")
fee, _ := cmd.Flags().GetFloat64("fee")
expire, _ := cmd.Flags().GetString("expire")
......@@ -342,7 +340,6 @@ func reWriteRawTx(cmd *cobra.Command, args []string) {
params := rpctypes.ReWriteRawTx{
Tx: txHash,
Execer: execer,
To: to,
Fee: feeInt64 * 1e4,
Expire: expire,
......
......@@ -310,7 +310,6 @@ func addSignRawTxFlags(cmd *cobra.Command) {
cmd.Flags().StringP("addr", "a", "", "account address (optional)")
cmd.Flags().StringP("expire", "e", "120s", "transaction expire time")
cmd.Flags().Float64P("fee", "f", 0, "transaction fee (optional)")
cmd.Flags().StringP("execer", "x", "", "new transaction execer (optional)")
cmd.Flags().StringP("to", "t", "", "new to addr (optional)")
// A duration string is a possibly signed sequence of
......@@ -350,7 +349,6 @@ func signRawTx(cmd *cobra.Command, args []string) {
key, _ := cmd.Flags().GetString("key")
addr, _ := cmd.Flags().GetString("addr")
index, _ := cmd.Flags().GetInt32("index")
execer, _ := cmd.Flags().GetString("execer")
to, _ := cmd.Flags().GetString("to")
fee, _ := cmd.Flags().GetFloat64("fee")
expire, _ := cmd.Flags().GetString("expire")
......@@ -367,7 +365,6 @@ func signRawTx(cmd *cobra.Command, args []string) {
Expire: expire,
Index: index,
Fee: feeInt64 * 1e4,
NewExecer: []byte(execer),
NewToAddr: to,
}
ctx := jsonclient.NewRPCCtx(rpcLaddr, "Chain33.SignRawTx", params, nil)
......
......@@ -54,7 +54,7 @@ message CreateTx {
message ReWriteRawTx {
string tx = 1;
bytes execer = 2;
// bytes execer = 2;
string to = 3;
string expire = 4;
int64 fee = 5;
......
......@@ -206,7 +206,7 @@ message ReqSignRawTx {
// int32 mode = 6;
string token = 7;
int64 fee = 8;
bytes newExecer = 9;
// bytes newExecer = 9;
string newToAddr = 10;
}
......
......@@ -80,9 +80,6 @@ func (wallet *Wallet) ProcSignRawTx(unsigned *types.ReqSignRawTx) (string, error
return "", err
}
if unsigned.GetNewExecer() != nil {
tx.Execer = unsigned.NewExecer
}
if unsigned.NewToAddr != "" {
tx.To = unsigned.NewToAddr
}
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment