jiraworklog is a command line application that synchronizes worklog entries between your local machine and a Jira server. The main functionality that it provides is:
- Reading your worklogs on your local machine from either a delimiter-separated values format such as CSV or an Excel format.
- Tracking any additions, modifications, or deletions of worklogs on your local machine and uploading the appropriate changes to your worklogs on the Jira server.
Once you have a configuration file set up then uploading worklogs to the Jira server is as simple as providing the worklogs to the jiraworklog application through standard input or via the --file
argument.
> cat worklogs.csv
description,start,end,tags
Data pipeline,2021-01-12 10:00,2021-01-12 10:30,P9992-3
Write specifications,2021-01-12 13:15,2021-01-12 14:15,P9992-3
> jiraworklog --file worklogs.csv
Auto-confirm. The following changes will be made.
-- Add to remote worklogs ----------------------------------
Tuesday January 12, 2021
P9992-3 10:00-10:30 (0:30) Data pipeline
P9992-3 13:15-14:15 (1:00) Write specifications
jiraworklog is a Python application distributed through PyPI. If you have Python 3.9 or greater available on your machine then you can install it with a command like the following.
python -m pip install jiraworklog --user
jiraworklog requires a configuration file to be set up providing information about how to parse local worklog entries and Jira server authentication, among other things. Once the configuration file has been set up, provide your worklogs to the jiraworklog application either through standard input or via the --file
argument. The application determines whether there have been any additions, modifications, or deletions of worklogs on your local machine and uploads the appropriate changes to your worklogs on the Jira server. When all of the worklogs that appear in the Jira server have been uploaded via jiraworklog, this amounts to synchronizing the worklogs from your local worklogs with the Jira server.
The other ways that worklogs can appear on the Jira server are through the Jira web application or web API. When worklogs are placed on the Jira server that jiraworklog isn't aware of, it effectively ignores those worklogs with the one exception that if an identical worklog is added to the local worklogs then it is considered to correspond to the appropriate remote worklog. This policy prevents jiraworklog from uploading the worklog a second time and also links the local and remote worklogs so that a future change in the local worklog results in a corresponding change to the remote worklog.
Use the --help
option to view the available command-line options.
jiraworklog --help
If the local worklogs are stored in a file worklogs.csv
then you can use a command like the following to upload your worklogs to the Jira server.
jiraworklog --file worklogs.csv
Similarly you can pass the local worklogs in via standard input.
cat worklogs.csv | jiraworklog
If you have an Excel file then you can also read it in using the --file
option. Reading Excel files from standard input is currently not supported.
jiraworklog --file worklogs.xlsx
Jira supports two forms of authentication for its API: basic authentication and OAuth. Currently only basic authentication is supported by jiraworklog.
Authentication to Jira via basic authentication requires the use of an API token. You can create a token if you do not have one by following the instructions found in the Manage API tokens for your Atlassian account page in the Atlassian Support website.
jiraworklog requires a configuration file to be set up providing information about how to parse local worklog entries and Jira server authentication, among other things. The configuration file setup is the most complicated part of getting jiraworklog up and running, but once it is set up you will usually not need to touch it except to specify new Jira issues.
You can see the full configuration file specification in Configuration file format. But usually the easiest way to create a new configuration file is by using the --init
command-line option as shown in the following example. This will run an interactive script that prompts you for the necessary information and then constructs a configuration file for you using that information.
jiraworklog --init
By default the jiraworklog application looks for the configuration file at ~/.jwconfig.yaml
. If you store your configuration file at that location then you need only provide your worklogs when you invoke the jiraworklog
application.
# Assumes that your configuration file is located at ~/.jwconfig.yaml
jiraworklog --file worklogs.csv
If your configuration file is not located in the default location then you can specify it by using the --config-path
command-line option.
# Use the --config-path option if your configuration file is located in a
# non-default location (in this example at path/to/jwconfig.yaml)
jiraworklog --config-path path/to/jwconfig.yaml --file worklogs.csv
The jiraworklog configuration file is expected to follow a YAML format.
An example of a valid configuration file is shown below. We'll break down the various elements in the following sections.
jwconfig_version: 0.1.0
basic_auth:
server: "https://runway.atlassian.net"
user: "[email protected]"
api_token: "J6ab6YMa1HVWADNOmO6TC623"
issues_map:
local-p1-1: "P01"
local-p1-2: "P01"
local-p2: "P02"
# If you are using an Excel file then this field gets replaced by a
# `parse_excel` section (see below)
parse_delimited:
col_labels:
description: "task"
start: "start"
end: "end"
tags: "tags"
col_formats:
start: "%Y-%m-%d %H:%M"
end: "%Y-%m-%d %H:%M"
timezone: "US/Eastern"
delimiter2: ":"
Example parse_excel
section.
# If you are using an Excel file then use a `parse_excel` section like
# the following in place of the `parse_delimited` section
parse_excel:
col_labels:
description: "task"
start: "start"
end: "end"
duration: null
tags: "tags"
col_formats:
timezone: "US/Eastern"
delimiter2: ":"
The configuration file version specification is used so that the jiraworklog application knows how to read a given configuration file. An example version specification key value pair is shown below.
jwconfig_version: 0.1.0
jwconfig_version
is a string providing the jiraworklog version for which the configuration file was written.
Currently the only form of authentication supported by jiraworklog is basic authentication using an API token. An example basic authentication mapping is shown below. See the Jira authentication section for details on how to create an API token.
basic_auth:
server: "https://runway.atlassian.net"
user: "[email protected]"
api_token: "J6ab6YMa1HVWADNOmO6TC623"
There are three possible keys within the basic_auth
mapping. If you do not wish to store one or more of these values in the configuration file then you can instead provide a given value by using the corresponding environmental variable as described below.
server
: a string providing the server URL. If this value is omitted ornull
then jiraworklog reads in the information from theJW_SERVER
environmental variable.user
: a string providing the user ID, which is usually an email address. If this value is omitted ornull
then jiraworklog reads in the information from theJW_USER
environmental variable.api_token
: a string providing a user's API token. If this value is omitted ornull
then jiraworklog reads in the information from theJW_API_TOKEN
environmental variable.
The issues mapping section of the configuration file specifies a mapping of your local worklog tags to the names of the corresponding Jira issues. The names of the local tags and their corresponding Jira issue keys might be the same, but they need not be. You are also allowed to have multiple local tags map to the same Jira issue (thus your worklogs can be finer-grained than the Jira issues).
In the following example there are 3 mappings from local tags to Jira issues. The first entry maps worklogs tagged with local-p1-1
to the Jira issue with key P01
, while the second entry maps worklogs tagged with local-p1-2
to the same Jira issue with key P01
. The last entry maps entries tagged with local-p2
to the Jira issue with key P02
.
issues_map:
local-p1-1: "P01"
local-p1-2: "P01"
local-p2: "P02"
There are 0 or more key/value pairs in the issues_map
mapping (although note that there's nothing for jiraworklog to do when there are 0 entries). Each value must be a string corresponding to a Jira issue key, and multiple entries are allowed to correspond to the same Jira issue.
The worklog parsing section of the configuration file provides the information for jiraworklog to know how to read in the local worklogs. Currently jiraworklog supports either delimiter-separated values formats such as CSV or an Excel format.
In the event that your worklogs are represented using a delimiter-separated values format such as CSV then you will need to provide a parse_delimited
section in the configuration file as described in the Delimiter-separated values worklog parsing section.
In the event that your worklogs are represented using an Excel format then you will need to provide a parse_excel
section in the configuration file as described in the Excel worklog parsing section.
If your local worklogs are provided using a delimiter-separated values format such as CSV then you will need to provide a parse_delimited
section in the configuration file in order to specify how the data is parsed by jiraworklog. An example parse_delimited
section is shown below.
parse_delimited:
col_labels:
description: "task"
start: "start"
end: "end"
duration: null
tags: "tags"
col_formats:
start: "%Y-%m-%d %H:%M"
end: "%Y-%m-%d %H:%M"
timezone: "US/Eastern"
delimiter2: ":"
dialect: {}
The parse_delimited
mapping has two required entries, col_labels
and col_formats
, while an optional third entry dialect
is allowed to be omitted or null
(or to be an empty mapping for that matter, as shown in the preceding example).
-
col_labels
: a mapping of entries specifying the meaning of the relevant columns in the source data. For example, if you had a column in your data namedStart Time
corresponding to the worlog entry start datetimes, then you would provide an entrystart: "Start Time"
in the mapping.Only 2 out of 3 of the columns corresponding to the worklogs
start
,end
, andduration
s are required, although all three can be provided.description
: a string specifying the name of the column providing the description of the worklog.start
: a string specifying the name of the column providing the start datetime of the worklogs (this can be omitted ornull
).end
: a string specifying the name of the column providing the end datetime of the worklogs (this can be omitted ornull
).duration
: a string specifying the name of the column providing the duration of the worklogs (this can be omitted ornull
). The duration can be provided in a form like"2h 30m"
, which would correspond to a duration of 2 hours and 30 minutes (i.e. 150 minutes). The valid units of time arew
for weeks,d
for days,h
for hours,m
for minutes, ands
for seconds. Not every unit of time need be included in a given worklog duration entry.tags
: a string specifying the name of the column providing the tags for the worklogs. Tags are the mechanism that are used to identify which Jira issue, if any, that a given worklog corresponds to. A worklog is allowed to have multiple tags, although only one tag can correspond to a Jira issue. If there are multiple tags then they are specified using a string that is separated by thedelimiter2
character. For example, ifdelimiter2
is specified as":"
and a given tags entry isdata processing:P9992-3
then the tags would bedata processing
andP9992-3
.
-
col_formats
: a mapping of entries providing various column parsing information.The
start
andend
columns specify the formats in which the datetimes are provided. As an example, consider the datetime format2021-01-29 15:45
representing the datetime of January 29th, 2021 at 15 hours and 45 minutes after midnight. The formatting string for this datetime format would be%Y-%m-%d %H:%M
. The datetime entries are parsed by the Python functionstrptime
which has formatting rules as described in the strftime() and strptime() Format Codes section of the datetime Python documentation.-
start
: a string specifying the worklogs start datetime format. This should be omitted ornull
if there is no start datetime column. -
end
: a string specifying the worklogs end datetime format. This should be omitted ornull
if there is no end datetime column. -
timezone
If your timezone information is already included within your worklog start and end datetime strings then this should be omitted ornull
. Otherwise, it is a string specifying your timezone.The list of allowed timezone strings can be found by running either
python -c 'import pytz, prettyprinter; prettyprinter.pprint(pytz.common_timezones)'
to see the most common timezones orpython -c 'import pytz, prettyprinter; prettyprinter.pprint(pytz.common_timezones)'
to see all available timezones. -
delimiter2
a single-character string specifying the character upon which to split the tags (this can be omitted ornull
). Ifdelimiter2
is omitted ornull
then no tag splitting is performed.
-
-
dialect
: a mapping specifying the parsing of the delimiter-separated values data (this can be omitted ornull
).jiraworklog uses Python's csv library, and the parsing options exposed to the user are exactly those provided by the library and which are described in the Dialects and Formatting Parameters section of the Python csv documentation. Any option can be omitted or
null
, in which case the default value defined by the csv library is used. Note thatDialect.strict
is always set toTrue
by jiraworklog.By default the csv library parses CSV files (i.e.
Dialect.delimiter
is specified as','
).The main complication when constructing delimiter-separated values data is what to do when the delimiter appears as part of one of the entries. One approach is to escape the delimiter using a predetermined escape character such as
\
. When the escape character itself appears in the data it is itself escaped so that\\
is interpreted as a literal\
. Another approach is to quote an entire entry using a predetermined quoting character such as"
so that for a CSV format an entry likeMe, Myself & Irene
would be presented as"Me, Myself & Irene"
. The quoting character might itself appear in a given entry, in which case it also needs to be escaped, often by doubling the character so that""
is interpreted as a literal"
so that for a CSV format an entry likeThe movie "Me, Myself & Irene"
would be presented as"The movie ""Me, Myself & Irene"""
. TheDialect.quoting
,Dialect.quotechar
,Dialect.escapechar
, andDialect.doublequote
options in the csv library control the settings related to these considerations.delimiter
: a single-character string (this can be omitted ornull
).doublequote
: eithertrue
orfalse
(this can be omitted ornull
).escapechar
a single-character string (this can be omitted ornull
).lineterminator
a string (this can be omitted ornull
). Note that this value currently has no effect on the csv library's parser.quotechar
: a single-character string (this can be omitted ornull
).quoting
: one of"QUOTE_ALL"
,"QUOTE_MINIMAL"
,"QUOTE_NONNUMERIC"
, or"QUOTE_NONE"
(this can be omitted ornull
).skipinitialwhitespace
: eithertrue
orfalse
(this can be omitted ornull
).
If your local worklogs are provided using a delimiter-separated values format such as CSV then you will need to provide a parse_excel
section in the configuration file in order to specify how the data is parsed by jiraworklog. An example parse_excel
section is shown below.
parse_excel:
col_labels:
description: "task"
start: "start"
end: "end"
duration: null
tags: "tags"
col_formats:
timezone: "US/Eastern"
delimiter2: ":"
The parse_delimited
mapping has two required entries, col_labels
and col_formats
.
-
col_labels
: a mapping of entries specifying the meaning of the relevant columns in the source data. For example, if you had a column in your data namedStart Time
corresponding to the worlog entry start datetimes, then you would provide an entrystart: "Start Time"
in the mapping.Only 2 out of 3 of the columns corresponding to the worklogs
start
,end
, andduration
s are required, although all three can be provided.description
: a string specifying the name of the column providing the description of the worklog.start
: a string specifying the name of the column providing the start datetime of the worklogs (this can be omitted ornull
).end
: a string specifying the name of the column providing the end datetime of the worklogs (this can be omitted ornull
).duration
: a string specifying the name of the column providing the duration of the worklogs (this can be omitted ornull
). The duration can be provided in a form like"2h 30m"
, which would correspond to a duration of 2 hours and 30 minutes (i.e. 150 minutes). The valid units of time arew
for weeks,d
for days,h
for hours,m
for minutes, ands
for seconds. Not every unit of time need be included in a given worklog duration entry.tags
: a string specifying the name of the column providing the tags for the worklogs. Tags are the mechanism that are used to identify which Jira issue, if any, that a given worklog corresponds to. A worklog is allowed to have multiple tags, although only one tag can correspond to a Jira issue. If there are multiple tags then they are specified using a string that is separated by thedelimiter2
character. For example, ifdelimiter2
is specified as":"
and a given tags entry isdata processing:P9992-3
then the tags would bedata processing
andP9992-3
.
-
col_formats
: a mapping of entries providing various column parsing information.-
timezone
a string specifying your timezone.The list of allowed timezone strings can be found by running either
python -c 'import pytz, prettyprinter; prettyprinter.pprint(pytz.common_timezones)'
to see the most common timezones orpython -c 'import pytz, prettyprinter; prettyprinter.pprint(pytz.common_timezones)'
to see all available timezones. -
delimiter2
a single-character string specifying the character upon which to split the tags (this can be omitted ornull
). Ifdelimiter2
is omitted ornull
then no tag splitting is performed.
-
This section is still under construction. Please feel free to post an issue or pull request suggesting any software that can be used to record worklog entries or interoperate with Jira worklogs.
- Microsoft Excel is a spreadsheet application that doesn't have specific support for worklogs but is perfectly amenable to manual entry of worklogs. The Excel data format is supported by jiraworklog.
- clockify is a web/desktop/mobile application that allows you to record worklog entries and create reports, among many other features. You can export your worklogs to CSV format which can then be uploaded to Jira via jiraworklog. Also note that there is a Clockify Jira plugin that integrates a clock in / clock out button into the Jira website such that when used the resulting worklog entry is registered both for Jira and for Clockify.