A terminal application for Pocket (based on the original by rakanalh)
Find a file
2016-02-17 23:14:14 +01:00
pocket_cli Fix less encoding issue 2016-02-17 23:14:14 +01:00
.gitignore Added some files to ignore 2016-02-11 20:22:19 +01:00
LICENSE Initial commit 2016-02-10 20:47:10 +01:00
manifest.in Improve readme, prepare setup.py for first release 2016-02-16 21:33:13 +01:00
README.md Added note for python3 2016-02-16 21:40:11 +01:00
requirements.txt Handle different encodings, use six 2016-02-17 20:53:16 +01:00
setup.py Added progress to requirements 2016-02-16 21:38:37 +01:00

Pocket CLI

Pocket-CLI is an application for reading / listing and managing your GetPocket.com articles from the terminal.

Features

  • Retrieves and indexes all of your articles and saves them into a CSV file in your home directory for quicker response.
  • Enables you to specify your reading speed to calculate the amount of time each article requires. You can estimate your reading speed from online tests such as Speed Reading Online Test
  • Able to sort articles by reading time (default) and Article ID
  • Enables you to search articles by keywords, tags and sort by GetPocket's sorting params. This will perform a request to Pocket.
  • Automated app configuration through pocket-cli configure command.
  • Uses LESS to list article for easy navigation.
  • Multiple fetch command calls will retrieve articles since last fetch.

Note: This is a Python 3 application tested on 3.5.0. Work in progress to make it 2.7 compatible.

Installation

pip install pocket-cli

Usage

Usage: pocket-cli [OPTIONS] COMMAND [ARGS]...

Options:
    --help  Show this message and exit.

Commands:
    add
    archive
    configure
    fetch
    list
    random
    read
    search

Commands

To configure the app (for first time use)

pocket-cli configure

To add a new article URL with additional params.

pocket-cli add --url <URL> --title <title> --tags <tag1> --tags <tag2>

Mark a specific article as read.

pocket-cli archive <ID>

To fetch all articles / or articles added since last fetch

pocket-cli fetch

To list your articles

pocket-cli list --limit 10 --order [asc|desc]

To select a random article for you to read

pocket-cli random --archive --browser

--archive will mark this article as read
--browser will open the article in your default browser

To read an article

pocket-cli random --open-origin --archive

--archive will mark this article as read
--open-origin will open the article's original URL rather than Pocket's.

To search for specific articles

pocket-cli --state [unread|archive|all] --sort [newest|oldest|title|site] --tag <search_by_tag> <Search Term>

Cronjob

You can add /path/to/pocket-cli fetch to your crontab to let the app fetch new articles every once and a while. For example, to fetch every 3 hours, execute crontab -e and add the following line:

* */3 * * * /usr/local/bin/pocket-cli fetch

Contribution

Contributions are welcome! Fork the repository, create a branch, implement your changes and create a pull request and i'll be happy to review and merge your features / changes.

License

The MIT License (MIT)

Copyright (c) 2016 Rakan Alhneiti

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.