OXID eShop is available under two different licenses, GPLv3 and a commercial license.
That's why, before contributing for the first time, you must sign the Contributor License Agreement. You can find more information about it on the FAQ page OXID Contribution and Contributor Agreement FAQ: https://oxidforge.org/en/oxid-contribution-and-contributor-agreement-faq
First off, you have to fork the repository OXID-eSales/oxideshop_ce to your list of repositories.
You will find the following branches in <github_username>/oxideshop_ce repository:
- master, presently our main branch on this repo, is the so called development branch: All new features will be developed here as well as bug fixes for the next major version.
- b-6.x is the maintenance branch for the present major version. Only Backwards compatible changes as well as new compatible features are possible.
- b-5.3-ce appears as the so called legacy branch: fixes for critical bugs only.
In general, contributions can be taken over for all branches. Bug fixes committed to only one branch will be pushed to the other branches manually. Of course you can also consider to commit e.g. bug fixes to more than one branch.
- make sure composer is installed on your system
$ git clone https://github.com/OXID-eSales/oxideshop_ce.git
$ cd oxideshop_ce
$ composer install --no-dev
$ cp source/config.inc.php.dist source/config.inc.php
If you want to install OXID eShop including example data like products, categories etc., you first need to install the demo data package:
$ composer require --no-update oxid-esales/oxideshop-demodata-ce:dev-b-6.0
$ composer update --no-dev
To reduce the size of the repository when cloning you can use a so called "shallow clone". With it, the history will be truncated and can save more than 90% of the disk space and traffic in comparison to a full repository clone.
Here is an example of how to use a shallow clone:
git clone --depth 1 https://github.com/OXID-eSales/oxideshop_ce.git
- please leave the the branch names as they are
- if you want to fix a bug or develop a new feature, define an own branch in your repository off of one of the three branches above. Name it e.g. feature/foo or bug/bugname for better tracability
- change whatever you want and push it to your forked repository
- when changes are pushed, create a Pull request on github for your branch
- additional changes to pull request can be done by making additional commits on your branch
For more information about this, please see:
http://codeinthehole.com/writing/pull-requests-and-other-good-practices-for-teams-using-github/
Now you'll be asked for signing an OXID Contributor Agreement (this has to be done once). After that we can start checking your code. In every case, whether or not we could take over your contribution, you'll be informed.
When sending your pull request, please provide a clear, meaningful and detailed information what your code is about and what it will do, best including a screen shot if possible. If you want to discuss your contribution and your code before committing it, please go to the dev-general mailing list: https://lists.oxidforge.org/mailman/listinfo/dev-general.
You will find technical help with Git and GitHub on this place:
https://help.github.com/
Please find a collection of helpful development tools as well as a link to the OXID specific Coding style guidelines at https://oxidforge.org/en/coding-standards.html. We also kindly request to PHP Unit tests for your code.