Commit 1a2863b7 authored by pengjun's avatar pengjun

#627 add preIndex & preStatus to collateralize create

parent b975d224
...@@ -121,9 +121,11 @@ func (action *Action) GetCreateReceiptLog(collateralize *pty.Collateralize) *typ ...@@ -121,9 +121,11 @@ func (action *Action) GetCreateReceiptLog(collateralize *pty.Collateralize) *typ
c := &pty.ReceiptCollateralize{} c := &pty.ReceiptCollateralize{}
c.CollateralizeId = collateralize.CollateralizeId c.CollateralizeId = collateralize.CollateralizeId
c.PreStatus = collateralize.PreStatus
c.Status = collateralize.Status c.Status = collateralize.Status
c.CreateAddr = action.fromaddr c.CreateAddr = action.fromaddr
c.Index = collateralize.Index c.Index = collateralize.Index
c.PreIndex = collateralize.PreIndex
log.Log = types.Encode(c) log.Log = types.Encode(c)
...@@ -205,14 +207,14 @@ func (action *Action) GetFeedReceiptLog(collateralize *pty.Collateralize, record ...@@ -205,14 +207,14 @@ func (action *Action) GetFeedReceiptLog(collateralize *pty.Collateralize, record
} }
// GetCloseReceiptLog generate logs for Collateralize close action // GetCloseReceiptLog generate logs for Collateralize close action
func (action *Action) GetCloseReceiptLog(collateralize *pty.Collateralize) *types.ReceiptLog { func (action *Action) GetRetrieveReceiptLog(collateralize *pty.Collateralize) *types.ReceiptLog {
log := &types.ReceiptLog{} log := &types.ReceiptLog{}
log.Ty = pty.TyLogCollateralizeRetrieve log.Ty = pty.TyLogCollateralizeRetrieve
c := &pty.ReceiptCollateralize{} c := &pty.ReceiptCollateralize{}
c.CollateralizeId = collateralize.CollateralizeId c.CollateralizeId = collateralize.CollateralizeId
c.Status = collateralize.Status c.Status = collateralize.Status
c.PreStatus = pty.CollateralizeStatusCreated c.PreStatus = collateralize.PreStatus
c.CreateAddr = action.fromaddr c.CreateAddr = action.fromaddr
c.PreIndex = collateralize.PreIndex c.PreIndex = collateralize.PreIndex
c.Index = collateralize.Index c.Index = collateralize.Index
...@@ -462,6 +464,9 @@ func (action *Action) CollateralizeCreate(create *pty.CollateralizeCreate) (*typ ...@@ -462,6 +464,9 @@ func (action *Action) CollateralizeCreate(create *pty.CollateralizeCreate) (*typ
coll.Collateralize = *collateralize coll.Collateralize = *collateralize
coll.TotalBalance += create.TotalBalance coll.TotalBalance += create.TotalBalance
coll.Balance += create.TotalBalance coll.Balance += create.TotalBalance
coll.PreIndex = coll.Index
coll.PreStatus = coll.Status
coll.Index = action.GetIndex()
} }
clog.Debug("CollateralizeCreate created", "CollateralizeID", collateralizeID, "TotalBalance", create.TotalBalance) clog.Debug("CollateralizeCreate created", "CollateralizeID", collateralizeID, "TotalBalance", create.TotalBalance)
...@@ -1146,7 +1151,7 @@ func (action *Action) CollateralizeRetrieve(retrieve *pty.CollateralizeRetrieve) ...@@ -1146,7 +1151,7 @@ func (action *Action) CollateralizeRetrieve(retrieve *pty.CollateralizeRetrieve)
// 收回金额不能大于待放出金额 // 收回金额不能大于待放出金额
if retrieve.Balance > collateralize.Balance { if retrieve.Balance > collateralize.Balance {
clog.Error("CollateralizeRetrieve", "CollateralizeId", retrieve.CollateralizeId, "error", "balance error", "retrieve balance", retrieve.Balance, "available balance", collateralize.Balance) clog.Error("CollateralizeRetrieve", "CollateralizeId", retrieve.CollateralizeId, "error", "balance error", "retrieve balance", retrieve.Balance, "available balance", collateralize.Balance)
return nil, pty.ErrPermissionDeny return nil, types.ErrAmount
} }
// 解冻ccny // 解冻ccny
...@@ -1163,15 +1168,16 @@ func (action *Action) CollateralizeRetrieve(retrieve *pty.CollateralizeRetrieve) ...@@ -1163,15 +1168,16 @@ func (action *Action) CollateralizeRetrieve(retrieve *pty.CollateralizeRetrieve)
coll := &CollateralizeDB{*collateralize} coll := &CollateralizeDB{*collateralize}
coll.TotalBalance -= retrieve.Balance coll.TotalBalance -= retrieve.Balance
coll.Balance -= retrieve.Balance coll.Balance -= retrieve.Balance
coll.PreStatus = coll.Status
if coll.TotalBalance == 0 { if coll.TotalBalance == 0 {
coll.PreIndex = coll.Index
coll.Index = action.GetIndex()
coll.Status = pty.CollateralizeStatusClose coll.Status = pty.CollateralizeStatusClose
} }
coll.PreIndex = coll.Index
coll.Index = action.GetIndex()
coll.Save(action.db) coll.Save(action.db)
kv = append(kv, coll.GetKVSet()...) kv = append(kv, coll.GetKVSet()...)
receiptLog := action.GetCloseReceiptLog(&coll.Collateralize) receiptLog := action.GetRetrieveReceiptLog(&coll.Collateralize)
logs = append(logs, receiptLog) logs = append(logs, receiptLog)
return &types.Receipt{Ty: types.ExecOk, KV: kv, Logs: logs}, nil return &types.Receipt{Ty: types.ExecOk, KV: kv, Logs: logs}, nil
......
...@@ -24,6 +24,8 @@ func (c *Collateralize) execDelLocal(tx *types.Transaction, receiptData *types.R ...@@ -24,6 +24,8 @@ func (c *Collateralize) execDelLocal(tx *types.Transaction, receiptData *types.R
case pty.TyLogCollateralizeCreate: case pty.TyLogCollateralizeCreate:
set.KV = append(set.KV, c.deleteCollateralizeStatus(collateralizeLog.Status, collateralizeLog.Index)...) set.KV = append(set.KV, c.deleteCollateralizeStatus(collateralizeLog.Status, collateralizeLog.Index)...)
set.KV = append(set.KV, c.deleteCollateralizeAddr(collateralizeLog.CreateAddr, collateralizeLog.Index)...) set.KV = append(set.KV, c.deleteCollateralizeAddr(collateralizeLog.CreateAddr, collateralizeLog.Index)...)
set.KV = append(set.KV, c.addCollateralizeStatus(collateralizeLog.PreStatus, collateralizeLog.CollateralizeId, collateralizeLog.PreIndex)...)
set.KV = append(set.KV, c.addCollateralizeAddr(collateralizeLog.CreateAddr, collateralizeLog.CollateralizeId, collateralizeLog.PreStatus, collateralizeLog.PreIndex)...)
break break
case pty.TyLogCollateralizeBorrow: case pty.TyLogCollateralizeBorrow:
set.KV = append(set.KV, c.deleteCollateralizeRecordStatus(collateralizeLog.Status, collateralizeLog.Index)...) set.KV = append(set.KV, c.deleteCollateralizeRecordStatus(collateralizeLog.Status, collateralizeLog.Index)...)
...@@ -58,13 +60,10 @@ func (c *Collateralize) execDelLocal(tx *types.Transaction, receiptData *types.R ...@@ -58,13 +60,10 @@ func (c *Collateralize) execDelLocal(tx *types.Transaction, receiptData *types.R
//} //}
break break
case pty.TyLogCollateralizeRetrieve: case pty.TyLogCollateralizeRetrieve:
if collateralizeLog.Status == pty.CollateralizeStatusClose { set.KV = append(set.KV, c.deleteCollateralizeStatus(collateralizeLog.Status, collateralizeLog.Index)...)
set.KV = append(set.KV, c.deleteCollateralizeStatus(collateralizeLog.Status, collateralizeLog.Index)...) set.KV = append(set.KV, c.deleteCollateralizeAddr(collateralizeLog.CreateAddr, collateralizeLog.Index)...)
set.KV = append(set.KV, c.addCollateralizeStatus(pty.CollateralizeStatusCreated, collateralizeLog.CollateralizeId, set.KV = append(set.KV, c.addCollateralizeStatus(collateralizeLog.PreStatus, collateralizeLog.CollateralizeId, collateralizeLog.PreIndex)...)
collateralizeLog.PreIndex)...) set.KV = append(set.KV, c.addCollateralizeAddr(collateralizeLog.CreateAddr, collateralizeLog.CollateralizeId, collateralizeLog.PreStatus, collateralizeLog.PreIndex)...)
//set.KV = append(set.KV, c.addCollateralizeAddr(collateralizeLog.CreateAddr, collateralizeLog.CollateralizeId,
// collateralizeLog.PreStatus, collateralizeLog.PreIndex)...)
}
break break
} }
} }
......
...@@ -23,6 +23,8 @@ func (c *Collateralize) execLocal(tx *types.Transaction, receipt *types.ReceiptD ...@@ -23,6 +23,8 @@ func (c *Collateralize) execLocal(tx *types.Transaction, receipt *types.ReceiptD
switch item.Ty { switch item.Ty {
case pty.TyLogCollateralizeCreate: case pty.TyLogCollateralizeCreate:
set.KV = append(set.KV, c.deleteCollateralizeStatus(collateralizeLog.PreStatus, collateralizeLog.PreIndex)...)
set.KV = append(set.KV, c.deleteCollateralizeAddr(collateralizeLog.CreateAddr, collateralizeLog.PreIndex)...)
set.KV = append(set.KV, c.addCollateralizeStatus(collateralizeLog.Status, collateralizeLog.CollateralizeId, collateralizeLog.Index)...) set.KV = append(set.KV, c.addCollateralizeStatus(collateralizeLog.Status, collateralizeLog.CollateralizeId, collateralizeLog.Index)...)
set.KV = append(set.KV, c.addCollateralizeAddr(collateralizeLog.CreateAddr, collateralizeLog.CollateralizeId, collateralizeLog.Status, collateralizeLog.Index)...) set.KV = append(set.KV, c.addCollateralizeAddr(collateralizeLog.CreateAddr, collateralizeLog.CollateralizeId, collateralizeLog.Status, collateralizeLog.Index)...)
break break
...@@ -60,11 +62,10 @@ func (c *Collateralize) execLocal(tx *types.Transaction, receipt *types.ReceiptD ...@@ -60,11 +62,10 @@ func (c *Collateralize) execLocal(tx *types.Transaction, receipt *types.ReceiptD
//} //}
break break
case pty.TyLogCollateralizeRetrieve: case pty.TyLogCollateralizeRetrieve:
if collateralizeLog.Status == pty.CollateralizeStatusClose { set.KV = append(set.KV, c.deleteCollateralizeStatus(collateralizeLog.PreStatus, collateralizeLog.PreIndex)...)
set.KV = append(set.KV, c.addCollateralizeStatus(collateralizeLog.Status, collateralizeLog.CollateralizeId, collateralizeLog.Index)...) set.KV = append(set.KV, c.deleteCollateralizeAddr(collateralizeLog.CreateAddr, collateralizeLog.PreIndex)...)
set.KV = append(set.KV, c.deleteCollateralizeStatus(collateralizeLog.PreStatus, collateralizeLog.PreIndex)...) set.KV = append(set.KV, c.addCollateralizeStatus(collateralizeLog.Status, collateralizeLog.CollateralizeId, collateralizeLog.Index)...)
//set.KV = append(set.KV, c.deleteCollateralizeAddr(collateralizeLog.CreateAddr, collateralizeLog.PreIndex)...) set.KV = append(set.KV, c.addCollateralizeAddr(collateralizeLog.CreateAddr, collateralizeLog.CollateralizeId, collateralizeLog.Status, collateralizeLog.Index)...)
}
break break
} }
} }
......
...@@ -20,6 +20,7 @@ message Collateralize { ...@@ -20,6 +20,7 @@ message Collateralize {
int64 index = 14;//当前索引 int64 index = 14;//当前索引
int64 preIndex = 15;//上一个索引 int64 preIndex = 15;//上一个索引
int64 collBalance = 16;//抵押bty int64 collBalance = 16;//抵押bty
int32 preStatus = 17;//上一个状态
} }
// 借出记录 // 借出记录
......
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