2016-05-18 15:40:21 -04:00
# TeamspeakStats [![Build Status](https://travis-ci.org/Thor77/TeamspeakStats.svg?branch=master)](https://travis-ci.org/Thor77/TeamspeakStats) [![Coverage Status](https://coveralls.io/repos/Thor77/TeamspeakStats/badge.svg?branch=master&service=github)](https://coveralls.io/github/Thor77/TeamspeakStats?branch=master) [![Code Health](https://landscape.io/github/Thor77/TeamspeakStats/master/landscape.svg?style=flat)](https://landscape.io/github/Thor77/TeamspeakStats/master) [![PyPI](https://img.shields.io/pypi/v/tsstats.svg)](https://pypi.python.org/pypi/tsstats) [![Documentation Status](https://readthedocs.org/projects/teamspeakstats/badge/?version=latest)](http://teamspeakstats.readthedocs.io/en/latest/?badge=latest)
2017-02-14 02:00:55 -05:00
A simple Teamspeak stat-generator - based solely on server-logs
2015-03-05 12:53:47 -05:00
2016-05-11 14:39:45 -04:00
![screenshot ](screenshot.png )
2015-07-13 15:14:03 -04:00
# Installation
2016-05-11 14:40:23 -04:00
- Install the package via PyPi `pip install tsstats`
2016-10-28 17:42:44 -04:00
- Clone this repo `git clone https://github.com/Thor77/TeamspeakStats` and install with `python setup.py install`
- Just use the package as is via `python -m tsstats [-h]`
2015-07-13 15:14:03 -04:00
2015-03-13 16:03:42 -04:00
# Usage
2016-05-11 14:40:23 -04:00
- Run the script `tsstats [-h]`
2016-10-30 15:41:38 -04:00
- Optionally create a config-file (see [Configuration ](https://github.com/Thor77/TeamspeakStats#configuration ))
2017-02-14 02:00:55 -05:00
- The package works entirely off your Teamspeak server's logs, so that no ServerQuery account is necessary
2015-03-13 16:03:42 -04:00
2016-10-30 16:07:00 -04:00
# Example
```
tsstats -l /var/log/teamspeak3-server/ts3server*.log -o /var/www/tsstats.html
```
2017-02-14 02:00:55 -05:00
Parse logs matching `ts3server*.log` in `/var/log/teamspeak3-server` and write output to `/var/www/tsstats.html` .
2016-10-30 16:07:00 -04:00
2016-10-30 16:08:27 -04:00
# CLI-Usage
2015-08-26 14:00:48 -04:00
```
2016-06-08 12:12:57 -04:00
usage: tsstats [-h] [-c CONFIG] [--idmap IDMAP] [-l LOG] [-o OUTPUT] [-d]
2017-02-27 06:42:12 -05:00
[-ds] [-nod] [-t TEMPLATE] [-dtf DATETIMEFORMAT]
[-otth ONLINETIMETHRESHOLD]
2015-08-26 14:00:48 -04:00
2017-02-27 06:42:12 -05:00
A simple Teamspeak stats-generator, based solely on server-logs
2015-08-26 14:00:48 -04:00
optional arguments:
2016-06-08 12:12:57 -04:00
-h, --help show this help message and exit
-c CONFIG, --config CONFIG
path to config
--idmap IDMAP path to id_map
-l LOG, --log LOG path to your logfile(s)
-o OUTPUT, --output OUTPUT
path to the output-file
-d, --debug debug mode
2017-02-27 06:42:12 -05:00
-ds, --debugstdout write debug output to stdout
2016-06-23 15:42:03 -04:00
-nod, --noonlinedc don't add connect until now to onlinetime
2016-08-10 17:10:23 -04:00
-t TEMPLATE, --template TEMPLATE
path to custom template
2016-09-17 16:47:04 -04:00
-dtf DATETIMEFORMAT, --datetimeformat DATETIMEFORMAT
format of date/time-values (datetime.strftime)
2016-11-11 12:45:52 -05:00
-otth ONLINETIMETHRESHOLD, --onlinetimethreshold ONLINETIMETHRESHOLD
threshold for displaying onlinetime (in seconds)
2015-08-26 14:00:48 -04:00
```
2015-03-05 12:53:47 -05:00
# Configuration
2016-05-10 17:05:12 -04:00
#### [General]
| Key | Description |
|-----|-------------|
| log | Path to TS3Server-logfile(s) (supports [globbing ](https://docs.python.org/3/library/glob.html )) |
| output | Path to the location, where the generator will put the generated `.html` -file |
2016-06-08 12:12:57 -04:00
| idmap | Path to [IdentMap ](http://teamspeakstats.readthedocs.io/en/latest/identmap.html ) |
| debug | debug mode |
2017-02-27 06:43:24 -05:00
| debugstdout | write debug output (only) to stdout |
2016-06-25 14:45:46 -04:00
| onlinedc | Add timedelta from last-connect until now to onlinetime for connected clients |
2016-08-10 17:10:23 -04:00
| template | Path to a custom template file (relative from `tsstats/` or absolute) |
2016-09-17 16:47:04 -04:00
| datetimeformat | Format of date/time-values used for render-timestamp and last online (using [datetime.strftime ](https://docs.python.org/3/library/datetime.html#strftime-strptime-behavior )) |
2016-11-14 15:28:02 -05:00
| onlinetimethreshold | Clients with an onlinetime below that threshold (in seconds) are hidden in the onlinetime-section |
2015-05-18 13:43:37 -04:00
2015-03-05 12:53:47 -05:00
## Example
```
[General]
2016-05-10 17:05:12 -04:00
log = /usr/local/bin/teamspeak-server/logs/ts3server*_1.log
output = /var/www/html/stats.html
2015-05-12 15:38:34 -04:00
```
2016-10-30 14:49:19 -04:00
# Contributing
Please make sure tests are succeeding and your code follows [flake8 ](https://flake8.readthedocs.io )-guidelines.
## Run tests
- Install testing-requirements `pip install -r testing_requirements.txt`
- Run `py.test tsstats/`
2017-02-15 15:55:11 -05:00
## Supported Python-versions
* Python 2 (2.7)
* Python 3 (3.5, 3.6)