This document provides informal, internal guidance for work product editors in the OASIS OpenC2 Technical Committee (TC). It captures the working processes and norms being used by the OpenC2 TC in the development of OpenC2 standards under OASIS auspices. OpenC2 standards include the language specification, actuator profiles, transfer specifications, etc., as well as other supporting work products (the OASIS term for what a TC produces).
What is a "Work Product"? Work Product is the official OASIS term for the materials created by a TC in fulfillment of its charter (e.g. narrative documents, schemas, sample code).
What is an "Editor"? Excerpting from the OASIS Editor’s Manual (see Section 2), a work product editor is responsible for:
-
Creating and maintaining documents that reflect the consensus of the TC and incorporating agreed-upon changes clearly and unambiguously
-
Helping to find consensus positions and providing text that gets the TC to agreement
-
Bringing up unresolved issues at TC meetings, suggesting resolutions, and incorporating approved text as appropriate
-
Preparing documents for review, coordinating with TC Administration, and presenting the document to the Technical Committee for approval for a public review
-
Creating and maintaining public review comment logs
The guide says "It’s safe to say that the role of editor is likely to be the most intensive job of any in the Technical Committee. In return, however, you will find your name on the front page of the published work, you will exert the greatest influence over the form and substance of the finished document, and you will be in the best position to develop relationships with other experts and thought leaders in the TC."
These Documentation Norms will gradually be honed to a more polished form, but will likely always be something of a "work in progress".
- 1 Foreword
- List Of Figures
- To-Do List
- 2 OASIS Guidance for Editors
- 3 Work Product Development Overview
- 4 OpenC2 TC Work Product Development Process
- Appendix A: Links to Useful Software
- Appendix B: Getting Comfortable with GitHub
- Appendix C: Some Markdown and Document Management Tips
- Appendix E: Google Document Formatting Standards (Legacy)
- Parking Lot
- Figure 1: New Work Product Launch
- Figure 2: Working and Published Branches
- Figure 3: New Work Content Development
- Figure 4: Committee Specification Approval
- Figure 5: Relationships Among GitHub Repositories
- Figure 6: Upstream Fetch and Merge
To-Do: Need to clean up (or possibly remove) the end matter related to exporting GDocs to MD
To-Do: Determine if table formatting needs improvement
To-Do: Identify additional useful software tools (especially for non-Windows OSes)
Work product editors should become familiar with OASIS guidance on development of normative and non-normative products; here are links to important guidance documents:
-
OASIS Technical Committee Process: OASIS has a structured process for the establishment of TCs and the development of work products by a TC. While a document editor doesn't need an understanding of the complete process, familiarity with Section 2. TC Work Products will be helpful.
-
OASIS Editor's Manual: On 5 September 2018 the OASIS Technical Advisory Board (TAB) announced version 1.0 of the OASIS Editor's Manual, to be shared with specification editors. The manual is captured in four Google Docs for now. Anyone with the link can add comments and the TAB welcomes feedback. Please feel free to comment directly to the documents. If you prefer, you can send your thoughts to [email protected]. The Editor's Manual is published in four parts (about 30-35 total pages):
-
Part 1: The Role of Editor: explains the basics of the job you undertake when you volunteer to edit a work product.
-
Part 2: The Editorial Process: describes the work flow for TC work products from working draft through OASIS Standard.
-
Part 3: Document Structure: covers the components of work products including required sections and considerations about whether to organize a work product as a single part or a multi-part work.
-
Part 4: Work Product Preparation: covers lessons learned, tips, etc for preparing documents without errors.
-
-
Related guidance: Other documents produced by the OASIS TAB address related topics:
-
The OASIS Naming Directives. To keep a vast collection of works like the content from OASIS TCs organized in a sensible manner requires some rules governing the organization and naming of work. This document lists the limitations and requirements that apply to filenames, directories in the OASIS libraries, structural organization of work, namespaces, titles and version numbering, etc.
-
Keyword Guidelines for OASIS Specifications and Standards. Most normative content at OASIS uses RFC2119 keywords. (The exception is work planned to be submitted to a de jure standards organization like ISO at a later date.) This document provides guidance on how to most effectively use keywords with drafting specifications.
-
Guidelines to Writing Conformance Clauses for OASIS Specifications. OASIS specifications require a section with clauses that an implementation must comply with in order to be deemed a conforming implementation. This document gives guidance on how to go about preparing these for your specification.
-
Proposed Interoperability Guidelines. These guidelines help you write specifications that are precise enough to ensure that implementations are interoperable.
-
W3C Recommendation Citation List for OASIS Editors. This document lists current W3C Recommendations in proper citation format for easy cut-and-paste into OASIS specs.
-
IETF RFC Citation List for OASIS Editors. This document lists current IETF RFCs in proper citation format for easy cut-and-paste into OASIS specs.
-
Checklist for Verifying the Editorial Quality of OASIS Specifications. When you have a document ready to approve for publication, this document lists key checkpoints you can use to ensure that it is ready to go and avoid some common errors. This is the same checklist that OASIS staff and TAB use to review specification drafts during publication and public review.
-
This section describes the process the OpenC2 TC is using in developing work products.
The OpenC2 Language Specification is the foundation of a family of documents that collectively define the language, tailor its use with specific cybersecurity functions, and describe how other protocols are used in a supporting manner (e.g., for message transfer). This family includes a variety of document types:
- Language Specification
- Architecture Specification (pending)
- Actuator Profiles (APs)
- Transfer Specifications
- Supplementary documents
- Schemas
Documents of similar type (e.g., actuator profiles) within the family logically have similar content and organization, so familiarity with previously created OpenC2 specifications is helpful when developing a new work product.
The OpenC2 TC has been using a development process inspired by agile software development concepts. Under this process, editors work with the members of the TC to incrementally develop and gain consensus regarding the content of a work product. This process includes moderately frequent publication of Working Drafts (WDs) that are then presented to the OpenC2 TC for approval as Committee Specification Drafts (CSDs). Approval of a CSD formalizes and documents TC consensus on the material from that increment of development.
Once the editors and TC members agree that a work product is complete and mature, the remainder of its review and approval are governed by the OASIS TC Process for public review, approval as a Committee Specification, and eventual approval as an OASIS Standard (following additional public review). Sections 2.6 through 2.8 of the TC Process document describe those aspects of work product development.
The overall sequence for development of a work product, as currently performed within the OpenC2 TC, is as follows:
- Identify WP Need
- Determine WP name
- For Actuator Profiles, add the AP to the namespace registry
- Request starter template and GitHub repository
- Upload template and configure repository
- Apply agile, incremental development (cycle)
- Development activity review and approval through the working meeting process
- Intermittent WD releases / CSD approvals
- Conduct Public Review (cycle)
- CS Approval & Publication
Section 4 and the Appendices provide detailed information about these steps.
As of December 2018, the OpenC2 TC shifted to focus on GitHub as our primary tool for the development of work products, and has adopted Markdown (MD) as our preferred authoritative format for work products (AKA documents) and the GitHub Fork & Pull model for controlling the development of work product content. If you’re completely unfamiliar with GitHub, Annex B provides an introduction and links to other helpful information sources.
(NOTE: The use of Google Docs as an initial development platform for work products remains available as an option; a script is available to export Google Docs to Markdown and can be used when the editor(s) is ready to shift to GitHub to mature the document. All TC member should have access to the TC's Google Drive space.)
Markdown is a text-based language that uses a simple formatting syntax to make editing easy, the Markdown source very readable, and the processed output nicely formatted. Since OASIS uses GitHub repositories for version control, the OpenC2 TC is specifically using GitHub-Flavored Markdown (often shortened as GFM), the dialect of Markdown that is currently supported for user content on github.com and GitHub Enterprise.
GitHub offers many useful features to support our process, including rich version control features, issue capture and discussion, easy editing of text-based formats, and ready availability of free and open-source tools to support a variety of working preferences. There are three types of GitHub repositories in use by the OpenC2 TC:
-
TC Product Repos: For each TC-sponsored work product, OASIS TC Administration creates a GitHub "version control instance" (AKA "repository" (AKA "repo")), and assigns the editor(s) of the document as "maintainers". Maintainers have the privilege to commit changes to the repository's contents, be those changes their own work or contributions from other TC members. The assignment of maintainers is discussed in Section 4.3.2.
-
TC Working Repos: In addition to repos specific to individual work products, the TC has other repos to support its efforts, such as the capture of use cases, and a repository to support development of custom actuator profiles (which may eventually turn into TC work products and receive individual repos). This document is stored in the TC Operations repo, which is another "working repo".
-
TC Open Repos: These are established by the TC to capture the development of (primarily) software related to the TC's objectives.
This document is focused on the use of TC Product Repos to develop TC work products (e.g., specifications, committee notes). However, the TC's basic development process and the "fork & pull" model can be applied to updating the contents of all three types of repositories.
This section outlines the TC's standard work product development process.
Any TC member can propose a work product, typically by presenting their idea to the TC membership (e.g., at the monthly TC meeting). The work product will then need a name and an abstract in order to submit the request for a starter document (naming and starter document requests are discussed in the next section). In addition, the TC must approve a motion requesting the establishment of a version control instance (repo) for the newly identified work product; a simple majority vote is required for approval.
Once the need for a work product is established, the next step in creating a new work product is to name the document and create a shorthand for it. Give some thought to the product name when requesting a starter document, as that name will live on essentially forever. Consultation with the TC co-chairs and secretary is recommended, as well as familiarity with the OASIS Naming Directives. Consultation with the OASIS TC Administration team is also helpful, as they can assist with applying the naming directives and help avoid collisions with the names of other OASIS products.
The TC's work products can be broken into over-arching documents (e.g., Language Specification, Architecture Specification) that define OpenC2 overall, and supporting documents (e.g., actuator profiles, transfer specifications) that address specific features and functions. To provide for consistency, the following principles apply:
- Overarching documents should spell out OpenC2 in their titles.
- Supporting documents don't need to do so as they are dependent on the overarching documents.
The following example titles illustrate the application of these principals:
- Open Command and Control (OpenC2) Language Specification
- Open Command and Control (OpenC2) Architecture Specification
- OpenC2 Actuator Profile for cyberfunction
- OpenC2 Transfer Specification for protocol
Since the TC name (i.e., "openc2") is already included in the URLs and GitHub repo names that OASIS assigns there is no need to include "openc2" or "oc2" in the shorthand name for the product (a lesson learned since the TC's first work products were named). A useful convention is to include the document type, so the following patterns are recommended:
- Actuator profiles:
ap-<function shorthand>
- Transfer specifications:
transf-<protocol shorthand>
NOTE: The initial actuator profile for stateless packet filtering and transfer specification for HTTPS do not follow these patterns, but the patterns are recommended for new specifications. If a new type of document is needed, the TC co-chairs and secretary can assist in determining the naming pattern for the new document type.
As an example, an actuator profile for anti-virus might have the shorthand of "ap-av", leading to:
- Repository name: oasis-tcs / openc2-ap-av
- Document URL: docs.oasis-open.org/openc2/ap-av/v1.0/ap-av-v1.0.html
The OASIS TC Administration team will enforce the shorthand name originally attached to a product when creating OASIS-published versions (e.g., committee specification drafts [CSDs]).
Here are some example names from current committee work; the last three apply the naming conventions described above:
Document | Shorthand Name | Repo Name (openc2-...) |
---|---|---|
Open Command and Control (OpenC2) Language Specification | oc2ls | …-oc2ls |
Open Command and Control (OpenC2) Actuator Profile for Stateless Packet Filtering | oc2slpf | ...-apsc-stateless-packet-filter |
Specification for Transfer of OpenC2 Messages via HTTPS | open-impl-https | …-impl-https |
OpenC2 Actuator Profile for Packet Filtering | ap-pf | ... openc2-ap-pf |
Specification for Transfer of OpenC2 Messages via OpenDXL | transf-odxl | …openc2-transf-odxl |
Specification for Transfer of OpenC2 Messages via MQTT | transf-mqtt | ...-openc2-transf-mqtt |
All OpenC2 type definitions are contained in a specification, and each specification is assigned a globally-unique namespace in the form of a URI. Types in one specification can reference types defined in another specification using a namespaced name. As OpenC2 uses Actuator Profiles to extend the core language, for these extensions to be recognized new APs must be added to the Namespace Registry. A more complete discussion of OpenC2 namespaces can be found in Appendix F of the OpenC2 Architecture Specification.
A namespace entry has the following form (excerpt from the namespace registry):
Prop ID | Property Name | OpenC2 Specification | NS Prefix | Namespace | Status |
---|---|---|---|---|---|
OpenC2 Language Spec v1.1 Common Types | ls: | http://docs.oasis-open.org/openc2/ns/types/v1.1 | Types section of LS | ||
1024 | slpf | Stateless Packet Filtering AP | slpf: | http://docs.oasis-open.org/openc2/ns/ap-slpf/v1.0 | CSPRD01 2019/05/31 superseded by PF |
The namespace registry is maintained in the GitHub repository
for the Architecture
Specification, in
the file namespace-registry.md
. When initiating the development
of a new AP, a pull request should be made to update the
namespace registry file with a new line representing the new AP;
the Prop ID
value for the next AP should be one greater than
the Prop ID
of the highest-numbered Standard Actuator Profile,
and the Property Name
and Namespace
values should be set to
the <function-shorthand>
for the new AP.
The development environment for a new work product includes the starter document template from OASIS and the work product's GitHub repository ("repo"). The environment grows over time with forks of the repo created by contributors. The process for establishing and initializing the development environment is illustrated in Figure 1 and described in the following sections. The process utilizes the GitHub repository branching concept further described in section 4.3.3
(source: sources/work-product-init.plant.txt)
Once a new work product is identified and a product name and shorthand selected, the next step in the process is to request a template / starter document from OASIS. For a markdown-formatted product, a companion request is made for a GitHub repo in the TC's space (i.e., oasis-TCs / openc2-...).
While it might seem reasonable to launch a new work product by cloning an existing TC product, following the OASIS process has several advantages:
-
Encourages the TC and the editor(s) to think through naming the work product appropriately
-
Creates awareness of the new work product in OASIS TC Administration, and gives them an opportunity to identify any possible problems (e.g., a name collision with other OASIS work [which has happened])
-
Ensures that the work product begins from a template that reflects current OASIS formats and guidelines
Requesting a template / starter document creates no obligation for the TC or the editor(s) that the work product will be completed.
NOTE: OASIS changed their document formats in late 2020; an overview of the new structure for a specification is provided for reference in Document Template 2020. The starter document provided by OASIS contains much more complete guidance than the overview.
Both the template / starter document and a GitHub repo are requested using forms on the TC Admin Requests page. Any TC member may place the requests, but typically this will be handled by some one of: the document editor(s), the TC co-chairs, or the TC Secretary. Editors who are uncertain how to proceed should request assistance from the Secretary. Submitting a TC Admin request requires login with the submitter's OASIS Kavi credentials. The relevant forms on the TC Admin Requests page are:
-
Request a template / starter document (use the notes section of the request form to specificallyk request a Markdown-formatted starter document)
-
Request a TC GitHub version control instance be created (this requires a link to the TC meeting minutes where the repository request was approved)
NOTE: Links to Individual request forms are not provided here to allow for future changes by TC Admin. Use the TC Admin Requests link above to get to the list of forms.
In response to the request for a template / starter document, TC Admin will send a message to the TC mail list with an attached ZIP file containing:
- a Markdown file (.md) -- this is the main template or starter document, customized with titles and other elements for this Work Product
- an HTML version generated from the markdown - for reference
- a directory /styles containing an HTML style sheet (.css)
- a directory /images containing an example image file
- a "README" text file with important instructions
The editors / maintainers are responsible for unzipping the attachment and populating the repo with the starter document content for the work product. The email with the starter document package contains other valuable info, which the editor(s) should also read (the same information is included in the README text file).
OASIS TC Administration has overall control of repositories for
OASIS work products (i.e., repositories that appear in the
github.com/oasis-tcs/...
space on GitHub). TC Administration
are the only entity that can create new repositories, rename
existing repositories, archive a repository that is no longer
needed, and manage GitHub user privileges regarding any
particular repository.
When requesting a repository for a new work product, the TC provides descriptive information for the work product, a link to the TC meeting minutes that document approval of the repository's creation, and identifies the maintainer(s) to be assigned to the new repo. The OpenC2 TC's convention is that the maintainers of a work product repo are:
- All editors of the work product,
- The TC co-chairs, and
- The TC secretary.
The co-chairs and secretary are named as maintainers to provide backup / continuity if the editor(s) become unavailable. Every maintainer must establish a GitHub account. Document editors must be familiar with the OASIS guidance on using GitHub Repositories for OASIS TC Members' Chartered Work. In particular, the repo maintainers must enforce that contributions to the work product are only from TC members and that the Intellectual Property policy under which the TC operates is enforced.
The GitHub identifiers of the maintainers are listed in a "write team" on the site. When OASIS TC Administration creates the repo, they will assign the maintainers by addeing them to the write team, and then will notify the TC mail list once the repo has been created. A list of the TC's work product repos and the maintainers associated with each can be found on the OASIS Teams page on GitHub. Changes to a repository's write team can be intituted by emailing a request to the OASIS TC Administration team (i.e, Chet Ensign and Paul Knight).
The following branching scheme has been worked out to facilitate the configuration control of work products developed by the OpenC2 TC. The two branches in the repo are intended to organize the work as follows:
-
The Working branch contains the newest content for the work product, material that is actively being developed, and subject to potentially frequent and significant change. Contributors to the work product should target their inputs to the Working branch. Working Draft (WD) versions of the work product are identified using the GitHub Release feature with the Working branch content as the basis for the release, and the WD content is them uploaded to the TC's document store at OASIS (see Section 4.4.1 for details).
-
The Published (default) branch contains TC-/OASIS-approved Committee Specification (CS) and OASIS Standard (OS) versions of the work product. Until the first CS is approved the Published branch will only contain administrative documents.
The TC repos' standard README.md
files include the following
graphic to highlight this organization:
When OASIS creates a repository for the work product it will be populated with three files:
-
CONTRIBUTING.md: rules and restrictions on contributing to this repository
-
LICENSE.md: information on applicable OASIS policies and Intellectual Property (IP) constraints.
-
README.md: overview of the repository's contents and purpose. This file is displayed by default when anyone loads the repository home page (NOTE: this is different than the README.txt in the starter template).
The first two files must remain when other contents are added to the repository.
The OpenC2 TC has developed a model README.md file, a copy of which is contained in the TC Ops repo. The editor(s) should copy, rename, and modify the MODEL-README.md file with information specific to the new repository and the work product it contains. The model README.md is annotated with the types of updates needed and the TC Secretary can provise assistance in tailoring the model README.md for the specific work product.
As shown in Figure 1 above,
when the repo is available the maintainers should create a
working
branch from the published
branch, and then populate
the working
branch with the starter document received from TC
Administration (including the subdirectories and supporting
files). Activity to develop the product then proceeds as
described in the next section. The published
branch will only
have administrative files until a CS is approved, at which point
the maintainers populate it with the current CS version. Each
time a new CS is approved the published
branch is updated.
Typical contents of the working branch are:
<work product>.md <-- the primary file containing the work product contents
/images <-- folder with binary files for images in the document
/sources <-- folder with sources to allow editing/updating images
There may be other folders or files as appropriate to the work product under development.
Work-in-progress is always handled in the working
branch,
using the standard GitHub mechanisms of forking the work
product repository and creating pull requests (PRs) with
contributions. When Working Drafts (WDs) are declared, the
GitHub Release feature is used to create the WD package for
upload to OASIS. If a WD is approved as a Committee
Specification Draft (CSD) the editors should edit the
Release description to (i) record that the WD was approved
and the CSD version, and (ii) add a link to the published
CDS at OASIS. A link to the approval ballot can also be
added to the release description.
NOTE: In September 2024 OASIS published Document Life Cycle Best Practices and in November 2024 the OpenC2 TC adopted the standing rules suggested in that document as Standing Rules 7, 8 and 9. Those changes significantly affect the work product development process and the description below has not been updated to align. Work Product editors should consult the Best Practices document for guidance and request assistance from the TC Secretary if needed.
Developing a document on GitHub requires the editor to develop a level of comfort with two distinct skills:
- Authoring a document using Github-Flavored Markdown for formatting
- Using GitHub / Git procedures for version control
Document creation using GitHub is inherently text-based. It is possible for an editor to do all of their work entirely within GitHub, but for many it may be more comfortable and/or convenient to create a local copy of the repository to enable use of preferred text editors, working offline, etc. Annex A provides suggestions for useful software. Annex B provides an overview of establishing an environment with a related set of repositories to enable working in this manner and a link to an excellent explainer; other resources can readily be found by searching on-line. TC members are also happy to share their GitHub knowledge, and GitHub provides an extensive help library.
Figure 3 illlustrates the flow of information between GitHub and OASIS as working drafts are posted and CSDs are approved. It also illustrates the use of GitHub release tags to enable precisely locating specific versions of the work product in the repository. Figure 3 also shows updating the working version from a published CSD. It is common for OASIS TC Administration to find and fix issues in work products during publiction (e.g., correcting broken links). The incorporation of such changes into the working version aids in the publication of future versions. The details of such changes are commonly included in the message sent to the TC mail list when a CSD is published.
(source: sources/dev-content.plant.txt)
A frequent occurrence in developing a work product is the posting of a "Working Draft" (WD) version to OASIS. This must be done, in particular, any time a ballot is to be held to approve a document as a Committee Specification Draft (CSD), which happens periodically during our "agile" document development process. The GitHub Releases feature is used to tag a WD within GitHub and to help create the WD package for upload to OASIS. The creation of a WD is a two-step process:
-
In the
working
branch, refresh the document's table of contents (see next section) and ensure the document title page is updated to reflect the correct WD number and date. -
Use the GH Releases feature to create the release package.
As final preparation to create a WD, editors should
- update the WD sequence number and date information on the title page so that they are current, and
- update the TOC within the Markdown file prior to declaring a release to create a WD.
If using Microsoft Visual Studio Code, the Markdown All-In-One extension is very helpful, and can create and update TOCs within the editor.
Another alternative is pandoc. a flexible document conversion tool that can created the TOC in a local file, as follows:
pandoc -f gfm --toc --toc-depth=5 -s -o <outfile> <infile>
where <infile>
and <outfile>
are markdown files. The
<infile>
is the markdown file from GitHub containing the
working draft content. The TOC will be added to the <outfile>
at the beginning of the file, and the editors must manually move
it to the proper place in the document. There may be other
clean-up required of the TOC (e.g., extraneous headings); the
editor should review it carefully, delete unwanted content, and
confirm that all internal document links work properly.
The editor uses GitHub to create a release, and assigns it an appropriate identification tag, typically identifying the target version and the WD revision number (e.g., v1.0_WD05). GitHub creates a ZIP file containing the contents of the selected branch of the repository at the time of the release's creation. That ZIP file is the basis for the WD package.
The essential contents of the WD package are
- the Markdown file for the document, and
- any image files, which should be in the /images folder.
The /sources
folder can be deleted prior to uploading the WD to
OASIS.
The editor has the option to create and include an HTML file;
this can be done using pandoc
and the CSS files supplied by
OASIS in the template / starter document package. While the HTML
file is optional, creating one can be helpful in that the HTML
version provides an easily-readable rendered version of the
markdown file that can be reviewed in a browser for quality
control purposes. pandoc
comes into play again here to create
the HTML file. With the working
branch checked out and the
directory containing the work product markdown file as the
current directory, the following command will create the HTML
file:
pandoc -f gfm -t html <filename>.md -c styles/markdown-styles-v1.7.css -s -o <filename>.html --metadata title="Title of Specification Version X.Y"
NOTE: if creating an HTML file, the editor can also point to the CSS file maintaind at OASIS:
https://docs.oasis-open.org/templates/css/markdown-styles-v1.7.3a.css
; this URL can be referenced directly in thepandoc
command after the-c
option.
The editor should remove extraneous material from the ZIP file (e.g., the image sources in the /src folder) prior to uploading the ZIP file to OASIS as a WD.
An essential part of the OASIS standards development process is public review of TC work products, as documented in sections 2.6 and 2.8.2 of the TC Process. During a public review, comments are submitted via the TC mail list (for TC members) and the TC public comments list (for non-TC members). The TC is required to:
acknowledge the receipt of each comment, track the comments received, and post to its primary e-mail list the disposition of each comment at the end of the review period. (TC Process, Sections 2.6 & 2.8.2)
Disposition of comments can include any of (i) altering a document to address a comment, (ii) deferring a comment to future work (e.g., a later version of the document), or (iii) determining that no change is required. The OASIS requirement is to provide an artifact, posted to the TC's mail list, that records the TC disposition decisions. If no comments are received during a public review, an email recording that result is sent to the TC mail list as the artifact.
The OpenC2 TC is handling public review with a hybrid approach of a Comment Resolution Matrix (CRM) captured in a shared Google Sheet to maintain an overall record of comment disposition, along with the use of GitHub issues in the associated work product repo to capture the details of how each comment is addressed. The CRM connects the original comment emails in the public archives of the TC and comment mail lists with the GitHub issues and, if appropriate, pull requests where the details of comment disposition are recorded. When the process is complete, the CRM is exported to a PDF that is sent to the TC mail list as the definitive public artifact recording the outcomes.
The OpenC2 TC has a CRM
template
in the admin > template
folder on our Google
Drive.
Editors handling public review comments should make a copy of the
template, rename it appropriately, and use it for tracking
comment adjudication. The CRM template columns are as follows:
Column | Usage |
---|---|
Item # | A tracking identifier for the comment. Editor's discretion for assigning. It can be helpful to put this identifier into the titles of associated GitHub issues and pull requests for easy cross-referencing. Recommended use is to combine a shorthand for the document with a sequence number. Using a leading hundreds (or thousands) value for the sequence number can key it to a particular public review (e.g., HTTPS-101 is the first comment from the first public review, HTTPS-203 is the third comment from the second public review). The order of comments in the CRM has no significance. |
Source | Individual or organization that submitted the comment. |
Email Link | Web link to the specific email containing the comment in the OASIS public archive of the appropriate mail list (i.e., OpenC2 TC mail list public archive, OpenC2 TC comment mail list public archive) |
Section | Section of the document where the target of the comment appears. |
Page | Page where the target of the comment appears (usually from a PDF version of the document). Optionally a column may be inserted for the line where the target of the comment appears, if line numbering was applied to the public review document. |
Comment (or Comment Summary) | The comment text or (editor's discretion) a summary of the comment. If a summary is used, the editor should: Use care to correctly capture the intent of comment, and include the full text of the comment in the GitHub issue where it is addressed, to avoid any ambiguity. |
GitHub Issue Link | Web link to the GitHub issue where the comment will be discussed and disposition recorded. |
Resolution Summary | A brief summation of the disposition (e.g., "ACCEPTED: added language …", DEFERRED to later version). Having this summary in the CRM is important so that the permanent artifact in the OASIS archive meets the requirement to "post … the disposition of each comment", without need to refer to other sources. |
GitHub Change Link | Web link to the GitHub pull request where the specific document changes related to the comment, if any, are identified. |
Material? | Editor's assessment of whether any changes made to address the comment represent material changes to the work product. Material changes made to a document as a result of a public review require that the updated document undergo a subsequent public review of the changed material. |
Our editors have found it useful to employ GitHub's labels feature when organizing issues from public review comments for discussion. Labels can be used to identify:
- Which public review generated a comment (e.g., PR01, PR02)
- A set of issues planned for discussion at an upcoming meeting
- A set of issues that all relate to a particular topic with a work product (e.g., Group_Actions)
- Issues that have tentatively reached resolution (e.g., Candidate_For_Closure)
- Issues that are being deferred (e.g., Future)
Examine the issue labels in existing work product repos for additional examples. GitHub creates a default set of labels for a repository; these are oriented toward the standard software development use case, and editors should feel free to delete them if desired.
Figure 4 shows the process for approval and publication of an
OASIS Committee Specification (CS). The approval of a CS is
governed by Section
2.7
of the TC Procedures. Once a public review has been completed
without material changes to the document, TC can request OASIS TC
Administration conduct a Special Majority
Vote
to approve the document as a CS. Once the CS is approved, TC
Administration will create the CS version of the document in
multiple formats, and publish an announcement on the OASIS home
page. The work product maintainers should upload the CS versions
of the product to the repository’s published
branch, with
correspondent relevant updates to the README.md file. As with the
publication of a CSD, the editors should also update the
working
branch copy of the work product source to incorporate
any changes made by OASIS TC Administration in the publication of
the CS.
(source: sources/pub-cs.plant.txt)
-
Git: open source version control software. Required to create and manage local repositories for local / offline editing -- https://git-scm.com/
-
pandoc: This utility is a Swiss Army Knife of marked-up file conversions, and is also useful for creating tables of contents for Markdown files. -- https://pandoc.org/
-
Microsoft Visual Studio Code: powerful free text editor that integrates easily with Git / GitHub. With appropriate extensions you can get a side-by-side view of raw and rendered Markdown while editing. MS VSC is based on the Electron platform so it is available for Windows, Mac, and Linux -- https://code.visualstudio.com/
-
Diagrams.net (was Draw.io): an open source drawing tool (similar to Visio / Gliffy / LucidChart). It's a free, online diagram editor and viewer with a wide variety of shapes, icons, connector and templates. It can also import and export numerous file formats, albeit with some limitations. -- https://app.diagrams.net/
NOTE: In a February 2020 blog post it was announced that Draw.io is being renamed to diagrams.net. The new home page is www.diagrams.net. For now, draw.io redirects to diagrams.net, and the site still uses .drawio.png as the default format for saving files locally.)
-
Tables Generator: a website that will generate a template for a table in a variety of formats including Markdown, HTML, and others. This is a really useful resource for creating the structure of a table in Markdown, since doing that manually can be rather tedious. You an also populate table content along with structure. -- http://www.tablesgenerator.com/markdown_tables
For those unfamiliar with using GitHub and Git, this
article
provides a helpful (albeit colorfully presented and highly
opinionated) explanation of the concepts and processes (feel free
to skip the introductory rant and jump to the GitHub-oriented
meat [search for "my previous article"]). Another good
introduction is this
article
from someone who isn’t primarily a programmer. A web search for
"github writer" will yield other similar articles. Note that many
of these these articles tend to focus on the use of command line
git
, which may be only minimially necessary if you're using a
GitHub-aware editor. Also, some were published long enough ago
that some details of the GitHub user interface have changed, so
the screenshots may be a bit out-of-date.
If you're unfamiliar with the use of Git and GitHub for version control, the terminology and process can be a little bit hard to grasp. The articles linked above can definitely help. The following diagram illustrates the process of connecting GitHub repos and a local Git repo to work on products. The process steps are listed below the diagram, with links to the GitHub glossary for definitions of key terminology.
-
GitHub: A Project Owner creates a repository ("repo") for the document. This the "primary" version of the document, and its repo is the "Upstream Repo". In the case of OpenC2 TC work products, these repos are created and managed by OASIS TC Administration, with one or more TC members established as maintainers for the repo.
-
GitHub: A Contributor creates a fork (i.e., personal copy) of the upstream Repo in their own GitHub account. This fork will contain a copy of the upstream Repo's content as of the time the fork was created. The contributor can work purely in this document on the web, or create a local Git repo (step #3) where they can, for example, edit with their favorite text editor or Git-/GitHub-aware tool set.
-
Local: A Contributor "clones" their GitHub fork of the document to a repo in the Git environment on their local system.
NOTE: The default names in the GitHub documentation for the repos described in Steps 1 and 2 here are "upstream" for the "OASIS" repo, and "origin" for the "Fork" repo. The instructions in B.1 describes using
git
commands to establish the "OASIS" and "Fork" names used here.
-
Local: The Contributor can edit document content and create additional content, including graphics and other files in their local environment. Command line
git
or a git-aware editing tool is used on the local machine command line to update the local repo to reflect new and modified content. -
Local: When the Contributor wishes to submit material to change the primary document, they use the
git
"push" command (on the local command line) to replicate their content to their fork repo. This updates the fork repo to match the local repo. Pushes can be done frequently to propogate local changes to the GitHub fork as a backup mechanism, until the Contributor determines it is time to contribute their changes onward. Note thatgit
-aware editing tools, such as the Microsoft Visual Studio Code editor, have built-in support for pushing changes to GitHub, eliminating the need to use the command line. -
GitHub: The Contributor creates a Pull Request (PR) from their GitHub fork repo back to the upstream repo to contribute their proposed changes to the primary document. Pull requests can target the default branch of the upstream repo or any other chosen branch (e.g., the "working" branch being used to accumulate changes toward a future version of a document). Recall that while
main
is the standard default branch on GitHub,published
is the default for OpenC2 work product repos, as described in Section 4.3.3. -
GitHub: The Project Owner can accept a PR to merge the Contributor's material into the specified branch of the upstream repo. This modifies the upstream document by incorporating the Contributor's additions and deletions. GitHub offers the Project Owner the option to edit the contribution before merging the pull request.
As the above process is executed, the upstream repo may be receiving changes from multiple contributors, which means that any one contributor's fork may become out of sync with the upstream repo. GitHub has a feature to update a fork repo with changes from the upstream repo. As shown below in Figure 6, when viewing your fork of the upstream repository, GitHub will indicate if the currently selected branch is behind the corresponding upstream branch. Clicking on "Fetch upstream", and then selecting the "Fetch and merge" button will update the fork from the upstream repository. This greatly simplifies maintaining synchronization when multiple parties are contributing to the upstream repository. Once you've resynchronized your fork, you should then also synchronize the local clone. If the upstream and the fork are badly out of synchronization, it may still be more straightforward to delete and recreate the fork (and your local clone).
By default the local git
environment will identify the local
clone of your fork of a repository as origin
, and the original
repository that was forked as upstream
. It is possible to
rename the remote repositories to names the user prefers. This is
done using the command:
git remote rename <current> <new>
The following commands will change the default names to fork
and oasis
, respectively:
$ git remote rename origin fork
$ git remote rename upstream oasis
You can verify that two remote tracking branches have been
created: "fork" and "oasis" with the command git remote -v
:
$ git remote -v
fork https://github.com/<personal-account/<repo-name>.git (fetch)
fork https://github.com/<personal-account/<repo-name>.git (push)
oasis https://github.com/oasis-tcs/<repo-name>.git (fetch)
oasis https://github.com/oasis-tcs/<repo-name>.git (push)
Markdown is text-oriented and intended to be both easily readable in its raw form, and easily rendered into HTML or other more visually pleasing forms. GitHub provides some guides for using GitHub-Flavored Markdown (GFM):
-
Basic markdown writing and formatting syntax (covers most of what you need to know; somewhat more detailed than the overview provided below)
-
GFM overview: https://guides.github.com/features/mastering-markdown/ -- a quick guide to the most-used formatting features; will answer most questions.
-
GFM spec: https://github.github.com/gfm/ -- a detailed formal specification of GFM, more useful to programmers than editors, but can help with troubleshooting.
This section points out some aspect of using GFM to help simplify document creation, maintenance, and reading.
git
was originally created to track changes in computer source
code, which is generally very line-oriented, and lines of
computer code are typically relatively short. When GitHub
displays a diff, it's doing a line-by-line comparison between the
old and new versions. In a document, if a paragraph is one very
long line, it's much harder for GitHub to easily display the
line-in / line-out changes, so it's helpful to break the source
text into shorter lines and maintain that approach to make
changes more visible when viewing a diff (e.g., in a pull
request).
Cross-links to a section header or figure label within a document
use the same hyperlink structure as ordinary web links, but with
a specific format for the (link)
portion. As an example, the
following source:
[3.2.2 A Level 3 Heading](#322-a-level-3-heading)
will display as 3.2.2 A Level 3 Heading and is an active internal cross link.
The text to display is the same as with any other link, but the (link) portion has
- a single leading hash mark,
- the section number with punctuation removed, and
- the section name in lower case with all spaces replaced with hyphens.
When using a tool like pandoc
to create a TOC, all of the TOC
entries are automatically created using this format so that the
TOC is a collection of active links to the document's sections.
Experience has shown that automatic TOC creation doesn't always
correctly handle headings that contain characters like ampersands
(&) and forward or back slashes, so a quality control check of
generated links is important, and some manual editing may be
necessary to fix a link that doesn't work due to special
characters.
When creating graphics for a work product, editors should favor approaches that also create an editable original file, ideally in an open format, available to TC for future use. The goal is to ensure that a graphic can be edited, if necessary, for future document versions. The suggested approach for graphic handling is:
- Create a folder in the document repo to hold editable image
sources (e.g.,
/sources
) - Create images using an open source or widely available tool (see suggestions below)
- Export images for use in document from the image editor in a
suitable form (e.g., PNG, JPEG), and place those images in the
/images
folder in the document repo so that they can be linked into the document - Place the corresponding editable source files for the image in
the
/sources
folder
For images created and stored purely in web-based tools (e.g.,
Google Draw), create a file (e.g., SourceLinks.md
) in the
/sources
folder, and populate that file with brief descriptions
of the images and corresponding links to the original image file
in, e.g., the TC's Google Drive space.
Some suggestions for image editing / creation tools:
-
Diagrams.net, a free, on-line diagramming tool similar to Visio / Gliffy / LucidChart
-
PlantUML, a tool that can render a variety of images from structured source text. Excellent for creating sequence diagrams. PlantUML's on-line server can be used without need for any local software installation. Image source code can be freely transferred with copy-and-paste between a local copy of an image's source and the server's code window for updating.
-
Gravit Designer, "full featured" vector editor, has free and pro versions
-
Google Draw for diagrams created in the TC's OASIS Google Drive space
-
Well-known office application drawing tools (e.g., PowerPoint, LibreOffice)
While the OpenC2 TC is no longer primarily using Google Documents to collaboratively develop documents, that process was used successfully for some time, and a script is available to export a Google Document to Markdown (specifically GitHub-Flavored Markdown [GMF]) to create the authoritative version for final TC approval and publication. This appendix preserves the TC’s best practices for initially developing work products using Google Docs. Former TC member Jason Romano created the script for exporting Google Docs.
A Google Docs add-on called Paragraph Styles+ (PS+) is very useful to manage decimal outline numbering when developing work products in Google Documents. With the shift to using GFM for creating the TC’s authoritative versions, the visual formatting aspects of PS+ are no longer relevant, but its utility for renumbering remains helpful.
OASIS documents use decimal outline numbering. The use of Paragraph Styles+ makes this much easier. The TC uses "Annex" for supplement section to documents (e.g., examples, acronym lists, acknowledgements). Annex titles get Heading 1 formatting, which means Paragraph Styles+ will number them; we edit out those numbers during the publishing process.
(need conventions for figure & table numbering)
The Acknowledgements section should be the penultimate Annex, before the document revisions. The OpenC2 TC's standard for entries in Acknowledgements sections is
- Firstname Lastname, Org
sorted alphabetically by last name. For example:
-
Joseph Brule, National Security Agency.
-
David Lemire, G2, Inc.
-
Jason Romano, General Dynamics
Typically, document editors list any person who either voted or provided a comment via Github, Google Docs or via a ballot.
David Lemire: What is the significance of lines that have leading hash marks?
Jason Romano: That's Markdown code for heading styles. It's a quick hack to differentiate between numbered and un-numbered headings. I may be able to remove that now that I'm using Paragraph Styles+ to manage section numbers. I'll experiment with that.
Nope. Now I remember. If I call it a "Heading" then Paragraph Styles+ wants to give it a number. When the document is converted to Markdown, the hash marks get interpreted as Headings, so the Markdown looks fine. The HTML and PDF versions will be taken from the Markdown. So only the Google Doc will look a little weird.
David Lemire: So # texttextext and something styled Heading 1 are both Heading one in MD, and the numbering comes from PS+? Either way I guess I just leave the hash marks alone.
Jason Romano: For the most part, you won't have to worry about the hash marks, because they should only show up in the front matter which should be static and the appendices. You'll want to manually add appendix numbering: D.1, D.2, D.2.1, etc.
Using PS+ to apply heading format to Annexes and their subsections will result in something like this:
TBSL: inspecting the Google Doc to Markdown export results, some of the key points are here:
Formatting a trailing space: if in the Google doc a trailing space is formatted, e.g., bold or italic, that will cause glitches in the rendering of the markdown file. Example, with a $ sign replacing the trailing space in the Google Doc source; note that the $ is italic, but "we" isn't:
-
In Google doc: … in this *test document$*we include …, leads to
-
Markdown: … in this _test document _we include
The fix is to clear the formatting on the trailing space in the Google document and repeat the Markdown export.
Hash marks for headings
Limitations on table formatting
-
Markdown doesn't render lists inside of table cells. Need to manually format with numbers or asterisks if you need something like that.
-
If a table immediately follows a list in a Google Doc, the Markdown export script (as of Sept 2018) fails to insert a necessary blank line between the last list item and the table. The MD file needs to edited to manually add a blank line between the list and the table.
Clean-up:
-
Move GDoc process to an Annex as the alternative approach?
-
Can strip out all of the Paragraph Styles+ formatting specifics, since formatting is now going to be handled by MD rendering and HTML CSS.
- Need to confirm that GDoc Heading styles suffice for Jason's markdown conversion script
-
Probably still need the comment control script
-
Definitely need the MD export script
-
Figure 2 assumes a Committee Specification has been approved (the
v1.0 document) and work is proceeding on a future version (the
v1.1 document). For a new work product, as shown in Figure 1,
above, the published
branch would be populated with the
OASIS-supplied template, and then the working
branch created
from the published
so that the template is available in the
working
branch as the starting point. Note that this branching
strategy is intended for the work product managed in the repo.
There may be reasons to make changes directly to the published
branch, such as to update the information in the repo's README.md
file.