Is it possible to run a conference using only free software?

Shifting from IRL to digital on a tight timeline with the help of free software; how we did it and lessons learned for next time.
91 readers like this.
Working from home at a laptop

Opensource.com

The Free Software Foundation's (FSF) annual conference LibrePlanet went fully virtual in 2020 due to ongoing issues caused by the coronavirus pandemic. In our last week of preparations before the live event, increasingly disturbing news related to the virus made us realize we could not responsibly hold our usual conference on software freedom in person while protecting the safety of our participants and their communities. So we turned everything around to eventually bring 35 free software presentations to our community through the filter of a computer screen. After the conference, we had many people writing to ask us for more details about what we used to do it, so we wanted to take this opportunity to share how we were able to create a fully free interactive and educational virtual experience for the first time, but likely not the last.

LibrePlanet 2020 videos were recorded from the live stream and have been posted online for everyone to enjoy. For the sessions not entirely dependent on visual information from slides, we also provide the audio over an RSS (Atom) feed for anyone to listen to while they exercise, bake, garden, or otherwise seek distraction from stressful times.

HUBAngl and Icecast

Because our community is an international one, we have been streaming our event online for years using entirely free software. Thankfully, the tech team could build on this experience to make sure that we delivered a smooth online conference. Previously, we used HUBAngl, which was developed specifically for LibrePlanet, by Free Software Foundation (FSF) intern David Teste. It fetches audio and/or video input streams, and then streams to the Icecast streaming server. The streams that are broadcasted and stored can be audio-only, video-only, or both at once.

Gstreamer and Jitsi

In 2016, we gained some live streaming experience when we interviewed Edward Snowden live from Moscow. To minimize the risk of failed recordings due to overly complex or error-prone software systems, we made it a priority to achieve a pipeline with low latency, good image quality, and low CPU usage. The application we used then was Jitsi Meet, and the tech info and scripts we used for streaming from 2016 are available for your information and inspiration.

Using Ansible for multimedia reliability

Naturally, for this year, with no time for researching other applications, we opted to build on our experience with Jitsi Meet. We hosted our own instance for remote speakers to connect to and enter a video call with the conference organizers. A screen capture of this call was then simultaneously recorded by the FSF tech team and streamed out to the world over Gstreamer and Icecast.

To bypass recommendations of nonfree services or software, some parts of the Jitsi Meet configuration were set up differently with Ansible, rather than as suggested. In the days following the conference, we have already improved the script we used for streaming your screen or window, and it is free for you to use and adapt.

At the time of the conference, it was still considered safe to have a small number of people together, so we were able to have some of our staff and volunteers in the office. Speakers called into a dedicated digital conference room for their session, where they were assisted by a room monitor and a tech team member who coordinated the session together. The call was received on a local monitor in the office. Our three digital conference rooms all had similar streaming setups, with the local monitor being broadcast through Gstreamer to Icecast. The desktops used were ASUS KGPE-D16 motherboards with Libreboot; this hardware has previously also been certified under the Respects Your Freedom (RYF) certification program.

When everyone was ready, and everything worked, they would start the stream. All speakers were asked to deliver their slides in advance. That way, if a presenter had trouble sharing their screen with Jitsi Meet, the slides could be loaded from the FSF server and controlled by the tech team member in charge of coordinating that digital conference room instead. In some exceptional cases, like major time differences or panel coordination challenges, the talk was pre-recorded. If so, it was played locally on the machine with the MPV video player.

Interactivity

We hosted interactive IRC sessions on the Freenode network. In addition to a private channel to communicate directly with the speakers about technical issues, we had a general #libreplanet channel, and additional channels for every conference "room." In these rooms, the speakers connected directly to the audience to field questions and join the conversation. We enlisted volunteers to monitor the rooms for safe space policy issues, but the audience was so great and enthusiastic that we did not have a single issue!

Breakout rooms and hallway tracks

Each year at LibrePlanet, we've facilitated a self-organized meeting of associate members who discuss the FSF's work and opportunities and share their feedback and ideas with us afterward. We didn't want to miss out on this year's feedback, so we moved the member meeting online as well. This required more conversational communication and note-taking, so we opted for a combination of Etherpad for note-taking and written feedback, Mumble for voice communication, and the use of the dedicated IRC channel.

Issues and improvements

We had only a week to select and optimize our streaming setup, but the experience itself taught us a lot. If given the opportunity, or for those of you now bringing your event online, some things we would do differently are:

  • We would set up a continuous stream and insert the session into it; this would relieve the need to refresh between sessions and improve the viewer experience.
  • It is important to notify speakers of bandwidth used by the streaming. Make sure they test their connection or have dedicated Internet lines. This is especially important with the international connections, as they showed to be more unreliable than local connections; this presented itself mostly via connection issues and difficulties with sharing the presentation screen.
  • For a better experience for people on the move, or to experience the event via mobile, we advise the deployment of audio-only feeds and a lower bandwidth alternative feed for the videos.
  • The FSF tech team is currently experimenting with Big Blue Button and Canvas for interactive streaming that allows for video, slide sharing, and instant chat. We will post in more detail about our work with these applications soon; they are worth considering if you are planning a conference, interactive video session, or online meeting.

Free software tech conferences

Hosting your conference freely is absolutely possible. You do not have to compromise freedom when you want to connect to your community, and you most certainly do not have to settle for proprietary software to help you communicate.

If you have an upcoming event and are interested in a freedom-respecting setup but need a hand, you can email us at info@fsf.org, and we might be able to help. In recent weeks, the FSF technical and campaigns teams have spent a lot of time working on and communicating about free communication tools. And as always, you're welcome to become a member of the FSF itself.

What to read next
User profile image.
Zoë Kooyman is the executive director of the Free Software Foundation, a nonprofit that advocates every computer user's basic right to software that respects their freedom. The FSF is the organizational sponsor of the GNU Project as well as the steward of the GNU General Public License (GPL), the world's most widely used free software license.

5 Comments

Great article and resources. Thanks so much for sharing your experiences.

The only thing we are missing in our setup is an easy voting system, like in the reaction panel of Zoom.
Jitsi does have thumbs up and down, but everyone has to send them into the chat and you have to manually count them.
For all I could find, Jitsi is supposed to have (or had) a polling system, but it either got scraped or is very well hidden. Other than that, sure you can host your own conference with open source software, you just need the hardware

We've been using Jitsi for online meetings. Everything's fine. Doesn't have to complicated.

What did the set-up look like on attendees computers? Was it, for example, Jitsi in a web browser next to an IRC client? Or did you have something that allowed video + chat to all be inside one window?

Jitsi have a chat, so I guess there is no need for something separate, it's already all inside one window.

In reply to by Thomas

Creative Commons LicenseThis work is licensed under a Creative Commons Attribution-Share Alike 4.0 International License.