Symfony Core Team
The Symfony Core team is the group of developers that determine the direction and evolution of the Symfony project. Their votes rule if the features and patches proposed by the community are approved or rejected.
All the Symfony Core members are long-time contributors with solid technical expertise and they have demonstrated a strong commitment to drive the project forward.
This document states the rules that govern the Symfony core team. These rules are effective upon publication of this document and all Symfony Core members must adhere to said rules and protocol.
Role of a Core Team Member
In addition to being a regular contributor, core team members are expected to:
- Review, approve, and merge pull requests;
- Help enforce, improve, and implement Symfony processes and policies;
- Participate in the Symfony Core Team discussions (on Slack and GitHub).
Core Organization
Symfony Core members are divided into groups. Each member can only belong to one group at a time. The privileges granted to a group are automatically granted to all higher priority groups.
The Symfony Core groups, in descending order of priority, are as follows:
Project Leader
- Elects members in any other group;
- Merges pull requests in all Symfony repositories.
Mergers Team
- Merge pull requests on the main Symfony repository.
In addition, there are other groups created to manage specific topics:
- Security Team: manages the whole security process (triaging reported vulnerabilities, fixing the reported issues, coordinating the release of security fixes, etc.);
- Symfony UX Team: manages the UX repositories;
- Documentation Team: manages the whole symfony-docs repository.
Active Core Members
Project Leader:
- Fabien Potencier (fabpot).
Mergers Team (
@symfony/mergers
on GitHub):- Nicolas Grekas (nicolas-grekas);
- Christophe Coevoet (stof);
- Christian Flothmann (xabbuh);
- Kévin Dunglas (dunglas);
- Javier Eguiluz (javiereguiluz);
- Grégoire Pineau (lyrixx);
- Ryan Weaver (weaverryan);
- Robin Chalas (chalasr);
- Yonel Ceruto (yceruto);
- Tobias Nyholm (Nyholm);
- Wouter De Jong (wouterj);
- Alexander M. Turek (derrabus);
- Jérémy Derussé (jderusse);
- Oskar Stark (OskarStark);
- Thomas Calvet (fancyweb);
- Mathieu Santostefano (welcomattic);
- Kevin Bond (kbond);
- Jérôme Tamarelle (gromnan).
Security Team (
@symfony/security
on GitHub):Symfony UX Team (
@symfony/ux
on GitHub):- Ryan Weaver (weaverryan);
- Kevin Bond (kbond);
- Simon André (smnandre);
- Hugo Alliaume (kocal);
- Matheo Daninos (webmamba).
Documentation Team (
@symfony/team-symfony-docs
on GitHub):- Fabien Potencier (fabpot);
- Ryan Weaver (weaverryan);
- Christian Flothmann (xabbuh);
- Wouter De Jong (wouterj);
- Javier Eguiluz (javiereguiluz).
- Oskar Stark (OskarStark).
Former Core Members
They are no longer part of the core team, but we are very grateful for all their Symfony contributions:
- Bernhard Schussek (webmozart);
- Abdellatif AitBoudad (aitboudad);
- Romain Neutron (romainneutron);
- Jordi Boggiano (Seldaek);
- Lukas Kahwe Smith (lsmith77);
- Jules Pietri (HeahDude);
- Jakub Zalas (jakzal);
- Samuel Rozé (sroze);
- Tobias Schultze (Tobion);
- Maxime Steinhausser (ogizanagi);
- Titouan Galopin (tgalopin);
- Michael Cullum (michaelcullum).
Core Membership Application
About once a year, the core team discusses the opportunity to invite new members.
Core Membership Revocation
A Symfony Core membership can be revoked for any of the following reasons:
- Refusal to follow the rules and policies stated in this document;
- Lack of activity for the past six months;
- Willful negligence or intent to harm the Symfony project;
- Upon decision of the Project Leader.
Code Development Rules
Symfony project development is based on pull requests proposed by any member of the Symfony community. Pull request acceptance or rejection is decided based on the votes cast by the Symfony Core members.
Pull Request Voting Policy
-1
votes must always be justified by technical and objective reasons;+1
votes do not require justification, unless there is at least one-1
vote;- Core members can change their votes as many times as they desire during the course of a pull request discussion;
- Core members are not allowed to vote on their own pull requests.
Pull Request Merging Policy
A pull request can be merged if:
- It is a minor change;
- Enough time was given for peer reviews;
- It is a bug fix and at least two Mergers Team members voted
+1
(only one if the submitter is part of the Mergers team) and no Core member voted-1
(via GitHub reviews or as comments). - It is a new feature and at least two Mergers Team members voted
+1
(if the submitter is part of the Mergers team, two other members) and no Core member voted-1
(via GitHub reviews or as comments).
Pull Request Merging Process
All code must be committed to the repository through pull requests, except for minor change which can be committed directly to the repository.
Mergers must always use the command-line gh
tool provided by the
Project Leader to merge pull requests.
When merging a pull request, the tool asks for a category that should be chosen following these rules:
- Feature: For new features and deprecations; Pull requests must be merged in the development branch.
- Bug: Only for bug fixes; We are very conservative when it comes to merging older, but still maintained, branches. Read the Maintenance document for more information.
- Minor: For everything that does not change the code or when they don't need to be listed in the CHANGELOG files: typos, Markdown files, test files, new or missing translations, etc.
- Security: It's the category used for security fixes and should never be used except by the security team.
Getting the right category is important as it is used by automated tools to generate the CHANGELOG files when releasing new versions.
Release Policy
The Project Leader is also the release manager for every Symfony version.
Symfony Core Rules and Protocol Amendments
The rules described in this document may be amended at any time at the discretion of the Project Leader.
Note
Minor changes comprise typos, DocBlock fixes, code standards violations, and minor CSS, JavaScript and HTML modifications.