First of all, thank you for taking the time to read this and your interest in contributing to ownCloud Infinite Scale!
The following is a set of guidelines for contributing to most of the projects hosted in the ownCloud Organization on GitHub. These are mostly guidelines, not rules. Use your best judgment, and feel free to propose changes to this document in a pull request.
For simplicity reasons, this document mostly refers to the ownCloud Infinite Scale project, but it should be easily transferable to other (sub)projects.
I don't want to read this whole thing, I just have a question
What should I know before I get started
- Help spreading the word
- Reporting Bugs
- Suggesting Enhancements
- Your First Code Contribution
- Pull Requests
- Documentation Contributions
- Internationalization
- Deployments: Docker, Ansible and friends
Note: Please don't file an issue to ask a question. You'll get faster results by using the resources below.
For general questions, please refer to ownCloud's FAQs or ask on the ownCloud Central Server.
We also have a Rocket Chat Server to answer your questions specifically about ownCloud Infinite Scale.
To effectively contribute to ownCloud Infinite Scale, you need a Github account. You can get that for free at Github. You can find howtos on the internet, for example here.
For other ways of contributing, for example with translations, other systems require you to have an account as well, for example Transifex.
The ownCloud project follows the strict Github workflow of development as briefly described here.
ownCloud Infinite Scale is largely created by developers who are employed by the ownCloud company, which is located in Germany. It is providing support for ownCloud for customers worldwide. In addition there are engineering partners who also work full time on ownCloud related code, for example in CERN REVA.
Because of that fact, the pace that the development is moving forward is sometimes high for people who are not willing and/or able to spend a comparable amount of time to contribute. Even though this can be a challenge, it should not scare anybody away. Here is our clear commitment that we feel honored by everybody who is interested in our work and improves it, no matter how big the contribution might be.
We as the full time devs from either organization are doing our best to listen, review and consider all changes that are brought forward following this guideline and make sense for the project.
We are very happy that there is no CLA required for most of the code of ownCloud Infinite Scale.
Currently, only for the following components you need to sign a Contributors License Agreement:
Please make sure to read and understand the details of the CLA before starting to invest time on a component that requires it. If you have any questions or concerns please feel free to raise them with us.
There are many ways to contribute to open source projects, and all are equally valuable and appreciated.
This way to contribute to the project can not be overestimated: People who talk about their experience with ownCloud Infinite Scale and help others with that are the key to success of the project.
There are too many ways of doing that to line them up here, but examples are answering questions in ownCloud Central or on ownCloud Talk, writing blog posts etc pp.
There is no formal guideline to this, just do it :-)
This section guides you through submitting a bug report for ownCloud Infinite Scale. Following these guidelines helps maintainers and the community understand your report π, reproduce the behavior π» π», and find related reports π.
Before creating bug reports, please check this list as you might find out that you don't need to create one. When you are creating a bug report, please include as many details as possible. Fill out the required template, the information it asks for helps us resolve issues faster.
Note: If you find a Closed issue that seems like it is the same thing that you're experiencing, open a new issue and include a link to the original issue in the body of your new one. If you have permission to reopen the issue, feel free to do so.
- Make sure you are running a recent version Usually, developers' interest in old versions of software drops very fast once a new shiny version has been released. So the general recommendation is: Use the latest released version or even the current master to reproduce problems that you might encounter. That helps a lot to attract developers attention.
- Determine which repository the problem should be reported in.
- Perform a cursory search with possibly a more granular filter on the repository, to see if the problem has already been reported. If it has and the issue is still open, add a comment to the existing issue instead of opening a new one if you have new information. Please abstain from adding "plus ones", except using the Github emojis. That might indicate how many users are affected.
Bugs are tracked as GitHub issues. After you've determined which repository your bug is related to, create an issue on that repository and provide the following information by filling in the template.
Explain the problem and include additional details to help maintainers reproduce the problem:
- Use a clear and descriptive title for the issue to identify the problem.
- Describe the exact steps which reproduce the problem in as many details as possible. Start with describing, from a user perspective, what you tried to achieve, i.e. "I want to share some pictures with Grandma". When listing steps, don't just say what you did, but explain how you did it. For example, if you uploaded a file to ownCloud, say which client you used, which way of uploading you chose, if the name was special somehow and how big it was.
- Provide specific examples to demonstrate the steps. Include links to files or GitHub projects, or copy/pasteable snippets, which you use in those examples. If you're providing snippets in the issue, use Markdown code blocks.
- Describe the behavior you observed after following the steps and point out what exactly is the problem with that behavior.
- Explain which behavior you expected to see instead and why.
- Include screenshots and animated GIFs which show you following the described steps and clearly demonstrate the problem. You can use this tool to record GIFs on macOS and Windows, and this tool or this tool on Linux.
- If you report a web browser related problem, consider to using the browser's Web developer tools (such as the debugger, console or network monitor) to check what happened. Make sure to add screenshots of the utilities if you are short of time to interpret it.
- If the problem wasn't triggered by a specific action, describe what you were doing before the problem happened and share more information using the guidelines below.
Provide more context by answering these questions:
- Did the problem start happening recently (e.g. after updating to a new version) or was this always a problem?
- If the problem started happening recently, can you reproduce the problem in an older version? What's the most recent version in which the problem doesn't happen? You can find more information about how to set up test environments in the developer documentation.
- Can you reliably reproduce the issue? If not, provide details about how often the problem happens and under which conditions it normally happens.
Include details about your configuration and environment as asked for in the template.
This section guides you through submitting an enhancement suggestion for ownCloud Infinite Scale, including completely new features and minor improvements to existing functionality. Following these guidelines helps maintainers and the community understand your suggestion π and find related suggestions π.
Before creating enhancement suggestions, please check this list as you might find out that you don't need to create one. When you are creating an enhancement suggestion, please include as many details as possible. Fill in the template, including the steps that you imagine you would take if the feature you're requesting existed.
- Check if there's already an extension or other component which provides that enhancement, even in a different way.
- Perform a cursory search to see if the enhancement has already been suggested. If it has, add a comment to the existing issue instead of opening a new one. Feel free to use the Github emojis to indicate that you are in favour of an enhancement request.
Enhancement suggestions are tracked as GitHub issues. After you've determined which repository your enhancement suggestion is related to, create an issue on that repository and provide the following information:
- Use a clear and descriptive title for the issue to identify the suggestion.
- Provide a step-by-step description of the suggested enhancement in as many details as possible.
- Provide specific examples to demonstrate the steps. Include copy/pasteable snippets which you use in those examples, as Markdown code blocks.
- Explain why this enhancement would be useful to most ownCloud users.
- List some other projects or products where this enhancement exists.
Unsure where to begin contributing to ownCloud? You can start by looking through these Needs-help
issues:
- The Good first issue label marks good items to start with.
- Tests needed - issues which would benefit from a test.
- Help wanted issues - issues which should be a bit more involved.
It is fine to pick one of the list following personal preference. While not perfect, number of comments is a reasonable proxy for impact a given change will have.
To find out how to set up ownCloud Infinite Scale for local development please refer to the Developer Documentation. It contains a lot of information that will come in handy when starting to work on the project.
All contributions to ownClouds projects use so called pull requests following the Github PR workflow.
Please follow these steps to have your contribution considered by the maintainers:
- Follow all instructions in the template
- Follow the styleguides where applicable
- After you submit your pull request, verify that all status checks are passing
What if the status checks are failing?
If a status check is failing, and you believe that the failure is unrelated to your change, please leave a comment on the pull request explaining why you believe the failure is unrelated. A maintainer will re-run the status check for you. If we conclude that the failure was a false positive, then we will open an issue to track that problem with our status check suite.
While the prerequisites above must be satisfied prior to having your pull request reviewed, the reviewer(s) may ask you to complete additional design work, tests, or other changes before your pull request can be ultimately accepted.
ownCloud is very proud of the documentation it has, which is the work of a great team of people. Of course, also the documentation is open to contributions.
See the Getting Started Guide on how to get started. Other useful information is summarized in the Documentation Readme.
Our projects are getting translated into many languages to allow people from all over the world to use ownCloud in their native language. For translations, ownCloud uses Transifex as a community based collaboration platform for internationalization.
For contributions please refer to the Transifex Resources to learn how to improve ownClouds translations there.
Depending on the ownCloud component, there is complex deployment tooling to install in various environments. There is for example ownCloud Ansible with Ansible resources. Contributions to that are very appreciated and follow the same guidelines as every other code contribution.
To keep up with a consistent code and tooling landscape, some of the ownCloud modules maintain styleguides for contributions. It is mandatory to follow them in contributions.
- Use the present tense ("Add feature" not "Added feature")
- Use the imperative mood ("Move cursor to..." not "Moves cursor to...")
- Limit the first line to 72 characters or less
- Reference issues and pull requests liberally after the first line
- When only changing documentation, include
[docs-only]
in the commit title
Use the built in golang code formatter before submitting the patch. Also, consulting documentation like Effective Go or Practical Go helps to improve the code quality.
Refer to related documents in the ownCloud Web Repository.
See the ownCloud Documentation Styleguide.
This section lists the labels we use to help us track and manage issues and pull requests. Most labels are used across all ownCloud repositories, but some are specific.
GitHub search makes it easy to use labels for finding groups of issues or pull requests you're interested in. To help you find issues and pull requests, each label can be used in search links for finding open items with that label in the ownCloud repositories.
The labels are loosely grouped by their purpose, but it's not required that every issue has a label from every group or that an issue can't have more than one label from the same group.
The list here contains all the more general categories of issues which are followed by a colon and a specific value. For example severity 1 looks like Severity:sev1-critical
.
Describes the platform the issue is happening on, ie. iOS or Windows.
T-Shirt sizes for effort estimation to fix that bug or implement an enhancement. Ranges from XS to XXXL.
P1 to P4 (lowest) to indicate an priority. Mostly a tool for internal project management and support.
Flags to indicate the internal QA status in terms of process and priority. Please leave alone unless you're QA ;-)
Severity for the product, mostly impact on user.
The issue type, helps to structure the issues in the agile categories (Epic, Story...) but also organizational ones.
A general category of the topic of a ticket.
Categorizes the issue to also indicate the type of the issue.
The status in the ticket life cycle. Keep an eye on that one, especially for the Waiting-for-Feedback
tag which might indicate that the reporter is asked for feedback.
Another label that indicates the type of the issue.
Important for browser dependent web issues. It specifies the browser that shows the error.
Tags issues that were reported by one of the oCIS early adopters, ie. customers and users who start using ownCloud Infinite Scale before it's general availability.