smt/pmpd

PHP Music Player Daemon control implementation

v1.0.0 2015-12-02 09:09 UTC

This package is not auto-updated.

Last update: 2025-01-18 20:03:02 UTC


README

PHP client library for Music Player Daemon

Prerequesties

  • PHP 5.6+
  • Running MPD :)

Installation

composer require smt/pmpd dev-develop

Usage

use Smt\Pmpd\Client\Impl\DefaultClient;
use Smt\Pmpd\Configuration\HostConfiguration;
use Smt\Pmpd\Connection\Commands;
use Smt\Pmpd\Connection\ConnectionFactory;
use Smt\Pmpd\Entity\Enum\PlaybackState;
use Smt\Pmpd\Response\FailResponse;

$connectionFactory = new ConnectionFactory();
$config = new HostConfiguration();
$config->setHost('127.0.0.1');
$connection = $connectionFactory->createConnection($config);
$client = new DefaultClient($connection);

echo $client->getCurrent()->getTitle() . ' playing: ';
echo $client->getStatus()->getState() == PlaybackState::PLAYING . PHP_EOL;
$client->next();
$client->toggle();
$client->play();
$client->updateDatabaseAsync();
$response = $client->query(Commands::ADD_AND_RETURN_ID, 'Asking Alexandria - Not The American Average.flac', 1); // Add it to first position
if ($response instanceof FailResponse) {
    echo 'Something gone wrong :(' . PHP_EOL . PHP_EOL . $response->getMessage();
} else {
    echo 'Id in playlist:' . $response->get('Id') . PHP_EOL;
}

For more see documentation

Roadmap

  • Implement connection with password;
  • Write API documentation;
  • Cover with tests
  • Rewrite client to facade with subsystems;

License

This library is licensed under MIT license