source: https://codeberg.org/fediverse/fep/src/branch/main/feps/fep-a4ed.md
---
authors: @pukkamustard
status: FINAL
dateReceived: 2020-10-16
dateFinalized: 2021-01-18
---
FEP-a4ed: The Fediverse Enhancement Proposal Process
Summary
A Fediverse Enhancement Proposal (FEP) is a document that provides information to the Fediverse community. The goal of a FEP is to improve interoperability and well-being of diverse services, applications and communities that form the Fediverse.
This document describes the scope, format and process of publishing Fediverse Enhancement Proposals.
Scope and Objectives
A Fediverse Enhancement Proposal (FEP) should be a concise and focused documentation of a specific topic that is of interest to the Fediverse community.
A proposal should always have the intention of improving the interoperability and well-being of diverse services, applications and community of the Fediverse.
The Fediverse includes applications, services and communities using the ActivityPub protocol and other protocols that foster decentralized and diverse social media and culture.
Proposals may include descriptions of technical protocols and mechanism, documentation of experimental work or current best practices.
Proposals are not limited to technical topics and may focus on social and cultural aspects.
Proposals may be entertaining and humorous (unlike this proposal).
Language, Document Structure and Format
All Fediverse Enhancement Proposals must be written in English, be properly formatted as CommonMark [CommonMark] and be reasonably grammatical.
Authors should use inclusive language and examples and refrain from using oppressive terminology [Internet-Draft-terminology].
Proposal Title and Identifier
Every Fediverse Enhancement Proposals must have a descriptive title.
An identifier is computed from the proposal title as the first 4 digits of the sha256 hash (in hex). The identifier can be computed from the title with standard Unix tools:
$ echo -n "The Fediverse Enhancement Proposal Process" | sha256sum | cut -c-4
a4ed
By using the hash of the title as identifier we reduce the burden on editors to assign unique ids. This requires proposal titles to be unique.
Metadata
Proposal metadata is placed at the top of the document as key-value pairs between opening and closing ~—~.
Following metadata key-value pairs may be placed at the top of a proposal:
-
authors
: A comma separated list of authors of the proposal. -
status
: Indicates the proposal status. Can be eitherDRAFT
,WITHDRAWN
orFINAL
. -
dateReceived
: Date of when the proposal was added to the repository (when status is set toDRAFT
). -
dateWithdrawn
: Date of when the proposal status was set toWITHDRAWN
(only for proposals with statusWITHDRAWN
). -
dateFinalized
: Date of when the proposal status was set toFINAL
(only for proposals with statusFINAL
). -
relatedFeps
: A comma separated list of related FEPs (e.g.FEP-a4ed, FEP-141a, FEP-686f
). -
replaces
: A comma separated list of FEPs that are replaced by the proposal. -
replacedBy
: Identifier of a FEP that replaces the proposal.
Future FEPs may specify additional metadata fields.
Required Sections
Every FEP should include at least the following sections:
- Summary: A short (no more than 200 words) summary of the proposal.
- Copyright: Indicating that the proposal has been placed in the public domain.
Following sections may be included in a proposal:
- History: An overview of previous related efforts and how they relate to the proposal.
- Implementations: If applicable an overview of services or applications that implement the proposal at time of submission.
- References: A list of documents and resources referenced by the proposal.
Copyright
Fediverse Enhancement Proposals must be placed in the public domain by the authors with a CC0 1.0 Universal (CC0 1.0) Public Domain Dedication.
The Fediverse Enhancement Proposals Process
+-------+
+-------> | FINAL |
| +-------+
+-------+ |
-------->| DRAFT | --------+
+-------+ |
^ | +-----------+
| +-------> | WITHDRAWN |
| +-----------+
| |
+-----------------------------+
- A Fediverse Enhancement Proposal can be submitted by individuals or groups of individuals (authors). See the
SUBMISSION.md
file for a list of accepted submission methods. - Within seven days one of the editors will read and respond to the proposal. The editor checks if the proposal conforms to the required structure and fits the scope and objective of the FEPs. The editor may request the authors to clarify, justify, or withdraw the proposal. Such a request must not reflect the personal bias of an editor. Rather, it will be made strictly to maintain a high quality of submissions. The editors reserve the right to reject a submission when a proposal amounts to blatant misuse of the process. The authors may seek feedback from the wider community if the submitted proposal is rejected or clarifications are requested.
- If a FEP editor approves a submission it receives the status
DRAFT
and is added to the repository. - While a proposal has the status
DRAFT
:- Authors are responsible for initiating community discussion and collecting feedback.
- Authors may submit updates to the proposal which will be checked in to the repository by an editor.
- Authors may withdraw the submission upon which an editor will set the status of the submission to
WITHDRAWN
.
- After at least 60 days the authors may request the proposal to be finalized. This is done by requesting final comments on the proposal.
- If there are no community objections within 14 days and the authors can show that they have initiated sufficient awareness and discussion of the proposal, an editor will set the status of the submission to
FINAL
.
- If there are no community objections within 14 days and the authors can show that they have initiated sufficient awareness and discussion of the proposal, an editor will set the status of the submission to
- If after 120 days the authors have not requested the proposal to be finalized or there is no community consensus, an editor will set the status of the submission to
WITHDRAWN
. - A proposal with status
FINAL
can not be changed or updated in a way that would lead to adjustments to implementations. Minor corrections are allowed. - Any substantial change to finalized proposal must be submitted as a separate FEP.
- The new FEP MUST include a
replaces
metadata attribute pointing to FEPs it supersedes. - If the new FEP becomes
FINAL
, the original one MUST point to it in an addedreplacedBy
metadata attribute.
- A proposal with status
WITHDRAWN
remains in the repository and can be resubmitted.
Editors
A list of editors is maintained in the EDITORS.md
file at the root of the FEP repository.
Submission Methods
A list of methods in which a proposal may be submitted is maintained in the SUBMISSION.md
file at the root of the FEP repository.
FEP-a4ed
FEP-a4ed (The Fediverse Enhancement Proposal Process) is a living document and can be updated despite having the FINAL
status.
History
The process and format described in this proposal is influenced by other community driven documentation efforts such as the BitTorrent Enhancement Proposal Process [BEP-1], Scheme Request for Implementation [SRFI] and the IETF RFC Series [RFC-8729].
References
- [SRFI] Dave Mason, Scheme Request For Implementation - Process
- [BEP-1] David Harrison, The BitTorrent Enhancement Proposal Process, 2008
- [RFC-8729] Housley, R., Ed., and L. Daigle, Ed., The RFC Series and RFC Editor, 2020
- [CommonMark] John MacFarlane, CommonMark Spec Version 0.29, 2019
- [Internet-Draft-terminology] Mallory Knodel, Terminology, Power and Oppressive Language
Copyright
CC0 1.0 Universal (CC0 1.0) Public Domain Dedication
To the extent possible under law, the authors of this Fediverse Enhancement Proposal have waived all copyright and related or neighboring rights to this work.