Skip to main content

Review tool for IETF documents

Project description

ietf-reviewtool

This is a simple Python 3 tool to download and review IETF documents, such as Internet-Drafts or RFCs, and comes packaged as a single ietf-reviewtool script.

About

ietf-reviewtool offers several different review tools:

  • fetch downloads items (I-Ds, charters, RFCs, etc.) for review

  • fetch-agenda downloads all items on the agenda of the next IESG telechat for review

  • strip strips headers, footers and pagination from items, similar to the earlier rfcstrip tool

  • review extracts inline reviews from the indicated items and formats them for sharing by email or submission to the IETF datatracker, with some functionality that is similar to the earlier idcomments tool

This is a work in progress. Additional functionality will be added over time, so there is a chance this documentation only covers a subset of what the actual tool offers. You can get command line help on the various tools by passing --help to ietf-reviewtool and its sub-tools.

Installation

You can install this via PyPI:

pip install ietf-reviewtool

Usage

An example workflow of the tool is as follows.

Downloading items

You first download the item for review:

ietf-reviewtool fetch rfc1925.txt

This downloads the text version of RFC1925 into a text file named rfc1925.txt and (by default) performs a strip operation on the file.

You will then open the stripped rfc1925.txt for review in your preferred text editor.

Reviewing

You can flag issues of three different severity levels, namely, "discuss", "comment" and "nit". (These levels are inspired by the IESG review process.)

In order to flag an issue of a given severity level, enter a new line at an appropriate location in the document that reads DISCUSS:, COMMENT: or NIT:.

Inline issues

Using rfc1925.txt as an example and using *** to indicate the added review content, you can flag an "inline" issue like this:

2. The Fundamental Truths

   (1)  It Has To Work.

***COMMENT: Well, duh.***

After saving the changed rfc1925.txt, you can then extract a formatted review as:

Section 2, paragraph 2, comment:
Well, duh.

See below for how to extract a review.

Using DISCUSS: or NIT: instead of COMMENT: will change the severity of the issue, as appropriate.

Issues with context

It is possible quote part of the original document, to give the review some context, like this:

***COMMENT:***
   (3)  With sufficient thrust, pigs fly just fine. However, this is
***Can we stop picking on pigs or pigeons?***

This will produce the following review:

Section 2, paragraph 5, comment:
>    (3)  With sufficient thrust, pigs fly just fine. However, this is

Can we stop picking on pigs or pigeons?

Inline nits

To quickly flag some editing nits, such as spelling errors, you can simply edit the text directly, correcting the nit. For example, to flag an existing spelling error in rfc1925.txt (where "agglutinate" is misspelled as "aglutenate"), you would simply correct the word in the text:

   (5)  It is always possible to ***agglutinate*** multiple separate problems
        into a single complex interdependent solution. In most cases
        this is a bad idea.

When extracting the formatted review, such inline corrections are added to the "nits" section in "diff" format:

Section 2, paragraph 7, nit:
-    (5)  It is always possible to aglutenate multiple separate problems
-                                       ^
+    (5)  It is always possible to agglutinate multiple separate problems
+                                    +   ^

Extracting the review

After editing a source file, you can extract a formatted review with:

ietf-reviewtool review rfc1925.txt

With the given example, this would result in the following output:

-------------------------------------------------------------------------
COMMENT
-------------------------------------------------------------------------
Section 2, paragraph 2, comment:
Well, duh.

Section 2, paragraph 5, comment:
>    (3)  With sufficient thrust, pigs fly just fine. However, this is

Can we not always pick on pigs or pigeons?

-------------------------------------------------------------------------
NIT
-------------------------------------------------------------------------
Section 2, paragraph 7, nit:
-    (5)  It is always possible to aglutenate multiple separate problems
-                                       ^
+    (5)  It is always possible to agglutinate multiple separate problems
+                                    +   ^

Configuration File

You can persist settings in a configuration file instead of passing them on the command line every time. The tool looks for a configuration file at:

  • macOS: ~/Library/Application Support/ietf-reviewtool/config
  • Linux: ~/.config/ietf-reviewtool/config (or $XDG_CONFIG_HOME/ietf-reviewtool/config)
  • Windows: C:\Users\<user>\AppData\Local\ietf-reviewtool\config

You can also specify a custom configuration file with --config <path>.

The configuration file uses configobj format. Use [global] for options that apply to all commands, and subcommand-specific sections like [review] for subcommand options. Option names match the CLI flags:

[global]
verbose = 1
width = 100
datatracker = 'https://datatracker.ietf.org/'

[review]
github-id = '@yourusername'
role = 'AD'
check-grammar = False
grammar-skip-rules = 'WHITESPACE_RULE,EN_QUOTES'

[fetch]
strip = True
fetch-xml = False

[fetch-agenda]
make-directory = True
save-agenda = True

Command-line arguments override configuration file values, which override defaults.

Acknowledgments

The ideas for some of these tools came from some of Henrik Levkowetz's earlier bash scripts. In the case of the strip tool, most of the original regular expressions were taken from his rfcstrip awk script.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ietf_reviewtool-0.5.0.tar.gz (44.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ietf_reviewtool-0.5.0-py3-none-any.whl (50.3 kB view details)

Uploaded Python 3

File details

Details for the file ietf_reviewtool-0.5.0.tar.gz.

File metadata

  • Download URL: ietf_reviewtool-0.5.0.tar.gz
  • Upload date:
  • Size: 44.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.14.0 Linux/6.11.0-1018-azure

File hashes

Hashes for ietf_reviewtool-0.5.0.tar.gz
Algorithm Hash digest
SHA256 24de9cf0773bf638e20b14414721ee554592324a6b31ece7cb48879130431015
MD5 efd92b8c9a771cb65b18e9c8668cb0e8
BLAKE2b-256 e16f2683c993611cf6f9f2a576f436ed3df15a71564ac897d83b6de88cbcaaaa

See more details on using hashes here.

File details

Details for the file ietf_reviewtool-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: ietf_reviewtool-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 50.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.14.0 Linux/6.11.0-1018-azure

File hashes

Hashes for ietf_reviewtool-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 0c7a5e8ed6218efdb6a969827324be0d37c5d464ff3d31287ef00ac64f793e5e
MD5 8ca264222c5b5def92df00bce2d58c3c
BLAKE2b-256 720b891228e825b0102cf97d4d5cf6bf40c4e9ad20adc89b6c5afd0de1c47a9d

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page