-
Notifications
You must be signed in to change notification settings - Fork 60
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: redirect to editor's draft of extensions policy
- Loading branch information
Showing
1 changed file
with
9 additions
and
301 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,303 +1,11 @@ | ||
<!DOCTYPE html> | ||
<html> | ||
<head> | ||
<meta charset='utf-8'> | ||
<script src='https://www.w3.org/Tools/respec/respec-w3c' async class='remove'></script> | ||
<script class='remove'> | ||
// All config options at https://respec.org/docs/ | ||
var respecConfig = { | ||
// Working Groups ids at https://respec.org/w3c/groups/ | ||
group: "socialcg", | ||
specStatus: "unofficial", | ||
editors: [{ | ||
name: "Evan Prodromou", | ||
url: "https://evanp.me/", | ||
}], | ||
github: { | ||
branch: "main", | ||
repoURL: "w3c/activitystreams", | ||
}, | ||
// See https://respec.org/docs/#xref for usage. | ||
xref: ["activitystreams-core", "activitystreams-vocabulary"], | ||
}; | ||
</script> | ||
</head> | ||
<body> | ||
<h1 id="title">Process for Including Extensions in Activity Streams 2.0</h1> | ||
<section id='abstract'> | ||
<p> | ||
This document describes the process and criteria for approving extensions | ||
for inclusion in the main Activity Streams 2.0 context document. | ||
</p> | ||
</section> | ||
<section id='sotd'> | ||
<p> | ||
This is a draft Note for publication by the SocialCG. It is not a W3C | ||
recommendation. | ||
</p> | ||
</section> | ||
<section> | ||
<h2>Motivation</h2> | ||
<p> | ||
Activity Streams 2.0, as described in [[activitystreams-core]] | ||
and [[activitystreams-vocabulary]] is a vocabulary for representing | ||
social data. It is used by, among others, the [[activitypub]] API and protocol. | ||
It is designed to be extensible, so that new terms can | ||
be used by publishers and consumers. | ||
</p> | ||
<p> | ||
Extensions provide at least the following benefits: | ||
</p> | ||
<ul> | ||
<li>Support specialist vocabularies for specific fields of interest</li> | ||
<li>Model social software patterns that were not common when | ||
Activity Streams 2.0 was originally published</li> | ||
<li>Provide alternate terms or structures for patterns already | ||
represented in Activity Streams 2.0 that improve the vocabulary's clarity | ||
or ease of use</li> | ||
</ul> | ||
<p> | ||
Any publisher can define an extension to Activity Streams 2.0, and use it in | ||
published documents. For example, a publisher could define an extension | ||
that provides a term for the favorite ice cream flavor of a person. | ||
</p> | ||
<figure> | ||
<figcaption> | ||
Context document for the example favorite ice cream flavor context. | ||
</figcaption> | ||
<div id="ex1-context" style="display: block;"> | ||
<pre class="example highlight json"> | ||
{ | ||
"@context": { | ||
"ic": "https://flavors.example/ns/icecream#", | ||
"favoriteIceCreamFlavor": { | ||
"@id": "ic:favoriteIceCreamFlavor", | ||
"@type": "@id" | ||
}, | ||
"Chocolate": "ic:Chocolate", | ||
"Vanilla": "ic:Vanilla", | ||
"Strawberry": "ic:Strawberry", | ||
"Pistachio": "ic:Pistachio" | ||
} | ||
} | ||
</pre> | ||
</div> | ||
</figure> | ||
<p> | ||
This publisher, or any other publisher, can create Activity Streams 2.0 | ||
documents that use this extension. | ||
</p> | ||
<figure> | ||
<figcaption> | ||
Example of a person with a favorite flavor of ice cream term. | ||
</figcaption> | ||
<div id="ex1-context" style="display: block;"> | ||
<pre class="example highlight json"> | ||
{ | ||
"@context": [ | ||
"https://www.w3.org/ns/activitystreams", | ||
"https://favorites.example/ns/icecream" | ||
], | ||
"id": "https://example.com/people/evan", | ||
"type": "Person", | ||
"name": "Evan Prodromou", | ||
"favoriteIceCreamFlavor": "Pistachio" | ||
} | ||
</pre> | ||
</div> | ||
</figure> | ||
<p> | ||
If the publisher uses different extensions in the same | ||
document with different terms, they will need to resolve | ||
those naming conflicts by hand. | ||
</p> | ||
<figure> | ||
<figcaption> | ||
Example of using two extensions with conflicting terms for "Chocolate" | ||
as an ice cream flavor and as a color of a horse's coat. | ||
</figcaption> | ||
<div id="ex1-context" style="display: block;"> | ||
<pre class="example highlight json"> | ||
{ | ||
"@context": [ | ||
"https://www.w3.org/ns/activitystreams", | ||
"https://favorites.example/ns/icecream", | ||
"https://horse.example/ns/colors" | ||
], | ||
"id": "https://example.com/people/evan", | ||
"type": "Person", | ||
"name": "Evan Prodromou", | ||
"favoriteIceCreamFlavor": "ic:Chocolate", | ||
"horseCoatColor": "horse:Chocolate" | ||
} | ||
</pre> | ||
</div> | ||
</figure> | ||
<p> | ||
Any publisher or consumer can implement this extension, subject to | ||
the terms of the creator's license(s), if any. | ||
</p> | ||
<p> | ||
Referencing many extensions can be a burden for publishers and consumers. | ||
Although one or two lines in the @context property of the Activity Streams 2.0 | ||
document may not be a problem, ten or twenty could be. In addition, | ||
the more extensions that are used, the more likely it is that there will | ||
be conflicts between terms. | ||
</p> | ||
<p> | ||
If an extension becomes very popular, it may be useful to include its terms | ||
and namespace in the main Activity Streams 2.0 context document. | ||
This will let publishers use the extension without having to include | ||
an additional line of context. It also provides an opportunity to resolve | ||
conflicts between terms in different extensions in the SocialCG. | ||
</p> | ||
<p> | ||
Thereafter, publishers will not need to include the extension's context URL | ||
in their documents. The extension's terms will be available for all documents | ||
that use the Activity Streams 2.0 context, without requiring a namespace | ||
prefix. | ||
</p> | ||
<figure> | ||
<figcaption> | ||
Theoretical example of using the favorite ice cream flavor term | ||
after it has been included in the main Activity Streams 2.0 context | ||
document. | ||
</figcaption> | ||
<div id="ex1-context" style="display: block;"> | ||
<pre class="example highlight json"> | ||
{ | ||
"@context": "https://www.w3.org/ns/activitystreams", | ||
"id": "https://example.com/people/evan", | ||
"type": "Person", | ||
"name": "Evan Prodromou", | ||
"favoriteIceCreamFlavor": "Chocolate" | ||
} | ||
</pre> | ||
</div> | ||
</figure> | ||
<p> | ||
This inclusion does not come without a price. First, the Activity Streams 2.0 | ||
context document is that much larger, which has a cost in terms of readability, | ||
maintainability, and bandwidth used. In addition, there is work for the | ||
SocialCG in updating, documenting, harmonizing, and maintaining the context | ||
document. | ||
</p> | ||
<p> | ||
This Note describes the criteria that the SocialCG will use to decide | ||
whether the benefits of simplicity and clarity by including extension | ||
terms in the main context document outweigh the costs of doing so. | ||
</p> | ||
<p> | ||
Properly implemented, this process provides a way to make Activity Streams 2.0 | ||
a continuously evolving vocabulary, serving new needs for developers and | ||
users, while maintaining the stability of the core terms. | ||
</p> | ||
</section> | ||
<section> | ||
<h2>Process</h2> | ||
<p>These are the steps to including an extension in | ||
the Activity Streams 2.0 context document.</p> | ||
<ol> | ||
<li><b>Publish the extension for review.</b> Extensions can be published | ||
through the Federation Enhancement Proposal (FEP) process, as Notes of | ||
the SocialCG, through another standardisation process, or by any other | ||
organisations or individuals. See "Criteria" below for required content. | ||
</li> | ||
<li> | ||
<b>Implement the extension.</b> See "Criteria" below for implementation requirements. | ||
</li> | ||
<li> | ||
<b>List the extension in the <a href="https://www.w3.org/wiki/Activity_Streams_extensions">Activity Streams 2.0 extensions registry</a>.</b> | ||
</li> | ||
<li> | ||
<b>Propose the extension for inclusion.</b> The proposal should include a justification | ||
for inclusion of the extension. | ||
</li> | ||
<li> | ||
<b>Vote on the extension.</b> The SocialCG will vote on whether to include the | ||
extension in the Activity Streams 2.0 context document. | ||
</li> | ||
<li> | ||
<b>Create a draft version of the Activity Streams 2.0 context document including | ||
the extension terms and namespace.</b> This is the time to resolve any conflicts | ||
with existing names in the context document. | ||
</li> | ||
<li> | ||
<b>Test the draft version of the Activity Streams 2.0 context document.</b> | ||
</li> | ||
<li> | ||
<b>Publish the new version of the Activity Streams 2.0 context document.</b> | ||
</li> | ||
</ol> | ||
</section> | ||
<section> | ||
<h2>Criteria</h2> | ||
<p>To be included in the Activity Streams 2.0, extensions SHOULD meet these requirements.</p> | ||
<ul> | ||
<li> | ||
A unique namespace, distinct from the Activity Streams 2.0 namespace. | ||
</li> | ||
<li> | ||
A JSON-LD context document at a permanent URL. | ||
</li> | ||
<li>A document that describes the terms and usage of the extension.</li> | ||
<li> | ||
An intellectual property rights policy that is compatible with | ||
inclusion in a W3C specification. | ||
</li> | ||
<li> | ||
Demonstrated implementation by at least two (2) independent publishers. | ||
</li> | ||
<li> | ||
Demonstrated implementation by at least two (2) independent consumers. | ||
</li> | ||
</ul> | ||
<p>Extensions to be included MAY meet these criteria:</p> | ||
<ul> | ||
<li> | ||
A security review, either by the submitter, members of the SocialCG, or by the <a href="https://www.w3.org/Security/wiki/IG/W3C_spec_review">SecurityIG]</a>. | ||
</li> | ||
<li> | ||
A privacy review, either by the submitter, members of the SocialCG, or others. | ||
</li> | ||
<li> | ||
An accessibility (A11Y) review. | ||
</li> | ||
<li> | ||
An internationalisation (I18N) review. | ||
</li> | ||
</ul> | ||
</section> | ||
<section id='history'> | ||
<h2>Previous Work</h2> | ||
<p> | ||
The section on Extensibility in [[activitystreams-core]] says, in part, | ||
"Some popular extensions are included in the Activity Streams 2.0 namespace | ||
document [...]". It does not define how extensions are added and which | ||
criteria are used to decide whether an extension is popular enough to be | ||
included. | ||
</p> | ||
<p> | ||
<a href="https://www.w3.org/ns/activitystreams#extensions">The section on Extensions in the Activity Streams 2.0 namespace document</a> | ||
says, in part, "The extensions must document their terms in a spec-like way | ||
at a persistant [sic] URL. Approval of extensions will be by the Social Web WG | ||
until it closes, and after that by the followup Community Group. Process and criteria | ||
for extensions approval is being finalised and will be described or linked | ||
to here in due course." | ||
</p> | ||
</section> | ||
<section id='changelog'> | ||
<ul> | ||
<li> | ||
<strong>2023-09-29</strong>: Add review criteria. | ||
</li> | ||
<li> | ||
<strong>2023-06-24</strong>: First draft. | ||
</li> | ||
</ul> | ||
</section> | ||
<section id='conformance'> | ||
<!-- This section is filled automatically by ReSpec. --> | ||
</section> | ||
</body> | ||
</html> | ||
<head> | ||
<meta http-equiv="refresh" content="0;url=https://swicg.github.io/extensions-policy/"> | ||
<title>Page Redirection</title> | ||
</head> | ||
<body> | ||
<!-- Note: don't forget to include a message and a link for users who do not get automatically redirected --> | ||
<p>If you are not redirected automatically, follow this <a href='https://swicg.github.io/extensions-policy/'>link</a>.</p> | ||
</body> | ||
</html> |