2018-10-08 21:39:57 +00:00
|
|
|
package vat_grab
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"encoding/json"
|
|
|
|
"errors"
|
|
|
|
"github.com/ethereum/go-ethereum/common"
|
|
|
|
"github.com/ethereum/go-ethereum/core/types"
|
|
|
|
"github.com/vulcanize/vulcanizedb/pkg/transformers/shared"
|
|
|
|
"math/big"
|
|
|
|
)
|
|
|
|
|
|
|
|
type Converter interface {
|
|
|
|
ToModels(ethLogs []types.Log) ([]VatGrabModel, error)
|
|
|
|
}
|
|
|
|
|
|
|
|
type VatGrabConverter struct{}
|
|
|
|
|
|
|
|
func (VatGrabConverter) ToModels(ethLogs []types.Log) ([]VatGrabModel, error) {
|
|
|
|
var models []VatGrabModel
|
|
|
|
for _, ethLog := range ethLogs {
|
|
|
|
err := verifyLog(ethLog)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
ilk := string(bytes.Trim(ethLog.Topics[1].Bytes(), "\x00"))
|
2018-10-17 18:04:55 +00:00
|
|
|
urn := common.BytesToAddress(ethLog.Topics[2].Bytes())
|
|
|
|
v := common.BytesToAddress(ethLog.Topics[3].Bytes())
|
2018-10-08 21:39:57 +00:00
|
|
|
wBytes := shared.GetDataBytesAtIndex(-3, ethLog.Data)
|
2018-10-17 18:04:55 +00:00
|
|
|
w := common.BytesToAddress(wBytes)
|
2018-10-08 21:39:57 +00:00
|
|
|
dinkBytes := shared.GetDataBytesAtIndex(-2, ethLog.Data)
|
|
|
|
dink := big.NewInt(0).SetBytes(dinkBytes).String()
|
|
|
|
dartBytes := shared.GetDataBytesAtIndex(-1, ethLog.Data)
|
|
|
|
dart := big.NewInt(0).SetBytes(dartBytes).String()
|
|
|
|
|
|
|
|
raw, err := json.Marshal(ethLog)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
model := VatGrabModel{
|
|
|
|
Ilk: ilk,
|
|
|
|
Urn: urn.String(),
|
|
|
|
V: v.String(),
|
|
|
|
W: w.String(),
|
|
|
|
Dink: dink,
|
|
|
|
Dart: dart,
|
2018-10-22 21:29:02 +00:00
|
|
|
LogIndex: ethLog.Index,
|
2018-10-08 21:39:57 +00:00
|
|
|
TransactionIndex: ethLog.TxIndex,
|
|
|
|
Raw: raw,
|
|
|
|
}
|
|
|
|
models = append(models, model)
|
|
|
|
}
|
|
|
|
return models, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func verifyLog(log types.Log) error {
|
|
|
|
if len(log.Topics) < 4 {
|
|
|
|
return errors.New("log missing topics")
|
|
|
|
}
|
|
|
|
if len(log.Data) < shared.DataItemLength {
|
|
|
|
return errors.New("log missing data")
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|