While smaller and less controversial changes can still be made directly through pull requests, more substantial changes follow a multi-stage RFC process to ensure they are sufficiently thought out and vetted before being released for general availability in the schema.
The types of changes that warrant this RFC process include but are not limited to:
- Breaking changes targeting the next major version
- New top level fieldsets
- New fields to accommodate an unaddressed use case
- Changes that would alter the scope of ECS as a whole
Check out Proposing Changes for high level information about the RFC process.
Check out the series of stages an RFC will go through to be fully vetted.
It's important to understand the overall goals and intentions of the RFC process, so it is recommended that you read this and the document listed above. When you're ready to dive in,
- Create a new RFC document from the RFC template (described below)
- Fill in the details for your strawperson
- Open a PR to commit your RFC to rfcs/
- ECS committee and/or team members review
- ECS committee and/or team member merges RFC, formally accepting the strawperson
- Expand existing RFC document with additional details
- Open a PR to commit your proposed changes to the RFC and advance to stage 1
- ECS committee and/or team members review
- ECS committee and/or team member merges RFC, formally accepting the proposal
- Repeat steps 6-9 for stages 2 and 3
All new RFCs should be started by copying 0000-rfc-template.md with a name format of 0000-<dash-separated-name>.md
. When the first RFC stage is accepted, the ECS team will assign a unique RFC number, which will identify this RFC throughout all stages of the process.
Throughout the RFC template are comments that provide guidance on what type of content to include in each stage. It's ideal if you remove comments from your RFC as you fill out the content and they become obsolete. A pristine, finished RFC will have no explanatory comments remaining.
For the most part, content is additive as you move through the stages. Occasionally, advancing a stage will require modifying existing content. This is OK! This process should be iterative, and the RFC document is considered living until it is finished (i.e. accepted as stage 3).
While advancing through multiple stages at a time is possible if all the necessary information is provided and thoroughly vetted, moving changes through stage by stage provides the greatest opportunity to iterate efficiently on changes and a much lower chance of an author wasting a ton of their time.