The Joystream Community Repo is meant both as a resource for the community members of the Joystream project, and a place to submit their work or contributions.
If a KPI requires submitting a deliverable, eg. reports or some code, it is expected that a PR is made to this repo in order to qualify.
Although the community is meant to control the repo, Jsgenesis will approve and merge any pull requests for now. Note that the repo is licensed under GPLv3.
The workflow for changing the repo depends on the reason and purpose behind the change. A consistent part is for the contributor to fork the repo, and create a pull request to the applicable branch. All changes need to be approved with a proposal, except for selected files.
When a KPI requires a deliverable to be successful, the following steps must be made:
- A pull request is made to the master branch.
- A proposal is made to the Joystream testnet.
- The proposal (
Text
, or in some cases,Spending
) contains a link to the PR and other relevant information - When (if) the proposal is voted through, @bwhm and @blrhc is tagged
- The time of the latest commit will be used as the time of submission
- The proposal (
- The PR is reviewed, and as long as it does not contain anything malicious or does not comply with license, it is merged.
- The submission is added to the
Submission Log
If the deliverable is made by an individual, eg. for an existing or upcoming funding proposal, the following steps must be made:
- A pull request is made to the community branch, in a new folder within the
Community Contributions
directory.- Example:
Bot project - Author Name
- Example:
- A proposal is made to the Joystream testnet.
- The proposal (
Text
, or in some cases,Spending
) contains a link to the PR and other relevant information. - When (if) the proposal is voted through, @bwhm and @blrhc is tagged
- The proposal (
- The PR is reviewed, and as long as it does not contain anything malicious or does not comply with the license of the repo, it is merged.
- The submission is added to the
Submission Log
If a member of the Jsgenesis team wants to make changes to the repo, the following steps must be taken:
- A pull request is made to the master branch
- A
Text
proposal is made to the Joystream testnet.- The proposal contains a link to the PR and other relevant information
- When (if) the proposal is voted through, the PR is merged.
- The submission is added to the
Submission Log
- For general updates (updating links, text) these can just be gathered occasionally and submitted as a rolling update like this example: https://testnet.joystream.org/#/proposals/14 This does mean that it will take some time for the PRs to be approved by the council.
- In the event of some highly important change, a proposal could be made so that the matter is addressed more quickly than waiting for a rolling update
- If users want to be paid for updates or corrections, then they should open a PR (or multiple PRs) and link to it in a spending proposal, when this is approved it would have the same effect as approving the PR (which still has to be reviewed by Jsgenesis)
- As an example, if a user wants to add functionality to the telegram bot and be paid for it, they can open a PR and create a spending proposal linking to the PR