bridge_with_irc: Add command line arg to specify stream.
This commit is contained in:
parent
ed6c797d19
commit
a5bc4b716c
|
@ -15,11 +15,13 @@ import traceback
|
||||||
if False:
|
if False:
|
||||||
from typing import Any, Dict
|
from typing import Any, Dict
|
||||||
|
|
||||||
usage = """./irc-mirror.py --irc-server=IRC_SERVER --channel=<CHANNEL> --nick-prefix=<NICK> [optional args]
|
usage = """./irc-mirror.py --irc-server=IRC_SERVER --channel=<CHANNEL> --nick-prefix=<NICK> --stream=<STREAM> [optional args]
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
|
|
||||||
./irc-mirror.py --irc-server=127.0.0.1 --channel='#test' --nick-prefix=username
|
./irc-mirror.py --irc-server=127.0.0.1 --channel='#test' --nick-prefix=username --stream='test'
|
||||||
|
|
||||||
|
--stream is a Zulip stream.
|
||||||
|
|
||||||
Specify your Zulip API credentials and server in a ~/.zuliprc file or using the options.
|
Specify your Zulip API credentials and server in a ~/.zuliprc file or using the options.
|
||||||
|
|
||||||
|
@ -35,6 +37,7 @@ if __name__ == "__main__":
|
||||||
parser.add_argument('--port', default=6667)
|
parser.add_argument('--port', default=6667)
|
||||||
parser.add_argument('--nick-prefix', default=None)
|
parser.add_argument('--nick-prefix', default=None)
|
||||||
parser.add_argument('--channel', default=None)
|
parser.add_argument('--channel', default=None)
|
||||||
|
parser.add_argument('--stream', default="general")
|
||||||
|
|
||||||
options = parser.parse_args()
|
options = parser.parse_args()
|
||||||
# Setting the client to irc_mirror is critical for this to work
|
# Setting the client to irc_mirror is critical for this to work
|
||||||
|
@ -52,5 +55,5 @@ if __name__ == "__main__":
|
||||||
parser.error("Missing required argument")
|
parser.error("Missing required argument")
|
||||||
|
|
||||||
nickname = options.nick_prefix + "_zulip"
|
nickname = options.nick_prefix + "_zulip"
|
||||||
bot = IRCBot(zulip_client, options.channel, nickname, options.irc_server, options.port)
|
bot = IRCBot(zulip_client, options.stream, options.channel, nickname, options.irc_server, options.port)
|
||||||
bot.start()
|
bot.start()
|
||||||
|
|
|
@ -11,11 +11,12 @@ def zulip_sender(sender_string):
|
||||||
return nick + "@" + IRC_DOMAIN
|
return nick + "@" + IRC_DOMAIN
|
||||||
|
|
||||||
class IRCBot(irc.bot.SingleServerIRCBot):
|
class IRCBot(irc.bot.SingleServerIRCBot):
|
||||||
def __init__(self, zulip_client, channel, nickname, server, port=6667):
|
def __init__(self, zulip_client, stream, channel, nickname, server, port=6667):
|
||||||
# type: (Any, irc.bot.Channel, str, str, int) -> None
|
# type: (Any, str, irc.bot.Channel, str, str, int) -> None
|
||||||
irc.bot.SingleServerIRCBot.__init__(self, [(server, port)], nickname, nickname)
|
irc.bot.SingleServerIRCBot.__init__(self, [(server, port)], nickname, nickname)
|
||||||
self.channel = channel # type: irc.bot.Channel
|
self.channel = channel # type: irc.bot.Channel
|
||||||
self.zulip_client = zulip_client
|
self.zulip_client = zulip_client
|
||||||
|
self.stream = stream
|
||||||
|
|
||||||
def on_nicknameinuse(self, c, e):
|
def on_nicknameinuse(self, c, e):
|
||||||
# type: (ServerConnection, Event) -> None
|
# type: (ServerConnection, Event) -> None
|
||||||
|
@ -62,7 +63,7 @@ class IRCBot(irc.bot.SingleServerIRCBot):
|
||||||
def on_pubmsg(self, c, e):
|
def on_pubmsg(self, c, e):
|
||||||
# type: (ServerConnection, Event) -> None
|
# type: (ServerConnection, Event) -> None
|
||||||
content = e.arguments[0]
|
content = e.arguments[0]
|
||||||
stream = e.target
|
stream = self.stream
|
||||||
sender = zulip_sender(e.source)
|
sender = zulip_sender(e.source)
|
||||||
if sender.endswith("_zulip@" + IRC_DOMAIN):
|
if sender.endswith("_zulip@" + IRC_DOMAIN):
|
||||||
return
|
return
|
||||||
|
|
Loading…
Reference in a new issue