The primary communication forum for the Zulip community is the Zulip server hosted at chat.zulip.org:
- Users and administrators of Zulip organizations stop by to ask questions, offer feedback, and participate in product design discussions.
- Contributors to the project, including the core Zulip development team, discuss ongoing and future projects, brainstorm ideas, and generally help each other out.
Everyone is welcome to sign up and participate — we love hearing from our users! Public streams in the community receive thousands of messages a week. We recommend signing up using the special invite links for users, self-hosters and contributors to get a curated list of initial stream subscriptions.
To get help in real time, you will have the best luck finding core developers during daylight hours in North America (roughly between 15:00 UTC and 1:00 UTC), but the sun never sets on the Zulip community. Most questions get a reply within minutes to a few hours.
Community norms
Zulip is a friendly and welcoming community, and we love meeting new people, hearing about what brought them to Zulip, and getting their feedback.
Getting started
- Send test messages to #test here or as a PM to yourself to avoid disturbing others.
- Start a new topic unless you’re replying to an existing conversation. If you see a new user talking about something unrelated on an existing topic, move the messages to an appropriate new topic.
- If you’re not sure where to start, introduce yourself and your interests in #new members, using your name as the topic to create a dedicated space.
- Follow the community code of conduct.
Communication style
- Converse informally; there’s no need to use titles like “Sir” or “Madam”.
- Use gender-neutral language. For example, avoid using a pronoun like “her” or “his” in sentences like “Every developer should clean [their] keyboard at least once a week.”
Getting help
- When asking for help, provide the details needed for others to help you. For example, include the full traceback in a code block (not a screenshot), a link to the code or a WIP PR you’re having trouble debugging, etc.
- Ask questions on streams rather than PMing core contributors. You’ll get answers faster since other people can help, and it makes it possible for others to benefit from the discussion.
- Don’t ask the same question in multiple places. Moderators read every public stream, and make sure every question gets a reply.
- Use @-mentions sparingly. Unlike IRC or Slack, Zulip‘s topics make it easy to see what you’re replying to, so you don’t need to mention your conversation partner to make sure they will see or understand your reply. Core contributors will often @-mention someone who asked a question hours earlier to make sure they see the reply, but there is generally no need to @-mention a core contributor unless you need their timely attention.
Where do I send my message?
This section describes popular public streams on chat.zulip.org. Kick off the discussion by starting a new topic in the appropriate stream! Don’t stress too much about picking the right place if you’re not sure; anyone in the community can edit a topic name, and moderators can move a topic to a different stream.
Streams for everyone
- #feedback is for posting feedback on Zulip, including feature requests, things you’d like to see polished, or anything else!
- #issues, #mobile, #desktop, #zulip-terminal and #integrations are the best places to post bug reports or questions about how to do something. Note that #desktop should only be used for issues specific to the desktop app, which shares most of its UI and implementation with the web app.
- Everyone is welcome to introduce themselves in #new members. Posting here with your name as the topic is a great option if you’re uncertain where to start a conversation.
- #test here is for sending test messages without inconveniencing other users :). We recommend muting this stream when not using it.
Streams for Zulip users and administrators
- #user community is for Zulip users to discuss their experiences using and adopting Zulip.
- #production help is for all questions related to self-hosting Zulip.
- #zulip cloud is for all conversations about the Zulip Cloud service.
Streams for code contributors
- #development help is for asking for help with any Zulip server/web app development work (use the app streams #mobile, #desktop, or #zulip-terminal for help working on one of the apps).
- #provision help is for help specifically on setting up the server/web app development environment. #tools is other conversations about the server/web app developer tooling.
- #git help is for help with using Git.
- #code review is for getting feedback on your work. We encourage all developers to comment on work posted here, even if you’re new to the Zulip project; reviewing other PRs is a great way to develop experience, and even just manually testing a proposed new feature and posting feedback is super helpful. Note that GitHub is our primarily system for managing code review.
- #backend, #frontend, #documentation, and app-specific streams (#mobile, etc.) are the right place for general conversations about work in those areas (including design discussions, questions, updates on a project, or anything else).
- #automated testing is primarily used for automated notifications about CI failures, but is also a good place to discuss projects to improve Zulip’s automated testing infrastructure.
- #api design is a low-traffic stream for discussing and coordinating changes to the Zulip API, with all stakeholders present.
Streams for translators
- #translation is for discussing Zulip’s translations.
- Some languages have streams named like #translation/fr and #translation/zh_tw to coordinate translation work for that language.
Streams for anyone spending time in the community
- #announce is our low-traffic stream for project announcements (releases, etc.).
- #checkins is for progress updates on what you’re working on and its status; usually folks post with their name as the topic. Everyone is welcome to participate!
- #design is where we discuss UI and feature design and collect feedback on potential design changes. We love feedback, so don’t hesitate to speak up! Note that #feedback is usually the best place for end users to start a topic about a proposed design change; #design is primarily intended for discussing changes the community is actively working on.
- #discussions is where we do fun community conversations like “Ask Me Anything” Q&A sessions with project members.
- #documentation is where we discuss improving Zulip’s user, sysadmin, API, and developer documentation.
- #general is for all topics of general interest.
- #learning is for posting great learning resources one comes across.
- #off topic is is for occasional conversations not related to Zulip, usually things of general interest to open-source communities.
You can always find the description for the stream you’re reading at the top of the Zulip app.
Anything else to keep in mind?
Don’t try to read everything
Keeping up with everything happening in the Zulip project is both difficult and rarely a useful goal. To make the best use of your time, we highly recommend that you unsubscribe from streams that you aren’t interested in, mute streams that are only of occasional interest, and make use of Zulip’s skimming features, like Recent Topics, to spend your time on conversations that interest you.
Searching for past conversations
To look for previous threads about something, we recommend using the
following search operators:
streams:public <your keyword(s)>.
This will search the full history of all public streams for <your
keyword(s)>, including messages sent before you joined and messages
on public streams you’re not subscribed to.
New features are tested here
We continuously test out new features or ideas on chat.zulip.org before rolling them out to Zulip Cloud or including them in a Zulip Server release (or deciding not to!). Please report in #issues anything you notice that seems broken! It’s likely you’ve found a bug in an upcoming feature.