Project

TokiCLI

0.0
Repository is archived
No commit activity in last 3 years
No release in over 3 years
Toki.app command-line client: read your Toki data from the local database or from the App.net backup channel. Show the log for an app, the top apps, the grand total, usage by day or range of days, etc. Use the API in another app, or launch the local server.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 1.5
~> 10.0
~> 3.0

Runtime

>= 1.4.5, ~> 1.4
>= 0.3.2, ~> 0.3
>= 1.4.2, ~> 1.4
~> 1.6
~> 0.18
 Project Readme

Gem Version

Build Status

TokiCLI

Toki.app command-line client and API server.

Access your Toki data from the local database or from the App.net backup channel, via the CLI interface or the served API.

TokiServer example


UPDATE

Toki.app will cease to function when App.net will shut down their servers on 2017/03/14.

TokiCLI will continue to function but will then be irrelevant as there will not be anything to track anymore via Toki.app (and TokiCLI's App.net-related will also cease to function, of course).

You will still be able to read and analyse your existing data with TokiCLI.


Installation

gem install TokiCLI

Usage

Help

toki

shows the basic commands.

toki help <command>

shows help and available options for a specific command.

Example:

toki help bundle

Total

The total command shows the total usage time for all apps.

toki total

The results are sorted by ascending usage time.

Top

The top command shows your top used apps.

toki top

TokiCLI shows the top 5 by default, but you can specify a number with the -n option:

toki top -n 10

Day

The day command shows your top used apps on a specific day.

The date you type has to be formatted like this: year-month-day

toki day 2014-04-19

Since

The since command shows your top used apps since a specific day.

toki since 2014-04-19

Before

The before command shows your top used apps before a specific day.

toki before 2014-04-19

Range

The range command shows your top used apps between two specific days.

toki range 2014-04-17 2014-04-19

App

Complete log for an app

toki app airmail

Several apps may contain the same name. In that case, they will all be processed.

Example: toki app apple

App before

Complete log for an app before a specific day

toki app airmail --before 2014-04-19

App since

Complete log for an app since a specific day

toki app airmail --since 2014-04-19

App day

Complete log for an app on a specific day

toki app airmail --day 2014-04-19

App range

Complete log for an app between two specific days

toki app airmail --range 2014-04-19 2014-05-12

Bundle

Complete log for an app, given its exact bundle ID.

Same features as for app, just give an app bundle instead of an app name.

This should always return only one app log.

toki bundle it.bloop.airmail
toki bundle it.bloop.airmail --before 2014-04-19
toki bundle it.bloop.airmail --since 2014-04-19
toki bundle it.bloop.airmail --day 2014-04-19
toki bundle it.bloop.airmail --range 2014-04-19 2014-05-12

Activity

Recent Toki activity log.

toki activity

Activity since

Complete Toki activity log since a specific day.

toki activity --since 2014-04-19

Activity day

Complete Toki activity log for a specific day.

toki activity --day 2014-04-19

Scan

Scan for apps name.

Will crawl the Applications folder and try to resolve app names from bundle identifiers.

Toki can display apps names in results only if apps have been scanned.

Option: JSON

Export the Toki results as a JSON file with the --json option:

toki total --json

toki day 2014-04-18 --json

toki top -n10 -J

Option: CSV

Export the Toki results as a CSV file with the --csv option:

toki total --csv

toki day 2014-04-18 --csv

toki top -n10 -C

Delete

Completely delete all traces of an app in the database.

With backup:

toki delete it.bloop.airmail

Without backup:

toki delete it.bloop.airmail --no-backup

Restore database from App.net

Toki.app backs up your Toki tracked apps data 'in the cloud' via an App.net channel.

TokiCLI should be able to download this data and rebuild the Toki database if you lost your local install or if it has been compromised.

toki restore

API

Server for the API

toki serve

Returns a JSON response for each request.

Examples of API calls with curl:

curl http://localhost:4567/api/apps/top/10
curl http://localhost:4567/api/apps/day/2014-05-27
curl http://localhost:4567/api/apps/range/2014-05-27/2014-05-30
curl http://localhost:4567/api/logs/app/safari/
curl http://localhost:4567/api/logs/app/safari/since/2014-05-27
curl http://localhost:4567/api/logs/bundle/com.apple.Safari/before/2014-05-27
curl http://localhost:4567/api/user
curl http://localhost:4567/api/bundles

Find the list of all endpoints with curl http://localhost:4567/api.

Library

You can also use the TokiCLI API in another app:

require 'TokiCLI'

Basic

Create a basic TokiCLI API instance without referencing bundles:

toki = TokiCLI::TokiAPI.new("#{~/Library/path/to/tokiapp/db}", {})

With apps names

Create a TokiCLI FileOps instance:

fileops = TokiCLI::FileOps.new

Scan for apps names (see ##Tools):

fileops.save_bundles

Create a TokiCLI API instance:

toki = TokiCLI::TokiAPI.new(fileops.db_file, fileops.bundles)

See toki_api.rb and fileops.rb for the list of available methods.

Toki

Toki is a Mac OS X app written by Keitaroh Kobayashi.

It's a time tracker for your apps that sits in the menu bar.

Important

TokiCLI does not track your apps.

Tracking is the job of Toki.app by @keita.

TokiCLI interacts only with the Toki.app database or the App.net backup channel.