Skip to content

Latest commit

 

History

History
440 lines (329 loc) · 19.7 KB

CONTRIBUTING.md

File metadata and controls

440 lines (329 loc) · 19.7 KB

Solid Technical Reports Contributing Guide

Thank you for investing your time in contribution to the Solid project!

The solid/specification repository contains the source code of the work on Solid Technical Reports (TR) of the W3C Solid Community Group (CG) to meet the needs of the Solid Project.

The TRs include specifications, use cases and requirements, best practices and guidelines, primers and notes about the Solid ecosystem.

The CG has a Charter (source).

Code of conduct

Read the Solid Code of Conduct and the Positive Work Environment at W3C: Code of Ethics and Professional Conduct to keep our community approachable and respectable.

See additional resources for education and training to promote a positive work environment.

Conformance

The key words “MUST” and “MUST NOT” are to be interpreted as described in BCP 14 RFC2119 RFC8174 when, and only when, they appear in all capitals, as shown here.

Contributions

In order to be a substantive contributor to work items, you MUST be a member of the CG. It’s easy to join the CG if you’d like to contribute. People agree to the W3C Community License Agreement (CLA) upon joining the CG.

We accept different types of contributions as described below.

To ensure that anyone can follow along a contribution and support verification, provide citations to significant units of information, e.g., references to specific requirements in technical reports, decisions made in a formal meeting. To promote accountable discourse, request citations when questioning uncited claims.

Discussions

If you'd like help troubleshooting a pull request (PR) you're working on, have a great new idea, or want to share implementation feedback, join us in Solid specification chat.

Issues

Issues are used to track tasks that contributors can help with. If an issue has a triage label, we haven't reviewed it yet and so you are not encouraged to begin work on it.

If you've found something in the content or the website that might need to be updated, search open issues to see if someone else has reported the same thing. If it's something new, open an issue. We'll use the issue to have a conversation about the problem you want to fix.

Pull requests

A pull request is a way to suggest changes in our repository.

Translations

We aim to have our documents internationalized and available in multiple languages. The source content in Solid repositories are written in English. We accept contributions to localize the English content.

Contributions at source repository

Each CG work item listed at Solid Technical Reports has its own repository. It is strongly encouraged that any issues and PRs are made at their source.

