Skip to content

nolash/piknik

Repository files navigation

NAME

piknik - Issue tracking using CLI

SYNOPSIS

piknik add [ -d store_dir ] [ --alias issue_alias ] caption

piknik show [ -i issue_id ] [ -d store_dir ] [ -r renderer ] [ --state state ]

piknik show [ -d store_dir ] -r html [ -o output_dir ]

piknik mod < -i issue_id > [ -d store_dir ] [ --state state ] [ -t tag ] [ -u tag ] [ --dep issue_id ] [ --undep issue_id ] [ --assign id ] [ --unassign id ]

piknik mod < -i issue_id > [ -d store_dir ] [ --block ]

piknik mod < -i issue_id > [ -d store_dir ] [ --unblock ]

piknik comment < -i issue_id > [ -d store_dir ] [ [ -x "text content" ... ] [ -y file ... ] ... ]

DESCRIPTION

This tool enables issue tracking by command line interface.

After an issue has been created it can move through different pre-defined, kanban-like states. They can also be tagged, assigned and commented on.

COMMANDS

The following commands are available:

show - Output all issues for all or selected issue states.

add - Propose a new issue.

mod - Tag, assign, set dependencies and modify state of an existing issue.

comment - Add comment to an existing issue.

Common options

-d

: Issue state store directory.

-h

--help Command help summary.

-iissue_id

--issue-idissue_id Issue to operate on. Argument can be issue alias or full issue uuid. Only available with mod and comment.

-sstate

--statestate Limit output to issue having the given state. (Only valid with show or mod).

-v

: Write debugging log to standard error.

Options for add

--alias

: Specify alias used to refer to issue when using -i. If not specified, an alias will be auto-generated. See ALIAS. Only available with add.

Options for show

-f

--files Save attachments to filesystem. Can be used in the context of viewing details of a single issue, or in conjunction with -r html -o. Only available with show.

-odir

--files-dirdir Output issue details to individual files in dir. Only available with show -r html ....

-rformat

--rendererformat Output format. Valid values are plain and html.

-reverse

: Sort comments with oldest first. Only available with show.

--show-finished

: Include issues with state FINISHED in output. Only available with show.

Options for mod

--assignkey_id

: Assign the issue to entity defined by key_id. If it is the first assignment for an issue, the assigned will become the issue owner (see --owner and ACTIONS/Assignment below. Only available with mod.

--block

: Set the BLOCKED state on the issue. Preserves the previous state; a following --unblock instruction will return the issue to the pre-blocked state. Only available with mod.

--depissue_id

: Make the current issue (identified by -i dependent on issue_id. Only available with mod.

--ownerkey_id

: Set the entity represented by key_id as issue owner.

-ttag

--tagtag Add the given tag to the issue. Only available with mod.

--unassignkey_id

: Remove the assignment of the issue to entity defined by key_id. Only available with mod.

--unblock

: Remove block on issue. Will return the issue to its previous state (before the block). Only available with mod.

--undepissue_id

: Remove dependency on issue_id. Only available with mod.

-utag

--untagtag Remove the given tag from the issue. Only available with mod.

Options for comment

-spgp_key_fingerprint

--sign-aspgp_key_fingerprint Use the private key matching the fingerprint to sign (instead of the default key). Only available with comment.

-xtext

--texttext Add a text content part to the comment. Must be enclosed by double quotes. Only available with comment.

-yfile

--filefile Add file as content part to the comment. Can be any type of file. Only available with comment. See the COMMENT section for more information.

STATES

The tracking of the issue lifetime is organized using a pre-defined set of kanban-like states.

PROPOSED

: The initial state of an issue after being created by piknik add. Is intended for review by issue board moderator.

BACKLOG

: The initial state of an issue after being "accepted" by a moderator.

PENDING

: An issue has been queued for imminent processing.

DOING

: An issue is currently being worked on.

REVIEW

: Work that was done on an issue is currently in review.

BLOCKED

: Progress on a PENDING issue is currently not possible.

FINISHED

: Processing of an issue has been completed.

ACTIONS

Assignment

Indicates an individual or entity that is responsible for processing the issue.

Currently assigments are defined as hexadecimal values. By convention, the value should correspond to e.g. a public key or a key fingerprint (e.g. PGP). piknik will check that the value is hexadecimal, but will not do additional verification.

The first assigned entity to an issue automatically becomes the issue owner. The issue ownership may be changed using --owner, but ownership cannot be removed entirely after the initial assignment.

Tagging

Any issue may be assigned any number of tags. Tags may be added and removed individually.

Dependencies

Any issue may be set as dependent on another issue. Dependencies may be set or unset. Dependencies must be manually managed, and will not be magically removed as a side-effect of state transitions.

COMMENTING

Comments are stored as email-like Multipart MIME message logs. They may include any number of plaintext and file attachment parts intermingled.

All comments must be signed using a PGP key. Unless the -s flag is used, the default signing key will be used. It is currently not possible to comment without a PGP key.

RENDERING

There are currently two rendering options for displaying issue indices and individual issue details, plain (plain text) and html. Ideosyncracies for each are described below.

PLAIN

When listing the issue index, output will be in the form:

[STATE]
<caption>	<tags>	<uuid>	[(alias)]

Per-issue render should be self-explanatory.

HTML

If rendered with -o outdir it creates a browseable version of individual issues from the issue index in the specified directory.

Some image types will by default be displayed inline. There is currently no way to toggle this behavior.

EXAMPLE

This example illustrates a possible lifetime of an issue.

# propose new issue
piknik add Title describing the issue --alias myissue

# accept proposed issue (move to backlog state)
piknik mod -i myissue --accept

# move the issue to state "DOING"
piknik mod -i myissue --state doing

# tag the issue as a "BUG"
piknik mod -i myissue --tag bug

# Add a signed text comment to the issue
piknik comment -i myissue -x "This is a text comment"

# Add a comment with intermixed text and attachment contents to the issue
piknik comment -i myissue -x "This is a text comment with two attachments " -y attachment.png -y another.pdf -x "This text follows the attachments"

# Write index of all issues as plain text to standard output
piknik show

# Write issue details as plain text to standard output
piknik show -i myissue

# Write index of all issues as html to standard output
piknik show --render html

# Write index and individual issue as browseable html to directory "outdir"
piknik show --render html -o outdir

# Mark issue as finished
piknik mod -i myissue --finish

KNOWN ISSUES

Currently issues are tracked using - in fact - piknik. An HTML (read-only) render can be found at https://holbrook.no/issues/piknik

LICENSE

This documentation and its source is licensed under the Creative Commons Attribution-Sharealike 4.0 International license.

The source code of the tool this documentation describes is licensed under the GNU General Public License 3.0.

COPYRIGHT AND CONTACT

Louis Holbrook

https://holbrook.no

PGP: 59A844A484AC11253D3A3E9DCDCBD24DD1D0E001

SOURCE CODE

https://git.defalsify.org/piknik

ABOUT THIS DOCUMENT

This document was generated using pandoc -f man -t markdown ...