cyrusdavid / transmission

Just another PHP JSON-RPC client library for Transmission
MIT License
18 stars 2 forks source link

PHP Transmission RPC Client

A fully-tested PHP JSON-RPC client library for Transmission

Build Status

Table of Contents

Installation

Install through Composer:

{
  "require": {
    "vohof/transmission": "1.0.*"
  }
}

Example Usage

$config = array(
    'host'     => 'http://127.0.0.1',
    'endpoint' => '/transmission/rpc',
    'username' => 'foo', // Optional
    'password' => 'bar' // Optional
);

$transmission = new Vohof\Transmission($config);

// Add a torrent
$torrent = $transmission->add('magnet:?xt=urn:btih:335990d615594b9be409ccfeb95864e24ec702c7&dn=Ubuntu+12.10+Quantal+Quetzal+%2832+bits%29&tr=udp%3A%2F%2Ftracker.openbittorrent.com%3A80&tr=udp%3A%2F%2Ftracker.publicbt.com%3A80&tr=udp%3A%2F%2Ftracker.istole.it%3A6969&tr=udp%3A%2F%2Ftracker.ccc.de%3A80&tr=udp%3A%2F%2Fopen.demonii.com%3A1337');

// or
$content = base64_encode(file_get_contents('MyTorrent.torrent'));
$torrent = $transmission->add($content, true);

// Stop a torrent
$transmission->action('stop', $torrent['id']);

// Limit download speed
$transmission->set($torrent['id'], array('downloadLimit' => 100));

// Get torrent size
$transmission->get($torrent['id'], array('totalSize'));

// Remove torrent
$transmission->remove($torrent['id']););

// Remove torrent and its files
$transmission->remove($torrent['id'], true);

// Stats
$transmission->getStats();

See the tests for more usage

Use Transmission with Laravel

Add the service provider and alias the package in config/app.php

'providers' => array(
    ...
    'Vohof\TransmissionServiceProvider'
),
'aliases' => array(
    ...
    'Transmission' => 'Vohof\TransmissionFacade'
)

Publish config and modify app/config/packages/transmission/config.php

$ php artisan config:publish transmission --path=vendor/vohof/transmission/src/config

Use the library:

Transmission::add($base64EncodedTorrent, true);
Torrent::stats();

Advanced

The library uses Guzzle as it's HTTP Client but you can choose to swap it with something else if you want (eg. Buzz)

class BuzzClient extends \Vohof\ClientAbstract {
    ...
}

$transmission = new Vohof\Transmission($config, new BuzzClient);

To-Do

License

See LICENSE