The persistent version of technical reports published in solid/specification (see publishing technical reports are intended to be read-only snapshots of the CG work items.

A low-barrier way to add concrete suggestions is to submit a user story. User stories are descriptions of desired features written in a special way, see the description there for details. User stories might then be used when formulating use cases and requirements.

Creating and solving issues

Create a new issue

If you spot a problem with the technical reports being worked on in this repository or would like to request a feature, search if an issue already exists. If a related issue doesn't exist, you can open a new issue. In the issue, include relevant information that can help others, e.g., links to specifications, issues, implementations, test suite, discussions.

Solve an issue

Scan through our existing issues to find one that interests you. You can narrow down the search using labels as filters. See Labels for more information. If you find an issue to work on, you are welcome to open a PR with a fix.

Make changes

Make changes locally

  1. Install Git
  2. Fork the repository.
  3. Create a working branch and start with your changes!

Commit your update

Commit the changes once you are happy with them. See Atom's contributing guide to know how to use emoji for commit messages.

Once your changes are ready, don't forget to self-review to speed up the review process:zap:.

Self-review

You are strongly encouraged to review your own PR first.

For content changes, make sure that you:

Creating a pull request

When you're finished with the changes to documents that are maintained in this repository, create a PR.

  • Include atomic commits, small PRs: "one concern, one PR".
  • In the PR comment, provide as much context and evidence to help reviewers evaluate the PR. Identify, classify, describes the changes as per W3C Process Correction Classes.
  • Don't forget to link PR to issue if you are solving one.
  • We can ask for changes to be made before a PR can be merged, either using suggested changes or PR comments. You can apply suggested changes directly through the UI. You can make any other changes in your fork, then commit them to your branch.
  • As you update your PR and apply changes, mark each conversation as resolved.
  • If you run into any merge issues, checkout this git tutorial to help you resolve merge conflicts and other issues.
  • You can attribute a commit to more than one author by adding one or more Co-authored-by: NAME <[email protected]> per line to commit's message (after two empty lines). See github tutorial.
  • To help maintain a clean Git history, consider using squash merge for PRs, especially when incorporating reviews and code additions.

Your PR is merged!

Congratulations 🎉 Solid community thanks you ✨.

Work items

In general, all documents in scope of the group are welcome. Work items can be documents — such as Technical Reports, Primers, Best Practices and Guidelines, Use Cases and Requirements, Surveys, QA, and so forth — or software.

Workspace Selection

Consider the following guidance to identify the appropriate workspace to use to efficiently manage communication and collaboration within the Solid Project.

When the work in consideration:

  • involves or spans over various stakeholders, specialized groups, or horizontal groupings, then start a Solid Project-wide endeavor
  • is about current CG work items, then it should be proposed within or across those current work items
  • is within the scope of the CG but identifies a gap in work items, then follow the procedure to propose a New Work Item

If you are unsure where the work may fit, please create an issue detailing the stakeholders, problem context, and technical or knowledge goals.

New work item proposal

  • Propose new work item as an issue in https://github.com/solid/specification and propose it as an agenda topic in a group meeting.
  • Include publicly accessible link to abstract or draft.
  • List and link to owners (at least 1 person for advancing the work item and 1 other person).
  • Answer the following questions in order to document how you are meeting the requirements for a new work item at the W3C Solid Community Group. Please note if this work item supports certain programs or another government or private sector project.
    1. Explain what you are trying to do, using no jargon or acronyms.
    2. How is it done today, and what are the limits of the current practice?
    3. What is new in your approach, and why do you think it will be successful?
    4. How are you involving participants from multiple skill sets and global locations in this work item? (Skill sets: technical, design, product, marketing, anthropological, and UX. Global locations: Africa, the Americas, APAC, Europe, Middle East, Antarctica.)
    5. What actions are you taking to make this work item accessible to a non-technical audience?

Publishing a technical report

This section describes how to prepare the technical reports and how they'll be published on the Solid website.

General guidance

  • Content: the full content of the technical report MUST be human-readable with HTML alone. It is strongly discouraged that any CSS and JavaScript interferes with the accessibility of the content.
  • Offline-friendly: there MUST not be any mandatory external dependencies (e.g., a network connection) to retrieve, to render, or to manipulate the content of the article.
  • Privacy: scripts MUST not be used to identify or track readers.

There are two parts to publishing a technical report that applies to all reports:

  1. PR including the technical report in HTML and all local script and media files.
  2. Updating the technical report index (if necessary).

Published documents will be publicly accessible under the paths https://solidproject.org/TR/ or https://solidproject.org/ED/.

Versioned technical report

The PR for a versioned technical report MUST include two HTML documents:

  1. "Latest version" of the TR under the root (/) directory.
  2. "This version" (also known as the persistent version) of the TR under the /{YYYY}/ (year in 4 digits) directory.

We recommend that the latest version of the technical reports use a {shortname}, e.g., protocol, wac, and the persistent version of the technical report follows the following form: {shortname}-{YYYYMMDD}.

All files use common file name extensions, e.g., .html.

The documents will be published under the path https://solidproject.org/TR/.

For example, the Solid Protocol is available from the following URLs:

When a new version of the technical report is made available, we follow the same process. The updated "latest version" document will then link to the new latest persistent version. All persistent versions link to the latest version.

Versioned technical reports MUST indicate their version using the Semantic Versioning scheme in the document. The first release of a technical report MUST use 1.0.0 (for version-core). Any release can use a pre-release value part of the version indicating the document status and the publication date, e.g., "Version 1.0.0-CG-DRAFT" indicates a CG Draft.

Non-versioned technical report

The PR for a non-versioned technical report MUST include one HTML document and follow the same requirements as in "latest version" (see versioned technical report).

The documents will be published under the path https://solidproject.org/TR/.

Editor's draft

The PR for a non-versioned technical report MUST include one HTML document and follow the same requirements as in "latest version" (see versioned technical report).

The document will be published under the path https://solidproject.org/ED/. For example, the Editor's Draft of the Solid Protocol is available from https://solidproject.org/ED/protocol .

Technical Report index

When a new technical report is added, information about it is modified, or a new work item is being worked on by the CG, a follow-up can PR can be made to update the Technical Report index.

Publication Rules

W3C CG reports are not required to follow the publication requirements as W3C reports on the standards track. However, we recommend using the W3C's Publication rules for Recommendation (“REC”) as a guideline. Solid CG's technical reports differ along the lines of document status, rights, identifiers. To help readers already familiar with W3C technical reports, it is recommended to maintain the same look and feel.

See also the W3C Manual of Style guide containing best current practice, written for editors and authors of W3C technical reports.

We also make the following recommendations:

Decisions

Also see https://www.w3.org/Consortium/Process/#decisions for general guidance.

Processing pull requests

Unless there is a prior CG decision otherwise, changes to TRs use the W3C Process Correction Classes as follows:

Correction Class Requirements Time
No changes to text content Editors MAY PR and/or merge at their discretion. Within 5 days or 2 meetings.
Changes that do not functionally affect interpretation of the document Editors SHOULD PR and/or merge at their discretion. Within 5 days or 2 meetings.
Other changes that do not add new features MUST PR. Within 10 days or 2 meetings.
New features MUST PR. Within 10 days or 2 meetings.
Changes to the contents of a registry table Editors or chairs MUST PR. Within 10 days or 2 meetings.

For PRs involving other types of changes:

Document Type Requirements Time
Meeting Minutes MUST PR. After 1 day; within 2 days.
Contributing Guide MUST PR. Within 10 days or 2 meetings.

Vocabulary Management

TRs might refer to or make use of namespaces for specific functionality. The CG handles the management of Solid vocabularies under its responsibility through the solid/vocab repository.

The policy for the management of Solid vocabularies under the W3C namespace is described in Adding to W3C RDF Namespaces.

Meetings

The CG Meeting Guidelines describes how to participate and record meetings. There is a minutes template that can be used by scribes to transcribe the meeting.

The general steps to propose, review, and publish meeting agenda and minutes as follows:

  1. Create a PR containing the agenda for the upcoming meeting with:
  • Title: "Add YYYY-MM-DD agenda and minutes"
  • Assignees: to yourself (or others)
  • Labels: "category: meeting"
  1. Copy the agenda to a collaborative editor, which would be used during the meeting.
  2. Share the URLs to both the agenda PR and live editor across various communication channels such as chats and mailing lists. Include these URLs in the description of the calendar event for the meeting.
  3. Following the meeting, update the PR with the minutes collected from the live editor, acknowledging scribes by adding them as Co-authored-by: NAME <[email protected]>.
  4. Squash merge the PR once substantial feedback has been reviewed and integrated for publication.

Communication

The opinions of CG members may carry particular weight, whether they are expressed within our community or elsewhere. As a CG member:

  • It is assumed you are speaking as an individual unless you state otherwise.
  • If you want to express the opinion of your organisation or a group you are affiliated with, make it clear before you state their view.
  • Do not use phrases like "on behalf of the CG" or "the CG thinks that" unless the group has asked you to do so.
  • When communicating CG decisions, provide references to what was decided and what was not decided.