Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ActivityWatch/aw-client
Client library for ActivityWatch
https://github.com/ActivityWatch/aw-client
activitywatch client library python
Last synced: 2 months ago
JSON representation
Client library for ActivityWatch
- Host: GitHub
- URL: https://github.com/ActivityWatch/aw-client
- Owner: ActivityWatch
- License: mpl-2.0
- Created: 2016-04-22T11:19:48.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2024-01-31T12:23:33.000Z (12 months ago)
- Last Synced: 2024-04-14T00:33:59.919Z (9 months ago)
- Topics: activitywatch, client, library, python
- Language: Python
- Size: 473 KB
- Stars: 40
- Watchers: 5
- Forks: 39
- Open Issues: 13
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
- awesome-activitywatch - aw-client
README
aw-client
=========[![GitHub Actions badge](https://github.com/ActivityWatch/aw-client/workflows/Build/badge.svg)](https://github.com/ActivityWatch/aw-client/actions)
[![PyPI](https://img.shields.io/pypi/v/aw-client)](https://pypi.org/project/aw-client/)
[![Code style: black](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/psf/black)
[![Typechecking: Mypy](http://www.mypy-lang.org/static/mypy_badge.svg)](http://mypy-lang.org/)Client library for ActivityWatch in Python.
Please see [the documentation][docs] for usage, and take a look at `examples/`.
- [Documentation][docs]
- [API Reference][apiref][docs]: https://docs.activitywatch.net/en/latest/
[apiref]: https://docs.activitywatch.net/en/latest/api/python.html#aw-client## How to install
Install from pip: `pip install aw-client`
Install the latest version directly from github without cloning: `pip install git+https://github.com/ActivityWatch/aw-client.git`
To install from a cloned version:
- clone repo: `git clone https://github.com/ActivityWatch/aw-client.git`
- cd into the directory: `cd aw-client`
- run `poetry install` (will create a virtualenv, if none activated)
- If you don't want to use poetry you can also use `pip install .`, but that might not get the exact version of the dependencies (due to not reading the `poetry.lock` file).## Usage
For the CLI:
```
$ aw-client --help
Usage: aw-client [OPTIONS] COMMAND [ARGS]...CLI utility for aw-client to aid in interacting with the ActivityWatch
serverOptions:
--host TEXT Address of host
--port INTEGER Port to use
-v, --verbose Verbosity
--testing Set to use testing ports by default
--help Show this message and exit.Commands:
buckets List all buckets
canonical Query 'canonical events' for a single host (filtered,...
events Query events from bucket with ID `bucket_id`
heartbeat Send a heartbeat to bucket with ID `bucket_id` with JSON `data`
query Run a query in file at `path` on the server
report Generate an activity report
```## Debugging
* Run python with `LOG_LEVEL=debug` to get additional debugging output
* If invalid events have been queued for submission, you may need to delete the file-based queues generated by this library
* To use the development version of this library use `aw-client = {path = "../aw-client" }` in `pyproject.toml`## Examples
The [`examples/`](examples/) directory contains a couple of example scripts, including:
- [`time_spent_today.py`](examples/time_spent_today.py) - fetches all non-afk events and sums their duration to get the total active time for the day.
- [`working_hours.py`](https://github.com/ActivityWatch/aw-client/blob/master/examples/working_hours.py) - computes hours worked per day (matching a "work" category rule), and exports matching events to a JSON file (for auditing).
- [`load_dataframe.py`](https://github.com/ActivityWatch/aw-client/blob/master/examples/load_dataframe.py) - loads events from a host using a categorizing & AFK-filtering query, put result in a pandas dataframe, and export as CSV.
- [`merge_buckets.py`](examples/merge_buckets.py) - merges two buckets with non-intersecting events by moving all events from one into the other.
- [`redact_sensitive.py`](examples/redact_sensitive.py) - redact sensitive events.