A weechat relay client built with React Native using Expo. Heavily inspired by weechat-android.
Binary packages are distrubited via TestFlight for iOS users. Join the beta test group here: https://testflight.apple.com/join/0jFsQpot.
Binary packages are not built for Android. However, the project can be built locally and easily installed on a device.
All examples below uses example.com
as hostname, and 9001
as port number, but you should of course replace them with your own values as needed.
/relay add weechat 9001
/set relay.network.password <your secret password>
Note that WeechatRN requires the relay to be configured with the "weechat" protocol, not the "irc" protocol.
It is recommended to front the relay with a webserver to provide TLS termination. This can easily be done with nginx or other webservers.
Example nginx.conf
which exposes /weechat
on example.com
with TLS:
http {
# ...
server {
listen 443 ssl http2;
server_name example.com;
ssl_certificate cert.pem;
ssl_certificate_key cert.key;
ssl_session_cache shared:SSL:1m;
ssl_session_timeout 5m;
ssl_ciphers HIGH:!aNULL:!MD5;
ssl_prefer_server_ciphers on;
location /weechat {
proxy_pass http://localhost:9001/weechat;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "Upgrade";
proxy_read_timeout 604800;
proxy_set_header X-Real-IP $remote_addr;
}
}
}
Fill in the hostname and password fields with the appropriate values. Check the SSL box if weechat is fronted with a proxy that supports it or if a SSL relay is configured in weechat itself.
Note that /weechat
will be appended to the configured hostname. The path suffix is not configurable. However, the hostname may also contain a path. For example, if you have exposed the weechat WebSocket at https://example.com/~user/weechat
, simply enter example.com/~user
as the hostname, and check the SSL box. Do not include the scheme (https://
) in the hostname field.
Push notifications can be sent to WeechatRN for private messages and highlights with the use of a helper script.
To install the script, download weechatrn.py to weechat's python/autoload
directory. This directory may reside in ~/.weechat
or ~/.local/share/weechat
, depending on your setup.
Once downloaded, load the script via /python load weechatrn.py
.
On (re)connect, WeechatRN will store a token in weechat, which will be used to send push notifications to the device.
By default, push notifications will be sent for all highlights and private messages. You can disable notifications for the current buffer with /set plugins.var.python.WeechatRN.notify_current_buffer off
.
# Install dependencies for project
npm install
# Launch Expo
npm start
On your device, scan the QR code with the Camera app (iOS) or the Expo Client (Android).