Skip to content

Latest commit

 

History

History

go

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Berty go/

go.dev reference Code coverage

Please, read the main README.md file first.

This folder contains most of the go code needed by the project.

Download

Main binary:

git clone https://github.com/berty/berty
cd berty/go
make install

# if things go wrong, please run and share the result of
make doctor

Main components

  • ./cmd/...: binaries / entrypoints
    • cd go; make install
  • ./pkg/...: packages especially made to be imported by other projects
  • ./internal/: internal packages that can be useful to understand how things are working under the hood
    • you won't be able to import them directly from your projects; if you think that an internal package should be made public, open an issue
  • ./framework: bridges used by mobile apps

Usage

Daemon

foo@bar:~$ berty daemon
2020-11-16T20:46:31Z	INFO 	bty               	metrics listener	{"handler": "/bty/metrics", "listener": "[::]:8888"}
...

Now you can interact with the daemon API.

Mini

TODO

Share Invite

foo@bar:~$ berty share-invite
█████████████████████████████████████████████████
█████████████████████████████████████████████████
████ ▄▄▄▄▄ ██▄▀▀▄▄▀     ▄▀█ ▀▄█▀▀█▄▀▀█ ▄▄▄▄▄ ████
████ █   █ █▄▀█▀▀  ▀▀█▀█▄█▀ █▀ ▄▀▀ █ █ █   █ ████
████ █▄▄▄█ ██▄ ▀▄ ▄▀    ▀▀  ▀█▀ ▀▀  ▀█ █▄▄▄█ ████
████▄▄▄▄▄▄▄█ █▄█ ▀ ▀▄▀ ▀ ▀ █▄▀ █ ▀▄█ █▄▄▄▄▄▄▄████
████▄▄▄▀▄ ▄  ▄▀█▄▀▀█ ██▀ █▀█▀ █▀▀▄█▄   ▀█▀▄██████
████ ▀ ▀▀▀▄▄█▀▀▀▄▀ █▀ ▀▀▄  ▀ ▀█▀▀ ███  █▄██▄▄████
██████▄▄█▄▄▀██▀  ▀   █▄█  ▄▀▀██ ▀██▀ ▄▄██▄█▄▀████
████▀█▄ ▀▀▄▄▀▄▄▄ ▀▄▄   ▀ ▀█▀█▀█▀▄ ▄██▄▀▀ ▄█▄▄████
████▄█ ▀ █▄▀ ▄▄▄▀▄█  ▄███▀▀█ ▄▄▄ ▄█  ▀ ███▄  ████
████▀▀ ▀ ▀▄█▀▄ ▀█▄██▄▄█▀  ███▀▄▀█▀█▀▀█   █▄█ ████
████▄ ▄▄▄▄▄█  ▄▀███ █▀█▄  █ ▀▄  ▀▄   ▄▄ █ ▀▀ ████
████ ▄█▄▀ ▄▄█▄▄▀█▀▀▀█ ▀▀▀▀ ▀▀▀▀█▄ ▀▀ █   ▄▄  ████
████▀▄█ █ ▄  ▀█▀▀▀█▀▀    █▀█ ▀▀▄ ▀▀██  ██▀▀▀▄████
████▀█ ▀▀▀▄▀████ ▀ ██▀ ▀▀ █▀  ▄█ ▀▄▀█▀█▄▀ ▄▄ ████
████▄██▄██▄█▀▄ ▀ ▀ ▀ █ ▄█ █▄████▀ █▄█▄ █▄ ▀  ████
████▄▀▀▄ ▀▄   █▄  ▄▄ ▀▄▀▀ ▀█▀▀▄▀▄ ▄▀██▀▄███▄▄████
████▄██▄▄▄▄█ ▄▄  ██▄ ███  █▀ ██▀▀█▀█ ▄▄▄ ▀  ▄████
████ ▄▄▄▄▄ █ ▀██▀▄██▀▄█▀ ▀ █▀ ▀█▀▀▄▄ █▄█ ▀█▄ ████
████ █   █ █▄█ ▀███ █▀██ ▄██▀▄ ▄██▀█▄▄▄  ███ ████
████ █▄▄▄█ █ █▄▀█▀ ▀█ ▀▀▀ ▀█▄ ███▀ ▄▄▀██ ██ ▄████
████▄▄▄▄▄▄▄█▄▄██▄▄█████▄▄███▄▄██▄▄█▄▄▄█▄█▄█▄▄████
█████████████████████████████████████████████████
▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀▀
html url: https://berty.tech/id#key=CiDjoRYoVim_Wl-XNgLkdwuTQWoDmL0H-Kg8G_cZOe9PmBIgFQsGC-WIjFwI8fSXsQ4KOrNL0hS0zXWzTH2O2w5QSak&name=demo

Info

