Metadata-Version: 2.1
Name: joca
Version: 1.3.6
Summary: Sync project lead with ical (for on call assignees)
Home-page: https://www,github.com/betsythefc/joca
Author: Bryce McNab
Author-email: brycemcnab@pm.me
License: UNKNOWN
Description-Content-Type: UNKNOWN
Platform: UNKNOWN
Classifier: Programming Language :: Python :: 2.7
Classifier: Operating System :: OS Independent
Classifier: Development Status :: 5 - Production/Stable
Classifier: License :: OSI Approved :: GNU General Public License v3 (GPLv3)
Classifier: Topic :: Software Development :: Version Control :: Git
Requires-Dist: requests
Requires-Dist: jira
Requires-Dist: icalendar
Requires-Dist: jsonschema

joca
====

Jira On Call Assignee

Check an ical url (files not supported yet) for current on call.

`PyPI <https://pypi.org/project/joca/>`__

Installation
============

::

   pip install joca

Configuration file
==================

The configuration holds 3 sections, ``local``, ``jira`` and
``projects``.

-  ``local`` is for configuring logging.
-  ``jira`` houses the username, password and server url of the Jira
   instance joca connects to.
-  ``projects`` is a list of objects that tell joca what project, what
   ical and the regex to apply to the event summary to extract the users
   name.

Here is a basic configuration:

::

   {
       "local": {
           "logging": {
               "file": "/var/log/joca.log",
               "format": "%(asctime)s %(levelname)s %(message)s",
               "level": "info"
           },
       },
       "jira": {
           "server": "https://instance.jira.com",
           "username": "api-user",
           "password": "hunter2"
       },
       "projects": [
           {
               "key": "PROJ",
               "ical": "https://totally.a-website.com/calendar",
               "regex": "^(.*)$"
           }
       ]
   }

-  ``local.logging``, ``format`` is not required.
-  ``local.logging.level`` doesn’t need to be uppercase.
-  ``projects.#.key`` doesn’t have to be uppercase, joca will handle
   that.

``projects`` is a list, so feel free to have multiple projects set up,
and it will loop over them.

To do
=====

Check out todo.txt for the basic list of to-do’s.

todo.txt follows the syntax rules laid out
`here <https://github.com/todotxt/todo.txt>`__.

Version Numbering
=================

joca follows the three major tenets of
`SemVer <https://semver.org/spec/v2.0.0.html>`__.

   Given a version number MAJOR.MINOR.PATCH, increment the:

   -  MAJOR version when you make incompatible API changes,
   -  MINOR version when you add functionality in a backwards-compatible
      manner, and
   -  PATCH version when you make backwards-compatible bug fixes.

   Additional labels for pre-release and build metadata are available as
   extensions to the MAJOR.MINOR.PATCH format. (Preston-Warner, 2013)

Build metadata MAY be denoted by appending a hyphen and a series of dot
separated identifiers immediately following the patch or pre-release
version.

Build version follows `RFC-1912 section
2.2 <https://tools.ietf.org/html/rfc1912#section-2.2>`__:

   The recommended syntax is YYYYMMDDnn (YYYY=year, MM=month, DD=day,
   nn=revision number. This won’t overflow until the year 4294" (Barr,
   1996)

Example: ``1.23.4-2018033000``:

-  Major version ``1``
-  Minor version ``23``
-  Patch version ``4``
-  Build number ``2018033000`` => ``2018`` ``03`` ``30`` ``00``

Please read the full spec at the link above or in the citations.

Copyright
=========

   JOCA – Jira On Call Assignee – Change project lead based on an ical
   event. Copyright (C) 2018 Bryce McNab

   This program is free software: you can redistribute it and/or modify
   it under the terms of the GNU General Public License as published by
   the Free Software Foundation, either version 3 of the License, or (at
   your option) any later version.

   This program is distributed in the hope that it will be useful, but
   WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
   General Public License for more details.

   You should have received a copy of the GNU General Public License
   along with this program. If not, see http://www.gnu.org/licenses/.

Citations
=========

Preston-Warner, T. (2013). *Semantic Versioning 2.0.0*. Retrieved
November 27, 2017, from https://semver.org/spec/v2.0.0.html

Barr, D. (1996). *Common DNS Operational and Configuration Errors*.
Retrieved on March 30, 2018, from
https://tools.ietf.org/html/rfc1912#section-2.2


