This section specifies an administrative process and conventions to support the creation and management of GitHub organizations for working groups and single-document repositories in a uniform way. The steps may be done manually by the IETF Secretariat, or they may be automated. See <
https://github.com/richsalz/ietf-gh-scripts> and <
https://github.com/martinthomson/i-d-template> for working examples of automation that is in use in some working groups.
In this document the question of whether processes should be manual or automated is deliberately left unspecified, since these are implementation details that the IETF Secretariat and Tools Team will address.
Most of the conventions below are drawn from [
RFC 8874].
This document specifies that there be a facility in the IETF Datatracker (<
https://datatracker.ietf.org/>) interface to allow an area director (AD) or working group chair to request the creation of a GitHub organization for a particular working group. Ideally, this facility would appear both as part of the working group chartering UI and the working group page UI.
When an area director or working group chair makes a request to create a GitHub organization, the following process would be initiated:
-
Create a GitHub organization for the working group.
-
Name the organization in the format ietf-wg-<wgname>...
-
Initialize the organization by designating the IETF Secretariat and the area directors in the working group's area as owners. If the responsible AD for the working group is from another area, that AD will be an owner as well.
-
Initialize the organization with a team that has administrator access. This team will consist of the working group chairs and working group secretary, if one exists.
After the organization is created, the URL for the organization would be added to the working group's page in the Datatracker.
Steps [
3] and [
4] above imply that the GitHub identities of the organization owners and administrators are known. Recording GitHub identities in the Datatracker (see <
https://trac.tools.ietf.org/tools/ietfdb/ticket/2548>) would facilitate this. The person requesting the organization would need to be notified if the GitHub identities of any of the people meant to be owners or administrators were not available.
If a working group already has an organization, it would be useful to be able to make it have the same management as one would get by going through the steps in
Section 2.1. That is, it would be good to be able to run Steps [
3] and [
4] from
Section 2.1 so that the rest of the activities in this section, such as personnel changes, work the same way as for organizations that were created as specified herein.
When there are personnel changes in the area or the working group, those changes would be reflected in the GitHub organization. There should be an ability in the Datatracker to specify that personnel changes have occurred.
When a working group is closed, the team with administrative access would be removed, and the owner list would be returned to the Secretariat and current ADs at the time of closing. The organization summary and the repositories within the organization would be updated to indicate that they are no longer under development. Later, the owner list could become just the Secretariat, or it might include others chosen by the Secretariat or the IESG.
There are many different scenarios and configurations where it might be useful to have automation or established administrative conventions for repositories within WG organizations, such as:
-
Creating a new repository for an individual draft (at the discretion of the WG chair);
-
Creating a new repository for an already adopted working group draft;
-
Migrating an existing document repository into the WG organization; and
-
Creating a new repository that contains multiple drafts.
As an incremental step, this document specifies that there be a facility in the Datatracker interface to allow an administrator of an ietf-wg-<wgname> organization to request the creation of a new repository within that organization for a single document. The document authors would be identified as collaborators. The repository name would be the draft name. Ideally, the repository would be configured with a skeleton draft file, default CONTRIBUTING, LICENSE, and README files, and continuous integration support, in the vein of <
https://github.com/martinthomson/i-d-template>. Performing this step would automatically inform the IETF Secretariat that this repository should be backed up as described in
Section 3.2.
The IETF Datatracker should allow users to add links to repositories (for GitHub and other repository services) on working group, document, and user pages. At the time of this writing, this feature was under development.