foo@bar:~$ berty info
{
  "protocol": {
    "process": {
      "version": "v2.210.2-dev.1+g73f9f964",
      "vcsRef": "73f9f964",
      "uptimeMs": "6544",
      "userCpuTimeMs": "1105",
      "systemCpuTimeMs": "468",
      "startedAt": "1605559580",
      "rlimitCur": "2560",
      "numGoroutine": "657",
      "nofile": "57",
      "numCpu": "4",
      "goVersion": "go1.15.4",
      "operatingSystem": "darwin",
      "hostName": "REDACTED",
      "arch": "amd64",
      "rlimitMax": "9223372036854775807",
      "pid": "22456",
      "ppid": "22455",
      "uid": "501",
      "workingDir": "REDACTED",
      "systemUsername": "Guilhem Fanton"
    },
    "p2p": {
      "connectedPeers": "30"
    },
    "orbitdb": {
      "accountMetadata": {
        "progress": "4",
        "maximum": "4"
      }
    }
  },
  "messenger": {
    "protocolInSameProcess": true,
    "db": {
      "accounts": "1",
      "members": "1",
      "devices": "1"
    }
  }
}

--help

foo@bar:~$ berty -h
USAGE
  berty [global flags] <subcommand> [flags] [args...]

SUBCOMMANDS
  daemon        start a full Berty instance (Berty Protocol + Berty Messenger)
  mini          start a terminal-based mini berty client (not fully compatible with the app)
  banner        print the Berty banner of the day
  version       print software version
  info          display system info
  groupinit     initialize a new multi-member group
  share-invite  share invite link on your terminal or in the dev channel on Discord
  token-server  token server, a basic token server issuer without auth or logging
  repl-server   replication server
  peers         list peers
  export        export messenger data from the specified berty node

FLAGS
  -log.file ...                             if specified, will log everything in JSON into a file and nothing on stderr
  -log.filters info+:bty*,-*.grpc error+:*  zapfilter configuration
  -log.format color                         can be: json, console, color, light-console, light-color
  -log.service berty                        service name, used by the tracer
  -log.tracer ...                           specify "stdout" to output tracing on stdout or <hostname:port> to trace on jaeger

ADVANCED
  -log.filters=':default: CUSTOM'  equivalent to -log.filters='info+:bty*,-*.grpc error+:* CUSTOM'
                                   -> more info at https://github.com/moul/zapfilter

foo@bar:~$ berty daemon -h
USAGE
  berty [global flags] daemon [flags]

FLAGS
  -config ...                                                                   config file (optional)
  -log.file ...                                                                 if specified, will log everything in JSON into a file and nothing on stderr
  -log.filters info+:bty*,-*.grpc error+:*                                      zapfilter configuration
  -log.format color                                                             can be: json, console, color, light-console, light-color
  -log.service berty                                                            service name, used by the tracer
  -log.tracer ...                                                               specify "stdout" to output tracing on stdout or <hostname:port> to trace on jaeger
  -metrics.listener ...                                                         Metrics listener, will enable metrics
  -metrics.pedantic false                                                       Enable Metrics pedantic for debug
  -node.disable-group-monitor false                                             disable group monitoring
  -node.display-name guilhemfanton (cli)                                        display name
  -node.listeners /ip4/127.0.0.1/tcp/9091/grpc                                  gRPC API listeners
  -node.no-notif false                                                          disable desktop notifications
  -node.rebuild-db false                                                        reconstruct messenger DB from OrbitDB logs
  -node.restore-export-path ...                                                 inits node from a specified export path
  -p2p.ble true                                                                 if true Bluetooth Low Energy will be enabled
  -p2p.disable-ipfs-network false                                               disable as much networking feature as possible, useful during development
  -p2p.ipfs-api-listeners ...                                                   IPFS API listeners
  -p2p.local-discovery true                                                     if true local discovery will be enabled
  -p2p.max-backoff 1m0s                                                         maximum p2p backoff duration
  -p2p.min-backoff 1s                                                           minimum p2p backoff duration
  -p2p.multipeer-connectivity true                                              if true Multipeer Connectivity will be enabled
  -p2p.rdvp :default:                                                           list of rendezvous point maddr, ":dev:" will add the default devs servers, ":none:" will disable rdvp
  -p2p.relay-hack false                                                         *temporary flag*; if set, Berty will use relays from the config optimistically
  -p2p.swarm-announce ...                                                       IPFS announce addrs
  -p2p.swarm-listeners :default:                                                IPFS swarm listeners
  -p2p.swarm-no-announce ...                                                    IPFS exclude announce addrs
  -p2p.webui-listener :3999                                                     IPFS WebUI listener
  -preset ...                                                                   applies various default values, see ADVANCED section below
  -store.dir /Users/guilhemfanton/Library/Application Support/berty-tech/berty  root datastore directory
  -store.inmem false                                                            disable datastore persistence
  -store.lowmem false                                                           enable LowMemory Profile, useful for mobile environment
  -tor.binary-path ...                                                          if set berty will use this external tor binary instead of his builtin one
  -tor.mode disabled                                                            changes the behavior of libp2p regarding tor, see advanced help for more details

ADVANCED
  -log.filters=':default: CUSTOM'        equivalent to -log.filters='info+:bty*,-*.grpc error+:* CUSTOM'
                                         -> more info at https://github.com/moul/zapfilter
  -preset=performance                    better performance: current development defaults
  -preset=anonymity                      better privacy: -tor.mode=required -p2p.local-discovery=false -p2p.multipeer-connectivity=false
  -p2p.swarm-listeners=:default:,CUSTOM  equivalent to -p2p.swarm-listeners=/ip4/0.0.0.0/tcp/0,/ip6/::/tcp/0,/ip4/0.0.0.0/udp/0/quic,/ip6/::/udp/0/quic,CUSTOM
  -p2p.rdvp=:default:,CUSTOM             equivalent to -p2p.rdvp=/ip4/51.159.21.214/tcp/4040/p2p/QmdT7Amhhn...,CUSTOM
                                         -> full list available at https://github.com/berty/berty/tree/master/config)
  -tor.mode=disabled                     tor is completely disabled
  -tor.mode=optional                     tor is added to the list of existing transports and can be used to contact other tor-ready nodes
  -tor.mode=required                     tor is the only available transport; you can only communicate with other tor-ready nodes

foo@bar:~$ berty mini -h
USAGE
  berty [global flags] mini [flags]

FLAGS
  -config ...                                                                   config file (optional)
  -log.file ...                                                                 if specified, will log everything in JSON into a file and nothing on stderr
  -log.filters info+:bty*,-*.grpc error+:*                                      zapfilter configuration
  -log.format color                                                             can be: json, console, color, light-console, light-color
  -log.service berty                                                            service name, used by the tracer
  -log.tracer ...                                                               specify "stdout" to output tracing on stdout or <hostname:port> to trace on jaeger
  -metrics.listener ...                                                         Metrics listener, will enable metrics
  -metrics.pedantic false                                                       Enable Metrics pedantic for debug
  -mini.group ...                                                               group to join, leave empty to create a new group
  -node.disable-group-monitor false                                             disable group monitoring
  -node.display-name guilhemfanton (cli)                                        display name
  -node.listeners ...                                                           gRPC API listeners
  -node.no-notif false                                                          disable desktop notifications
  -node.rebuild-db false                                                        reconstruct messenger DB from OrbitDB logs
  -node.remote-addr ...                                                         remote Berty gRPC API address
  -node.restore-export-path ...                                                 inits node from a specified export path
  -p2p.ble true                                                                 if true Bluetooth Low Energy will be enabled
  -p2p.disable-ipfs-network false                                               disable as much networking feature as possible, useful during development
  -p2p.ipfs-api-listeners ...                                                   IPFS API listeners
  -p2p.local-discovery true                                                     if true local discovery will be enabled
  -p2p.max-backoff 1m0s                                                         maximum p2p backoff duration
  -p2p.min-backoff 1s                                                           minimum p2p backoff duration
  -p2p.multipeer-connectivity true                                              if true Multipeer Connectivity will be enabled
  -p2p.rdvp :default:                                                           list of rendezvous point maddr, ":dev:" will add the default devs servers, ":none:" will disable rdvp
  -p2p.relay-hack false                                                         *temporary flag*; if set, Berty will use relays from the config optimistically
  -p2p.swarm-announce ...                                                       IPFS announce addrs
  -p2p.swarm-listeners :default:                                                IPFS swarm listeners
  -p2p.swarm-no-announce ...                                                    IPFS exclude announce addrs
  -p2p.webui-listener ...                                                       IPFS WebUI listener
  -preset ...                                                                   applies various default values, see ADVANCED section below
  -store.dir /Users/guilhemfanton/Library/Application Support/berty-tech/berty  root datastore directory
  -store.inmem false                                                            disable datastore persistence
  -store.lowmem false                                                           enable LowMemory Profile, useful for mobile environment
  -tor.binary-path ...                                                          if set berty will use this external tor binary instead of his builtin one
  -tor.mode disabled                                                            changes the behavior of libp2p regarding tor, see advanced help for more details

ADVANCED
  -log.filters=':default: CUSTOM'        equivalent to -log.filters='info+:bty*,-*.grpc error+:* CUSTOM'
                                         -> more info at https://github.com/moul/zapfilter
  -preset=performance                    better performance: current development defaults
  -preset=anonymity                      better privacy: -tor.mode=required -p2p.local-discovery=false -p2p.multipeer-connectivity=false
  -p2p.swarm-listeners=:default:,CUSTOM  equivalent to -p2p.swarm-listeners=/ip4/0.0.0.0/tcp/0,/ip6/::/tcp/0,/ip4/0.0.0.0/udp/0/quic,/ip6/::/udp/0/quic,CUSTOM
  -p2p.rdvp=:default:,CUSTOM             equivalent to -p2p.rdvp=/ip4/51.159.21.214/tcp/4040/p2p/QmdT7Amhhn...,CUSTOM
                                         -> full list available at https://github.com/berty/berty/tree/master/config)
  -tor.mode=disabled                     tor is completely disabled
  -tor.mode=optional                     tor is added to the list of existing transports and can be used to contact other tor-ready nodes
  -tor.mode=required                     tor is the only available transport; you can only communicate with other tor-ready nodes

foo@bar:~$ berty banner -h
USAGE
  berty banner [flags]

FLAGS
  -config ...                               config file (optional)
  -light false                              light mode
  -log.file ...                             if specified, will log everything in JSON into a file and nothing on stderr
  -log.filters info+:bty*,-*.grpc error+:*  zapfilter configuration
  -log.format color                         can be: json, console, color, light-console, light-color
  -log.service berty                        service name, used by the tracer
  -log.tracer ...                           specify "stdout" to output tracing on stdout or <hostname:port> to trace on jaeger
  -random false                             pick a random quote

ADVANCED
  -log.filters=':default: CUSTOM'  equivalent to -log.filters='info+:bty*,-*.grpc error+:* CUSTOM'
                                   -> more info at https://github.com/moul/zapfilter

foo@bar:~$ berty version -h
USAGE
  berty version

ADVANCED
  -log.filters=':default: CUSTOM'  equivalent to -log.filters='info+:bty*,-*.grpc error+:* CUSTOM'
                                   -> more info at https://github.com/moul/zapfilter

foo@bar:~$ berty info -h
USAGE
  berty [global flags] info [flags]

FLAGS
  -config ...                                                                   config file (optional)
  -info.anonymize false                                                         anonymize output for sharing
  -info.refresh 0s                                                              refresh every DURATION (0: no refresh)
  -log.file ...                                                                 if specified, will log everything in JSON into a file and nothing on stderr
  -log.filters info+:bty*,-*.grpc error+:*                                      zapfilter configuration
  -log.format color                                                             can be: json, console, color, light-console, light-color
  -log.service berty                                                            service name, used by the tracer
  -log.tracer ...                                                               specify "stdout" to output tracing on stdout or <hostname:port> to trace on jaeger
  -node.disable-group-monitor false                                             disable group monitoring
  -node.display-name guilhemfanton (cli)                                        display name
  -node.no-notif false                                                          disable desktop notifications
  -node.rebuild-db false                                                        reconstruct messenger DB from OrbitDB logs
  -node.remote-addr ...                                                         remote Berty gRPC API address
  -node.restore-export-path ...                                                 inits node from a specified export path
  -p2p.ble true                                                                 if true Bluetooth Low Energy will be enabled
  -p2p.disable-ipfs-network false                                               disable as much networking feature as possible, useful during development
  -p2p.ipfs-api-listeners ...                                                   IPFS API listeners
  -p2p.local-discovery true                                                     if true local discovery will be enabled
  -p2p.max-backoff 1m0s                                                         maximum p2p backoff duration
  -p2p.min-backoff 1s                                                           minimum p2p backoff duration
  -p2p.multipeer-connectivity true                                              if true Multipeer Connectivity will be enabled
  -p2p.rdvp :default:                                                           list of rendezvous point maddr, ":dev:" will add the default devs servers, ":none:" will disable rdvp
  -p2p.relay-hack false                                                         *temporary flag*; if set, Berty will use relays from the config optimistically
  -p2p.swarm-announce ...                                                       IPFS announce addrs
  -p2p.swarm-listeners :default:                                                IPFS swarm listeners
  -p2p.swarm-no-announce ...                                                    IPFS exclude announce addrs
  -preset ...                                                                   applies various default values, see ADVANCED section below
  -store.dir /Users/guilhemfanton/Library/Application Support/berty-tech/berty  root datastore directory
  -store.inmem false                                                            disable datastore persistence
  -store.lowmem false                                                           enable LowMemory Profile, useful for mobile environment
  -tor.binary-path ...                                                          if set berty will use this external tor binary instead of his builtin one
  -tor.mode disabled                                                            changes the behavior of libp2p regarding tor, see advanced help for more details

ADVANCED
  -log.filters=':default: CUSTOM'        equivalent to -log.filters='info+:bty*,-*.grpc error+:* CUSTOM'
                                         -> more info at https://github.com/moul/zapfilter
  -preset=performance                    better performance: current development defaults
  -preset=anonymity                      better privacy: -tor.mode=required -p2p.local-discovery=false -p2p.multipeer-connectivity=false
  -p2p.swarm-listeners=:default:,CUSTOM  equivalent to -p2p.swarm-listeners=/ip4/0.0.0.0/tcp/0,/ip6/::/tcp/0,/ip4/0.0.0.0/udp/0/quic,/ip6/::/udp/0/quic,CUSTOM
  -p2p.rdvp=:default:,CUSTOM             equivalent to -p2p.rdvp=/ip4/51.159.21.214/tcp/4040/p2p/QmdT7Amhhn...,CUSTOM
                                         -> full list available at https://github.com/berty/berty/tree/master/config)
  -tor.mode=disabled                     tor is completely disabled
  -tor.mode=optional                     tor is added to the list of existing transports and can be used to contact other tor-ready nodes
  -tor.mode=required                     tor is the only available transport; you can only communicate with other tor-ready nodes

foo@bar:~$ berty groupinit -h
USAGE
  berty groupinit

FLAGS
  -config ...                               config file (optional)
  -log.file ...                             if specified, will log everything in JSON into a file and nothing on stderr
  -log.filters info+:bty*,-*.grpc error+:*  zapfilter configuration
  -log.format color                         can be: json, console, color, light-console, light-color
  -log.service berty                        service name, used by the tracer
  -log.tracer ...                           specify "stdout" to output tracing on stdout or <hostname:port> to trace on jaeger

ADVANCED
  -log.filters=':default: CUSTOM'  equivalent to -log.filters='info+:bty*,-*.grpc error+:* CUSTOM'
                                   -> more info at https://github.com/moul/zapfilter

foo@bar:~$ berty share-invite -h
USAGE
  berty [global flags] share-invite [flags]

FLAGS
  -config ...                                                                   config file (optional)
  -dev-channel false                                                            post qrcode on dev channel
  -log.file ...                                                                 if specified, will log everything in JSON into a file and nothing on stderr
  -log.filters info+:bty*,-*.grpc error+:*                                      zapfilter configuration
  -log.format color                                                             can be: json, console, color, light-console, light-color
  -log.service berty                                                            service name, used by the tracer
  -log.tracer ...                                                               specify "stdout" to output tracing on stdout or <hostname:port> to trace on jaeger
  -no-term false                                                                do not print the QR code in terminal
  -node.disable-group-monitor false                                             disable group monitoring
  -node.display-name guilhemfanton (cli)                                        display name
  -node.no-notif false                                                          disable desktop notifications
  -node.rebuild-db false                                                        reconstruct messenger DB from OrbitDB logs
  -node.remote-addr ...                                                         remote Berty gRPC API address
  -node.restore-export-path ...                                                 inits node from a specified export path
  -p2p.ble true                                                                 if true Bluetooth Low Energy will be enabled
  -p2p.disable-ipfs-network false                                               disable as much networking feature as possible, useful during development
  -p2p.ipfs-api-listeners ...                                                   IPFS API listeners
  -p2p.local-discovery true                                                     if true local discovery will be enabled
  -p2p.max-backoff 1m0s                                                         maximum p2p backoff duration
  -p2p.min-backoff 1s                                                           minimum p2p backoff duration
  -p2p.multipeer-connectivity true                                              if true Multipeer Connectivity will be enabled
  -p2p.rdvp :default:                                                           list of rendezvous point maddr, ":dev:" will add the default devs servers, ":none:" will disable rdvp
  -p2p.relay-hack false                                                         *temporary flag*; if set, Berty will use relays from the config optimistically
  -p2p.swarm-announce ...                                                       IPFS announce addrs
  -p2p.swarm-listeners :default:                                                IPFS swarm listeners
  -p2p.swarm-no-announce ...                                                    IPFS exclude announce addrs
  -preset ...                                                                   applies various default values, see ADVANCED section below
  -store.dir /Users/guilhemfanton/Library/Application Support/berty-tech/berty  root datastore directory
  -store.inmem false                                                            disable datastore persistence
  -store.lowmem false                                                           enable LowMemory Profile, useful for mobile environment
  -tor.binary-path ...                                                          if set berty will use this external tor binary instead of his builtin one
  -tor.mode disabled                                                            changes the behavior of libp2p regarding tor, see advanced help for more details

ADVANCED
  -log.filters=':default: CUSTOM'        equivalent to -log.filters='info+:bty*,-*.grpc error+:* CUSTOM'
                                         -> more info at https://github.com/moul/zapfilter
  -preset=performance                    better performance: current development defaults
  -preset=anonymity                      better privacy: -tor.mode=required -p2p.local-discovery=false -p2p.multipeer-connectivity=false
  -p2p.swarm-listeners=:default:,CUSTOM  equivalent to -p2p.swarm-listeners=/ip4/0.0.0.0/tcp/0,/ip6/::/tcp/0,/ip4/0.0.0.0/udp/0/quic,/ip6/::/udp/0/quic,CUSTOM
  -p2p.rdvp=:default:,CUSTOM             equivalent to -p2p.rdvp=/ip4/51.159.21.214/tcp/4040/p2p/QmdT7Amhhn...,CUSTOM
                                         -> full list available at https://github.com/berty/berty/tree/master/config)
  -tor.mode=disabled                     tor is completely disabled
  -tor.mode=optional                     tor is added to the list of existing transports and can be used to contact other tor-ready nodes
  -tor.mode=required                     tor is the only available transport; you can only communicate with other tor-ready nodes

foo@bar:~$ berty token-server -h
USAGE
  berty [global flags] token-server [flags]

FLAGS
  -auth.secret ...                          base64 encoded secret
  -auth.sk ...                              base64 encoded signature key
  -config ...                               config file (optional)
  -http.listener 127.0.0.1:8080             http listener
  -log.file ...                             if specified, will log everything in JSON into a file and nothing on stderr
  -log.filters info+:bty*,-*.grpc error+:*  zapfilter configuration
  -log.format color                         can be: json, console, color, light-console, light-color
  -log.service berty                        service name, used by the tracer
  -log.tracer ...                           specify "stdout" to output tracing on stdout or <hostname:port> to trace on jaeger
  -svc ...                                  comma separated list of supported services as name@ip:port

ADVANCED
  -log.filters=':default: CUSTOM'  equivalent to -log.filters='info+:bty*,-*.grpc error+:* CUSTOM'
                                   -> more info at https://github.com/moul/zapfilter

foo@bar:~$ berty repl-server -h
USAGE
  berty [global flags] repl-server [flags]

FLAGS
  -config ...                                                                   config file (optional)
  -log.file ...                                                                 if specified, will log everything in JSON into a file and nothing on stderr
  -log.filters info+:bty*,-*.grpc error+:*                                      zapfilter configuration
  -log.format color                                                             can be: json, console, color, light-console, light-color
  -log.service berty                                                            service name, used by the tracer
  -log.tracer ...                                                               specify "stdout" to output tracing on stdout or <hostname:port> to trace on jaeger
  -node.auth-pk ...                                                             Protocol API Authentication Public Key (base64 encoded)
  -node.auth-secret ...                                                         Protocol API Authentication Secret (base64 encoded)
  -node.listeners /ip4/127.0.0.1/tcp/9091/grpc                                  gRPC API listeners
  -p2p.ble true                                                                 if true Bluetooth Low Energy will be enabled
  -p2p.disable-ipfs-network false                                               disable as much networking feature as possible, useful during development
  -p2p.ipfs-api-listeners ...                                                   IPFS API listeners
  -p2p.local-discovery true                                                     if true local discovery will be enabled
  -p2p.max-backoff 1m0s                                                         maximum p2p backoff duration
  -p2p.min-backoff 1s                                                           minimum p2p backoff duration
  -p2p.multipeer-connectivity true                                              if true Multipeer Connectivity will be enabled
  -p2p.rdvp :default:                                                           list of rendezvous point maddr, ":dev:" will add the default devs servers, ":none:" will disable rdvp
  -p2p.relay-hack false                                                         *temporary flag*; if set, Berty will use relays from the config optimistically
  -p2p.swarm-announce ...                                                       IPFS announce addrs
  -p2p.swarm-listeners :default:                                                IPFS swarm listeners
  -p2p.swarm-no-announce ...                                                    IPFS exclude announce addrs
  -p2p.webui-listener :3999                                                     IPFS WebUI listener
  -preset ...                                                                   applies various default values, see ADVANCED section below
  -store.dir /Users/guilhemfanton/Library/Application Support/berty-tech/berty  root datastore directory
  -store.inmem false                                                            disable datastore persistence
  -store.lowmem false                                                           enable LowMemory Profile, useful for mobile environment
  -tor.binary-path ...                                                          if set berty will use this external tor binary instead of his builtin one
  -tor.mode disabled                                                            changes the behavior of libp2p regarding tor, see advanced help for more details

ADVANCED
  -log.filters=':default: CUSTOM'        equivalent to -log.filters='info+:bty*,-*.grpc error+:* CUSTOM'
                                         -> more info at https://github.com/moul/zapfilter
  -preset=performance                    better performance: current development defaults
  -preset=anonymity                      better privacy: -tor.mode=required -p2p.local-discovery=false -p2p.multipeer-connectivity=false
  -p2p.swarm-listeners=:default:,CUSTOM  equivalent to -p2p.swarm-listeners=/ip4/0.0.0.0/tcp/0,/ip6/::/tcp/0,/ip4/0.0.0.0/udp/0/quic,/ip6/::/udp/0/quic,CUSTOM
  -p2p.rdvp=:default:,CUSTOM             equivalent to -p2p.rdvp=/ip4/51.159.21.214/tcp/4040/p2p/QmdT7Amhhn...,CUSTOM
                                         -> full list available at https://github.com/berty/berty/tree/master/config)
  -tor.mode=disabled                     tor is completely disabled
  -tor.mode=optional                     tor is added to the list of existing transports and can be used to contact other tor-ready nodes
  -tor.mode=required                     tor is the only available transport; you can only communicate with other tor-ready nodes

foo@bar:~$ berty peers -h
USAGE
  berty [global flags] peers [flags]

FLAGS
  -config ...                                                                   config file (optional)
  -log.file ...                                                                 if specified, will log everything in JSON into a file and nothing on stderr
  -log.filters info+:bty*,-*.grpc error+:*                                      zapfilter configuration
  -log.format color                                                             can be: json, console, color, light-console, light-color
  -log.service berty                                                            service name, used by the tracer
  -log.tracer ...                                                               specify "stdout" to output tracing on stdout or <hostname:port> to trace on jaeger
  -node.remote-addr ...                                                         remote Berty gRPC API address
  -p2p.ble true                                                                 if true Bluetooth Low Energy will be enabled
  -p2p.disable-ipfs-network false                                               disable as much networking feature as possible, useful during development
  -p2p.ipfs-api-listeners ...                                                   IPFS API listeners
  -p2p.local-discovery true                                                     if true local discovery will be enabled
  -p2p.max-backoff 1m0s                                                         maximum p2p backoff duration
  -p2p.min-backoff 1s                                                           minimum p2p backoff duration
  -p2p.multipeer-connectivity true                                              if true Multipeer Connectivity will be enabled
  -p2p.rdvp :default:                                                           list of rendezvous point maddr, ":dev:" will add the default devs servers, ":none:" will disable rdvp
  -p2p.relay-hack false                                                         *temporary flag*; if set, Berty will use relays from the config optimistically
  -p2p.swarm-announce ...                                                       IPFS announce addrs
  -p2p.swarm-listeners :default:                                                IPFS swarm listeners
  -p2p.swarm-no-announce ...                                                    IPFS exclude announce addrs
  -peers.refresh 1s                                                             refresh every DURATION (0: no refresh)
  -preset ...                                                                   applies various default values, see ADVANCED section below
  -store.dir /Users/guilhemfanton/Library/Application Support/berty-tech/berty  root datastore directory
  -store.inmem false                                                            disable datastore persistence
  -store.lowmem false                                                           enable LowMemory Profile, useful for mobile environment
  -tor.binary-path ...                                                          if set berty will use this external tor binary instead of his builtin one
  -tor.mode disabled                                                            changes the behavior of libp2p regarding tor, see advanced help for more details

ADVANCED
  -log.filters=':default: CUSTOM'        equivalent to -log.filters='info+:bty*,-*.grpc error+:* CUSTOM'
                                         -> more info at https://github.com/moul/zapfilter
  -preset=performance                    better performance: current development defaults
  -preset=anonymity                      better privacy: -tor.mode=required -p2p.local-discovery=false -p2p.multipeer-connectivity=false
  -p2p.swarm-listeners=:default:,CUSTOM  equivalent to -p2p.swarm-listeners=/ip4/0.0.0.0/tcp/0,/ip6/::/tcp/0,/ip4/0.0.0.0/udp/0/quic,/ip6/::/udp/0/quic,CUSTOM
  -p2p.rdvp=:default:,CUSTOM             equivalent to -p2p.rdvp=/ip4/51.159.21.214/tcp/4040/p2p/QmdT7Amhhn...,CUSTOM
                                         -> full list available at https://github.com/berty/berty/tree/master/config)
  -tor.mode=disabled                     tor is completely disabled
  -tor.mode=optional                     tor is added to the list of existing transports and can be used to contact other tor-ready nodes
  -tor.mode=required                     tor is the only available transport; you can only communicate with other tor-ready nodes

foo@bar:~$ berty export -h
USAGE
  berty [global flags] export [flags]

