Skycoin BBS is a next generation decentralised social network (BBS stands for Bulletin Board System).
Skycoin BBS uses the Skycoin CX Object System (CXO) to store and synchronise data between nodes.
There are many configurations for running a Skycoin BBS Node.
- By default, a node cannot host/create new boards. But a node can be set as master to enable such an ability.
- A node can also be configured to run purely in memory (RAM) so nothing is stored on disk.
- Additionally, you can run a node in test mode where it simulates the actions of users. This is useful for developers or those setting up master nodes.
First ensure that go
is installed and the GOPATH
environment variable is set.
Get the source code, dependencies and build BBS Node:
go get github.com/skycoin/bbs/cmd/bbsnode
The executable will be in $GOPATH/bin
.
By default (aka running bbsnode
without specifying flags), a BBS Node will have the following characteristics:
-
Not in master mode - This means that the node does not have the ability to create and host boards. However, it can subscribe to boards of other nodes it is connected to and interact with those.
-
Saves configuration and cxo files - Configuration files for boards, users and message queue will be stored in the
$HOME/.skybbs
directory. CXO files will be in$HOME/.skybbs/cxo
. -
Uses the following ports - The CXO Daemon will listen on
8998
and8997
(RPC). The BBS Node will host it's web interface and JSON API on7410
. -
Launches the browser - After the
bbsnode
has successfully started, the browser will be launched to display the web interface.
The following examples assume that you have $GOPATH/bin
in your $PATH
, and the above executables have been built.
bbsnode --help
Master nodes have the ability to create and host boards.
bbsnode \
-master=true \
-rpc-port=8234 \
-rpc-remote-address=34.215.131.150:8234 \
-cxo-port=8456 \
-web-gui-enable=false
Other nodes connect to the master node via it's CXO Port (specified with cxo-port
flag). If the external IP address of the server of the above example is 34.215.131.150
, then other nodes can connect via the address 34.215.131.150:8456
(assuming that the port 8456
is shared).
Nodes that run as master will host a BBS RPC server. Other nodes add posts, threads and votes, on hosted boards via this RPC connection. Hence, a port needs to be specified of where the RPC connection is hosted, as well as the remote address of the connection. The flags rpc-port
and rpc-remote-address
are used to specify these.
If a graphical user interface is not needed for the node, setting web-gui-enable
to false can disable it.
This mode is ideal for testing, or if you don't wish to save anything to disk.
bbsnode \
-memory-mode=true
The save-config
flag determines whether or not to save the Skycoin BBS configuration files for boards, users and messages. Here, it is set as false.
When the cxo-memory-mode
flag is set to true, instead of storing objects and configurations to file, the cxo client and server will store everything in memory. When the application exits, everything stored locally will be deleted.
In test mode, the node generates a board, and creates threads, posts and votes as different users. It does this in intervals.
bbsnode \
-test-mode=true \
-test-mode-threads=4 \
-test-mode-users=50 \
-test-mode-min=1 \
-test-mode-max=5 \
-test-mode-timeout=10 \
-test-mode-post-cap=200
Test mode forces the node to be run as master. BBS configuration files will not be stored in test mode, and CXO files will be stored in /tmp
and deleted after the node exits.
test-mode-threads
specifies how many threads are to be created on the test board.test-mode-users
specifies how many simulated users are to be created.test-mode-min
is the minimum interval in seconds between simulated activity.test-mode-max
is the maximum interval in seconds between simulated activity.test-mode-timeout
is the time in seconds before all simulated activity stops. This can be set as-1
to disable the timeout.test-most-post-cap
is the maximum number of posts that are allowed to be created. This can be set as-1
to disable the cap.
There are currently two ways of interacting with Skycoin BBS.
-
Web interface - By default, the flags
web-gui-enable
andweb-gui-open-browser
are enabled. Hence, when BBS is launched, the web gui will be opened via the system browser. -
Restful json api - This is ideal for controlling nodes without a graphical user interface (in a server), or for building applications or administrator tools. Documentation for the api is provided as a Postman Collection located at docfiles/postman_collection.json.