Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/scttcper/qbittorrent
qBittorrent api wrapper
https://github.com/scttcper/qbittorrent
qbittorrent torrent-clients
Last synced: 5 days ago
JSON representation
qBittorrent api wrapper
- Host: GitHub
- URL: https://github.com/scttcper/qbittorrent
- Owner: scttcper
- License: mit
- Created: 2019-03-11T05:55:38.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2024-12-24T03:57:53.000Z (26 days ago)
- Last Synced: 2025-01-10T06:57:20.893Z (9 days ago)
- Topics: qbittorrent, torrent-clients
- Language: TypeScript
- Homepage: https://qbittorrent.vercel.app
- Size: 1.33 MB
- Stars: 45
- Watchers: 5
- Forks: 15
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome - qbittorrent - qBittorrent api wrapper (TypeScript)
README
# qBittorrent [![npm](https://badgen.net/npm/v/@ctrl/qbittorrent)](https://www.npmjs.com/package/@ctrl/qbittorrent) [![coverage](https://badgen.net/codecov/c/github/scttcper/qbittorrent)](https://codecov.io/gh/scttcper/qbittorrent)
> TypeScript api wrapper for [qBittorrent](https://www.qbittorrent.org/) using [ofetch](https://github.com/unjs/ofetch)
### Install
```console
npm install @ctrl/qbittorrent
```### Use
```ts
import { QBittorrent } from '@ctrl/qbittorrent';const client = new QBittorrent({
baseUrl: 'http://localhost:8080/',
username: 'admin',
password: 'adminadmin',
});async function main() {
const res = await client.getAllData();
console.log(res);
}
```### API
Docs: https://qbittorrent.vercel.app
qBittorrent Api Docs: https://github.com/qbittorrent/qBittorrent/wiki/WebUI-API-(qBittorrent-4.1)### Normalized API
These functions have been normalized between torrent clients to easily support switching between multiple torrent clients. See [below](#see-also) for alternative supported torrent clients
##### getAllData
Returns all torrent data and an array of label objects. Data has been normalized and does not match the output of native `listTorrents()`.
```ts
const data = await client.getAllData();
console.log(data.torrents);
```##### getTorrent
Returns one torrent data from torrent hash
```ts
const data = await client.getTorrent('torrent-hash');
console.log(data);
```##### pauseTorrent and resumeTorrent
Pause or resume a torrent
```ts
const paused = await client.pauseTorrent();
console.log(paused);
const resumed = await client.resumeTorrent();
console.log(resumed);
```##### removeTorrent
Remove a torrent. Does not remove data on disk by default.
```ts
// does not remove data on disk
const result = await client.removeTorrent('torrent_id', false);
console.log(result);// remove data on disk
const res = await client.removeTorrent('torrent_id', true);
console.log(res);
```##### addTorrent
Add a torrent, has client specific options. Also see normalizedAddTorrent
```ts
const result = await client.addTorrent(fs.readFileSync(torrentFile));
console.log(result);
```##### normalizedAddTorrent
Add a torrent and return normalized torrent data, can start a torrent paused and add label
```ts
const result = await client.normalizedAddTorrent(fs.readFileSync(torrentFile), {
startPaused: false;
label: 'linux';
});
console.log(result);
```##### export and create from state
If you're shutting down the server often (serverless?) you can export the state
```ts
const state = client.exportState()
const client = QBittorrent.createFromState(config, state);
```### See Also
All of the following npm modules provide the same normalized functions along with supporting the unique apis for each client.
deluge - https://github.com/scttcper/deluge
transmission - https://github.com/scttcper/transmission
utorrent - https://github.com/scttcper/utorrent### Start a test docker container
```
docker run -d \
--name=qbittorrent \
-e PUID=1000 \
-e PGID=1000 \
-e TZ=Etc/UTC \
-e WEBUI_PORT=8080 \
-p 8080:8080 \
-p 6881:6881 \
-p 6881:6881/udp \
--restart unless-stopped \
lscr.io/linuxserver/qbittorrent:latest
```