go-xmpp/cmd/fluuxmpp/README.md

199 lines
5.0 KiB
Markdown
Raw Normal View History

2019-08-06 07:03:48 -07:00
# fluuxmpp
2019-07-16 15:31:33 -07:00
2019-08-06 09:27:51 -07:00
fluuxIO's XMPP command-line tool
2019-07-16 15:31:33 -07:00
## Installation
2019-08-06 07:03:48 -07:00
To install `fluuxmpp` in your Go path:
2019-07-16 15:31:33 -07:00
```
2019-08-06 07:03:48 -07:00
$ go get -u gosrc.io/xmpp/cmd/fluuxmpp
2019-07-16 15:31:33 -07:00
```
## Usage
```
2019-08-06 07:03:48 -07:00
$ fluuxmpp --help
fluuxIO's xmpp comandline tool
2019-08-06 02:00:52 -07:00
2019-07-17 14:56:13 -07:00
Usage:
2019-08-06 07:03:48 -07:00
fluuxmpp [command]
2019-08-06 02:00:52 -07:00
Available Commands:
check is a command-line to check if you XMPP TLS certificate is valid and warn you before it expires
help Help about any command
send is a command-line tool to send to send XMPP messages to users
Flags:
2019-08-06 07:03:48 -07:00
-h, --help help for fluuxmpp
2019-08-06 02:00:52 -07:00
2019-08-06 07:03:48 -07:00
Use "fluuxmpp [command] --help" for more information about a command.
2019-08-06 02:00:52 -07:00
```
### check tls
```
2019-08-06 07:03:48 -07:00
$ fluuxmpp check --help
2019-08-06 02:00:52 -07:00
is a command-line to check if you XMPP TLS certificate is valid and warn you before it expires
Usage:
2019-08-06 07:03:48 -07:00
fluuxmpp check <host[:port]> [flags]
2019-07-17 14:56:13 -07:00
Examples:
2019-08-06 07:03:48 -07:00
fluuxmpp check chat.sum7.eu:5222 --domain meckerspace.de
2019-08-06 02:00:52 -07:00
Flags:
-d, --domain string domain if host handle multiple domains
-h, --help help for check
```
### sending messages
```
2019-08-06 07:03:48 -07:00
$ fluuxmpp send --help
2019-08-06 02:00:52 -07:00
is a command-line tool to send to send XMPP messages to users
Usage:
2019-08-06 07:03:48 -07:00
fluuxmpp send <recipient,> [message] [flags]
2019-08-06 02:00:52 -07:00
Examples:
2019-08-06 07:03:48 -07:00
fluuxmpp send to@chat.sum7.eu "Hello World!"
2019-07-17 14:56:13 -07:00
Flags:
--addr string host[:port]
2019-08-06 07:03:48 -07:00
--config string config file (default is ~/.config/fluuxmpp.yml)
2019-08-06 02:00:52 -07:00
-h, --help help for send
2019-07-17 14:56:13 -07:00
--jid string using jid (required)
2019-07-27 16:32:05 -07:00
-m, --muc recipient is a muc (join it before sending messages)
2019-07-17 14:56:13 -07:00
--password string using password for your jid (required)
```
## Examples
2019-08-06 02:00:52 -07:00
### check tls
If you server is on standard port and XMPP domains matches the hostname you can simply use:
```
2019-08-06 07:03:48 -07:00
$ fluuxmpp check chat.sum7.eu
2019-08-06 02:00:52 -07:00
info All checks passed
⇢ address="chat.sum7.eu" domain=""
⇢ main.go:43 main.runCheck
⇢ 2019-07-16T22:01:39.765+02:00
```
You can also pass the port and the XMPP domain if different from the server hostname:
```
2019-08-06 07:03:48 -07:00
$ fluuxmpp check chat.sum7.eu:5222 --domain meckerspace.de
2019-08-06 02:00:52 -07:00
info All checks passed
⇢ address="chat.sum7.eu:5222" domain="meckerspace.de"
⇢ main.go:43 main.runCheck
⇢ 2019-07-16T22:01:33.270+02:00
```
Error code will be non-zero in case of error. You can thus use it directly with your usual
monitoring scripts.
### sending messages
2019-07-17 14:56:13 -07:00
Message from arguments:
```bash
2019-08-06 07:03:48 -07:00
$ fluuxmpp send to@example.org "Hello World!"
2019-07-17 14:56:13 -07:00
info client connected
⇢ cmd.go:56 main.glob..func1.1
⇢ 2019-07-17T23:42:43.310+02:00
info send message
2019-07-27 16:32:05 -07:00
⇢ muc=false text="Hello World!" to="to@example.org"
2019-07-17 14:56:13 -07:00
⇢ send.go:31 main.send
⇢ 2019-07-17T23:42:43.310+02:00
```
Message from STDIN:
```bash
2019-08-06 07:03:48 -07:00
$ journalctl -f | fluuxmpp send to@example.org -
2019-07-17 14:56:13 -07:00
info client connected
⇢ cmd.go:56 main.glob..func1.1
⇢ 2019-07-17T23:40:03.177+02:00
info send message
⇢ muc=false text="-- Logs begin at Mon 2019-07-08 22:16:54 CEST. --" to="to@example.org"
⇢ send.go:31 main.send
⇢ 2019-07-17T23:40:03.178+02:00
info send message
⇢ muc=false text="Jul 17 23:36:46 RECHNERNAME systemd[755]: Started Fetch mails." to="to@example.org"
⇢ send.go:31 main.send
⇢ 2019-07-17T23:40:03.178+02:00
^C
```
2019-07-27 16:32:05 -07:00
Multiple recipients:
2019-07-17 14:56:13 -07:00
```bash
2019-08-06 07:03:48 -07:00
$ fluuxmpp send to1@example.org,to2@example.org "Multiple recipient"
2019-07-17 14:56:13 -07:00
info client connected
⇢ cmd.go:56 main.glob..func1.1
⇢ 2019-07-17T23:47:57.650+02:00
info send message
2019-07-27 16:32:05 -07:00
⇢ muc=false text="Multiple recipient" to="to1@example.org"
2019-07-17 14:56:13 -07:00
⇢ send.go:31 main.send
⇢ 2019-07-17T23:47:57.651+02:00
info send message
2019-07-27 16:32:05 -07:00
⇢ muc=false text="Multiple recipient" to="to2@example.org"
2019-07-17 14:56:13 -07:00
⇢ send.go:31 main.send
⇢ 2019-07-17T23:47:57.652+02:00
```
Send to MUC:
```bash
2019-08-06 07:03:48 -07:00
journalctl -f | fluuxmpp send testit@conference.chat.sum7.eu - --muc
2019-07-17 14:56:13 -07:00
info client connected
⇢ cmd.go:56 main.glob..func1.1
⇢ 2019-07-17T23:52:56.269+02:00
info send message
⇢ muc=true text="-- Logs begin at Mon 2019-07-08 22:16:54 CEST. --" to="testit@conference.chat.sum7.eu"
⇢ send.go:31 main.send
⇢ 2019-07-17T23:52:56.270+02:00
info send message
⇢ muc=true text="Jul 17 23:48:58 RECHNERNAME systemd[755]: mail.service: Succeeded." to="testit@conference.chat.sum7.eu"
⇢ send.go:31 main.send
⇢ 2019-07-17T23:52:56.277+02:00
^C
```
2019-08-06 02:00:52 -07:00
## Authentification
2019-07-17 14:56:13 -07:00
2019-08-06 02:00:52 -07:00
### Configuration file
2019-07-27 16:32:05 -07:00
2019-07-17 14:56:13 -07:00
In `/etc/`, `~/.config` and `.` (here).
2019-09-04 10:16:44 -07:00
You could create the file name `fluuxmpp` with you favorite file extension (e.g. `toml`, `yml`).
2019-07-17 14:56:13 -07:00
2019-08-06 07:03:48 -07:00
e.g. ~/.config/fluuxmpp.toml
2019-07-17 14:56:13 -07:00
```toml
jid = "bot@example.org"
password = "secret"
addr = "example.com:5222"
2019-07-17 14:56:13 -07:00
```
2019-08-06 02:00:52 -07:00
### Environment variables
2019-07-27 16:32:05 -07:00
2019-07-17 14:56:13 -07:00
```bash
export FLUXXMPP_JID='bot@example.org';
export FLUXXMPP_PASSWORD='secret';
export FLUXXMPP_ADDR='example.com:5222';
2019-08-06 07:03:48 -07:00
fluuxmpp send to@example.org "Hello Welt";
2019-07-17 14:56:13 -07:00
```
2019-08-06 02:00:52 -07:00
### Parameters
2019-07-27 16:32:05 -07:00
Warning: This should not be used for production systems, as all users on the system
can read the running processes, and their parameters (and thus the password).
2019-07-17 14:56:13 -07:00
```bash
2019-08-06 07:03:48 -07:00
fluuxmpp send to@example.org "Hello World!" --jid bot@example.org --password secret --addr example.com:5222;
2019-07-16 15:31:33 -07:00
```