The Status module that consumes go-ethereum https://status.im
Go to file
Dmitry Shulyak ed1cdf0418
Custom status bootnodes (#968)
This change makes invalidation mechanism more aggressive. With a primary goal to invalidate short living nodes faster. In current setup any node that became known in terms of discovery will stay in this state until it will fail to respond to 5 queries. Removing them earlier from a table allows to reduce latency for finding required nodes.

The second change, one adds a version for discovery, separates status dht from ethereum dht.
After we rolled out discovery it became obvious that our boot nodes became spammed with irrelevant nodes. And this made discovery process very long, for example with separate dht discovery takes ~2s, with mutual dht - it can take 1m-10m and there is still no guarantee to find a max amount of peers, cause status nodes is a very small part of whole ethereum infra.

In my understanding, we don't need to be a part of ethereum dht, and lower latency is way more important for us.

Closes: #941
Partially closes: #960 (960 requires futher investigations on devices)
2018-05-18 16:43:07 +03:00
.github Move CONTRIBUTING.md to top level (#798) 2018-04-04 12:51:05 +02:00
.vscode Add config required to debug statusd on VS Code 2018-05-01 14:15:43 +02:00
_assets Custom status bootnodes (#968) 2018-05-18 16:43:07 +03:00
cmd Custom status bootnodes (#968) 2018-05-18 16:43:07 +03:00
extkeys wallet compatibility (#858) 2018-05-14 19:13:56 +02:00
geth [#ISSUE-947/ISSUE-946] Rate limit and batch limit on any mail server query (#949) 2018-05-17 13:21:04 +02:00
lib Move signal logic into signal package 2018-05-03 09:35:58 +02:00
logutils Add LogEnabled attribute to NodeConfig to, used in the call from status-react (#866) 2018-04-26 18:28:42 +02:00
mailserver add cmd/statusd-prune (#957) 2018-05-17 19:24:00 +02:00
metrics Refactor in-app metrics (#963) 2018-05-16 17:36:59 +02:00
notifier Notifier package to interact with gorush notifications (#910) 2018-05-08 16:30:03 +02:00
profiling Add profiling with pprof (#754) 2018-03-23 14:58:40 +01:00
services fix default range value for shhext_requestMessages (#934) 2018-05-10 16:47:54 +02:00
sign Move signal logic into signal package 2018-05-03 09:35:58 +02:00
signal Dump peer infos as discovery summary 2018-05-15 13:11:28 +03:00
static Update bindata 2018-04-09 15:42:36 +02:00
t [#ISSUE-947/ISSUE-946] Rate limit and batch limit on any mail server query (#949) 2018-05-17 13:21:04 +02:00
timesource Fix mid computation in timesource 2018-05-15 19:34:37 +03:00
vendor Custom status bootnodes (#968) 2018-05-18 16:43:07 +03:00
.codeclimate.yml #759 Codeclimate config (#843) 2018-04-23 15:55:21 +02:00
.dockerignore Ignore *.test files from all folders (#635) 2018-02-08 14:23:08 +02:00
.gitignore Add config required to debug statusd on VS Code 2018-05-01 14:15:43 +02:00
.gometalinter.json Disable unparam linter 2018-02-19 11:40:08 +01:00
.travis.yml Bump up Go version to 1.10 2018-05-09 16:13:34 +02:00
CONTRIBUTING.md Move CONTRIBUTING.md to top level (#798) 2018-04-04 12:51:05 +02:00
Gopkg.lock add cmd/statusd-prune (#957) 2018-05-17 19:24:00 +02:00
Gopkg.toml Refactor in-app metrics (#963) 2018-05-16 17:36:59 +02:00
LICENSE.md Create LICENSE.md 2016-09-21 10:00:29 +08:00
Makefile Custom status bootnodes (#968) 2018-05-18 16:43:07 +03:00
README.md Add config required to debug statusd on VS Code 2018-05-01 14:15:43 +02:00

README.md

Status bindings for go-ethereum

TravisCI Builds GoDoc Master Build Status Develop Build Status

Docs

Intro

status-go is an underlying part of Status - a browser, messenger, and gateway to a decentralized world.

It's written in Go and requires Go 1.8 or above.

It uses Makefile to do most common actions. See make help output for available commands.

status-go uses go-ethereum with some patches applied in it, located under vendor/ directory. See geth patches README for more info.

Build

There are two main modes status-go can be built:

  • standalone server
  • library to link for Android or iOS

Use following Makefile commands:

  • make statusgo (builds binary into build/bin/statusd)
  • make statusgo-android (builds .aar file build/android-16/aar)
  • make statusgo-ios and make statusgo-ios-simulator (builds iOS related artifacts in build/os-9.3/framework)

In order to build and use status-go directly from status-react, follow the instructions in https://wiki.status.im/Building_Status, under the 'Building Status with the checked-out version of status-go' section.

Debugging

In order to see the log files while debugging on an Android device, do the following:

  • Ensure that the app can write to disk by granting it file permissions. For that, you can for instance set your avatar from a file on disk.
  • Connect a USB cable to your phone and make sure you can use adb.

Run

adb shell tail -f sdcard/Download/geth.log

IDE Debugging

If you're using Visual Studio Code, you can rename the .vscode/launch.example.json file to launch.json so that you can run the app with the debugger attached.

Testing

To setup accounts passphrase you need to setup an environment variable: export ACCOUNT_PASSWORD="secret_pass_phrase".

Make sure the dependencies are installed first by running:

make lint-install
make mock-install

To test fully statusgo, use:

make ci

To test statusgo using a given network by name, use:

make ci networkid=rinkeby

To test statusgo using a given network by number ID, use:

make ci networkid=3

If you have problems running tests on public network we suggest reading e2e guide.

If you want to launch specific test, for instance RPCSendTransactions, use the following command:

go test -v ./geth/api/ -testify.m ^RPCSendTransaction$

Note -testify.m as testify/suite is used to group individual tests.

Licence

Mozilla Public License 2.0