Andrea Maria Piana d60a6713fe Enable mailserver cycle by default
This commit enables mailserver cycle logic by default and make a few
changes:

1) Nodes are graylisted instead of being blacklisted for a set amount of
   time. The reason is that if we blacklist, any cut in connectivity
   might result in long delays before reconnecting, especially on spotty
   connections.

2) Fixes an issue on the devp2p server, whereby the node would not
   connect to one of the static nodes since all the connection slots
   where filled. The fix is a bit inelegant, it always connects to
   static nodes, ignoring maxpeers, but it's tricky to get it to work
   since the code is clearly not written to select a specific node.

3) Adds support to pinned mailservers

4) Add retries to mailservers requests. It uses a closure for now, I
   think we should eventually have a channel etc, but I'd leave that for
   later.
2022-03-19 08:56:22 +00:00
..
2020-07-27 17:14:50 +02:00
2022-03-14 13:48:34 -04:00
2022-03-01 15:58:32 +01:00
2022-03-14 13:48:34 -04:00
2022-03-14 13:48:34 -04:00
2021-09-30 13:02:41 +01:00
2022-02-17 12:40:33 +00:00
2021-05-26 08:33:38 +02:00
2021-07-26 17:06:32 -04:00
2021-06-29 13:15:15 +02:00
2020-09-07 12:15:58 +02:00
2021-10-04 12:19:15 +02:00
2019-11-21 17:19:22 +01:00
2022-03-14 13:48:34 -04:00
2022-03-14 13:48:34 -04:00
2022-03-14 13:48:34 -04:00
2022-03-14 13:48:34 -04:00
2022-03-14 13:48:34 -04:00
2022-02-17 12:40:33 +00:00
2021-09-30 13:02:41 +01:00
2021-10-04 12:19:15 +02:00
2022-02-17 12:40:33 +00:00
2022-02-17 12:40:33 +00:00
2022-03-14 13:48:34 -04:00
2021-12-10 15:36:59 +00:00
2022-03-14 13:48:34 -04:00
2022-03-14 13:48:34 -04:00
2021-07-22 13:41:49 -04:00

status-go/protocol

This is an implementation of the secure transport and payloads which are a part of the Status Client specification.

This implementation uses SQLite and SQLCipher for persistent storage.

The payloads are encoded using protocol-buffers.

Content

  • messenger.go is the main file which exports Messenger struct. This is a public API to interact with this implementation of the Status Chat Protocol.
  • protobuf/ contains protobuf files implementing payloads described in the Payloads spec.
  • encryption/ implements the Secure Transport spec.
  • transport/ connects the Status Chat Protocol with a wire-protocol which in our case is either Whisper or Waku.
  • datasync/ is an adapter for MVDS.
  • applicationmetadata/ is an outer layer wrapping a payload with an app-specific metadata like a signature.
  • identity/ implements details related to creating a three-word name and identicon.
  • migrations/ contains implementation specific migrations for the sqlite database which is used by Messenger as a persistent data store.

History

Originally this package was a dedicated repo called status-protocol-go and was migrated into status-go. The new status-go/protocol package maintained its own dependencies until sub modules were removed and the root go.mod file managed all dependencies for the entire status-go repo.