The Node.js Foundation Technical Steering Committee is the technical governing body of the Node.js Foundation. It admits and oversees all top-level Projects in the Node.js Foundation. It also elects a representative to the Node.js Foundation Board of Directors.
For more details read the TSC Charter adopted by the Node.js Foundation Board of Directors on June 17th 2015.
If your project is interested in joining the Node.js Foundation please read the Project Lifecycle.md documentation.
The TSC is responsible for Node.js Core project, a number of projects depended upon by Node.js Core, and a number of projects adjacent to Node.js Core.
The TSC exercises autonomy in managing its responsibilities and seeks agreement from the Node.js Foundation Board on any change to the scope of those responsibilities as defined below.
Node.js Core is defined as the contents of the repository located at
https://github.com/nodejs/node from which the node
executable and associated
packages are built, excluding the vendored projects included in the codebase
located in the deps and tools directories that are copied in from
externally maintained repositories.
Additional projects fall within the TSC's scope of responsibility which are dependencies of Node.js Core in that they are required to plan, test, build, document and ship Node.js releases.
These projects are located in the following repositories:
- https://github.com/nodejs/TSC
- https://github.com/nodejs/build — administration delegated to the Build Working Group
- https://github.com/nodejs/citgm — administration delegated to the Core Technical Committee, managed by the Smoke Testing Team
- https://github.com/nodejs/docker-node — administration delegated to the Docker Working Group
- https://github.com/nodejs/http-parser — administration delegated to the Core Technical Committee
- https://github.com/nodejs/LTS — administration delegated to the Core Technical Committee, managed by the LTS Team
- https://github.com/nodejs/node-eps — administration delegated to the Core Technical Committee
- https://github.com/nodejs/nodejs-dist-indexer — administration delegated to the Build Working Group
- https://github.com/nodejs/nodejs-latest-linker — administration delegated to the Build Working Group
- https://github.com/nodejs/nodejs-nightly-builder — administration delegated to the Build Working Group
- https://github.com/nodejs/nodejs.org — administration delegated to the Website Working Group
- https://github.com/nodejs/secrets — private, administration delegated to the Build Working Group
- https://github.com/libuv/libuv — currently under Incubation
The TSC is responsible for a number of projects that are not strictly required to plan, test, build, document and ship Node.js releases. Projects that are adjacent are either created from within the technical organization managed by the TSC or are adopted into that organization from outside.
In the case of adopting existing projects, once the TSC has decided that adoption appropriate, it should seek agreement from the Node.js Foundation Board for such adoption as it impacts on the scope of technical activities of the Foundation.
If the Node.js Foundation Board wishes to adopt an existing project, it must seek agreement from the TSC that such adoption is appropriate and that any changes to scope that it entails are acceptable.
Current adjacent projects that are within the TSC's scope of responsibility can be found at the following locations:
- https://github.com/nodejs/abi-stable-node — administration delegated to the API Working Group
- https://github.com/nodejs/abi-stable-node-addon-examples — administration delegated to the API Working Group
- https://github.com/nodejs/api — administration delegated to the API Working Group
- https://github.com/nodejs/benchmarking — administration delegated to the Benchmarking Working Group
- https://github.com/nodejs/code-and-learn
- https://github.com/nodejs/diagnostics — administration delegated to the Diagnostics Working Group
- https://github.com/nodejs/docs — administration delegated to the Documentation Working Group
- https://github.com/nodejs/education
- https://github.com/nodejs/email — administration delegated to the Build Working Group
- https://github.com/nodejs/evangelism — administration delegated to the Evangelism Working Group
- https://github.com/nodejs/github-bot — administration delegated to the Core Technical Committee, managed by the GitHub Bot Team
- https://github.com/nodejs/help — administration delegated to the Evangelism Working Group
- https://github.com/nodejs/http — administration delegated to the Core Technical Committee, managed by the HTTP team
- https://github.com/nodejs/http2 — administration delegated to the Core Technical Committee, managed by the HTTP/2 team
- https://github.com/nodejs/iojs.org — administration delegated to the Website Working Group
- https://github.com/nodejs/installer — administration delegated to the Core Technical Committee
- https://github.com/nodejs/Intl — administration delegated to the Intl Working Group
- https://github.com/nodejs/llnode — administration delegated to the Post Mortem Working Group
- https://github.com/nodejs/nan — administration delegated to the Addon API Working Group
- https://github.com/nodejs/node-addon-examples — administration delegated to the Addon API Working Group)
- https://github.com/nodejs/node-chakracore — administration delegated to the Core Technical Committee
- https://github.com/nodejs/node-gyp — administration delegated to the Core Technical Committee
- https://github.com/nodejs/node-inspect — administration delegated to the Diagnostics Working Group
- https://github.com/nodejs/node-report — administration delegated to the Post Mortem Working Group
- https://github.com/nodejs/post-mortem — administration delegated to the Post Mortem Working Group
- https://github.com/nodejs/promises — administration delegated to the Promises Working Group
- https://github.com/nodejs/readable-stream — administration delegated to the Streams Working Group
- https://github.com/nodejs/summit
- https://github.com/nodejs/testing — administration delegated to the Testing Working Group
- And various language and resource translation groups under https://github.com/nodejs/
The TSC exercises autonomy in setting up and maintaining procedures, policies, and management and administrative structures as it deems appropriate for the maintenance and operation of these projects and resources.
Included in the responsibilities of the TSC are:
- Managing code and documentation creation and changes for the listed projects and resources
- Setting and maintaining standards covering contributions of code, documentation and other materials
- Managing code and binary releases: types, schedules, frequency, delivery mechanisms
- Making decisions regarding dependencies of the Node.js Core project, including what those dependencies are and how they are bundled with source code and releases
- Creating new repositories and projects under the nodejs GitHub organization as required
- Setting overall technical direction for the Node.js Core project, including high-level goals and low-level specifics regarding features and functionality
- Setting and maintaining appropriate standards for community discourse via the various mediums under TSC control
- Setting and maintaining governance rules for the conduct and make-up of the TSC, Working Groups and other bodies within the TSC's domain
Many of these responsibilities will be delegated by the TSC to appropriate bodies such as the Working Groups.
TSC members are responsible for top level technical community concerns. The role is mostly administrative and is responsible for admitting new Top Level Projects, Top Level Working Groups, and advocating for any needs in the technical side of the foundation to the Node.js Foundation Board of Directors.
TSC members can nominate new members at any time. Candidates for membership tend to be people who have a competancy for community management and a high tolerance and patience for process minutiae as the TSC delegates most of its responsibilities to other projects and working groups.
Every Top Level Project not currently incubating can appoint someone to the TSC whom they elect at their own discretion.
- addaleax - Anna Henningsen <anna@addaleax.net> (she/her)
- bnoordhuis - Ben Noordhuis <info@bnoordhuis.nl>
- ChALkeR - Сковорода Никита Андреевич <chalkerx@gmail.com> (he/him)
- cjihrig - Colin Ihrig <cjihrig@gmail.com>
- evanlucas - Evan Lucas <evanlucas@me.com> (he/him)
- fhinkel - Franziska Hinkelmann <franziska.hinkelmann@gmail.com>
- Fishrock123 - Jeremiah Senkpiel <fishrock123@rocketmail.com>
- indutny - Fedor Indutny <fedor.indutny@gmail.com>
- jasnell - James M Snell <jasnell@gmail.com> (he/him)
- joshgav - Josh Gavant <josh.gavant@outlook.com>
- joyeecheung - Joyee Cheung <joyeec9h3@gmail.com> (she/her)
- mcollina - Matteo Collina <matteo.collina@gmail.com> (he/him)
- mhdawson - Michael Dawson <michael_dawson@ca.ibm.com> (he/him)
- mscdex - Brian White <mscdex@mscdex.net>
- MylesBorins - Myles Borins <myles.borins@gmail.com> (he/him)
- ofrobots - Ali Ijaz Sheikh <ofrobots@google.com>
- rvagg - Rod Vagg <rod@vagg.org>
- shigeki - Shigeki Ohtsu <ohtsu@ohtsu.org> (he/him)
- targos - Michaël Zasso <targos@protonmail.com> (he/him)
- thefourtheye - Sakthipriyan Vairamani <thechargingvolcano@gmail.com> (he/him)
- trevnorris - Trevor Norris <trev.norris@gmail.com>
- Trott - Rich Trott <rtrott@gmail.com> (he/him)
- chrisdickinson - Chris Dickinson <christopher.s.dickinson@gmail.com>
- isaacs - Isaac Z. Schlueter <i@izs.me>
- orangemocha - Alexis Campailla <orangemocha@nodejs.org>
- piscisaureus - Bert Belder <bertbelder@gmail.com>
- nebrius - Bryan Hughes <bryan@nebri.us>
- misterdjules - Julien Gilli <jgilli@nodejs.org>
Many teams/groups post meeting videos to the Node.js Foundation YouTube channel.
Any GitHub team maintainer is allowed Manager
access to the Google Plus
account allowing them to add/manage video content and schedule events
(live broadcasts).
Members of the TSC are allowed Owner
access to the Google Plus account. This
role can do all Manager
activities and add/remove other members from the
Google Plus account.
To request access, open an issue.
-
Mentors
Project mentorship is not a technical role. In fact, mentors are discouraged from giving technical advice to projects. Instead, the purpose of mentorship is to encourage and improve a projects ability to be participatory, transparent, and effective. Mentors are there to help projects adopt and iterate on policies and processes that achieve these goals and eventually allow them to graduate the incubation phase.
* Mikeal Rogers (@mikeal) Currently assigned to Express. * James Snell (@jasnell) Currently assigned to Express. * Rod Vagg (@rvagg) Currently assigned to libuv.
-
Top-Level Projects
-
Core TLP
-
Core WGs (streams, http, Intl)
The Node.js TSC is chartered to oversee the technical governance of all Top Level Projects and Working Groups under the Node.js Foundation. The TSC establishes the default governance, conduct, and licensing policies for all Top Level Projects. Top Level Projects and Working Groups have broad powers of self-governance.
To propose a change or addition to policies or processes that are intended to
cover all Top Level Projects and Working Groups in the foundation, a PR should
be opened in the nodejs/TSC
repository.
The pull request can be labeled tsc-agenda
to request that it be put on the
agenda for the next TSC meeting.
The Node.js Foundation Board of Directors retains certain rights (especially legal considerations). If the TSC endorses a proposal, they will escalate to the Node.js Foundation Board of Directors when required to do so.
In some cases, existing individual groups have the right to refuse changes to their charters. The TSC can not mandate existing working groups alter their charters. If such a situation arises, the TSC may decide to revoke the group's charter.