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 (
...
@@ -9,19 +9,15 @@ import (
"github.com/ethereum-optimism/optimism/indexer/database"
"github.com/ethereum-optimism/optimism/indexer/database"
"github.com/ethereum-optimism/optimism/op-bindings/bindings"
"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"
"github.com/ethereum/go-ethereum/ethclient"
)
)
var
(
EthAddress
=
common
.
HexToAddress
(
"0xDeadDeAddeAddEAddeadDEaDDEAdDeaDDeAD0000"
)
)
type
StandardBridgeInitiatedEvent
struct
{
type
StandardBridgeInitiatedEvent
struct
{
// We hardcode to ERC20 since ETH can be pseudo-represented as an ERC20 utilizing
// We hardcode to ERC20 since ETH can be pseudo-represented as an ERC20 utilizing
// the hardcoded ETH address
// the hardcoded ETH address
*
bindings
.
L1
StandardBridgeERC20BridgeInitiated
*
bindings
.
StandardBridgeERC20BridgeInitiated
CrossDomainMessengerNonce
*
big
.
Int
CrossDomainMessengerNonce
*
big
.
Int
RawEvent
*
database
.
ContractEvent
RawEvent
*
database
.
ContractEvent
...
@@ -30,7 +26,7 @@ type StandardBridgeInitiatedEvent struct {
...
@@ -30,7 +26,7 @@ type StandardBridgeInitiatedEvent struct {
type
StandardBridgeFinalizedEvent
struct
{
type
StandardBridgeFinalizedEvent
struct
{
// We hardcode to ERC20 since ETH can be pseudo-represented as an ERC20 utilizing
// We hardcode to ERC20 since ETH can be pseudo-represented as an ERC20 utilizing
// the hardcoded ETH address
// the hardcoded ETH address
*
bindings
.
L1
StandardBridgeERC20BridgeFinalized
*
bindings
.
StandardBridgeERC20BridgeFinalized
CrossDomainMessengerNonce
*
big
.
Int
CrossDomainMessengerNonce
*
big
.
Int
RawEvent
*
database
.
ContractEvent
RawEvent
*
database
.
ContractEvent
...
@@ -39,12 +35,12 @@ type StandardBridgeFinalizedEvent struct {
...
@@ -39,12 +35,12 @@ type StandardBridgeFinalizedEvent struct {
// StandardBridgeInitiatedEvents extracts all initiated bridge events from the contracts that follow the StandardBridge ABI. The
// 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.
// correlated CrossDomainMessenger nonce is also parsed from the associated messenger events.
func
StandardBridgeInitiatedEvents
(
events
*
ProcessedContractEvents
)
([]
StandardBridgeInitiatedEvent
,
error
)
{
func
StandardBridgeInitiatedEvents
(
events
*
ProcessedContractEvents
)
([]
StandardBridgeInitiatedEvent
,
error
)
{
ethBridgeInitiatedEvents
,
err
:=
_standardBridgeInitiatedEvents
[
bindings
.
L1
StandardBridgeETHBridgeInitiated
](
events
)
ethBridgeInitiatedEvents
,
err
:=
_standardBridgeInitiatedEvents
[
bindings
.
StandardBridgeETHBridgeInitiated
](
events
)
if
err
!=
nil
{
if
err
!=
nil
{
return
nil
,
err
return
nil
,
err
}
}
erc20BridgeInitiatedEvents
,
err
:=
_standardBridgeInitiatedEvents
[
bindings
.
L1
StandardBridgeERC20BridgeInitiated
](
events
)
erc20BridgeInitiatedEvents
,
err
:=
_standardBridgeInitiatedEvents
[
bindings
.
StandardBridgeERC20BridgeInitiated
](
events
)
if
err
!=
nil
{
if
err
!=
nil
{
return
nil
,
err
return
nil
,
err
}
}
...
@@ -55,12 +51,12 @@ func StandardBridgeInitiatedEvents(events *ProcessedContractEvents) ([]StandardB
...
@@ -55,12 +51,12 @@ func StandardBridgeInitiatedEvents(events *ProcessedContractEvents) ([]StandardB
// StandardBridgeFinalizedEvents extracts all finalization bridge events from the contracts that follow the StandardBridge ABI. The
// 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.
// 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
)
{
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
{
if
err
!=
nil
{
return
nil
,
err
return
nil
,
err
}
}
erc20BridgeFinalizedEvents
,
err
:=
_standardBridgeFinalizedEvents
[
bindings
.
L1
StandardBridgeERC20BridgeFinalized
](
rawEthClient
,
events
)
erc20BridgeFinalizedEvents
,
err
:=
_standardBridgeFinalizedEvents
[
bindings
.
StandardBridgeERC20BridgeFinalized
](
rawEthClient
,
events
)
if
err
!=
nil
{
if
err
!=
nil
{
return
nil
,
err
return
nil
,
err
}
}
...
@@ -69,10 +65,10 @@ func StandardBridgeFinalizedEvents(rawEthClient *ethclient.Client, events *Proce
...
@@ -69,10 +65,10 @@ func StandardBridgeFinalizedEvents(rawEthClient *ethclient.Client, events *Proce
}
}
// parse out eth or erc20 bridge initiated events
// 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
,
events
*
ProcessedContractEvents
,
)
([]
StandardBridgeInitiatedEvent
,
error
)
{
)
([]
StandardBridgeInitiatedEvent
,
error
)
{
l1StandardBridgeABI
,
err
:=
bindings
.
L1
StandardBridgeMetaData
.
GetAbi
()
StandardBridgeABI
,
err
:=
bindings
.
StandardBridgeMetaData
.
GetAbi
()
if
err
!=
nil
{
if
err
!=
nil
{
return
nil
,
err
return
nil
,
err
}
}
...
@@ -88,23 +84,23 @@ func _standardBridgeInitiatedEvents[BridgeEvent bindings.L1StandardBridgeETHBrid
...
@@ -88,23 +84,23 @@ func _standardBridgeInitiatedEvents[BridgeEvent bindings.L1StandardBridgeETHBrid
var
eventName
string
var
eventName
string
var
finalizeMethodName
string
var
finalizeMethodName
string
switch
any
(
tmp
)
.
(
type
)
{
switch
any
(
tmp
)
.
(
type
)
{
case
bindings
.
L1
StandardBridgeETHBridgeInitiated
:
case
bindings
.
StandardBridgeETHBridgeInitiated
:
eventName
=
"ETHBridgeInitiated"
eventName
=
"ETHBridgeInitiated"
finalizeMethodName
=
"finalizeBridgeETH"
finalizeMethodName
=
"finalizeBridgeETH"
case
bindings
.
L1
StandardBridgeERC20BridgeInitiated
:
case
bindings
.
StandardBridgeERC20BridgeInitiated
:
eventName
=
"ERC20BridgeInitiated"
eventName
=
"ERC20BridgeInitiated"
finalizeMethodName
=
"finalizeBridgeERC20"
finalizeMethodName
=
"finalizeBridgeERC20"
default
:
default
:
panic
(
"should not be here"
)
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
))
initiatedBridgeEvents
:=
make
([]
StandardBridgeInitiatedEvent
,
len
(
processedInitiatedBridgeEvents
))
for
i
,
bridgeInitiatedEvent
:=
range
processedInitiatedBridgeEvents
{
for
i
,
bridgeInitiatedEvent
:=
range
processedInitiatedBridgeEvents
{
log
:=
events
.
eventLog
[
bridgeInitiatedEvent
.
GUID
]
log
:=
events
.
eventLog
[
bridgeInitiatedEvent
.
GUID
]
bridgeData
:=
new
(
BridgeEvent
)
var
bridgeData
BridgeEvent
err
:=
UnpackLog
(
bridgeData
,
log
,
eventName
,
l1
StandardBridgeABI
)
err
:=
UnpackLog
(
&
bridgeData
,
log
,
eventName
,
StandardBridgeABI
)
if
err
!=
nil
{
if
err
!=
nil
{
return
nil
,
err
return
nil
,
err
}
}
...
@@ -119,28 +115,28 @@ func _standardBridgeInitiatedEvents[BridgeEvent bindings.L1StandardBridgeETHBrid
...
@@ -119,28 +115,28 @@ func _standardBridgeInitiatedEvents[BridgeEvent bindings.L1StandardBridgeETHBrid
return
nil
,
err
return
nil
,
err
}
}
var
erc20BridgeData
*
bindings
.
L1
StandardBridgeERC20BridgeInitiated
var
erc20BridgeData
*
bindings
.
StandardBridgeERC20BridgeInitiated
var
expectedCrossDomainMessage
[]
byte
var
expectedCrossDomainMessage
[]
byte
switch
any
(
bridgeData
)
.
(
type
)
{
switch
any
(
bridgeData
)
.
(
type
)
{
case
*
bindings
.
L1
StandardBridgeETHBridgeInitiated
:
case
bindings
.
StandardBridgeETHBridgeInitiated
:
ethBridgeData
:=
any
(
bridgeData
)
.
(
*
bindings
.
L1
StandardBridgeETHBridgeInitiated
)
ethBridgeData
:=
any
(
bridgeData
)
.
(
bindings
.
StandardBridgeETHBridgeInitiated
)
expectedCrossDomainMessage
,
err
=
l1
StandardBridgeABI
.
Pack
(
finalizeMethodName
,
ethBridgeData
.
From
,
ethBridgeData
.
To
,
ethBridgeData
.
Amount
,
ethBridgeData
.
ExtraData
)
expectedCrossDomainMessage
,
err
=
StandardBridgeABI
.
Pack
(
finalizeMethodName
,
ethBridgeData
.
From
,
ethBridgeData
.
To
,
ethBridgeData
.
Amount
,
ethBridgeData
.
ExtraData
)
if
err
!=
nil
{
if
err
!=
nil
{
return
nil
,
err
return
nil
,
err
}
}
// represent eth bridge as an erc20
// represent eth bridge as an erc20
erc20BridgeData
=
&
bindings
.
L1
StandardBridgeERC20BridgeInitiated
{
erc20BridgeData
=
&
bindings
.
StandardBridgeERC20BridgeInitiated
{
// Represent ETH using the hardcoded address
// Represent ETH using the hardcoded address
LocalToken
:
EthAddress
,
RemoteToken
:
EthAddress
,
LocalToken
:
predeploys
.
LegacyERC20ETHAddr
,
RemoteToken
:
predeploys
.
LegacyERC20ETHAddr
,
// Bridge data
// Bridge data
From
:
ethBridgeData
.
From
,
To
:
ethBridgeData
.
To
,
Amount
:
ethBridgeData
.
Amount
,
ExtraData
:
ethBridgeData
.
ExtraData
,
From
:
ethBridgeData
.
From
,
To
:
ethBridgeData
.
To
,
Amount
:
ethBridgeData
.
Amount
,
ExtraData
:
ethBridgeData
.
ExtraData
,
}
}
case
*
bindings
.
L1
StandardBridgeERC20BridgeInitiated
:
case
bindings
.
StandardBridgeERC20BridgeInitiated
:
_temp
:=
any
(
bridgeData
)
.
(
bindings
.
L1
StandardBridgeERC20BridgeInitiated
)
_temp
:=
any
(
bridgeData
)
.
(
bindings
.
StandardBridgeERC20BridgeInitiated
)
erc20BridgeData
=
&
_temp
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
{
if
err
!=
nil
{
return
nil
,
err
return
nil
,
err
}
}
...
@@ -157,11 +153,11 @@ func _standardBridgeInitiatedEvents[BridgeEvent bindings.L1StandardBridgeETHBrid
...
@@ -157,11 +153,11 @@ func _standardBridgeInitiatedEvents[BridgeEvent bindings.L1StandardBridgeETHBrid
}
}
// parse out eth or erc20 bridge finalization events
// 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
,
rawEthClient
*
ethclient
.
Client
,
events
*
ProcessedContractEvents
,
events
*
ProcessedContractEvents
,
)
([]
StandardBridgeFinalizedEvent
,
error
)
{
)
([]
StandardBridgeFinalizedEvent
,
error
)
{
l1StandardBridgeABI
,
err
:=
bindings
.
L1
StandardBridgeMetaData
.
GetAbi
()
StandardBridgeABI
,
err
:=
bindings
.
StandardBridgeMetaData
.
GetAbi
()
if
err
!=
nil
{
if
err
!=
nil
{
return
nil
,
err
return
nil
,
err
}
}
...
@@ -183,21 +179,21 @@ func _standardBridgeFinalizedEvents[BridgeEvent bindings.L1StandardBridgeETHBrid
...
@@ -183,21 +179,21 @@ func _standardBridgeFinalizedEvents[BridgeEvent bindings.L1StandardBridgeETHBrid
var
bridgeData
BridgeEvent
var
bridgeData
BridgeEvent
var
eventName
string
var
eventName
string
switch
any
(
bridgeData
)
.
(
type
)
{
switch
any
(
bridgeData
)
.
(
type
)
{
case
bindings
.
L1
StandardBridgeETHBridgeFinalized
:
case
bindings
.
StandardBridgeETHBridgeFinalized
:
eventName
=
"ETHBridgeFinalized"
eventName
=
"ETHBridgeFinalized"
case
bindings
.
L1
StandardBridgeERC20BridgeFinalized
:
case
bindings
.
StandardBridgeERC20BridgeFinalized
:
eventName
=
"ERC20BridgeFinalized"
eventName
=
"ERC20BridgeFinalized"
default
:
default
:
panic
(
"should not be here"
)
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
))
finalizedBridgeEvents
:=
make
([]
StandardBridgeFinalizedEvent
,
len
(
processedFinalizedBridgeEvents
))
for
i
,
bridgeFinalizedEvent
:=
range
processedFinalizedBridgeEvents
{
for
i
,
bridgeFinalizedEvent
:=
range
processedFinalizedBridgeEvents
{
log
:=
events
.
eventLog
[
bridgeFinalizedEvent
.
GUID
]
log
:=
events
.
eventLog
[
bridgeFinalizedEvent
.
GUID
]
var
bridgeData
BridgeEvent
var
bridgeData
BridgeEvent
err
:=
UnpackLog
(
&
bridgeData
,
log
,
eventName
,
l1
StandardBridgeABI
)
err
:=
UnpackLog
(
&
bridgeData
,
log
,
eventName
,
StandardBridgeABI
)
if
err
!=
nil
{
if
err
!=
nil
{
return
nil
,
err
return
nil
,
err
}
}
...
@@ -256,19 +252,19 @@ func _standardBridgeFinalizedEvents[BridgeEvent bindings.L1StandardBridgeETHBrid
...
@@ -256,19 +252,19 @@ func _standardBridgeFinalizedEvents[BridgeEvent bindings.L1StandardBridgeETHBrid
return
nil
,
errors
.
New
(
"unable to extract `_nonce` parameter from relayMessage calldata"
)
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
)
{
switch
any
(
bridgeData
)
.
(
type
)
{
case
bindings
.
L1StandardBridgeETHBridgeInitiat
ed
:
case
bindings
.
StandardBridgeETHBridgeFinaliz
ed
:
ethBridgeData
:=
any
(
bridgeData
)
.
(
bindings
.
L1
StandardBridgeETHBridgeFinalized
)
ethBridgeData
:=
any
(
bridgeData
)
.
(
bindings
.
StandardBridgeETHBridgeFinalized
)
erc20BridgeData
=
&
bindings
.
L1
StandardBridgeERC20BridgeFinalized
{
erc20BridgeData
=
&
bindings
.
StandardBridgeERC20BridgeFinalized
{
// Represent ETH using the hardcoded address
// Represent ETH using the hardcoded address
LocalToken
:
EthAddress
,
RemoteToken
:
EthAddress
,
LocalToken
:
predeploys
.
LegacyERC20ETHAddr
,
RemoteToken
:
predeploys
.
LegacyERC20ETHAddr
,
// Bridge data
// Bridge data
From
:
ethBridgeData
.
From
,
To
:
ethBridgeData
.
To
,
Amount
:
ethBridgeData
.
Amount
,
ExtraData
:
ethBridgeData
.
ExtraData
,
From
:
ethBridgeData
.
From
,
To
:
ethBridgeData
.
To
,
Amount
:
ethBridgeData
.
Amount
,
ExtraData
:
ethBridgeData
.
ExtraData
,
}
}
case
bindings
.
L1StandardBridgeERC20BridgeInitiat
ed
:
case
bindings
.
StandardBridgeERC20BridgeFinaliz
ed
:
_temp
:=
any
(
bridgeData
)
.
(
bindings
.
L1
StandardBridgeERC20BridgeFinalized
)
_temp
:=
any
(
bridgeData
)
.
(
bindings
.
StandardBridgeERC20BridgeFinalized
)
erc20BridgeData
=
&
_temp
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