This page outlines opportunities for people who want to contribute to the Hubs project. We welcome external contributions that align with the project's mission around enabling collaboration and communication through shared 3D spaces. You can find information about how to contribute to Hubs and the supporting projects that make up the platform here.
Contributors are expected to abide by the project's Code of Conduct and to be respectful of the project and people working on it.
The following GitHub projects are part of the Hubs platform and governed by these contributing guidelines:
- https://github.com/mozilla/hubs/ - the core Hubs project
- https://github.com/mozilla/spoke - 3D editor for creating scenes
- https://github.com/mozilla/janus-plugin-sfu - networking
- https://github.com/mozilla/reticulum - server infrastructure for Hubs
- https://github.com/mozilla/hubs-ops - operations infrastructure for Hubs
- https://github.com/MozillaReality/hubs-discord-bot - Hubs' Discord integration
We are happy to receive contributions to the Hubs platform in a number of different ways as outlined below. Please note that all contributions are subject to approval by the project maintainers. We ask (but do not require) that those interested in contributing to Hubs consider joining the public Hubs Discord chat server to connect with the dev team, ask questions, and view discussions about work being done on the project.
💻 Code Contributions
Hubs has a client-server architecture that gives multiple users the ability to connect to a shared room on the server. If you are interested in contributing to the Hubs client, follow the instructions in the Readme to get started. If you want to contribute to the networking or infrastructure, consider looking at the reticulum or Janus repositories. If you are interested in working on the code for Spoke, the 3D editor used to create custom environments for Hubs rooms, explore the Spoke repository.
For more information on the inner workings of Hubs and the architectural decisions behind the project, check out this presentation on the Mozilla Hubs Code Base by Engineering Lead Greg Fodor.
Issues that are open are tagged. If you explore a bug or feature request that you'd like to fix, make a comment on the case so we know you're looking into it! We try to use the 'good first issue' tag to identify some cases that may be easier than others to begin with as you get started with the code base.
Steps to contributing code to the Hubs project:
- Clone the repo you want to contribute to and get things running locally
- Find an issue or improvement that you want to fix - give us a heads up that you're working on it by dropping in a comment on the issue.
- Fix the bug! Test out your changes on your local setup and let us know if you have questions or want another opinion about the fix.
- Submit your PR for a code review and someone from the team will take a look and give feedback. Make sure you follow up! We'll close the PR if it seems like you've abandoned it by not responding to any questions or comments we leave in the review. If your PR adds a new feature, consider requesting the 'What's New' tag. With the 'What's New' tag, any text in the main body of the PR up to (and including) an image will be added to the Hubs website. Gifs are especially appreciated! This pull request shows an example of how the 'What's New' tag can be used.
- Celebrate! 🎉 You're helping Mozilla's mission to make the web an open and accessible place for social experiences!
🐛Filing Issues and Feature Requests
Reporting bugs, feature requests, and questions that you have about the platform helps the team prioritize the work that we're doing and make Hubs better! We welcome user-submitted issues and use GitHub's built-in issue tracking for our bug reporting process.
If you are filing a bug, please include information about the operating system, device, and browser that you were using when you saw the bug. Example: Seen on Windows 10 with Firefox 66.0.5 on Oculus Rift
The more detail the better! If you are able to reproduce a bug on multiple different browsers or on both desktop and mobile, that information is helpful for us to know about
Screenshots when appropriate are much appreciated 📷
We will do our best to respond to and tag inbound issues as they are submitted in a timely manner. Bugs will be prioritized according to the following table:
|P0||Needs immediate attention. Affects many users and their ability to use core product functionality of connecting to rooms with other users.||No one can enter any Hubs rooms with any VR headset|
|P1||Address as quickly as possible. Affects many users and their ability to use a common product feature. Workaround is difficult or unavailable.||Teleporting doesn't work for users on Quest with the Oculus browser.|
|P2||Address when able. Affects some users regularly but mildly, or is a hard-to-repro failure seen rarely that is fixed with an easy workaround.||Lobby camera in Camera mode does not show emojis shared from iOS. |
One user reports getting disconnected after ten minutes in a particular room, but no one else experiences it and they are able to refresh to re-enter.
|P3||Address when able after P2 bugs are fixed. Affects a small set of users inconsistently in a non-breaking way with an easy workaround.||Every so often, a standalone VR headset will show up as a mobile phone in the user list. Refreshing fixes it.|
🎨 3D Art
If you are a 3D artist and want to support what we're doing with Hubs, consider creating and releasing content under a Creative Commons license or creating scenes using the Spoke web editor and releasing them as remixable environments. Content with low polygon counts that are optimized to run well on the web are much appreciated! In particular, we'd love to see scenes that capture a wide range of experiences.
Our documentation for Hubs is hosted on the GitHub Hubs Wiki section of the project. The documentation for Spoke is hosted on the GitHub Spoke Wiki For contributing corrections or additional pages for the Wiki, please file an issue as a suggestion in the corresponding repository with your proposed content and we will review it and add it to the wiki when all looks good!
Hubs is currently en-US only, but if you would like to work with us on localization efforts, submit a suggestion through the GitHub issues and we'll work with you from there.
🦆 General Help
We believe in the power of community (that's why we're building this, after all!) and know that not all forms of support will come from something outlined here. Feel free to jump into our public Discord chat server to chat with us and ask about how you can get involved! See our help page for other ways to contact us.