[Tools-discuss] Zulip Trial & the IETF

Tim April <ietf@tapril.net> Wed, 23 December 2020 20:11 UTC

Return-Path: <ietf@tapril.net>
X-Original-To: tools-discuss@ietfa.amsl.com
Delivered-To: tools-discuss@ietfa.amsl.com
Received: from localhost (localhost [127.0.0.1]) by ietfa.amsl.com (Postfix) with ESMTP id 79CEB3A09E0 for <tools-discuss@ietfa.amsl.com>; Wed, 23 Dec 2020 12:11:46 -0800 (PST)
X-Virus-Scanned: amavisd-new at amsl.com
X-Spam-Flag: NO
X-Spam-Score: -1.899
X-Spam-Level:
X-Spam-Status: No, score=-1.899 tagged_above=-999 required=5 tests=[BAYES_00=-1.9, HTML_MESSAGE=0.001, RCVD_IN_MSPIKE_H2=-0.001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001, URIBL_BLOCKED=0.001] autolearn=ham autolearn_force=no
Received: from mail.ietf.org ([4.31.198.44]) by localhost (ietfa.amsl.com [127.0.0.1]) (amavisd-new, port 10024) with ESMTP id sHL2ZIFuD0Qz for <tools-discuss@ietfa.amsl.com>; Wed, 23 Dec 2020 12:11:44 -0800 (PST)
Received: from mail-qv1-f48.google.com (mail-qv1-f48.google.com [209.85.219.48]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by ietfa.amsl.com (Postfix) with ESMTPS id 13D093A09D6 for <tools-discuss@ietf.org>; Wed, 23 Dec 2020 12:11:43 -0800 (PST)
Received: by mail-qv1-f48.google.com with SMTP id bd6so317312qvb.9 for <tools-discuss@ietf.org>; Wed, 23 Dec 2020 12:11:43 -0800 (PST)
X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:subject:date:message-id:mime-version; bh=ygfhL+65j+4qEFVbFm+keI+OShnzDhH5l+czMQ/uChI=; b=WkhYclvekHqm2xDH2bXqLHJzZUku2qLnJQ1r0D7IMtMzdgsEJRnaCJf4EkD5OmVc1t wCM/x1eCEMRHhWUiLv2ZZSfVrF+maJA6QjFcObci+DKYjbIG6dFP0oe2udgkNgmhYcSF ljeLTWu5dpXqyw7p26MZrigKru1E4cHY3eVklrjQlDz2zWI3uaXbVwC0NsMJG3y6zDBB AJQKfUSuHxVOtUTMsh7mUKXUrnKN6FFxsjn2nWFhnRKh32MT9Bur52x5YtB4OrmvLXfH WElyzkfPa6VcNxsQ7Xs6oTPiL4xNVhHhSIEywbrcY/KwvJ06e8gn1Dnm1uWKJIRZJHMW nrnw==
X-Gm-Message-State: AOAM530xINBjiqjOt7MaeSyNICykzWgKLs/Y6blmwbJ48Yq99+FvlIUp Hug93NwQpuXv1ovXYUjf5wWBju9/1/t/hQ==
X-Google-Smtp-Source: ABdhPJyKV3bHS5V+xN7T9DXprc5ClfpFIX4qbFjZuIHa4wmXSKZXf3IwS1FklZzxOnCzRbzaIf5ptA==
X-Received: by 2002:a0c:c583:: with SMTP id a3mr28285687qvj.15.1608754302035; Wed, 23 Dec 2020 12:11:42 -0800 (PST)
Received: from [172.19.45.128] (g2001-4878-8037-0100-0000-0000-0000-0109.deploy.static.akamaitechnologies.com. [2001:4878:8037:100::109]) by smtp.gmail.com with ESMTPSA id i27sm10619033qkk.15.2020.12.23.12.11.41 for <tools-discuss@ietf.org> (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Wed, 23 Dec 2020 12:11:41 -0800 (PST)
From: Tim April <ietf@tapril.net>
To: tools-discuss@ietf.org
Date: Wed, 23 Dec 2020 15:11:40 -0500
X-Mailer: MailMate (1.13.1r5676)
Message-ID: <957DBF5D-FC38-4E73-93A4-AEE93CF012AB@tapril.net>
MIME-Version: 1.0
Content-Type: multipart/alternative; boundary="=_MailMate_CBE7D70B-C482-4126-B71B-2D66CA9D8300_="
Archived-At: <https://mailarchive.ietf.org/arch/msg/tools-discuss/WAvOx6dkPKu-UanUYtzeNhGjydg>
Subject: [Tools-discuss] Zulip Trial & the IETF
X-BeenThere: tools-discuss@ietf.org
X-Mailman-Version: 2.1.29
Precedence: list
List-Id: IETF Tools Discussion <tools-discuss.ietf.org>
List-Unsubscribe: <https://www.ietf.org/mailman/options/tools-discuss>, <mailto:tools-discuss-request@ietf.org?subject=unsubscribe>
List-Archive: <https://mailarchive.ietf.org/arch/browse/tools-discuss/>
List-Post: <mailto:tools-discuss@ietf.org>
List-Help: <mailto:tools-discuss-request@ietf.org?subject=help>
List-Subscribe: <https://www.ietf.org/mailman/listinfo/tools-discuss>, <mailto:tools-discuss-request@ietf.org?subject=subscribe>
X-List-Received-Date: Wed, 23 Dec 2020 20:11:47 -0000

Hello IETFers. As the chat system trials continue, I figured I would add 
my thoughts on how the Zulip service might fit into existing IETF work 
flows. If there are any comments / questions / suggestions about zulip 
or the text below, please let me know. (I have also posted this text to 
the Zulip trial server 
[here](https://zulip-trial1.ietf.org/#narrow/stream/19-trial1-feedback/topic/Zulip.20Trial.20.26.20the.20IETF/near/15457))

Thanks,

--tim

## Overview of Zulip

First, if you're new to Zulip, I would recommend reading the [Getting 
Started with Zulip (~300 
words)](https://zulip-trial1.ietf.org/help/getting-started-with-zulip) 
documentation found on the Zulip trail server. This is a quick intro 
written by the Zulip developers and some of its users. I would also 
suggest going a little deeper into the documentation, specifically 
reading about [Streams and Topics (~300 
words)](https://zulip-trial1.ietf.org/help/about-streams-and-topics), 
which covers the Zulip conversation model.

The most important difference, in my opinion, between Zulip and most of 
the other popular chat systems is their conversation model. With most 
systems, like Slack, Matrix or even XMPP, conversations are separated 
into channels, rooms or chat rooms respectively. For some of the newer 
chat systems, threads have been added to conversations as an after 
thought, but in Zulip, threading was an initial design feature so the 
system was built to support threading, in a similar way to email.

Zulip started out as a web based re-implementation of 
[Zephyr](https://en.wikipedia.org/wiki/Zephyr_(protocol)) to allow 
better separation topics within a conversation, very similar to how 
there are threads within a mailing list.

As Zulip has grown over the years since it was introduced, the threading 
model has remained nearly the same, and in the 6 years I have been an 
active user, I have found that it helps quite a bit with focusing on the 
topics I need to focus on while letting me go back and review other 
conversations as I have time.

## Proposed use of Topics

Since the new chat system trials have started, I have spent some time 
thinking about how the IETF might make use of Zulip if it were to be 
selected as the replacement for XMPP. Below are my thoughts on how 
conversations might happen in the tool. It is important to note that the 
way conversations happen in Zulip tend to drift towards a set of roughly 
agreed on norms rather than any hard and fast rules.

### Working Group Use

For each working group, I would think that it would start out with two 
Zulip streams, one would be for the mailing list mirror and the other 
would be for other discussions like what exists in XMPP right now.

For the mail mirror, I would imagine that this stream would be set up to 
receive messages from each of their respective mailings lists. As an 
example, in the trial system, the stream named "list:dnsop" receives any 
messages to dnsop@ietf.org.

Additionally, another stream would be setup for discussion within a 
working group which might just be the working group name like "dnsop". 
In the working group stream, conversations about current work could take 
place with its own topic in the stream for each piece of work.

In addition to using public streams, a private stream could be employed 
to allow working group chairs to communicate with each other. Depending 
on their work flows, the working group chairs may wish to have their 
mailing list(s) copied directly into Zulip, or to just use the system as 
a chat replacement.

It is also worth noting that additional streams could be used to further 
separate some work items, such as focused work on a particular draft. In 
the case where a draft has its own stream, there might be different 
topics for each work item that is open for the draft. If the draft is 
using GitHub, there might be a conversation in the stream for each of 
the GitHub issues to better separate each of the conversations.

Speaking of GitHub, Zulip does have an extensive set of 
[integrations](https://zulip-trial1.ietf.org/integrations/), including 
GitHub which can send all sorts of events directly into Zulip as changes 
happen to the repository.

### Non Working Group Lists

Like working group use, non-working group lists can have similar 
integrations using the "list:" prefix for the email mirror and then a 
separate stream for chat based discussions.

## Archiving

One concern that might come up is archiving messages sent to Zulip, 
similar to how all email messages are archived. There is a 
[zulip-archive](https://github.com/zulip/zulip-archive) tool maintained 
by the Zulip developers which can export all messages in public streams 
to a HTML format for archiving. Other alterations to this tool could be 
made to archive directly into the mail archive maintained by the tools 
team if it would seem valuable.