azuracast / nowplaying
A lightweight PHP adapter for viewing the current now playing data in Icecast and SHOUTcast 1/2. A part of the AzuraCast software suite.
Installs: 41 654
Dependents: 1
Suggesters: 0
Security: 0
Stars: 29
Watchers: 6
Forks: 12
Open Issues: 0
pkg:composer/azuracast/nowplaying
Requires
- php: >=8.1
- ext-json: *
- ext-libxml: *
- ext-simplexml: *
- ext-xml: *
- guzzlehttp/guzzle: >7
- psr/http-client: *
- psr/http-factory: *
- psr/log: >=1
Requires (Dev)
README
NowPlaying is a lightweight, modern, object-oriented PHP library that abstracts out the currently playing metadata from popular radio broadcast software into a single common return format.
Installing
NowPlaying is a Composer package that you can include in your project by running:
composer require azuracast/nowplaying
Compatibility
| Now Playing data | Detailed client information | |
|---|---|---|
| Icecast (2.4+) | ✅ | ✅ | 
| SHOUTcast 2 | ✅ | ✅ | 
| SHOUTcast 1 | ✅ | ❌ | 
Usage Example
<?php // Example PSR-17 and PSR-18 implementation from Guzzle 7 // Install those with: // composer require guzzlehttp/guzzle $httpFactory = new GuzzleHttp\Psr7\HttpFactory(); $adapterFactory = new NowPlaying\AdapterFactory( $httpFactory, $httpFactory, new GuzzleHttp\Client ); $adapter = $adapterFactory->getAdapter( NowPlaying\Enums\AdapterType::Shoutcast2, 'http://my-station-url.example.com:8000' ); // You can also call: // $adapterFactory->getShoutcast2Adapter('http://url'); // Optionally set administrator password $adapter->setAdminUsername('admin'); // "admin" is the default $adapter->setAdminPassword('AdminPassword!'); // The first argument to the functions is the mount point or // stream ID (SID), to pull one specific stream's information. $now_playing = $adapter->getNowPlaying('1'); $clients = $adapter->getClients('1');
Example "now playing" response (PHP objects represented in JSON):
{
  "currentSong": {
    "text": "Joe Bagale - Until We Meet Again",
    "title": "Until We Meet Again",
    "artist": "Joe Bagale"
  },
  "listeners": {
    "total": 0,
    "unique": 0
  },
  "meta": {
    "online": true,
    "bitrate": 128,
    "format": "audio/mpeg"
  },
  "clients": []
}
Example "clients" response:
[
  {
    "uid": 1,
    "ip": "127.0.0.1",
    "userAgent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.81 Safari/537.36",
    "connectedSeconds": 123
  }
]