Metadata-Version: 2.1
Name: git-pw
Version: 2.2.3
Summary: Git-Patchwork integration tool
Home-page: https://github.com/getpatchwork/git-pw
Author: Stephen Finucane
Author-email: stephen@that.guru
License: MIT License
Project-URL: Bug Tracker, https://github.com/getpatchwork/git-pw/issues
Project-URL: Source Code, https://github.com/getpatchwork/git-pw
Project-URL: Documentation, https://git-pw.readthedocs.io
Keywords: git patchwork
Platform: UNKNOWN
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python
Classifier: Development Status :: 4 - Beta
Classifier: Environment :: Console
Classifier: Intended Audience :: Developers
Classifier: Intended Audience :: Information Technology
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Requires-Python: >=3.5
License-File: LICENSE

======
git-pw
======

.. NOTE: If editing this, be sure to update the line numbers in 'doc/index'

.. image:: https://badge.fury.io/py/git-pw.svg
   :target: https://badge.fury.io/py/git-pw
   :alt: PyPi Status

.. image:: https://readthedocs.org/projects/git-pw/badge/?version=latest
   :target: http://git-pw.readthedocs.io/en/latest/?badge=latest
   :alt: Documentation Status

.. image:: https://github.com/getpatchwork/git-pw/actions/workflows/ci.yaml/badge.svg
   :target: https://github.com/getpatchwork/git-pw/actions/workflows/ci.yaml
   :alt: Build Status

*git-pw* is a tool for integrating Git with `Patchwork`__, the web-based patch
tracking system.

.. important::

   `git-pw` only supports Patchwork 2.0+ and REST API support must be enabled
   on the server end. You can check for support by browsing ``/about`` for your
   given instance. If this page returns a 404, you are using Patchwork < 2.0.

   The `pwclient`__ utility can be used to interact with older Patchwork
   instances or instances with the REST API disabled.

__ http://jk.ozlabs.org/projects/patchwork/
__ https://patchwork.ozlabs.org/help/pwclient/

Installation
------------

The easiest way to install *git-pw* and its dependencies is using ``pip``. To
do so, run:

.. code-block:: bash

   $ pip install git-pw

You can also install *git-pw* manually. First, install the required
dependencies.  On Fedora, run:

.. code-block:: bash

   $ sudo dnf install python3-requests python3-click python3-pbr \
       python3-arrow python3-tabulate python3-yaml

On Ubuntu, run:

.. code-block:: bash

   $ sudo apt-get install python3-requests python3-click python3-pbr \
       python3-arrow python3-tabulate python3-yaml

Once dependencies are installed, clone this repo and run ``setup.py``:

.. code-block:: bash

   $ git clone https://github.com/getpatchwork/git-pw
   $ cd git-pw
   $ pip install --user .  # or 'sudo python setup.py install'

Getting Started
---------------

To begin, you'll need to configure Git settings appropriately. The following
settings are **required**:

``pw.server``
  The URL for the Patchwork instance's API. This should include the API
  version::

      https://patchwork.ozlabs.org/api/1.2

  You can discover the API version supported by your instance by comparing the
  server version, found at ``/about``, with the API versions provided in the
  `documentation`__. For example, if your server is running Patchwork version
  3.0.x, you should use API version 1.2.

  __ https://patchwork.readthedocs.io/en/stable-3.0/api/rest/#rest-api-versions

``pw.project``
  The project name or list-id. This will appear in the URL when using the web
  UI::

      https://patchwork.ozlabs.org/project/{project_name}/list/

For read-write access, you also need authentication - you can use either API
tokens or a username/password combination:

``pw.token``
  The API token for your Patchwork account.

``pw.username``
  The username for your Patchwork account.

``pw.password``
  The password for your Patchwork account.

If only read-only access is desired, credentials can be omitted.

The following settings are **optional** and may need to be set depending on
your Patchwork instance's configuration:

``pw.states``
  The states that can be applied to a patch using the ``git pw patch update``
  command. Should be provided in slug form (``changes-requested`` instead of
  ``Changes Requested``). Only required if your Patchwork instance uses
  non-default states.

You can set these settings using the ``git config`` command. This should be
done in the repo in which you intend to apply patches. For example, to
configure the Patchwork project, run:

.. code-block:: bash

   $ git config pw.server 'https://patchwork.ozlabs.org/api/1.1/'
   $ git config pw.project 'patchwork'

Development
-----------

If you're interested in contributing to *git-pw*, first clone the repo:

.. code-block:: bash

   $ git clone https://github.com/getpatchwork/git-pw
   $ cd git-pw

Create a *virtualenv*, then install the package in `editable`__ mode:

.. code-block:: bash

   $ virtualenv .venv
   $ source .venv/bin/activate
   $ pip install --editable .

__ https://pip.pypa.io/en/stable/reference/pip_install/#editable-installs

Documentation
-------------

Documentation is available on `Read the Docs`__

__ https://git-pw.readthedocs.org/



