Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/matteopolak/tcd
Twitch chat downloader CLI and GUI.
https://github.com/matteopolak/tcd
archive chat cli download downloader gui iced postgresql prisma rust tcd twitch twitch-chat-downloader
Last synced: 3 months ago
JSON representation
Twitch chat downloader CLI and GUI.
- Host: GitHub
- URL: https://github.com/matteopolak/tcd
- Owner: matteopolak
- License: gpl-3.0
- Created: 2022-11-08T20:13:59.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2022-12-19T00:45:47.000Z (about 2 years ago)
- Last Synced: 2024-10-04T22:12:53.395Z (3 months ago)
- Topics: archive, chat, cli, download, downloader, gui, iced, postgresql, prisma, rust, tcd, twitch, twitch-chat-downloader
- Language: Rust
- Homepage:
- Size: 722 KB
- Stars: 8
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Twitch Chat Downloader 🗒️
![Build Status](https://github.com/matteopolak/tcd/actions/workflows/build.yml/badge.svg)
![Release Status](https://github.com/matteopolak/tcd/actions/workflows/release.yml/badge.svg)
[![License:GPLv3](https://img.shields.io/badge/license-GPL--3.0-yellow.svg)](https://opensource.org/licenses/GPL-3.0)
[![Rust:Nightly](https://img.shields.io/badge/rust-nightly-blue.svg)](https://www.rust-lang.org/tools/install)[tcd](https://github.com/matteopolak/tcd) is a multi-threaded **T**witch **C**hat **D**ownloader built in Rust 🦀.
```powershell
Usage: tcd [OPTIONS] <--channel |--video >Options:
-c, --channel The channel(s) to download
-i, --client-id The Twitch client ID to use in the request headers
-f, --format Used with --output or --stdout [default: csv] [possible values: csv, jsonl]
-l, --limit Downloads the first n videos from each channel
-e, --live If specified, polls for new videos every `poll` seconds
-o, --output If specified, pipes data to the file
-p, --postgres [] The PostgreSQL connection string [default: DATABASE_URL env]
-q, --quiet Whether to print download progress
-s, --stdout If specified, pipes data to stdout
-t, --threads The number of threads to use [default: 10]
-v, --video The video ids to download the chat for
-w, --wait The number of minutes to wait between polls (`live` only) [default: 30]
-h, --help Print help information
-V, --version Print version information
```Pipe the chat messages of the first 5 videos of `Atrioc`, `Linkus7` and `Aspecticor` to the file `hitman.csv`
```powershell
tcd --channel atrioc --channel linkus7 --channel aspecticor --limit 5 --output hitman.csv
```Save the chat from the videos with id `1649326959` and `1648474855` to the connected PostgreSQL database.
```powershell
tcd --video 1649326959 --video 1648474855 --postgres
```## Building from source
```bash
# build the binary
cargo build --release# execute the binary
target/release/tcd --help
```## Generating datasets
Some pre-made dataset scripts are located in the [queries](./queries) directory.
You can run these with `cargo run -p queries --example `.## Using pre-made datasets
Pre-made datasets can be downloaded from [the Mediafire folder](https://www.mediafire.com/folder/agnhlbxz0q5zw/datasets).
## Piping data to a database
`tcd` supports saving data directly to a PostgreSQL database.
First, apply the Prisma schema with the following commands:```bash
# apply schema.prisma to the database
# note: this WILL wipe all database content
cargo prisma migrate dev --name init# generate the Prisma client
cargo prisma generate
```Or execute the [`migration.sql`](./scripts/migration.sql) SQL statements against your database.
Then, set the `DATABASE_URL` environment variable (a `.env` file works too), or supply the connection URL with `--postgres `.## Output format
Data piped to a file or stdout will be in the following format:
`--format csv`
```csv
channel,video_id,comment_id,commenter_id,created_at,text
atrioc,1680333612,5e0e429e-949d-4a23-9160-96da782a7354,mazman100,"2022-12-16 04:34:39.236 +00:00","NOOO"
atrioc,1680333612,b9939674-1340-4623-b351-c03d07c1e394,dazloc_,"2022-12-16 04:34:41.341 +00:00","WE BACK"
````--format jsonl`
```json
{"channel":"atrioc","video_id":1642642569,"comment_id":"3f445ae2-2f6e-4256-b367-df8132454786","commenter":"mazman100","created_at":"2022-11-03 21:25:22.754 +00:00","text":"NOOO"}
{"channel":"atrioc","video_id":1642642569,"comment_id":"b9939674-1340-4623-b351-c03d07c1e394","commenter":"dazloc_","created_at":"2022-12-16 04:34:41.341 +00:00","text":"WE BACK"}
```