Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

rewired-0.5.3 vs [email protected] #126

Closed
wants to merge 136 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
136 commits
Select commit Hold shift + click to select a range
dd5f4e0
Order book (#1)
0xshinobii Nov 23, 2022
83beb4a
sync upstream v0.4.4 - v0.4.5
atvanguard Sep 30, 2023
b87aa3e
Place orders at block build time (#2)
lumos42 Dec 9, 2022
80d7895
Orderbook as Genesis (#3)
atvanguard Dec 9, 2022
04bc1ae
Fixes after merge
lumos42 Dec 9, 2022
fbb788e
Fix executeOrder tx gas prices
lumos42 Dec 9, 2022
06fe04e
Sync local db when a new node is added (#4)
lumos42 Dec 14, 2022
1a3ffac
sync upstream v0.4.6
atvanguard Sep 30, 2023
ece2444
sync upstream v0.4.7
atvanguard Sep 30, 2023
739fcc7
Add Match limit orders with same price and base asset quantity (#5)
vipulsharma21 Dec 27, 2022
cfb42eb
unsubscribe from chainAcceptedEvent feed on shutdown
vipulsharma21 Dec 29, 2022
4903895
refactor limit_order to move out limit_order_txs logic and initialize…
vipulsharma21 Dec 30, 2022
48254f0
asquare|deven|fdgod add check if orderbook contract tx in listenAndSt…
vipulsharma21 Jan 4, 2023
a2d2303
sync upstream v0.4.8
atvanguard Sep 30, 2023
0c72765
Partial fills (#10)
vipulsharma21 Jan 14, 2023
a2157f0
change price check in matching engine to match if longOrder price >= …
vipulsharma21 Jan 19, 2023
a2f9e89
add genesis contracts + mocked orderBook (#14)
atvanguard Jan 20, 2023
ac1b9cc
Handle events + liquidations + funding (#11)
atvanguard Jan 25, 2023
a93a907
Add artifacts
lumos42 Jan 26, 2023
4a2e43a
Merge pull request #15 from hubble-exchange/orderbook_data_api
vipulsharma21 Jan 30, 2023
143127b
sync upstream @ 76e3fe2
atvanguard Sep 30, 2023
c295953
remove artifacts
atvanguard Jan 31, 2023
04694a5
Bump versions in run_local
lumos42 Feb 1, 2023
3270527
add tests and refactor code (#16)
vipulsharma21 Feb 8, 2023
e174d79
testing fixes
lumos42 Feb 9, 2023
85960d2
Fix errors after merge
lumos42 Feb 12, 2023
465a550
Add GetOrderBook API for UI data
lumos42 Feb 12, 2023
4a3c285
Fix lastPrice
lumos42 Feb 13, 2023
d87c742
Use env variable for artifacts path
lumos42 Feb 13, 2023
e676ef1
assing new int to FilledBaseQuantity
vipulsharma21 Feb 15, 2023
7cb30ee
Merge pull request #17 from hubble-exchange/add_unit_tests
vipulsharma21 Feb 17, 2023
fdfe6a1
small changes in build_block_pipeline
vipulsharma21 Feb 17, 2023
4ca51ea
Add GetOpenOrders API
lumos42 Feb 17, 2023
311b2ed
Add fields in GetOpenOrders API
lumos42 Feb 17, 2023
5546f3a
Change struct for OpenOrdersResponse
lumos42 Feb 17, 2023
e194af7
sync upstream v0.4.9 (22d56f10)
atvanguard Sep 30, 2023
a1811d8
Add a hacky way to notify consensus engine to buildBlock after order …
lumos42 Feb 20, 2023
e61e8e6
Add salt in getOpenOrders response
lumos42 Feb 23, 2023
498009d
sync upstream v0.4.10 (1d7b284e)
atvanguard Sep 30, 2023
0f4af5a
sync upstream v0.4.11 (ed0f30ab)
atvanguard Sep 30, 2023
7b86784
Fix funding payment error
lumos42 Mar 5, 2023
7d3f7f5
Use order id instead of signature in OrderMap
lumos42 Mar 5, 2023
eaf3947
Convert amounts to string in orderbook APIs
lumos42 Mar 6, 2023
619e60a
Add path prefix in events processor
lumos42 Mar 6, 2023
c2ffe69
Add logs in ListenAndProcessTransactions
lumos42 Mar 9, 2023
5a755b6
Fix block sync logic in ListenAndProcessTransactions
lumos42 Mar 9, 2023
003724e
sync upstream v0.4.12 (8a28b234)
atvanguard Sep 30, 2023
d10640d
fix tests and some refactoring (#20)
vipulsharma21 Mar 10, 2023
9444540
add genesis contract interfaces (#19)
atvanguard Mar 10, 2023
84daaf6
remove test
vipulsharma21 Mar 10, 2023
3bf328a
Run and upgrade scripts using avalanche cli (#18)
lumos42 Mar 13, 2023
9f02867
Merge pull request #21 from hubble-exchange/change_orderbooktx_add_tx…
vipulsharma21 Mar 15, 2023
70d6f7a
increase initial gas token balance for test accounts (#22)
0xshinobii Mar 17, 2023
7aef066
Merge pull request #23 from hubble-exchange/get_validator_key_from_env
vipulsharma21 Mar 17, 2023
897d451
update abis and fix tests (#24)
atvanguard Mar 17, 2023
0b3dfc0
remove unused workflows and add test, skip failing tests
vipulsharma21 Mar 20, 2023
e234fd6
fix ci by adding validator_private_key
vipulsharma21 Mar 20, 2023
fcf544d
sync upstream @ 21c1fb1
atvanguard Sep 30, 2023
e4f7031
Handle reorgs in memory db ++ (#26)
atvanguard Mar 28, 2023
c47af58
Add order hash in GetOrderBook API response
lumos42 Mar 28, 2023
0054371
Change Orderbook event handling - use indexed fields (#28)
lumos42 Mar 29, 2023
ea77f24
Merge pull request #29 from hubble-exchange/orderbookdata_websocketapi
vipulsharma21 Apr 1, 2023
961de76
Fixes and Logging Improvements (#31)
atvanguard Apr 5, 2023
5b0a789
Add EVM db tests (#30)
lumos42 Apr 10, 2023
766c112
Merge pull request #32 from hubble-exchange/aggregated_orderbook_data
vipulsharma21 Apr 11, 2023
88372ef
sync upstream v0.5.0 (157e9b95)
atvanguard Sep 30, 2023
fdd0f80
Fetch underlying price to filter orders (#34)
atvanguard Apr 17, 2023
234b24f
add logs to hubblefeed if head block is replaced with another during …
vipulsharma21 Apr 17, 2023
b942cc2
add timestamp in abi for orderbook events
vipulsharma21 Apr 18, 2023
5f8792b
fix tests
vipulsharma21 Apr 18, 2023
3982e6c
Add multi-vm tests for Orderbook (#36)
lumos42 Apr 20, 2023
d48f916
Ensure memory DB functions have RWMutex locking (#39)
lumos42 Apr 20, 2023
256922f
Merge pull request #38 from hubble-exchange/dynamic_validator_tx_gas_…
vipulsharma21 Apr 21, 2023
42e59bd
Cancel open orders where available margin < 0 (#40)
lumos42 Apr 28, 2023
bb69593
Optimal pnl (#41)
atvanguard Apr 29, 2023
903d29f
sync upstream v0.5.1 (14b51cb0)
atvanguard Sep 30, 2023
9cde813
Hubblenext (#45)
atvanguard May 9, 2023
fab48fd
Fix integration tests & reduceOnly bugfix (#48)
lumos42 May 16, 2023
01ed2c4
WIP: add hubbleconfigmanager precompile to set order configs from con…
vipulsharma21 May 18, 2023
d2afd1b
Bibliophile Precompile (#49)
atvanguard May 24, 2023
5c00416
Save snapshots of memory database to improve node restart time
lumos42 May 29, 2023
785cf9a
move hubbleconfigmanager precompile logic to hubblebibliophile (#53)
vipulsharma21 May 29, 2023
2887ab4
Order no sig (#52)
atvanguard May 29, 2023
dc422e7
Cleanup logs and change log format (#54)
lumos42 May 30, 2023
8ebd48f
bibliophile.getPositionSizes (#55)
atvanguard May 30, 2023
3a27f4e
update abis, merge hubblenext
atvanguard May 30, 2023
365ea59
load validator_private_key from file and specify path in chain.json (…
vipulsharma21 Jun 1, 2023
9d78fb1
GetUnderlyingPrices in precompile (#57)
atvanguard Jun 1, 2023
d7c19ce
Support partial fulfillment of reduce-only orders (#60)
lumos42 Jun 1, 2023
caa7d02
Hubblenext Fixes and Improvements (#67)
atvanguard Jun 12, 2023
801e811
New match price algorithm (#68)
atvanguard Jun 15, 2023
7e8a681
New precompile at 0x03...4 (#69)
atvanguard Jun 18, 2023
d2dfb40
Trading apis (#71)
atvanguard Jun 20, 2023
58a7aad
send blockNum as uint64
atvanguard Jun 20, 2023
0a88640
Retry Failed Orders (#72)
atvanguard Jun 21, 2023
f36ecad
Red stone (#73)
atvanguard Jun 22, 2023
6d08d9f
Fixes (#74)
atvanguard Jun 22, 2023
27a9278
Fix incorrect lastPremiumFraction issue (#76)
lumos42 Jun 26, 2023
3bd6dbd
Add new precompile method + fix bug in getting short orders (#78)
atvanguard Jun 29, 2023
3b5318f
Add custom monitoring and custom Log Handler (#75)
lumos42 Jul 5, 2023
1516a08
Order type agnostic execution (#79)
atvanguard Jul 7, 2023
1c21e10
Add IOC order and refactor (#82)
lumos42 Jul 10, 2023
4351b44
fix release step of ci to publish release and artifacts as per git ta…
vipulsharma21 Jul 12, 2023
5437a15
recover from panic while build_block_pipeline and processing events; …
vipulsharma21 Jul 12, 2023
467f385
IOC Orders precompile update (#85)
atvanguard Jul 14, 2023
f9fc002
Hubblenext (#86)
atvanguard Jul 16, 2023
4722a73
sync upstream v0.5.3 (402510e)
atvanguard Sep 30, 2023
2ba429b
SDK APIs and other misc. changes (#87)
lumos42 Aug 2, 2023
b0d09f2
sync upstream v0.5.2 (9a1c548)
atvanguard Sep 30, 2023
1791bdc
Run matching pipeline as soon as orders are received (#92)
lumos42 Aug 7, 2023
e377134
Test variables read from contracts via slots (#89)
vipulsharma21 Aug 8, 2023
2556913
fix testing_apis.go (#93)
vipulsharma21 Aug 11, 2023
6a3737b
add integration tests for bibliophile and juror (#83)
vipulsharma21 Aug 11, 2023
ebeec54
Add StreamMarketTrades API and custom config fields (#91)
lumos42 Aug 11, 2023
c9beda7
updated Dockerfile to correct subnet id
chpiatt Aug 11, 2023
236d9f0
:bug: GetOrderFilledAmount (#96)
atvanguard Aug 17, 2023
a6871a8
Fix snapshot logic and add GetSnapshot API (#99)
lumos42 Aug 20, 2023
c11b9db
log orders in validateOrdersAndDetermineFillPrice (#97)
lumos42 Aug 20, 2023
dad68c9
Fix snapshot bug (#101)
lumos42 Aug 22, 2023
0c28177
MemoryDB State Fixes (#103)
atvanguard Aug 29, 2023
64e3e74
Post Only Orders (#95)
atvanguard Sep 3, 2023
2c31171
Fixes to Post Only Deployment (#106)
atvanguard Sep 4, 2023
d463630
Remove backward compatible changes/upgrades (#109)
lumos42 Sep 13, 2023
7deed53
Make IOC orders great again (#110)
atvanguard Sep 13, 2023
e4ea59c
Precompile refactor (#112)
atvanguard Sep 17, 2023
b5ace40
Refactor order structures (#111)
lumos42 Sep 18, 2023
97248de
Precompile updates (#113)
atvanguard Sep 20, 2023
e8c6db2
Separate OrderBook and LimitOrderbook (#114)
lumos42 Sep 24, 2023
687817a
remove validator tx from being added to txpool during reorg (#115)
vipulsharma21 Sep 24, 2023
df412d7
Prevent duplicate match transactions (#116)
lumos42 Sep 25, 2023
850d417
add integration tests for place order and cancel order (#108)
vipulsharma21 Sep 28, 2023
bc928d5
Support multi-collateral in getNormalizedMargin functions + refactor …
atvanguard Sep 29, 2023
68774e3
Moar unit tests for Juror (#119)
lumos42 Sep 29, 2023
9d06705
Mid price (#121)
atvanguard Sep 30, 2023
4472792
Rewire fixes (#125)
atvanguard Oct 1, 2023
13816b0
Review fixes
lumos42 Oct 2, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
5 changes: 5 additions & 0 deletions .avalanche-cli.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
{
"node-config": {
"log-level": "info"
}
}
10 changes: 5 additions & 5 deletions .github/workflows/bench.yml
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,8 @@ jobs:
- uses: actions/setup-go@v3
with:
go-version: "1.19"
- run: go mod download
shell: bash
- run: ./scripts/build_bench_precompiles.sh
shell: bash
# - run: go mod download
# shell: bash
# - run: ./scripts/build_bench_precompiles.sh
# shell: bash

2 changes: 1 addition & 1 deletion .github/workflows/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ on:
- master
tags:
- 'v[0-9]+.[0-9]+.[0-9]+'
pull_request:
# pull_request:

jobs:
lint_test:
Expand Down
71 changes: 0 additions & 71 deletions .github/workflows/codeql-analysis.yml

This file was deleted.

8 changes: 6 additions & 2 deletions .github/workflows/release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,10 @@ on:
tags:
- 'v[0-9]+.[0-9]+.[0-9]+'

permissions:
contents: write
packages: write

jobs:
release:
# needs: [lint_test, unit_test, e2e_test, simulator_test]
Expand All @@ -15,7 +19,7 @@ jobs:
uses: actions/checkout@v3
with:
fetch-depth: 0
path: subnet-evm
path: hubblenet
- name: Set up Go
uses: actions/setup-go@v3
with:
Expand Down Expand Up @@ -43,7 +47,7 @@ jobs:
distribution: goreleaser
version: latest
args: release --clean
workdir: ./subnet-evm/
workdir: ./hubblenet/
env:
# https://docs.github.com/en/actions/security-guides/automatic-token-authentication#about-the-github_token-secret
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
32 changes: 32 additions & 0 deletions .github/workflows/test.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
name: Build + test + release

on:
push:
branches:
- '*'

tags:
- "*"
# pull_request:

jobs:
unit_test:
name: Golang Unit Tests v${{ matrix.go }} (${{ matrix.os }})
runs-on: ${{ matrix.os }}
strategy:
matrix:
go: ["1.19.3"]
os: [ubuntu-22.04]
steps:
- uses: actions/checkout@v3
- uses: actions/setup-go@v3
with:
go-version: ${{ matrix.go }}
- run: go mod download
shell: bash
- run: go test github.com/ava-labs/subnet-evm/plugin/evm/...
shell: bash
- run: go test github.com/ava-labs/subnet-evm/precompile/contracts/ticks
shell: bash
- run: go test github.com/ava-labs/subnet-evm/precompile/contracts/juror
shell: bash
14 changes: 14 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,9 @@ awscpu
# Test binary, build with `go test -c`
*.test

# orderbook tests dependencies
tests/orderbook/node_modules

# Output of the go coverage tool, specifically when used with LiteIDE
*.out

Expand Down Expand Up @@ -50,3 +53,14 @@ cmd/simulator/simulator

# goreleaser
dist/

# generator rpc file for e2e tests
contract-examples/dynamic_rpc.json

#sqlite
plugins/evm/hubble.db

*.bin
local_status.sh

networks/*/*.env
8 changes: 4 additions & 4 deletions .goreleaser.yml
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
# ref. https://goreleaser.com/customization/build/
builds:
- id: subnet-evm
- id: hubblenet
main: ./plugin
binary: subnet-evm
binary: hubblenet-{{.Version}}
flags:
- -v
ldflags: -X github.com/ava-labs/subnet-evm/plugin/evm.Version=v{{.Version}}
Expand Down Expand Up @@ -33,5 +33,5 @@ release:
# Repo in which the release will be created.
# Default is extracted from the origin remote URL or empty if its private hosted.
github:
owner: ava-labs
name: subnet-evm
owner: hubble-exchange
name: hubblenet
4 changes: 2 additions & 2 deletions Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -24,10 +24,10 @@ COPY . .
ARG SUBNET_EVM_COMMIT
ARG CURRENT_BRANCH

RUN export SUBNET_EVM_COMMIT=$SUBNET_EVM_COMMIT && export CURRENT_BRANCH=$CURRENT_BRANCH && ./scripts/build.sh /build/srEXiWaHuhNyGwPUi444Tu47ZEDwxTWrbQiuD7FmgSAQ6X7Dy
RUN export SUBNET_EVM_COMMIT=$SUBNET_EVM_COMMIT && export CURRENT_BRANCH=$CURRENT_BRANCH && ./scripts/build.sh /build/o1Fg94YukvVRijwyThAavybVfwVJH3dhyz94g6qYRGdQ5Arqp

# ============= Cleanup Stage ================
FROM avaplatform/avalanchego:$AVALANCHE_VERSION AS builtImage

# Copy the evm binary into the correct location in the container
COPY --from=builder /build/srEXiWaHuhNyGwPUi444Tu47ZEDwxTWrbQiuD7FmgSAQ6X7Dy /avalanchego/build/plugins/srEXiWaHuhNyGwPUi444Tu47ZEDwxTWrbQiuD7FmgSAQ6X7Dy
COPY --from=builder /build/o1Fg94YukvVRijwyThAavybVfwVJH3dhyz94g6qYRGdQ5Arqp /avalanchego/build/plugins/o1Fg94YukvVRijwyThAavybVfwVJH3dhyz94g6qYRGdQ5Arqp
14 changes: 14 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,17 @@
# Hubble v2

To run a fresh local network - run `./scripts/run_local.sh`
To run on the same network with updated evm code(it preserves all evm state) - run `./scripts/upgrade_local.sh`
To kill network - run `avalanche network stop && avalanche network clean`

To see logs - run `./scripts/show_logs.sh`

# Accounts
var userAddress1 = "0x8db97C7cEcE249c2b98bDC0226Cc4C2A57BF52FC"
var privateKey1 = "56289e99c94b6912bfc12adc093c9b51124f0dc54ac7a766b2bc5ccf558d8027"
var userAddress2 = "0x4Cf2eD3665F6bFA95cE6A11CFDb7A2EF5FC1C7E4"
var privateKey2 = "31b571bf6894a248831ff937bb49f7754509fe93bbd2517c9c73c4144c0e97dc"

# Subnet EVM

[![Build + Test + Release](https://github.com/ava-labs/subnet-evm/actions/workflows/lint-tests-release.yml/badge.svg)](https://github.com/ava-labs/subnet-evm/actions/workflows/lint-tests-release.yml)
Expand Down
143 changes: 143 additions & 0 deletions accounts/abi/solidity.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,143 @@
package abi

import (
"encoding/json"
"strings"

"github.com/ethereum/go-ethereum/log"
)

type SolidityJSON struct {
ContractName string `json:"contractName"`
SourceName string `json:"sourceName"`
Abi []Abi `json:"abi"`
}

type Abi struct {
Inputs []Input `json:"inputs"`
StateMutability string `json:"stateMutability,omitempty"`
Type string `json:"type"`
Anonymous bool `json:"anonymous,omitempty"`
Name string `json:"name,omitempty"`
Outputs []Input `json:"outputs,omitempty"`
}

type Input struct {
Components []Input `json:"components"`
InternalType string `json:"internalType"`
Name string `json:"name"`
Type string `json:"type"`
Indexed bool `json:"indexed"`
}

func getFunctionType(type_ string) FunctionType {
typeMap := map[string]FunctionType{
"function": Function,
"receive": Receive,
"fallback": Fallback,
"constructor": Constructor,
}
return typeMap[type_]
}

func FromSolidityJson(abiJsonInput string) (ABI, error) {
solidityJson := SolidityJSON{}
err := json.Unmarshal([]byte(abiJsonInput), &solidityJson)
if err != nil {
log.Error("Error in decoding ABI json", "err", err)
return ABI{}, err
}

var constructor Method
var receive Method
var fallback Method

methods := map[string]Method{}
events := map[string]Event{}
errors := map[string]Error{}

for _, method := range solidityJson.Abi {
inputs := []Argument{}
for _, input := range method.Inputs {
components := []ArgumentMarshaling{}
if strings.HasPrefix(input.Type, "tuple") { // covers "tuple", "tuple[2]", "tuple[]"
for _, component := range input.Components {
components = append(components, ArgumentMarshaling{
Name: component.Name,
Type: component.Type,
InternalType: component.InternalType,
})
}
}

type_, _ := NewType(input.Type, input.InternalType, components)
inputs = append(inputs, Argument{
Name: input.Name,
Type: type_,
Indexed: input.Indexed,
})
}

if method.Type == "event" {
abiEvent := NewEvent(method.Name, method.Name, method.Anonymous, inputs)
events[method.Name] = abiEvent
continue
}

if method.Type == "error" {
abiError := NewError(method.Name, inputs)
errors[method.Name] = abiError
continue
}

outputs := []Argument{}
for _, output := range method.Outputs {
components := []ArgumentMarshaling{}
if output.Type == "tuple" || output.Type == "tuple[2]" {
for _, component := range output.Components {
components = append(components, ArgumentMarshaling{
Name: component.Name,
Type: component.Type,
InternalType: component.InternalType,
})
}
}
type_, _ := NewType(output.Type, output.InternalType, components)
outputs = append(outputs, Argument{
Name: output.Name,
Type: type_,
Indexed: output.Indexed,
})
}

methodType := getFunctionType(method.Type)
abiMethod := NewMethod(method.Name, method.Name, methodType, method.StateMutability, false, method.StateMutability == "payable", inputs, outputs)

// don't include the method in the list if it's a constructor
if methodType == Constructor {
constructor = abiMethod
continue
}
if methodType == Fallback {
fallback = abiMethod
continue
}
if methodType == Receive {
receive = abiMethod
continue
}
methods[method.Name] = abiMethod
}

Abi := ABI{
Constructor: constructor,
Methods: methods,
Events: events,
Errors: errors,

Receive: receive,
Fallback: fallback,
}

return Abi, nil
}
14 changes: 14 additions & 0 deletions chain.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
{
"snowman-api-enabled": true,
"local-txs-enabled": true,
"priority-regossip-frequency": "1s",
"tx-regossip-max-size": 32,
"priority-regossip-max-txs": 500,
"priority-regossip-txs-per-address": 200,
"priority-regossip-addresses": ["0xf39Fd6e51aad88F6F4ce6aB8827279cffFb92266", "0x70997970C51812dc3A010C7d01b50e0d17dc79C8", "0x3C44CdDdB6a900fa2b585dd299e03d12FA4293BC", "0x8db97C7cEcE249c2b98bDC0226Cc4C2A57BF52FC"],
"validator-private-key-file": "/tmp/validator.pk",
"is-validator": true,
"trading-api-enabled": true,
"testing-api-enabled": true,
"load-from-snapshot-enabled": true
}
Loading