Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
S
sidecar-client-chain33
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
JIRA
JIRA
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
link33
sidecar-client-chain33
Commits
5d8d0160
Commit
5d8d0160
authored
Aug 05, 2022
by
suyanlong
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
fix paracross exec address bug
parent
453fd14c
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
52 additions
and
8 deletions
+52
-8
paracross.go
paracross/paracross.go
+51
-8
paracross.toml
paracross/paracross.toml
+1
-0
No files found.
paracross/paracross.go
View file @
5d8d0160
...
...
@@ -67,9 +67,10 @@ type Paracross struct {
cancel
context
.
CancelFunc
// 保存区块:(latest_height-6)高度以下的区块
// 分类块中的交易为:已完成、未完成的交易。
notify
chan
int64
// 高度完成提醒
heightDiff
int64
// 高度差
step
int64
notify
chan
int64
// 高度完成提醒
heightDiff
int64
// 高度差
step
int64
execAddress
string
isTest
bool
logger
hclog
.
InterceptLogger
...
...
@@ -159,6 +160,15 @@ func (p *Paracross) Initialize(configPath string, ID string, extra []byte) error
p
.
MinTxFeeRate
=
chain33Config
.
Chain33
.
Fee
p
.
isTest
=
chain33Config
.
Chain33
.
IsTest
p
.
paraHeight
=
atomic
.
NewUint64
(
0
)
if
strings
.
ToUpper
(
chain33Config
.
Chain33
.
Symbol
)
==
"YCC"
{
execAddress
,
err
:=
address
.
GetExecAddress
(
ID
,
2
)
if
err
!=
nil
{
return
errors
.
Wrap
(
err
,
"execAddress"
)
}
p
.
execAddress
=
execAddress
}
else
{
p
.
execAddress
=
address
.
ExecAddress
(
ID
)
}
config33
=
fmt
.
Sprintf
(
config33
,
p
.
title
,
chain33Config
.
Chain33
.
Addr
)
p
.
logger
.
Info
(
config33
)
...
...
@@ -450,7 +460,7 @@ func (p *Paracross) lockEvent(lock *types33.AssetsTransfer, tx *types33.Transact
Contract
:
&
types
.
Contract
{
ChainID
:
cast
.
ToString
(
p
.
chainID
),
ExecName
:
ID
,
Address
:
address
.
ExecAddress
(
ID
)
,
// 合约地址
Address
:
p
.
execAddress
,
// 合约地址
CallMethod
:
"AssetTransfer"
,
},
Payload
:
&
types
.
MapAssetInfo
{
...
...
@@ -477,7 +487,7 @@ func (p *Paracross) lockCrossEvent(lock *paracorssTypes.CrossAssetTransfer, tx *
Contract
:
&
types
.
Contract
{
ChainID
:
cast
.
ToString
(
p
.
chainID
),
ExecName
:
ID
,
Address
:
address
.
ExecAddress
(
ID
)
,
// 合约地址
Address
:
p
.
execAddress
,
// 合约地址
CallMethod
:
"CrossAssetTransfer"
,
},
Payload
:
&
types
.
MapAssetInfo
{
...
...
@@ -500,7 +510,7 @@ func (p *Paracross) unLockEvent(unlock *types33.AssetsWithdraw, tx *types33.Tran
Contract
:
&
types
.
Contract
{
ChainID
:
cast
.
ToString
(
p
.
chainID
),
ExecName
:
ID
,
Address
:
address
.
ExecAddress
(
ID
)
,
// 合约地址
Address
:
p
.
execAddress
,
// 合约地址
CallMethod
:
"AssetsWithdraw"
,
},
Payload
:
&
types
.
MapAssetInfo
{
...
...
@@ -702,7 +712,7 @@ func (p *Paracross) SubmitIBTP(ibtp *pb.IBTP) (*pb.SubmitIBTPResponse, error) {
if
event
.
Payload
.
EventType
==
types
.
EventType_Burn
{
// 用户在联盟链一侧发起销毁。
// 第一次提交。
tx
,
err
:=
p
aracorssTypes
.
CreateRawAssetTransferTxExt
(
p
.
chainID
,
p
.
MinTxFeeRate
,
&
types33
.
CreateTx
{
tx
,
err
:=
p
.
CreateRawAssetTransferTxExt
(
p
.
chainID
,
p
.
MinTxFeeRate
,
&
types33
.
CreateTx
{
To
:
event
.
Payload
.
BurnAddress
,
Amount
:
event
.
Payload
.
BurnAmount
,
Fee
:
p
.
MinTxFeeRate
,
...
...
@@ -740,6 +750,39 @@ func (p *Paracross) SubmitIBTP(ibtp *pb.IBTP) (*pb.SubmitIBTPResponse, error) {
return
nil
,
errors
.
New
(
"ibtp error"
)
}
func
(
p
*
Paracross
)
CreateRawAssetTransferTxExt
(
chainID
int32
,
minFee
int64
,
param
*
types33
.
CreateTx
)
(
*
types33
.
Transaction
,
error
)
{
// 跨链交易需要在主链和平行链上执行, 所以应该可以在主链和平行链上构建
if
!
types33
.
IsParaExecName
(
param
.
GetExecName
())
{
return
nil
,
types33
.
ErrInvalidParam
}
transfer
:=
&
paracorssTypes
.
ParacrossAction
{}
if
!
param
.
IsWithdraw
{
v
:=
&
paracorssTypes
.
ParacrossAction_AssetTransfer
{
AssetTransfer
:
&
types33
.
AssetsTransfer
{
Amount
:
param
.
Amount
,
Note
:
param
.
GetNote
(),
To
:
param
.
GetTo
(),
Cointoken
:
param
.
TokenSymbol
,
}}
transfer
.
Value
=
v
transfer
.
Ty
=
paracorssTypes
.
ParacrossActionAssetTransfer
}
else
{
v
:=
&
paracorssTypes
.
ParacrossAction_AssetWithdraw
{
AssetWithdraw
:
&
types33
.
AssetsWithdraw
{
Amount
:
param
.
Amount
,
Note
:
param
.
GetNote
(),
To
:
param
.
GetTo
(),
Cointoken
:
param
.
TokenSymbol
,
ExecName
:
param
.
ExecName
,
}}
transfer
.
Value
=
v
transfer
.
Ty
=
paracorssTypes
.
ParacrossActionAssetWithdraw
}
rawtx
:=
&
types33
.
Transaction
{
Execer
:
[]
byte
(
param
.
GetExecName
()),
Payload
:
types33
.
Encode
(
transfer
),
To
:
p
.
execAddress
,
Fee
:
param
.
Fee
,
}
tx
,
err
:=
types33
.
FormatTxExt
(
chainID
,
true
,
minFee
,
param
.
GetExecName
(),
rawtx
)
if
err
!=
nil
{
return
nil
,
err
}
return
tx
,
nil
}
// 模拟status
func
(
p
*
Paracross
)
getNodeStatus
(
curTxHashs
[][]
byte
,
blockDetail
*
types33
.
BlockDetail
,
paraHeight
int64
)
(
*
paracorssTypes
.
ParacrossNodeStatus
,
error
)
{
// var (
...
...
@@ -828,7 +871,7 @@ func (p *Paracross) CreateRawCommitTx(commit *paracorssTypes.ParacrossCommitActi
}
tx
:=
&
types33
.
Transaction
{
Payload
:
types33
.
Encode
(
action
),
To
:
address
.
ExecAddress
(
execer
)
,
To
:
p
.
execAddress
,
Expire
:
types33
.
Now
()
.
Unix
()
+
int64
(
120
),
// 120s
}
return
p
.
FormatTx
(
tx
)
...
...
paracross/paracross.toml
View file @
5d8d0160
...
...
@@ -14,6 +14,7 @@ fee = 100000
#被监听链ID
chain_id
=
0
step
=
10
symbol
=
"BTY"
[log]
#日志级别
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment