libp2p-chat

command
v0.0.0-...-f8f499d Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 18, 2019 License: MIT Imports: 17 Imported by: 0

README

Pre-Chat Using 'libp2p'

This prototype uses various packages from projects of Protocol Labs:

It is inspired by chat-with-rendezvous

Get and build
go get github.com/programming-reactive-systems-in-go/prototypes/libp2p

go build chat.go
Usage
Usage of ./chat:
  -b string
    	Address of bootstrap peer, <multiaddr>/<peerID>
  -r string
    	Unique string to identify group of nodes. Share this with your friends to let them connect with you
Start it with a unique identifier and default bootstrap peers

Create a new uuid, e.g. by uuidgen

uuidgen > uuid.txt


Use different terminal windows to run

./chat -r $(cat uuid.txt)
Start it with your bootstrap peer

Install IPFS if needed.

Stop the daemon, if running.

ipfs shutdown


Remove all bootstrap peers and start the daemon.

ipfs bootstrap rm all
ipfs daemon &


Choose peer address for private network.

ipfs id -f="<addrs>\n"


Create a new uuid.

uuidgen > uuid.txt


Start the application, e.g. on localhost.

./chat -r $(cat uuid.txt) -b $(ipfs id -f="<addrs>\n" | grep 127.0.0.1/tcp/4001)
Internal commands
<CMD USAGE>: \rendezvous
<CMD USAGE>: \chat
<CMD USAGE>: \con
<CMD USAGE>: \peer <peer.ID Qm*...>
<CMD USAGE>: \addpeer <peer.ID Qm*...>
<CMD USAGE>: \quit

Documentation

The Go Gopher

There is no documentation for this package.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL