IRC bouncer
Du kan inte välja fler än 25 ämnen Ämnen måste starta med en bokstav eller siffra, kan innehålla bindestreck ('-') och vara max 35 tecken långa.
Causal Agent db3433432b
Refactor filterUserhostInNames
1 timme sedan
rc.d Set up /var/run/calico and /usr/local/etc/pounce 1 vecka sedan
.gitignore Revert "Test getopt_config" 1 dag sedan
Darwin.mk Assume LibreSSL from brew on Darwin 1 vecka sedan
LICENSE Change license to GPLv3 1 vecka sedan
Linux.mk Use -l:filename in Linux.mk 6 dagar sedan
Makefile Revert "Test getopt_config" 1 dag sedan
README.7 Add capsicum note to README 2 dagar sedan
bounce.c Rename listen to local 3 dagar sedan
bounce.h Filter userhost-in-names 2 dagar sedan
calico.1 Document calico service configuration 6 dagar sedan
client.c Refactor filterUserhostInNames 1 timme sedan
compat.h Fix compat.h for #defined strlcpy 6 dagar sedan
config.c Revert "Test getopt_config" 1 dag sedan
dispatch.c Declare more missing functions and deal with lack of SO_NOSIGPIPE 1 vecka sedan
local.c Rename listen to local 3 dagar sedan
pounce.1 Add userhost-in-names to manual 2 dagar sedan
ring.c Change license to GPLv3 1 vecka sedan
server.c Change license to GPLv3 1 vecka sedan
state.c Filter invite-notify 2 dagar sedan

README.7

README(7)          FreeBSD Miscellaneous Information Manual          README(7)

NAME
     pounce – IRC pouncer :3

DESCRIPTION
     pounce is a multi-client, TLS-only IRC bouncer.  It takes a simple
     approach, using a multiple-consumer ring buffer and the IRCv3.2
     server-time extension to communicate with clients.

     pounce requires LibreSSL (-ltls) and targets FreeBSD.  It can also be
     built on Darwin or GNU/Linux by copying the appropriate file to config.mk
     and modifying as needed.  On FreeBSD, processes are sandboxed with
     capsicum(4).  On other systems, who knows what might happen?

RATIONALE
     As a former znc(1) user, I was dissatisfied with the multi-client
     experience it offered.  I wanted to connect from both my laptop and my
     phone and have full chat history on both.  With znc(1), my options were
     either having both clients spammed with redundant history every time they
     connect, or having one client consume the buffer and the other get no
     history at all.

     With a multiple-consumer ring buffer, each client has its own place in
     the history and can be brought up to date independently.  Additionally,
     by expecting clients to implement the server-time extension, all events
     can be accurately replayed, rather than being limited to messages.

FILES
     bounce.h    declarations and common functions
     bounce.c    configuration and event loop
     local.c     local server binding
     server.c    remote server connection
     client.c    remote client connections
     state.c     state shared between clients
     ring.c      buffer between server and clients
     config.c    getopt_long(3)-integrated configuration parsing
     dispatch.c  SNI socket dispatch
     compat.h    compatibility with lesser operating systems
     rc.d/       FreeBSD rc(8) scripts

SEE ALSO
     calico(1), pounce(1)

Causal Agency                  November 10, 2019                 Causal Agency