FLAGS
  -config ...                                                                   config file (optional)
  -export-path ...                                                              path of the export tarball
  -log.file ...                                                                 if specified, will log everything in JSON into a file and nothing on stderr
  -log.filters info+:bty*,-*.grpc error+:*                                      zapfilter configuration
  -log.format color                                                             can be: json, console, color, light-console, light-color
  -log.service berty                                                            service name, used by the tracer
  -log.tracer ...                                                               specify "stdout" to output tracing on stdout or <hostname:port> to trace on jaeger
  -node.disable-group-monitor false                                             disable group monitoring
  -node.display-name guilhemfanton (cli)                                        display name
  -node.no-notif false                                                          disable desktop notifications
  -node.rebuild-db false                                                        reconstruct messenger DB from OrbitDB logs
  -node.remote-addr ...                                                         remote Berty gRPC API address
  -node.restore-export-path ...                                                 inits node from a specified export path
  -p2p.ble true                                                                 if true Bluetooth Low Energy will be enabled
  -p2p.disable-ipfs-network false                                               disable as much networking feature as possible, useful during development
  -p2p.ipfs-api-listeners ...                                                   IPFS API listeners
  -p2p.local-discovery true                                                     if true local discovery will be enabled
  -p2p.max-backoff 1m0s                                                         maximum p2p backoff duration
  -p2p.min-backoff 1s                                                           minimum p2p backoff duration
  -p2p.multipeer-connectivity true                                              if true Multipeer Connectivity will be enabled
  -p2p.rdvp :default:                                                           list of rendezvous point maddr, ":dev:" will add the default devs servers, ":none:" will disable rdvp
  -p2p.relay-hack false                                                         *temporary flag*; if set, Berty will use relays from the config optimistically
  -p2p.swarm-announce ...                                                       IPFS announce addrs
  -p2p.swarm-listeners :default:                                                IPFS swarm listeners
  -p2p.swarm-no-announce ...                                                    IPFS exclude announce addrs
  -preset ...                                                                   applies various default values, see ADVANCED section below
  -store.dir /Users/guilhemfanton/Library/Application Support/berty-tech/berty  root datastore directory
  -store.inmem false                                                            disable datastore persistence
  -store.lowmem false                                                           enable LowMemory Profile, useful for mobile environment
  -tor.binary-path ...                                                          if set berty will use this external tor binary instead of his builtin one
  -tor.mode disabled                                                            changes the behavior of libp2p regarding tor, see advanced help for more details

ADVANCED
  -log.filters=':default: CUSTOM'        equivalent to -log.filters='info+:bty*,-*.grpc error+:* CUSTOM'
                                         -> more info at https://github.com/moul/zapfilter
  -preset=performance                    better performance: current development defaults
  -preset=anonymity                      better privacy: -tor.mode=required -p2p.local-discovery=false -p2p.multipeer-connectivity=false
  -p2p.swarm-listeners=:default:,CUSTOM  equivalent to -p2p.swarm-listeners=/ip4/0.0.0.0/tcp/0,/ip6/::/tcp/0,/ip4/0.0.0.0/udp/0/quic,/ip6/::/udp/0/quic,CUSTOM
  -p2p.rdvp=:default:,CUSTOM             equivalent to -p2p.rdvp=/ip4/51.159.21.214/tcp/4040/p2p/QmdT7Amhhn...,CUSTOM
                                         -> full list available at https://github.com/berty/berty/tree/master/config)
  -tor.mode=disabled                     tor is completely disabled
  -tor.mode=optional                     tor is added to the list of existing transports and can be used to contact other tor-ready nodes
  -tor.mode=required                     tor is the only available transport; you can only communicate with other tor-ready nodes

Other Binaries

rdvp

foo@bar:~$ rdvp -h
USAGE
  rdvp [global flags] <subcommand>

SUBCOMMANDS
  serve   
  genkey  

FLAGS
  -log.file stderr      if specified, will log everything in JSON into a file and nothing on stderr
  -log.filters info+:*  logged namespaces
  -log.format color     if specified, will override default log format

foo@bar:~$ rdvp serve -h
USAGE
  rdvp [global flags] serve [flags]

EXAMPLE
  rdvp genkey > rdvp.key
  rdvp serve -pk `cat rdvp.key` -db ./rdvp-store

FLAGS
  -announce ...                                        addrs that will be announce by this server
  -config ...                                          config file (optional)
  -db :memory:                                         rdvp sqlite URN
  -l /ip4/0.0.0.0/tcp/4040,/ip4/0.0.0.0/udp/4141/quic  lists of listeners of (m)addrs separate by a comma
  -metrics ...                                         metrics listener, if empty will disable metrics
  -pk ...                                              private key (generated by `rdvp genkey`)

foo@bar:~$ rdvp genkey -h
USAGE
  genkey

FLAGS
  -length 2048   The length (in bits) of the key generated.
  -type Ed25519  Type of the private key generated, one of : Ed25519, ECDSA, Secp256k1, RSA

betabot

foo@bar:~$ betabot -h
Usage of betabot:
  -addr string
    	remote 'berty daemon' address (default "127.0.0.1:9091")
  -display-name string
    	bot's display name (default "guilhemfanton (betabot)")
  -staff-conversation-link string
    	link of the staff's conversation to join
  -store string
    	store file path (default "./betabot.store")