Add documentation
This commit is contained in:
parent
867bdcf978
commit
2c4724638a
2
.gitignore
vendored
2
.gitignore
vendored
@ -1,2 +1,2 @@
|
|||||||
config.js
|
/config.js
|
||||||
node_modules/
|
node_modules/
|
||||||
|
56
README.md
Normal file
56
README.md
Normal file
@ -0,0 +1,56 @@
|
|||||||
|
# XMPP Lightning Anti-Spam
|
||||||
|
|
||||||
|
In order to combat spam in public chat rooms, they can be configured so that
|
||||||
|
new, unknown participants have to request voice before being able to write
|
||||||
|
messages (known as a "moderated channel").
|
||||||
|
|
||||||
|
This bot listens to those voice requests, and when it sees one, it sends a
|
||||||
|
direct message to the user, which offers to give them voice immediately, in
|
||||||
|
exchange for a small amount of sats[^1], payable via the Lightning Network[^2].
|
||||||
|
|
||||||
|
## Requirements
|
||||||
|
|
||||||
|
* [Node.js](https://nodejs.org) and [NPM](https://www.npmjs.com)
|
||||||
|
* An XMPP account, which has admin permissions for the channels you want it to
|
||||||
|
manage voice requests in
|
||||||
|
* A hosted Lightning Network account compatible with LndHub clients (e.g. a
|
||||||
|
[Kosmos](https://kosmos.org) or [Alby](https://getalby.com/)
|
||||||
|
account, or self-hosted with
|
||||||
|
[lndhub.go](https://github.com/getAlby/lndhub.go)).
|
||||||
|
|
||||||
|
## Setup
|
||||||
|
|
||||||
|
Clone this repository:
|
||||||
|
|
||||||
|
git clone https://gitea.kosmos.org/raucao/xmpp-lightning-antispam.git
|
||||||
|
|
||||||
|
Install required dependencies:
|
||||||
|
|
||||||
|
npm install
|
||||||
|
|
||||||
|
Create a config file from the included sample:
|
||||||
|
|
||||||
|
cp samples/config.js config.js
|
||||||
|
|
||||||
|
Edit the config file using your favorite editor:
|
||||||
|
|
||||||
|
vim config.js
|
||||||
|
|
||||||
|
Start the program:
|
||||||
|
|
||||||
|
npm start
|
||||||
|
|
||||||
|
## Deployment
|
||||||
|
|
||||||
|
Set up as described above, or use a cloud platform instead.
|
||||||
|
|
||||||
|
An example for a systemd service can be found in
|
||||||
|
`samples/xmpp-lightning-antispam.service`.
|
||||||
|
|
||||||
|
## Contact
|
||||||
|
|
||||||
|
E-Mail, Chat, Lightning: raucao@kosmos.org
|
||||||
|
|
||||||
|
[^1]: Sats are the smallest unit of bitcoin (1 sat = 0.00000001 BTC)
|
||||||
|
[^2]: The Lightning Network is a peer-to-peer network for instantly and very
|
||||||
|
cheaply sending and receiving bitcoin directly between nodes
|
@ -1,10 +1,11 @@
|
|||||||
{
|
{
|
||||||
"name": "xmpp-lightning-antispam",
|
"name": "xmpp-lightning-antispam",
|
||||||
"version": "1.1.0",
|
"version": "1.1.0",
|
||||||
"description": "",
|
"description": "A bot for moderated XMPP channels, offering voice for Lightning donations",
|
||||||
"main": "index.js",
|
"main": "index.js",
|
||||||
"type": "module",
|
"type": "module",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
|
"start": "node index.js",
|
||||||
"test": "echo \"Error: no test specified\" && exit 1"
|
"test": "echo \"Error: no test specified\" && exit 1"
|
||||||
},
|
},
|
||||||
"author": "Râu Cao",
|
"author": "Râu Cao",
|
||||||
|
13
samples/xmpp-lightning-antispam.service
Normal file
13
samples/xmpp-lightning-antispam.service
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
[Unit]
|
||||||
|
Description=XMPP Lightning Antispam bot
|
||||||
|
After=network.target
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
Type=simple
|
||||||
|
User=deploy
|
||||||
|
WorkingDirectory=/opt/xmpp-lightning-antispam
|
||||||
|
ExecStart=/usr/bin/node index.js
|
||||||
|
Restart=on-failure
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
Loading…
x
Reference in New Issue
Block a user