Hi 👋
We're happy that you'd like to contribute to this project. The following guide will help you get started.
Run the following command in the repository root
yarn install
yarn build:all
There are also build scripts for individual packages in case you don't need to build everything.
This repository contains multiple packages. Depending on your contribution you'll need to run some of these. Please refer to the package overview to understand which are the relevant packages for you.
Each package has the necessary scripts inside the root package.json
file.
Please note that some packages could require extra setup steps:
- please check the README of each package as well
- please check for
.env-example
files that show you how to create a local.env
file for the given package to hold credentials
- Don't forget to update the documentation
- If you need to update tutorials, don't forget to also update the relevant codesandboxes as well (in case we have one)
- Don't forget to update relevant sample apps located in
sample-apps/react
- Don't forget to update the documentation // TODO
- Don't forget to add/update unit and/or integration tests
- Documentation for the Node.js client lives in the protocol repository, don't forget to update that
To update SFU models and API endpoints generate ts client and copy the files to the packages/client/src/gen
folder.
We have a shell script which will generate the Coordinator models from the OpenAPI spec. This script expects the following directory structure to be set up:
chat
- thechat
repositorystream-video-js
- current repositorycd stream-video-js/packages/client && yarn generate:open-api:dev
Alternatively you can use the following script cd stream-video-js/packages/client && yarn generate:open-api
to generate the models from the protocol repository.
- CI checks are running on PRs, please pay attention to them, and fix issues in case an action fails
- Many sample applications are deployed to a preview environment, you can check your changes there as well, check the relevant action's output for links (some applications are internal, and only available to Stream developers)
- (internal) documentation is deployed to the staging docs site, you can check your changes there as well
Commits to main
will trigger the following CI steps:
- Version and release all changed packages
- The new version is calculated for each package automatically based on conventional commits
- The release configuration for each public package can be found in the
packages/<package name>/project.json
file - For more information checkout the documentation of the release tool we are using
- Known issue about the release process
- Documentation is deployed to the production site. An exception is the Node.js documentation, which needs to be deployed separately (see Client section for more details).
- All relevant sample apps are deployed