/exist_client

A client for posting data to Exist.io

Primary LanguageRubyMIT LicenseMIT

ExistClient

A tool for reporting metrics to Exist.io. It currently supports time tracking and completed tasks and supports plugins to work with different apps.

Installation

Install the gem:

$ gem install exist_client

Run the setup command:

$ exist_client setup

This will create a new directory called .exist in your home folder. Inside is a config file config.yml where you can configure ExistClient.

Configuration

In the config.yml file, you can specify which plugins to use as well as the cutoff hour to switch to a new day (it defaults to 5am).

plugins:
  tasks: omni_focus
  time_tracking: qbserve
cutoff_hour: 3

Plugins

Tasks

Time Tracking

Usage

In order to use the client, you will need an Exist API key. You can generate one here, then make it available as the environment variable EXIST_API_KEY.

Once you have your API key, you can send metrics manually with exist_client report.

If you're on a Mac and you want to run the report automatically, you can create a launchd agent. You can see an example that runs every day at 1pm here. The agent runs a helper command that looks like this:

#!/bin/bash

source ~/.secrets # Load your Exist API key
sleep 5 # Wait for network

# You may need to use something like ~/.rbenv/shims/exist_client if you use a ruby version manager
~/.rbenv/shims/exist_client report

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/[USERNAME]/exist_client. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the Contributor Covenant code of conduct.

License

The gem is available as open source under the terms of the MIT License.