underbbs/README.md

34 lines
1.2 KiB
Markdown
Raw Normal View History

2024-04-22 00:02:44 +00:00
# underBBS
2024-09-28 17:39:03 +00:00
underBBS is a protocol-agnostic decentralized social media client and toolkit
2024-04-22 00:02:44 +00:00
2024-07-07 17:07:18 +00:00
## design
2024-09-28 17:39:03 +00:00
`underbbs` can run in two modes depending on its executable name:
### web client
2024-07-07 17:07:18 +00:00
`underbbs` supports multiple simultaneous account logins, mediating them for each user through a gateway server that handles all protocol-specific logic via `adapter`s and streaming content to the user through a single websocket connection with a singular data interface.
each distinct `adapter` connection/configuration is represented in the frontend as a tab, and using the websocket's event-driven javascript interface with web components we can simply either store the data or tell the currently visible adapter that it might need to respond to the new data
adapters receive commands via a quartzgun web API and send data back on their shared websocket connection
2024-09-28 17:39:03 +00:00
### CLI
`underbbs-cli` pulls adapter credentials from `~/.config/underbbs/cli.conf` and accepts commands on individual adapters, printing data to standard output.
## building and running
2024-04-22 00:02:44 +00:00
2024-07-07 17:07:18 +00:00
requirements are
- go 1.22
- any recent nodejs that can do `typescript` and `webpack` 5
from the project root:
1. `./build.sh front`
2. `./build.sh server`
3. `./underbbs`
visit `http://localhost:9090/app`