2017-05-08 03:17:32 -04:00
============================
Toot - a Mastodon CLI client
============================
2017-04-12 11:23:50 -04:00
2017-11-19 14:17:14 -05:00
Interact with Mastodon social network from the command line.
2017-04-12 11:23:50 -04:00
2017-04-16 09:07:27 -04:00
.. image :: https://img.shields.io/travis/ihabunek/toot.svg?maxAge=3600&style=flat-square
:target: https://travis-ci.org/ihabunek/toot
2017-04-12 11:23:50 -04:00
.. image :: https://img.shields.io/badge/author-%40ihabunek-blue.svg?maxAge=3600&style=flat-square
:target: https://mastodon.social/@ihabunek
2017-08-26 05:35:20 -04:00
.. image :: https://img.shields.io/github/license/ihabunek/toot.svg?maxAge=3600&style=flat-square
2017-04-12 11:23:50 -04:00
:target: https://opensource.org/licenses/MIT
.. image :: https://img.shields.io/pypi/v/toot.svg?maxAge=3600&style=flat-square
:target: https://pypi.python.org/pypi/toot
2017-04-12 10:42:04 -04:00
Installation
------------
2017-09-07 08:59:58 -04:00
From APT package repository
~~~~~~~~~~~~~~~~~~~~~~~~~~~
This works for Debian, Ubuntu and derivatives.
The repo is signed with my `keybase.io <https://keybase.io/ihabunek> `_ key.
Add the `bezdomni.net` repository:
.. code-block ::
2017-11-19 14:17:14 -05:00
echo "deb http://bezdomni.net/packages/ ./" | sudo tee /etc/apt/sources.list.d/bezdomni.list
2017-09-07 08:59:58 -04:00
curl https://keybase.io/ihabunek/pgp_keys.asc | sudo apt-key add -
Install the package:
2017-08-29 08:10:46 -04:00
.. code-block ::
2017-09-07 08:59:58 -04:00
sudo apt update
sudo apt install python3-toot
2017-08-29 08:10:46 -04:00
2018-04-18 07:10:46 -04:00
From FreeBSD ports
~~~~~~~~~~~~~~~~~~
Install the package:
.. code-block ::
2018-05-05 18:43:25 -04:00
pkg install py36-toot
2018-04-18 07:10:46 -04:00
Build and install from sources:
.. code-block ::
cd /usr/ports/net-im/toot
make install
2018-01-02 14:22:42 -05:00
From Nixpkgs
~~~~~~~~~~~~
This works on NixOS or systems with the Nix package manager installed.
.. code-block ::
nix-env -iA nixos.toot
2017-12-28 05:00:53 -05:00
From OpenBSD ports
~~~~~~~~~~~~~~~~~~
2017-12-16 10:48:47 -05:00
Install the package:
.. code-block ::
pkg_add toot
Build and install from sources:
.. code-block ::
cd /usr/ports/net/toot
make install
2017-12-28 10:36:09 -05:00
Thanks to `Klemens Nanni <mailto:kl3@posteo.org> `_ for handling the OpenBSD ports.
2017-12-28 05:00:53 -05:00
2017-09-07 08:59:58 -04:00
From Python Package Index
~~~~~~~~~~~~~~~~~~~~~~~~~
2017-08-29 08:10:46 -04:00
Otherwise, install from PyPI using pip, preferably into a virtual environment:
2017-04-12 10:42:04 -04:00
.. code-block ::
pip install toot
Usage
-----
2017-04-16 09:07:27 -04:00
Running `` toot `` displays a list of available commands.
Running `` toot <command> -h `` shows the documentation for the given command.
2017-04-19 08:47:30 -04:00
.. code-block ::
$ toot
toot - a Mastodon CLI client
2017-04-26 06:11:52 -04:00
Authentication:
2017-12-29 05:52:00 -05:00
toot login Log in from the console, does NOT support two factor authentication
2017-08-26 08:39:53 -04:00
toot login_browser Log in using your browser, supports regular and two factor authentication
2018-01-02 04:44:32 -05:00
toot activate Switch between logged in accounts.
2017-08-26 08:39:53 -04:00
toot logout Log out, delete stored access keys
2018-01-02 04:44:32 -05:00
toot auth Show logged in accounts and instances
2017-04-26 06:11:52 -04:00
Read:
2017-08-26 08:39:53 -04:00
toot whoami Display logged in user details
toot whois Display account details
2018-01-02 04:44:32 -05:00
toot instance Display instance details
2017-08-26 08:39:53 -04:00
toot search Search for users or hashtags
toot timeline Show recent items in your public timeline
2017-12-29 05:52:00 -05:00
toot curses An experimental timeline app (doesn't work on Windows)
2017-04-26 06:11:52 -04:00
Post:
2017-08-26 08:39:53 -04:00
toot post Post a status text to your timeline
toot upload Upload an image or video file
2017-04-26 06:11:52 -04:00
Accounts:
2017-08-26 08:39:53 -04:00
toot follow Follow an account
toot unfollow Unfollow an account
toot mute Mute an account
toot unmute Unmute an account
toot block Block an account
toot unblock Unblock an account
2017-04-19 08:47:30 -04:00
To get help for each command run:
toot <command> --help
https://github.com/ihabunek/toot
2017-04-19 08:51:30 -04:00
It is possible to pipe status text into `toot post` , for example:
.. code-block ::
echo "Text to post" | toot post
cat mypost.txt | toot post
2017-04-16 09:07:27 -04:00
Authentication
--------------
2017-08-26 08:39:53 -04:00
Before tooting, you need to login to a Mastodon instance.
If you don't use two factor authentication you can log in directly from the command line:
2017-04-12 10:42:04 -04:00
.. code-block ::
2017-04-13 07:52:28 -04:00
toot login
2017-08-26 08:39:53 -04:00
You will be asked to chose an instance_ and enter your credentials.
If you do use **two factor authentication** , you need to log in through your browser:
2017-04-18 10:40:26 -04:00
.. code-block ::
2017-08-26 08:39:53 -04:00
toot login_browser
2017-04-18 10:40:26 -04:00
2017-08-26 08:39:53 -04:00
You will be redirected to your Mastodon instance to log in and authorize toot to access your account, and will be given an **authorization code** in return which you need to enter to log in.
2017-04-12 10:42:04 -04:00
2017-04-13 07:52:28 -04:00
.. _instance: https://github.com/tootsuite/documentation/blob/master/Using-Mastodon/List-of-Mastodon-instances.md
2017-04-12 11:18:56 -04:00
2018-01-02 04:44:32 -05:00
The application and user access tokens will be saved in the configuration file located at `` ~/.config/toot/instances/config.json `` .
2017-04-12 11:18:56 -04:00
2018-01-02 04:44:32 -05:00
It's possible to be logged into **multiple accounts** at the same time. Just repeat the above process for another instance. You can see all logged in accounts by running `` toot auth `` . The currently active account will have an **ACTIVE** flag next to it.
2017-04-12 11:18:56 -04:00
2018-01-02 04:44:32 -05:00
To switch accounts, use `` toot activate `` . Alternatively, most commands accept a `` --using `` option which can be used to specify the account you wish to use just that one time.
2017-04-13 07:52:28 -04:00
2018-01-02 04:44:32 -05:00
Finally you can logout from an account by using `` toot logout `` . This will remove the stored access tokens for that account.
2017-05-08 03:17:32 -04:00
License
-------
2017-11-19 15:49:31 -05:00
Copyright 2017 Ivan Habunek <ivan@habunek.com>
2017-05-08 03:17:32 -04:00
Licensed under the GPLv3: http://www.gnu.org/licenses/gpl-3.0.html