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

[all] Communication #2234

Merged
merged 327 commits into from
Mar 27, 2024
Merged
Show file tree
Hide file tree
Changes from 250 commits
Commits
Show all changes
327 commits
Select commit Hold shift + click to select a range
1c39ae5
various ugprades, etc
trajan0x Feb 16, 2024
8f3fd07
build out crdt db
trajan0x Feb 16, 2024
2ceb862
add crdt per validator
trajan0x Feb 16, 2024
2bf9f1a
Implement SynapseModule w/ ECREcover Around InterchainDB contract + T…
aureliusbtc Feb 16, 2024
00b4763
kill it
trajan0x Feb 16, 2024
7322e4a
finish libp2p
trajan0x Feb 16, 2024
a015d9c
fix typo in event name
aureliusbtc Feb 16, 2024
8b3781f
merge changes
trajan0x Feb 16, 2024
7e32266
f
trajan0x Feb 16, 2024
068bf45
Interchain + InterchainDB integration (#2046)
aureliusbtc Feb 16, 2024
c26f784
update
trajan0x Feb 16, 2024
3cd287a
add keccak'd datahash to event emit
aureliusbtc Feb 16, 2024
19e6cca
rehash
trajan0x Feb 16, 2024
ceecd0b
resolve merge conflict
trajan0x Feb 16, 2024
bb44ae2
reabigen
trajan0x Feb 16, 2024
c3cb568
change variable name
aureliusbtc Feb 16, 2024
72f2fff
Merge branch 'communication/synapsemodule-db-integration' into feat/c…
trajan0x Feb 16, 2024
c57fe11
Fix event variabl ename
aureliusbtc Feb 16, 2024
e00e6bd
Verfification
trajan0x Feb 16, 2024
13adac2
Merge branch 'communication/synapsemodule-db-integration' into feat/c…
trajan0x Feb 16, 2024
9feba9c
InterchainClient & Synapse Module InterchainDB Integration (#2045)
aureliusbtc Feb 16, 2024
b257ce3
Solidity library for generic M/N signature verification (#2047)
ChiTimesChi Feb 16, 2024
f824f63
regen
trajan0x Feb 16, 2024
0afbc0a
finish up
trajan0x Feb 16, 2024
2a1b3a7
fix synapse module
trajan0x Feb 16, 2024
171b5cc
update
trajan0x Feb 16, 2024
d0d13d8
emit entry hash
trajan0x Feb 16, 2024
25cbbde
Merge branch 'contracts/communication' into feat/commitee
trajan0x Feb 16, 2024
f6877eb
update
trajan0x Feb 16, 2024
8dc26b3
e2e test
trajan0x Feb 16, 2024
ef389b6
Chore/reorganize events (#2049)
ChiTimesChi Feb 16, 2024
bc775e6
[goreleaser] build app
trajan0x Feb 16, 2024
1f32921
committee [goreleaser] test
trajan0x Feb 16, 2024
a46e5ce
fix build [goreleaser]
trajan0x Feb 16, 2024
a1b05c2
rename file [goreleaser]
trajan0x Feb 16, 2024
f231221
rename modules
trajan0x Feb 16, 2024
f84aea1
Revert "rename modules"
trajan0x Feb 16, 2024
f968eb6
Merge branch 'contracts/communication' into feat/commitee
trajan0x Feb 16, 2024
ec8cfdf
expose view for isExecutable
aureliusbtc Feb 17, 2024
67f6dd6
scaffold
trajan0x Feb 17, 2024
666688b
Merge branch 'communicationn/executable-view' into feat/commitee
trajan0x Feb 17, 2024
09c4dff
fix build issues
aureliusbtc Feb 17, 2024
e2644a9
Merge branch 'communicationn/executable-view' into feat/commitee
trajan0x Feb 17, 2024
d0c9449
Interchain: Expose isExecutable View (#2055)
aureliusbtc Feb 17, 2024
784a36e
regen
trajan0x Feb 17, 2024
6f8ae1f
executor
trajan0x Feb 17, 2024
2c37a47
Interchain: execution options (gas limit, gas airdrop, etc) (#2056)
aureliusbtc Feb 17, 2024
701c919
up
trajan0x Feb 17, 2024
00da108
add InterchainClientV1 Harness for internal tests
aureliusbtc Feb 17, 2024
59e4d07
more mock
trajan0x Feb 17, 2024
759f51e
fix susd
trajan0x Feb 17, 2024
c9a789f
Contracts/communication synapse module (#2050)
ChiTimesChi Feb 19, 2024
e780c6a
Add versioned options (#2060)
ChiTimesChi Feb 19, 2024
52c0d64
0 optimistic
trajan0x Feb 19, 2024
169973a
Merge branch 'contracts/communication' into feat/commitee
aureliusbtc Feb 19, 2024
d600050
rm interchaimodule
aureliusbtc Feb 19, 2024
485ef81
Update contracts & re-gen abi post merge
aureliusbtc Feb 19, 2024
0fe13ff
update optionslib -> OptionsV1
aureliusbtc Feb 19, 2024
3b35b11
executor_test fixed
aureliusbtc Feb 19, 2024
d667beb
tidy up
trajan0x Feb 19, 2024
8dadc75
Merge branch 'master' into feat/commitee
trajan0x Feb 19, 2024
2d6dc04
[goreleaser] lint
trajan0x Feb 19, 2024
60017a6
update [goreleaser]
trajan0x Feb 19, 2024
9fc12e9
omnirpc [goreleaser]
trajan0x Feb 19, 2024
82a00d6
add mysql adapter [goreleaser]
trajan0x Feb 20, 2024
80de15a
[goreleaser] use pubkey
trajan0x Feb 20, 2024
7f96319
[goreleaser] enable sign
trajan0x Feb 20, 2024
353e4d3
[goreleaser] lgo
trajan0x Feb 20, 2024
ebb3300
[goreleaser] debug
trajan0x Feb 20, 2024
83980dd
new node [goreleaser]
trajan0x Feb 20, 2024
86ca547
enable libp2p [goreleaser]
trajan0x Feb 20, 2024
f971f02
libp2p fix [goreleaser]
trajan0x Feb 20, 2024
8930c83
Interfaces for execution (#2063)
ChiTimesChi Feb 20, 2024
fd0f3c1
rebuild w/ more tests [goreleaser]
trajan0x Feb 20, 2024
999f496
[goreleaser] g.wait
trajan0x Feb 20, 2024
a325fc9
cleanup
trajan0x Feb 20, 2024
e7ad96e
rebump db [goreleaser]
trajan0x Feb 20, 2024
3e8aeee
[goreleaser] pubsub over everything
trajan0x Feb 20, 2024
43fe7a5
attempt to use ipfs peers [goreleaser]
trajan0x Feb 20, 2024
ed01ed5
no more ipfs
trajan0x Feb 20, 2024
207e894
Contracts/communication update client interface (#2070)
ChiTimesChi Feb 20, 2024
b344693
Global db nonces in `InterchainDB` (#2068)
ChiTimesChi Feb 20, 2024
3d99400
Init basic script for testnet deploy (#2064)
aureliusbtc Feb 20, 2024
b388daf
Merge pull request #2071 from synapsecns/contracts/communication
aureliusbtc Feb 20, 2024
b00033b
[goreleaser] port first
trajan0x Feb 20, 2024
b58dd07
fix pubkey serialization [goreleaser]
trajan0x Feb 20, 2024
5fa006b
use sha256 [goreleaser]
trajan0x Feb 20, 2024
e5bd8e8
Fix/entry verified event (#2074)
ChiTimesChi Feb 20, 2024
25d0311
Interfaces for execution (#2063)
ChiTimesChi Feb 20, 2024
a39ae11
Contracts/communication update client interface (#2070)
ChiTimesChi Feb 20, 2024
1f2f20c
Global db nonces in `InterchainDB` (#2068)
ChiTimesChi Feb 20, 2024
72766e2
Init basic script for testnet deploy (#2064)
aureliusbtc Feb 20, 2024
e8fd130
fix NoOpInterchain for contract hcanges
aureliusbtc Feb 20, 2024
d7f21bb
re abi-gen post contract merges
aureliusbtc Feb 20, 2024
240eeba
WIP fixing types and contract changes
aureliusbtc Feb 20, 2024
e8cf23c
Merge branch 'feat/communication' into feat/commitee
aureliusbtc Feb 20, 2024
dd9e78c
abi-gen to use new event for interchainmodule
aureliusbtc Feb 20, 2024
45fa371
conform to DbNonce in place of DbWRiterNonce
aureliusbtc Feb 20, 2024
1ec8c79
add sin-executor test todo
aureliusbtc Feb 20, 2024
7cb935f
add todos w/ explainers of contract changes
aureliusbtc Feb 20, 2024
3f52f27
push updates
trajan0x Feb 20, 2024
b285fd1
rework committe [goreleaser]
trajan0x Feb 20, 2024
86dfe08
sin-executor [goreleaser]
trajan0x Feb 20, 2024
6f057cb
[goreleaser] add sin executor
trajan0x Feb 21, 2024
f7f8924
latest deployments
aureliusbtc Feb 21, 2024
4b764b0
rebuild [goreleaser]
trajan0x Feb 21, 2024
879b6fd
update [goreleaser]
trajan0x Feb 21, 2024
240aa0f
Adjust IApp to work with latest InterchainClient interface + Optional…
aureliusbtc Feb 21, 2024
747b8b9
chi changes (#2078)
aureliusbtc Feb 21, 2024
10d22a5
Merge pull request #2058 from synapsecns/feat/commitee
trajan0x Feb 21, 2024
11d8edb
Fix/interchain client events (#2077)
aureliusbtc Feb 22, 2024
d6c16d0
Add scripts to `communications` package (#2084)
ChiTimesChi Feb 22, 2024
8d20d26
Add `AppConfig` library (#2087)
ChiTimesChi Feb 22, 2024
ffacb6a
Add `InterchainTransaction` library (#2086)
ChiTimesChi Feb 22, 2024
c1a2c00
init execution service + gas oralce
aureliusbtc Feb 22, 2024
596c242
gasoracle
aureliusbtc Feb 22, 2024
89a1f2a
remove gasoracle for later pr
aureliusbtc Feb 22, 2024
024a059
fix committee tests
trajan0x Feb 22, 2024
2ee7e45
gosimple
trajan0x Feb 22, 2024
aa549c4
merge master
trajan0x Feb 23, 2024
b424f10
fix lint isuse
trajan0x Feb 23, 2024
e8194d3
Feat: message passing (#2094)
ChiTimesChi Feb 23, 2024
f24071b
authz
trajan0x Feb 23, 2024
d2fe1d4
Merge branch 'feat/communication' of https://github.com/synapsecns/sa…
trajan0x Feb 23, 2024
c2f6833
make peers
trajan0x Feb 23, 2024
343f132
Revert " make peers"
trajan0x Feb 23, 2024
02d7e7d
add client nonce to event
aureliusbtc Feb 23, 2024
9ff6ecf
do some cleanup
trajan0x Feb 23, 2024
09bf5a6
Merge branch 'interchain/client-event-clietn-nonce' into feat/communi…
trajan0x Feb 23, 2024
57306ac
fix broken contract
trajan0x Feb 23, 2024
932d5a4
updated abi
trajan0x Feb 23, 2024
b447050
contract fixes [sin-executor still broken
trajan0x Feb 23, 2024
8b03919
pass 2
trajan0x Feb 23, 2024
947d00e
imock
trajan0x Feb 23, 2024
cf43411
Revert "imock"
trajan0x Feb 23, 2024
103eaa8
wrap sin-executor
trajan0x Feb 24, 2024
6052813
Add ExecutionFees.sol collector contract & record upon execution serv…
aureliusbtc Feb 24, 2024
6b71b4e
Deploy to Sepolia & OP Sepolia
aureliusbtc Feb 24, 2024
99a3789
cleanup
trajan0x Feb 24, 2024
30a109e
[goreleaser]
trajan0x Feb 25, 2024
ca15b8b
add table prefix [goreleaser]
trajan0x Feb 25, 2024
06c1575
[goreleaser]
trajan0x Feb 25, 2024
68e6537
cleanup
trajan0x Feb 25, 2024
c8bbb0a
add yaml key for config [goreleaser]
trajan0x Feb 25, 2024
89071de
cleanup [goreleaser]
trajan0x Feb 25, 2024
23b782d
console
trajan0x Feb 25, 2024
91cfef4
Revert "console"
trajan0x Feb 25, 2024
cb15e8a
Deploy to Sepolia & OP Sepolia
aureliusbtc Feb 25, 2024
17780e2
Merge branch 'feat/communication' into feat/execution-service
aureliusbtc Feb 25, 2024
5a42ebe
feat: Enhance ExecutionService with gas oracle and options handling
aureliusbtc Feb 25, 2024
66eda32
[goreleaser] bump
trajan0x Feb 25, 2024
ddd347d
global message query [goreleaser]
trajan0x Feb 25, 2024
2315360
[goreleaser] peerstore
trajan0x Feb 25, 2024
b945b81
[goreleaser]
trajan0x Feb 25, 2024
9263917
[goreleaser] [ci skip]
trajan0x Feb 25, 2024
b1801ac
[goreleaser]
trajan0x Feb 25, 2024
7020474
do not provide too mayn signatures [goreleaser]
trajan0x Feb 25, 2024
8515a04
begin test
aureliusbtc Feb 25, 2024
732916d
don't start submitter if we don't need to relay
trajan0x Feb 25, 2024
d48dbe8
remove me pls [goreleaser]
trajan0x Feb 25, 2024
78ab9e6
Fix InterchainApp to conform to New interface, scripts & broadcast fo…
aureliusbtc Feb 26, 2024
c9d31cc
[goreleaser]
trajan0x Feb 26, 2024
9a60930
[goreleaser]
trajan0x Feb 26, 2024
7b516ba
Chore: forge fmt
ChiTimesChi Feb 26, 2024
5f44ae4
Merge branch 'master' into feat/communication
trajan0x Feb 26, 2024
ca919c6
Remove unneeded event ExecutionRequested variables
aureliusbtc Feb 26, 2024
62e8c27
Interchain client cleanup (#2105)
ChiTimesChi Feb 26, 2024
5b3b94b
Interchain tx/db nonce (#2112)
ChiTimesChi Feb 26, 2024
49772bb
dependency cleanup
trajan0x Feb 27, 2024
dbb8b66
Feat/: base for interchain app (#2109)
ChiTimesChi Feb 27, 2024
7f45d1b
interchain (#2123)
trajan0x Feb 28, 2024
d590340
forge fmt
trajan0x Feb 28, 2024
c1cfe4a
merge
trajan0x Feb 28, 2024
c807b4f
Execution Service Consolidation (#2125) (#2127) (#2128)
trajan0x Feb 28, 2024
9a39094
Merge pull request #2098 from synapsecns/feat/execution-service
trajan0x Feb 28, 2024
2150013
cleanup
trajan0x Feb 28, 2024
6f96f5d
Feat: synapse module cleanup (#2118)
ChiTimesChi Feb 29, 2024
842c699
Chore: `forge fmt`
ChiTimesChi Feb 29, 2024
2e7d400
Feat/owner address in constructor (#2132)
ChiTimesChi Feb 29, 2024
4f2d08a
Feat: expose client address (#2133)
ChiTimesChi Feb 29, 2024
565233c
Merge branch 'master' into feat/communication
trajan0x Mar 1, 2024
55e655e
Deploy scripts for communication testnet (#2185)
ChiTimesChi Mar 1, 2024
8130cc0
SIN Executor Config Chain ID restructure (#2198)
aureliusbtc Mar 3, 2024
faab935
Merge branch 'master' into feat/communication
trajan0x Mar 4, 2024
50296d3
[goreleaser]
trajan0x Mar 4, 2024
0da3b2e
Merge pull request #2201 from synapsecns/master
trajan0x Mar 4, 2024
06aa96a
Update .goreleaser.yml [goreleaser]
trajan0x Mar 4, 2024
354dc13
Feat: ping pong app (#2191)
ChiTimesChi Mar 4, 2024
30b387b
Experiment w/ toolchain fix [goreleaser] (see: ethereum-optimism/opti…
trajan0x Mar 4, 2024
ce88f15
Revert "Experiment w/ toolchain fix [goreleaser] (see: ethereum-optim…
trajan0x Mar 4, 2024
2596af4
pro bump [goreleaser]
trajan0x Mar 4, 2024
5057635
fix deploy [goreleaser]
trajan0x Mar 4, 2024
bcb3741
[goreleaser] do not reinstall go instead, pass go collect
trajan0x Mar 4, 2024
f73ee51
Chore: interchain explicit errors (#2206)
ChiTimesChi Mar 4, 2024
4d7f846
Chore: update solidity-devops to latest
ChiTimesChi Mar 4, 2024
0afc282
Feat: module data passing (#2205)
ChiTimesChi Mar 8, 2024
2c98aad
Rfq
trajan0x Mar 9, 2024
e756f47
[goreleaser] fix signature erorr
trajan0x Mar 9, 2024
0a09ba5
project lead
trajan0x Mar 9, 2024
c444ce5
[goreleaser]
trajan0x Mar 9, 2024
e4f4090
[goreleaser]
trajan0x Mar 9, 2024
2a47c71
[goreleaser] rebuild
trajan0x Mar 9, 2024
ce7d4e9
Merge branch 'master' into feat/communication
trajan0x Mar 9, 2024
ae3b197
[goreleaser]
trajan0x Mar 9, 2024
93e8af8
[goreleaser] be more verbose
trajan0x Mar 9, 2024
b0c0b02
[goreleaser]
trajan0x Mar 9, 2024
7a43dd3
periodically bootstarp [goreleaser]
trajan0x Mar 9, 2024
2cc0009
autodoc
trajan0x Mar 10, 2024
7fb3ec7
package.json fix
trajan0x Mar 10, 2024
87ac5c3
rerun job
trajan0x Mar 10, 2024
092b578
Revert "rerun job"
trajan0x Mar 10, 2024
55072b6
docs in gitignore
trajan0x Mar 10, 2024
d2717b6
revert me
trajan0x Mar 10, 2024
5fe38c4
Revert "revert me"
trajan0x Mar 10, 2024
bfb7343
add to readme
trajan0x Mar 10, 2024
2e00bf7
fix string literal
trajan0x Mar 10, 2024
e372bd8
Merge branch 'master' into feat/communication
trajan0x Mar 10, 2024
cf50b82
Merge branch 'master' into feat/communication
trajan0x Mar 13, 2024
2cc0af4
Merge branch 'master' into feat/communication
trajan0x Mar 13, 2024
3474489
Merge branch 'master' into feat/communication
trajan0x Mar 15, 2024
91d68c3
Fix remappings
ChiTimesChi Mar 15, 2024
c15ddf6
Synapse gas oracle v1 (#2295)
ChiTimesChi Mar 18, 2024
7fd2d8a
Merge branch 'master' into feat/communication
trajan0x Mar 21, 2024
c9a24a8
Feat: interchain batching prototype (#2239)
ChiTimesChi Mar 21, 2024
1792ef2
Remove submodules from `contracts-communication` (#2302)
ChiTimesChi Mar 21, 2024
3fbed08
make tidy fix
trajan0x Mar 21, 2024
32e4d8e
y
trajan0x Mar 21, 2024
a77d8be
Revert "y"
trajan0x Mar 21, 2024
8e9ffa3
Merge branch 'master' into feat/communication
ChiTimesChi Mar 21, 2024
08421ad
Add integration tests for `contracts-communication` (#2335)
ChiTimesChi Mar 21, 2024
679b474
regen
trajan0x Mar 21, 2024
a577904
Merge branch 'feat/communication' of https://github.com/synapsecns/sa…
trajan0x Mar 21, 2024
9816040
Update README.md
trajan0x Mar 21, 2024
d7da96c
[goreleaser]
trajan0x Mar 21, 2024
d9ff4d7
yarn
trajan0x Mar 21, 2024
7affb68
add flattener
trajan0x Mar 21, 2024
8ade4ba
Re-deploy Interchain Testnet Contracts (#2344)
aureliusbtc Mar 21, 2024
611ac45
update
trajan0x Mar 21, 2024
b8dfece
Merge branch 'master' into feat/communication
trajan0x Mar 21, 2024
b69d0ea
cleanup
trajan0x Mar 25, 2024
ba2ffa7
Merge branch 'master' into feat/communication
trajan0x Mar 27, 2024
e94a795
cleanup
trajan0x Mar 27, 2024
23a0eb3
Update ethergo/parser/tracely/README.md
trajan0x Mar 27, 2024
4426ffd
lint ethergo
trajan0x Mar 27, 2024
34b4810
fix merge
trajan0x Mar 27, 2024
125cbdb
fix https://github.com/synapsecns/sanguine/pull/2234#discussion_r1518…
trajan0x Mar 27, 2024
a6e6f06
example fix
trajan0x Mar 27, 2024
13addf2
remove docker caching from go builds
trajan0x Mar 27, 2024
7347f47
cleanup
trajan0x Mar 27, 2024
fa5a09a
ethergo
trajan0x Mar 27, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
The table of contents is too big for display.
Diff view
Diff view
  •  
  •  
  •  
8 changes: 8 additions & 0 deletions .codecov.yml
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,14 @@ flags:
paths:
- agents/
carryforward: true
committee:
paths:
- committee/
carryforward: true
sin-executor:
paths:
- sin-executor/
carryforward: true
screener-api:
paths:
- contrib/screener-api/
Expand Down
6 changes: 3 additions & 3 deletions .github/workflows/go.yml
Original file line number Diff line number Diff line change
Expand Up @@ -541,18 +541,18 @@ jobs:
# Foundry is required for flattening
- name: Install Foundry
uses: foundry-rs/foundry-toolchain@v1
if: ${{ contains(matrix.package, 'agents') || contains(matrix.package, 'services/rfq') }}
if: ${{ contains(matrix.package, 'agents') || contains(matrix.package, 'services/rfq') || contains(matrix.package, 'sin-executor') || contains(matrix.package, 'committee') }}
with:
version: nightly

- name: Install Node Dependencies
run: yarn install --immutable
if: ${{ contains(matrix.package, 'agents') || contains(matrix.package, 'services/rfq') }}
if: ${{ contains(matrix.package, 'agents') || contains(matrix.package, 'services/rfq') || contains(matrix.package, 'sin-executor') || contains(matrix.package, 'committee') }}

# Generate flattened files
- name: Run flattener
run: npx lerna exec npm run build:go
if: ${{ contains(matrix.package, 'agents') || contains(matrix.package, 'services/rfq') }}
if: ${{ contains(matrix.package, 'agents') || contains(matrix.package, 'services/rfq') || contains(matrix.package, 'sin-executor') || contains(matrix.package, 'committee') }}

# Setup Go
- uses: actions/setup-go@v4
Expand Down
6 changes: 6 additions & 0 deletions .github/workflows/goreleaser-actions.yml
Original file line number Diff line number Diff line change
Expand Up @@ -176,6 +176,12 @@ jobs:
username: ${{ github.actor }}
password: ${{ secrets.GITHUB_TOKEN }}

- name: debug
run: go version

- name: debug2
run: goreleaser -v

- name: Run GoReleaser (Release)
if: steps.branch-name.outputs.is_default == 'true'
run: goreleaser --timeout 900m --clean --debug -f ${{matrix.package}}/.goreleaser.yml
Expand Down
4 changes: 4 additions & 0 deletions .github/workflows/solidity.yml
Original file line number Diff line number Diff line change
Expand Up @@ -6,11 +6,13 @@ on:
- 'packages/contracts-core/**'
- 'packages/contracts-rfq/**'
- '.github/workflows/solidity.yml'
- 'packages/contracts-communication'
- 'packages/solidity-devops/**'
push:
paths:
- 'packages/contracts-core/**'
- 'packages/contracts-rfq/**'
- 'packages/contracts-communication'
- 'packages/solidity-devops/**'
- '.github/workflows/solidity.yml'

Expand All @@ -37,6 +39,7 @@ jobs:
contracts-core: 'packages/contracts-core/**'
contracts-rfq: 'packages/contracts-rfq/**'
solidity-devops: 'packages/solidity-devops/**'
contracts-communication: 'packages/contracts-communication/**'
- id: length
run: |
export FILTER_LENGTH=$(echo $FILTERED_PATHS | jq '. | length')
Expand Down Expand Up @@ -80,6 +83,7 @@ jobs:
{
"contracts-core": "${{ secrets.VERCEL_CONTRACT_DOCS_PROJECT_ID}}",
"contracts-rfq": "${{ secrets.VERCEL_CONTRACT_RFQ_DOCS_PROJECT_ID }}",
"contracts-communication": "${{ secrets.VERCEL_COMMUNICATION_DOCS_PROJECT_ID }}",
"solidity-devops": "${{ secrets.VERCEL_DEVOPS_DOCS_PROJECT_ID }}"
}
END
Expand Down
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -128,3 +128,4 @@ fastcache.tmp*
# ignore all go built files in local dirs
main
.devnet/

2 changes: 2 additions & 0 deletions .golangci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -99,6 +99,8 @@ linters:
- spancheck
# simply annoying
- perfsprint
# malfunctions on embedded structs
- typecheck
fast: false

issues:
Expand Down
148 changes: 75 additions & 73 deletions agents/go.mod

Large diffs are not rendered by default.

334 changes: 188 additions & 146 deletions agents/go.sum

Large diffs are not rendered by default.

64 changes: 64 additions & 0 deletions committee/.goreleaser.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
project_name: committee

monorepo:
tag_prefix: committee/
dir: committee/

builds:
# Linux AMD64
- id: committee
binary: committee
ldflags:
# We need to build a static binary because we are building in a glibc based system and running in a musl container
- -s -w -extldflags '-static'
# see above about workaround
tags:
- netgo
- osusergo
env:
- CC=gcc
- CXX=g++
main: main.go
goos:
- linux
goarch:
- amd64
# add a source archive at release time
source:
enabled: true

# Archives
archives:
- format: tar.gz
wrap_in_directory: true
format_overrides:
- goos: windows
format: zip
name_template: '{{.ProjectName}}-{{.Version}}_{{.Os}}_{{.Arch}}'
files:
- README.md

checksum:
name_template: checksums.txt

# Add a changelog
changelog:
sort: asc

dockers:
# Linux AMD64
- goos: linux
goarch: amd64
image_templates:
- 'ghcr.io/synapsecns/sanguine/committee:latest'
- 'ghcr.io/synapsecns/sanguine/committee:{{ .FullCommit }}'
- 'ghcr.io/synapsecns/sanguine/committee:{{ .Tag }}'
build_flag_templates:
- '--label=org.opencontainers.image.created={{.Date}}'
- '--label=org.opencontainers.image.name={{.ProjectName}}'
- '--label=org.opencontainers.image.revision={{.FullCommit}}'
- '--label=org.opencontainers.image.version={{.Version}}'
- '--label=org.opencontainers.image.source={{.GitURL}}'
dockerfile: ../docker/committee.Dockerfile
ids:
- committee
7 changes: 7 additions & 0 deletions committee/Makefile
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
include ../make/go.Makefile

generate: ## Generate code
cd $(GIT_ROOT)/packages/contracts-communication && yarn build:go
go generate ./...
Comment on lines +3 to +5
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The generate target correctly changes the directory to run yarn build:go and then runs go generate ./.... To improve clarity and maintainability, consider using a subshell for the directory change or explicitly navigating back to the original directory. This ensures that the directory change is temporary and does not affect subsequent commands.

For example, using a subshell:

-	cd $(GIT_ROOT)/packages/contracts-communication && yarn build:go
+	(cd $(GIT_ROOT)/packages/contracts-communication && yarn build:go)

Or, explicitly navigating back:

+	PWD=$(shell pwd)
	cd $(GIT_ROOT)/packages/contracts-communication && yarn build:go
+	cd $(PWD)



7 changes: 7 additions & 0 deletions committee/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
# Committee

Committee is an example implementation of a SIN committee. It is based on libp2p.

## Networking

Committee uses libp2p for networking. It uses the
35 changes: 35 additions & 0 deletions committee/cmd/cmd.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
// Package cmd provides the command line interface for the committee node.
package cmd

import (
"fmt"
"github.com/synapsecns/sanguine/core/commandline"
"github.com/synapsecns/sanguine/core/config"
"github.com/synapsecns/sanguine/core/metrics"
"github.com/urfave/cli/v2"
)

// Start starts the committee node.
func Start(args []string, buildInfo config.BuildInfo) {
app := cli.NewApp()
app.Name = buildInfo.Name()
app.Description = buildInfo.VersionString() + "committee provider for synapse"
app.Usage = fmt.Sprintf("%s --help", buildInfo.Name())
app.EnableBashCompletion = true

app.Before = func(c *cli.Context) error {
// nolint:wrapcheck
return metrics.Setup(c.Context, buildInfo)
}

// commands
app.Commands = cli.Commands{runCommand}
shellCommand := commandline.GenerateShellCommand(app.Commands)
app.Commands = append(app.Commands, shellCommand)
app.Action = shellCommand.Action

err := app.Run(args)
if err != nil {
panic(err)
}
}
56 changes: 56 additions & 0 deletions committee/cmd/commands.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
package cmd

import (
"fmt"
"github.com/synapsecns/sanguine/committee/config"
"github.com/synapsecns/sanguine/committee/node"
"github.com/synapsecns/sanguine/core/commandline"
"github.com/synapsecns/sanguine/core/metrics"
"github.com/urfave/cli/v2"
"gopkg.in/yaml.v2"
"os"
"path/filepath"
)

var configFlag = &cli.StringFlag{
Name: "config",
Usage: "path to the config file",
TakesFile: true,
}

var runCommand = &cli.Command{
Name: "run",
Description: "run the committee node",
Flags: []cli.Flag{
configFlag,
&commandline.LogLevel,
},
Action: func(c *cli.Context) error {
commandline.SetLogLevel(c)

input, err := os.ReadFile(filepath.Clean(c.String(configFlag.Name)))
if err != nil {
return fmt.Errorf("could not read config file: %w", err)
}

metricsProvider := metrics.Get()

var cfg config.Config
// TODO: consider moving this for marshal/unmarshall tests
err = yaml.Unmarshal(input, &cfg)
if err != nil {
return fmt.Errorf("could not unmarshal config: %w", err)
}

createdNode, err := node.NewNode(c.Context, metricsProvider, cfg)
if err != nil {
return fmt.Errorf("could not create node: %w", err)
}

err = createdNode.Start(c.Context)
if err != nil {
return fmt.Errorf("could not start node: %w", err)
}
return nil
},
}
trajan0x marked this conversation as resolved.
Show resolved Hide resolved
35 changes: 35 additions & 0 deletions committee/config/config.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
// Package config provides the configuration for the Synapse module.
package config

import (
"github.com/synapsecns/sanguine/ethergo/signer/config"
submitterConfig "github.com/synapsecns/sanguine/ethergo/submitter/config"
)

// Config is the config for the Synapse module.
type Config struct {
// Chains is a map of chain IDs to chain configs.
Chains map[int]string `yaml:"chains"`
// OmnirpcURL is the URL of the Omni RPC.
OmnirpcURL string `yaml:"omnirpc_url"`
// Database is the database config.
Database DatabaseConfig `yaml:"database"`
// Signer is the signer config.
Signer config.SignerConfig `yaml:"signer"`
// Submitter is the submitter config.
SubmitterConfig submitterConfig.Config `yaml:"submitter_config"`
// ShouldRelay is whether the node should relay.
ShouldRelay bool `yaml:"should_relay"`
// BootstrapPeers is the list of bootstrap peers.
BootstrapPeers []string `yaml:"bootstrap_peers"`
// P2PPort is the port for the p2p server.
P2PPort int `yaml:"p2p_port"`
// UsePeerID is wether or not to use the secp256k1 key for peer identification. This is a beta feature and currently can lead to rate limits/high bills on kms so should be turned off for now.
UsePeerID bool `yaml:"use_peer_id"`
}

// DatabaseConfig represents the configuration for the database.
type DatabaseConfig struct {
Type string `yaml:"type"`
DSN string `yaml:"dsn"` // Data Source Name
}
2 changes: 2 additions & 0 deletions committee/contracts/interchaindb/doc.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
// Package interchaindb contains the abi and contract bindings for the interchaindb contract.
package interchaindb
3 changes: 3 additions & 0 deletions committee/contracts/interchaindb/generate.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
package interchaindb

//go:generate go run github.com/synapsecns/sanguine/tools/abigen generate --sol ../../../packages/contracts-communication/flattened/InterchainDB.sol --pkg interchaindb --sol-version 0.8.20 --filename interchaindb --evm-version istanbul
35 changes: 35 additions & 0 deletions committee/contracts/interchaindb/helpers.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
package interchaindb

import (
"fmt"
"github.com/ethereum/go-ethereum/accounts/abi/bind"
"github.com/ethereum/go-ethereum/common"
"github.com/ethereum/go-ethereum/core/vm"
)

// InterchainDBRef is a reference to a InterchainDB.
//
// nolint: golint
type InterchainDBRef struct {
*InterchainDB
address common.Address
}

// Address is the contract address.
func (s *InterchainDBRef) Address() common.Address {
return s.address
}

// NewInterchainDBRef creates a new SynapseModulf with a contract ref.
func NewInterchainDBRef(address common.Address, backend bind.ContractBackend) (*InterchainDBRef, error) {
instance, err := NewInterchainDB(address, backend)
if err != nil {
return nil, fmt.Errorf("could not create instance of InterchainDB: %w", err)
}
return &InterchainDBRef{
InterchainDB: instance,
address: address,
}, nil
}
Comment on lines +23 to +33
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The function NewInterchainDBRef is correctly implemented and handles errors appropriately. However, the comment on line 23 has a typo: "SynapseModulf" should be "InterchainDBRef".

- // NewInterchainDBRef creates a new SynapseModulf with a contract ref.
+ // NewInterchainDBRef creates a new InterchainDBRef with a contract ref.

Additionally, consider adding more detailed documentation about the parameters and the return values for better clarity.


Committable suggestion

‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation.

Suggested change
// NewInterchainDBRef creates a new SynapseModulf with a contract ref.
func NewInterchainDBRef(address common.Address, backend bind.ContractBackend) (*InterchainDBRef, error) {
instance, err := NewInterchainDB(address, backend)
if err != nil {
return nil, fmt.Errorf("could not create instance of InterchainDB: %w", err)
}
return &InterchainDBRef{
InterchainDB: instance,
address: address,
}, nil
}
// NewInterchainDBRef creates a new InterchainDBRef with a contract ref.
func NewInterchainDBRef(address common.Address, backend bind.ContractBackend) (*InterchainDBRef, error) {
instance, err := NewInterchainDB(address, backend)
if err != nil {
return nil, fmt.Errorf("could not create instance of InterchainDB: %w", err)
}
return &InterchainDBRef{
InterchainDB: instance,
address: address,
}, nil
}


var _ vm.ContractRef = &InterchainDBRef{}
Loading
Loading