# Contributing First of all, thank you for contributing to AppFlowy Cloud! The goal of this document is to provide everything you need to know in order to contribute to AppFlowy Cloud and its different integrations. - [Assumptions](#assumptions) - [How to Contribute](#how-to-contribute) - [Development Workflow](#development-workflow) ## Assumptions 1. **You're familiar with [GitHub](https://github.com) and the [Pull Request](https://help.github.com/en/github/collaborating-with-issues-and-pull-requests/about-pull-requests)(PR) workflow.** 2. **You know about the [AppFlowy community](https://discord.gg/9Q2xaN37tV"). Please use this for help.** ## How to Contribute Contributions are welcome! Here's how you can help improve AppFlowy Cloud: 1. Identify or propose enhancements or fixes by checking [existing issues](https://github.com/AppFlowy-IO/AppFlowy-Cloud/issues) or [creating a new one](https://github.com/AppFlowy-IO/AppFlowy-Cloud/issues/new/choose). 2. [Fork the repository](https://help.github.com/en/github/getting-started-with-github/fork-a-repo) to your own GitHub account. Feel free to discuss your contribution with a maintainer beforehand. 3. [Create a feature or bugfix branch](https://help.github.com/en/github/collaborating-with-issues-and-pull-requests/creating-and-deleting-branches-within-your-repository) in your forked repo. 4. Familiarize yourself with the [Development Workflow](#development-workflow) for guidelines on maintaining code quality. 5. Implement your changes on the new branch. 6. [Open a Pull Request (PR)](https://help.github.com/en/github/collaborating-with-issues-and-pull-requests/creating-a-pull-request-from-a-fork) against the `main` branch of the original AppFlowy Cloud repo. Await feedback or approval from the maintainers. ## Development Workflow To get the server running locally, execute: ```bash ./build/run_local_server.sh ``` Ensure functionality by executing the test suite: ```bash cargo test ``` For a pull request (PR) to be considered, it must: - Pass all tests. - Adhere to [`clippy`](https://github.com/rust-lang/rust-clippy) linting standards: ```bash cargo clippy -- -D warnings ``` If `clippy` is not installed: ```bash rustup update rustup component add clippy ``` - Comply with the code formatting rules. To format your code: ```bash cargo fmt ``` To check formatting: ```bash cargo fmt --all -- --check ```