Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
N
nebula
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
exchain
nebula
Commits
04248fb0
Commit
04248fb0
authored
Aug 05, 2023
by
Hamdi Allam
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
fix standard bridge
parent
58a2d894
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
36 additions
and
40 deletions
+36
-40
standard_bridge.go
indexer/processor/standard_bridge.go
+36
-40
No files found.
indexer/processor/standard_bridge.go
View file @
04248fb0
...
...
@@ -9,19 +9,15 @@ import (
"github.com/ethereum-optimism/optimism/indexer/database"
"github.com/ethereum-optimism/optimism/op-bindings/bindings"
"github.com/ethereum-optimism/optimism/op-bindings/predeploys"
"github.com/ethereum/go-ethereum/common"
"github.com/ethereum/go-ethereum/ethclient"
)
var
(
EthAddress
=
common
.
HexToAddress
(
"0xDeadDeAddeAddEAddeadDEaDDEAdDeaDDeAD0000"
)
)
type
StandardBridgeInitiatedEvent
struct
{
// We hardcode to ERC20 since ETH can be pseudo-represented as an ERC20 utilizing
// the hardcoded ETH address
*
bindings
.
L1
StandardBridgeERC20BridgeInitiated
*
bindings
.
StandardBridgeERC20BridgeInitiated
CrossDomainMessengerNonce
*
big
.
Int
RawEvent
*
database
.
ContractEvent
...
...
@@ -30,7 +26,7 @@ type StandardBridgeInitiatedEvent struct {
type
StandardBridgeFinalizedEvent
struct
{
// We hardcode to ERC20 since ETH can be pseudo-represented as an ERC20 utilizing
// the hardcoded ETH address
*
bindings
.
L1
StandardBridgeERC20BridgeFinalized
*
bindings
.
StandardBridgeERC20BridgeFinalized
CrossDomainMessengerNonce
*
big
.
Int
RawEvent
*
database
.
ContractEvent
...
...
@@ -39,12 +35,12 @@ type StandardBridgeFinalizedEvent struct {
// StandardBridgeInitiatedEvents extracts all initiated bridge events from the contracts that follow the StandardBridge ABI. The
// correlated CrossDomainMessenger nonce is also parsed from the associated messenger events.
func
StandardBridgeInitiatedEvents
(
events
*
ProcessedContractEvents
)
([]
StandardBridgeInitiatedEvent
,
error
)
{
ethBridgeInitiatedEvents
,
err
:=
_standardBridgeInitiatedEvents
[
bindings
.
L1
StandardBridgeETHBridgeInitiated
](
events
)
ethBridgeInitiatedEvents
,
err
:=
_standardBridgeInitiatedEvents
[
bindings
.
StandardBridgeETHBridgeInitiated
](
events
)
if
err
!=
nil
{
return
nil
,
err
}
erc20BridgeInitiatedEvents
,
err
:=
_standardBridgeInitiatedEvents
[
bindings
.
L1
StandardBridgeERC20BridgeInitiated
](
events
)
erc20BridgeInitiatedEvents
,
err
:=
_standardBridgeInitiatedEvents
[
bindings
.
StandardBridgeERC20BridgeInitiated
](
events
)
if
err
!=
nil
{
return
nil
,
err
}
...
...
@@ -55,12 +51,12 @@ func StandardBridgeInitiatedEvents(events *ProcessedContractEvents) ([]StandardB
// StandardBridgeFinalizedEvents extracts all finalization bridge events from the contracts that follow the StandardBridge ABI. The
// correlated CrossDomainMessenger nonce is also parsed by looking at the parameters of the corresponding relayMessage transaction data.
func
StandardBridgeFinalizedEvents
(
rawEthClient
*
ethclient
.
Client
,
events
*
ProcessedContractEvents
)
([]
StandardBridgeFinalizedEvent
,
error
)
{
ethBridgeFinalizedEvents
,
err
:=
_standardBridgeFinalizedEvents
[
bindings
.
L1
StandardBridgeETHBridgeFinalized
](
rawEthClient
,
events
)
ethBridgeFinalizedEvents
,
err
:=
_standardBridgeFinalizedEvents
[
bindings
.
StandardBridgeETHBridgeFinalized
](
rawEthClient
,
events
)
if
err
!=
nil
{
return
nil
,
err
}
erc20BridgeFinalizedEvents
,
err
:=
_standardBridgeFinalizedEvents
[
bindings
.
L1
StandardBridgeERC20BridgeFinalized
](
rawEthClient
,
events
)
erc20BridgeFinalizedEvents
,
err
:=
_standardBridgeFinalizedEvents
[
bindings
.
StandardBridgeERC20BridgeFinalized
](
rawEthClient
,
events
)
if
err
!=
nil
{
return
nil
,
err
}
...
...
@@ -69,10 +65,10 @@ func StandardBridgeFinalizedEvents(rawEthClient *ethclient.Client, events *Proce
}
// parse out eth or erc20 bridge initiated events
func
_standardBridgeInitiatedEvents
[
BridgeEvent
bindings
.
L1StandardBridgeETHBridgeInitiated
|
bindings
.
L1
StandardBridgeERC20BridgeInitiated
](
func
_standardBridgeInitiatedEvents
[
BridgeEvent
bindings
.
StandardBridgeETHBridgeInitiated
|
bindings
.
StandardBridgeERC20BridgeInitiated
](
events
*
ProcessedContractEvents
,
)
([]
StandardBridgeInitiatedEvent
,
error
)
{
l1StandardBridgeABI
,
err
:=
bindings
.
L1
StandardBridgeMetaData
.
GetAbi
()
StandardBridgeABI
,
err
:=
bindings
.
StandardBridgeMetaData
.
GetAbi
()
if
err
!=
nil
{
return
nil
,
err
}
...
...
@@ -88,23 +84,23 @@ func _standardBridgeInitiatedEvents[BridgeEvent bindings.L1StandardBridgeETHBrid
var
eventName
string
var
finalizeMethodName
string
switch
any
(
tmp
)
.
(
type
)
{
case
bindings
.
L1
StandardBridgeETHBridgeInitiated
:
case
bindings
.
StandardBridgeETHBridgeInitiated
:
eventName
=
"ETHBridgeInitiated"
finalizeMethodName
=
"finalizeBridgeETH"
case
bindings
.
L1
StandardBridgeERC20BridgeInitiated
:
case
bindings
.
StandardBridgeERC20BridgeInitiated
:
eventName
=
"ERC20BridgeInitiated"
finalizeMethodName
=
"finalizeBridgeERC20"
default
:
panic
(
"should not be here"
)
}
processedInitiatedBridgeEvents
:=
events
.
eventsBySignature
[
l1
StandardBridgeABI
.
Events
[
eventName
]
.
ID
]
processedInitiatedBridgeEvents
:=
events
.
eventsBySignature
[
StandardBridgeABI
.
Events
[
eventName
]
.
ID
]
initiatedBridgeEvents
:=
make
([]
StandardBridgeInitiatedEvent
,
len
(
processedInitiatedBridgeEvents
))
for
i
,
bridgeInitiatedEvent
:=
range
processedInitiatedBridgeEvents
{
log
:=
events
.
eventLog
[
bridgeInitiatedEvent
.
GUID
]
bridgeData
:=
new
(
BridgeEvent
)
err
:=
UnpackLog
(
bridgeData
,
log
,
eventName
,
l1
StandardBridgeABI
)
var
bridgeData
BridgeEvent
err
:=
UnpackLog
(
&
bridgeData
,
log
,
eventName
,
StandardBridgeABI
)
if
err
!=
nil
{
return
nil
,
err
}
...
...
@@ -119,28 +115,28 @@ func _standardBridgeInitiatedEvents[BridgeEvent bindings.L1StandardBridgeETHBrid
return
nil
,
err
}
var
erc20BridgeData
*
bindings
.
L1
StandardBridgeERC20BridgeInitiated
var
erc20BridgeData
*
bindings
.
StandardBridgeERC20BridgeInitiated
var
expectedCrossDomainMessage
[]
byte
switch
any
(
bridgeData
)
.
(
type
)
{
case
*
bindings
.
L1
StandardBridgeETHBridgeInitiated
:
ethBridgeData
:=
any
(
bridgeData
)
.
(
*
bindings
.
L1
StandardBridgeETHBridgeInitiated
)
expectedCrossDomainMessage
,
err
=
l1
StandardBridgeABI
.
Pack
(
finalizeMethodName
,
ethBridgeData
.
From
,
ethBridgeData
.
To
,
ethBridgeData
.
Amount
,
ethBridgeData
.
ExtraData
)
case
bindings
.
StandardBridgeETHBridgeInitiated
:
ethBridgeData
:=
any
(
bridgeData
)
.
(
bindings
.
StandardBridgeETHBridgeInitiated
)
expectedCrossDomainMessage
,
err
=
StandardBridgeABI
.
Pack
(
finalizeMethodName
,
ethBridgeData
.
From
,
ethBridgeData
.
To
,
ethBridgeData
.
Amount
,
ethBridgeData
.
ExtraData
)
if
err
!=
nil
{
return
nil
,
err
}
// represent eth bridge as an erc20
erc20BridgeData
=
&
bindings
.
L1
StandardBridgeERC20BridgeInitiated
{
erc20BridgeData
=
&
bindings
.
StandardBridgeERC20BridgeInitiated
{
// Represent ETH using the hardcoded address
LocalToken
:
EthAddress
,
RemoteToken
:
EthAddress
,
LocalToken
:
predeploys
.
LegacyERC20ETHAddr
,
RemoteToken
:
predeploys
.
LegacyERC20ETHAddr
,
// Bridge data
From
:
ethBridgeData
.
From
,
To
:
ethBridgeData
.
To
,
Amount
:
ethBridgeData
.
Amount
,
ExtraData
:
ethBridgeData
.
ExtraData
,
}
case
*
bindings
.
L1
StandardBridgeERC20BridgeInitiated
:
_temp
:=
any
(
bridgeData
)
.
(
bindings
.
L1
StandardBridgeERC20BridgeInitiated
)
case
bindings
.
StandardBridgeERC20BridgeInitiated
:
_temp
:=
any
(
bridgeData
)
.
(
bindings
.
StandardBridgeERC20BridgeInitiated
)
erc20BridgeData
=
&
_temp
expectedCrossDomainMessage
,
err
=
l1
StandardBridgeABI
.
Pack
(
finalizeMethodName
,
erc20BridgeData
.
RemoteToken
,
erc20BridgeData
.
LocalToken
,
erc20BridgeData
.
From
,
erc20BridgeData
.
To
,
erc20BridgeData
.
Amount
,
erc20BridgeData
.
ExtraData
)
expectedCrossDomainMessage
,
err
=
StandardBridgeABI
.
Pack
(
finalizeMethodName
,
erc20BridgeData
.
RemoteToken
,
erc20BridgeData
.
LocalToken
,
erc20BridgeData
.
From
,
erc20BridgeData
.
To
,
erc20BridgeData
.
Amount
,
erc20BridgeData
.
ExtraData
)
if
err
!=
nil
{
return
nil
,
err
}
...
...
@@ -157,11 +153,11 @@ func _standardBridgeInitiatedEvents[BridgeEvent bindings.L1StandardBridgeETHBrid
}
// parse out eth or erc20 bridge finalization events
func
_standardBridgeFinalizedEvents
[
BridgeEvent
bindings
.
L1StandardBridgeETHBridgeFinalized
|
bindings
.
L1
StandardBridgeERC20BridgeFinalized
](
func
_standardBridgeFinalizedEvents
[
BridgeEvent
bindings
.
StandardBridgeETHBridgeFinalized
|
bindings
.
StandardBridgeERC20BridgeFinalized
](
rawEthClient
*
ethclient
.
Client
,
events
*
ProcessedContractEvents
,
)
([]
StandardBridgeFinalizedEvent
,
error
)
{
l1StandardBridgeABI
,
err
:=
bindings
.
L1
StandardBridgeMetaData
.
GetAbi
()
StandardBridgeABI
,
err
:=
bindings
.
StandardBridgeMetaData
.
GetAbi
()
if
err
!=
nil
{
return
nil
,
err
}
...
...
@@ -183,21 +179,21 @@ func _standardBridgeFinalizedEvents[BridgeEvent bindings.L1StandardBridgeETHBrid
var
bridgeData
BridgeEvent
var
eventName
string
switch
any
(
bridgeData
)
.
(
type
)
{
case
bindings
.
L1
StandardBridgeETHBridgeFinalized
:
case
bindings
.
StandardBridgeETHBridgeFinalized
:
eventName
=
"ETHBridgeFinalized"
case
bindings
.
L1
StandardBridgeERC20BridgeFinalized
:
case
bindings
.
StandardBridgeERC20BridgeFinalized
:
eventName
=
"ERC20BridgeFinalized"
default
:
panic
(
"should not be here"
)
}
processedFinalizedBridgeEvents
:=
events
.
eventsBySignature
[
l1
StandardBridgeABI
.
Events
[
eventName
]
.
ID
]
processedFinalizedBridgeEvents
:=
events
.
eventsBySignature
[
StandardBridgeABI
.
Events
[
eventName
]
.
ID
]
finalizedBridgeEvents
:=
make
([]
StandardBridgeFinalizedEvent
,
len
(
processedFinalizedBridgeEvents
))
for
i
,
bridgeFinalizedEvent
:=
range
processedFinalizedBridgeEvents
{
log
:=
events
.
eventLog
[
bridgeFinalizedEvent
.
GUID
]
var
bridgeData
BridgeEvent
err
:=
UnpackLog
(
&
bridgeData
,
log
,
eventName
,
l1
StandardBridgeABI
)
err
:=
UnpackLog
(
&
bridgeData
,
log
,
eventName
,
StandardBridgeABI
)
if
err
!=
nil
{
return
nil
,
err
}
...
...
@@ -256,19 +252,19 @@ func _standardBridgeFinalizedEvents[BridgeEvent bindings.L1StandardBridgeETHBrid
return
nil
,
errors
.
New
(
"unable to extract `_nonce` parameter from relayMessage calldata"
)
}
var
erc20BridgeData
*
bindings
.
L1
StandardBridgeERC20BridgeFinalized
var
erc20BridgeData
*
bindings
.
StandardBridgeERC20BridgeFinalized
switch
any
(
bridgeData
)
.
(
type
)
{
case
bindings
.
L1StandardBridgeETHBridgeInitiat
ed
:
ethBridgeData
:=
any
(
bridgeData
)
.
(
bindings
.
L1
StandardBridgeETHBridgeFinalized
)
erc20BridgeData
=
&
bindings
.
L1
StandardBridgeERC20BridgeFinalized
{
case
bindings
.
StandardBridgeETHBridgeFinaliz
ed
:
ethBridgeData
:=
any
(
bridgeData
)
.
(
bindings
.
StandardBridgeETHBridgeFinalized
)
erc20BridgeData
=
&
bindings
.
StandardBridgeERC20BridgeFinalized
{
// Represent ETH using the hardcoded address
LocalToken
:
EthAddress
,
RemoteToken
:
EthAddress
,
LocalToken
:
predeploys
.
LegacyERC20ETHAddr
,
RemoteToken
:
predeploys
.
LegacyERC20ETHAddr
,
// Bridge data
From
:
ethBridgeData
.
From
,
To
:
ethBridgeData
.
To
,
Amount
:
ethBridgeData
.
Amount
,
ExtraData
:
ethBridgeData
.
ExtraData
,
}
case
bindings
.
L1StandardBridgeERC20BridgeInitiat
ed
:
_temp
:=
any
(
bridgeData
)
.
(
bindings
.
L1
StandardBridgeERC20BridgeFinalized
)
case
bindings
.
StandardBridgeERC20BridgeFinaliz
ed
:
_temp
:=
any
(
bridgeData
)
.
(
bindings
.
StandardBridgeERC20BridgeFinalized
)
erc20BridgeData
=
&
_temp
}
...
...
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