Skip to main content

Manage Phabricator tasks from the comfort of your terminal

Project description

phable

Manage Phabricator tasks from the comfort of your terminal.

phable is a CLI allowing you to manage your Phorge/Phabricator tasks.

It tries to be very simple and not go overboard with features. You can:

  • create a new task
  • display a task details
  • move a task to a column on its current board
  • assign a task to a user
  • add a comment to a task
  • and more (see phable --help output for the full feature list)

Installation

$ pip install phable-cli

Usage

$ phable --help
Usage: phable [OPTIONS] COMMAND [ARGS]...

  Manage Phabricator tasks from the comfort of your terminal

Options:
  --version  Show the version and exit.
  --help     Show this message and exit.

Commands:
  assign             Assign one or multiple task ids to a username
  cache              Manage internal cache
  comment            Add a comment to a task
  config             Manage phable config
  create             Create a new task
  list               Lists and filter tasks
  move               Move one or several task on their current project board
  parent             Manage task parents
  report-done-tasks  Print the details of all tasks in the `from` column and move them to the `to` column.
  set                Set the fields of one or multiple tasks
  show               Show task details
  status             Set the status of one or multiple tasks [DEPRECATED]
  subscribe          Subscribe to one or multiple task ids
  tag                Add a tag on one or multiple tasks [DEPRECATED]

A few examples:

$ phable list --status open
$ phable list --status progress --status stalled --milestone

--status can be passed multiple times to match several statuses.

Setup

For phable to work, you need to define the following configuration, by running $EDITOR $(phable config show):

[phabricator]
url = # URL to your phabricator instance. Ex: `url = https://phabricator.wikimedia.org`
token = # API token. Generate a token from ${PHABRICATOR_URL}/settings/user/${YOUR_USERNAME}/page/apitokens/
default_project_phid = # id for the Phabricator project to be used by default when creating tasks.

To get default_project_phid, define the first 2 configurations, and run the following command, where T123456 is a task id belonging to your project.

$ phable show T123456 --format=json | jq -r '.attachments.projects.projectPHIDs[]'

Note: you can also expose these configuration through the following environment variables, for backwards compatibility:

  • PHABRICATOR_URL
  • PHABRICATOR_TOKEN
  • PHABRICATOR_DEFAULT_PROJECT_PHID

Tips and tricks

Refer to your own phabricator username

You can address your own phabricator username as self. For example, you can assign a task to yourself by running

phable assign --username self T123456

This can be useful when sharing command aliases to another user without having them change the username to their own.

Setting up aliases

You can define command aliases. For example, instead of typing phable move --column 'Done' --milestone T123456, you might want to type phable done T123456. To do this, open the phable configuration file, with $EDITOR $(phable config show) and define an alias:

[aliases]
done = move --column 'Done' --milestone

I personally currently have the following aliases:

$ phable config aliases list
done = move --column 'Done' --milestone
review = move --column 'Needs Review' --milestone
wip = move --column 'In Progress' --milestone
team-report = list --owner self --column 'In Progress' --column 'Needs Review' --column 'Blocked/Waiting' --column Done --milestone --format html

Phabricator task IDs as clickable links in iTerm2

If you're using iTerm2, you can turn the task IDs into clickable links, by going to iTerm2 > Settings > Profiles > Advanced > Smart Selection > Edit > [+]:

Then click on the new rule Notes field, and set it to Phabricator, and set the Regular expression field to T\d{6} (adjust the number of digits to what a task ID looks like in your instance. The latest created task has ID 385678 right now, so \d{6} gives us some leeway).

One that is done, holding Command when hovering on a task ID should turn it into a link.

Enabling autocompletion

bash

Add this to ~/.bashrc:

eval "$(_PHABLE_COMPLETE=bash_source phable)"

zsh

Add this to ~/.zshrc:

eval "$(_PHABLE_COMPLETE=zsh_source phable)"

fish

Add this to ~/.config/fish/completions/phable.fish:

_PHABLE_COMPLETE=fish_source phable | source

Contributing

Install all development dependencies using

make init

You can then run every linters and tests that would be run in CI by running:

make ci

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

phable_cli-0.1.19.tar.gz (27.8 kB view details)

Uploaded Source

Built Distribution

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

phable_cli-0.1.19-py3-none-any.whl (42.2 kB view details)

Uploaded Python 3

File details

Details for the file phable_cli-0.1.19.tar.gz.

File metadata

  • Download URL: phable_cli-0.1.19.tar.gz
  • Upload date:
  • Size: 27.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.14.6 Darwin/25.5.0

File hashes

Hashes for phable_cli-0.1.19.tar.gz
Algorithm Hash digest
SHA256 707280888aab40618417eae26f51c21ad0f81e772df4198ad15d29f2408dd011
MD5 22753e87901b86740c989f11a2ee7ba4
BLAKE2b-256 0a5be7314952f95d474da8a48112394148cc8b3f87ac8e658957342edf13b797

See more details on using hashes here.

File details

Details for the file phable_cli-0.1.19-py3-none-any.whl.

File metadata

  • Download URL: phable_cli-0.1.19-py3-none-any.whl
  • Upload date:
  • Size: 42.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.14.6 Darwin/25.5.0

File hashes

Hashes for phable_cli-0.1.19-py3-none-any.whl
Algorithm Hash digest
SHA256 982a7d114cf4ada1a5b26fcd29e343665829ec87faea059b5b596bb27c439e19
MD5 d46e417900498ff4dea8815e99f26677
BLAKE2b-256 81818a1c89118f815456461a169bba06ceae28d9b6ebf34170cb73766a451524

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