A library to fetch data from the radio-browser.info catalog of Internet radio stations by using the project's api.
use \AdinanCenci\RadioBrowser\RadioBrowser;
$browser = new RadioBrowser();
$tag = 'metal';
$orderBy = 'name';
$descendingOrder = true;
$stations = $browser->getStationsByTag($tag, $orderBy, $descendingOrder);
print_r($stations);
See examples of how to use in the "examples" directory.
- Get tags
- Get states
- Get stations by tag
- Get stations by country
- Get stations by clicks
- Get stations by votes
- Get stations in XML format
- Get servers IPs
The methods of \AdinanCenci\RadioBrowser\RadioBrowser
will return either associative arrays or stdObjects, depending on the $associative
parameter informed to the constructor.
Parameter | Type | Default | Description |
---|---|---|---|
$server | string|bool | https://de1.api.radio-browser.info/ | A Radio Browser server, it defaults to "'https://de1.api.radio-browser.info/", if false is informed the object will pick a random server, see the server section for more information. |
$associative | bool | true | If true, the methods will return associative arrays, stdObjects otherwise. |
If you need the data represented in a specific format, then use \AdinanCenci\RadioBrowser\RarioBrowserApi
. The different methods will return data formatted as: json, xml, csv, m3u, pls, xspf and ttl.
Parameter | Type | Default | Description |
---|---|---|---|
$server | string|bool | https://de1.api.radio-browser.info/ | A Radio Browser server, it defaults to "'https://de1.api.radio-browser.info/", if false is informed, the object will pick a random server, see the server section for more information. |
$format | string | json | The format the data must be served, possible values: json, xml, csv, m3u, pls, xspf, ttl. |
The ::getStationsByUuid($uuids)
search stations with the specified ids.
Parameter | Type | Description |
---|---|---|
$uuids | string|array | A list of uuids, either an array, or an comma separated string. |
The ::getStationsByUrl($url)
method search stations by their web page.
The ::getStationsByClicks($offset, $limit, $hideBroken)
method returns the most sintonized stations.
The ::getStationsByVotes($offset, $limit, $hideBroken)
method returns the most voted stations.
The ::getStationsByRecentClicks($offset, $limit, $hideBroken)
method returns the currently most popular stations.
The ::getStationsByLastChange($offset, $limit, $hideBroken)
method returns the stations last updated.
The ::getStationOlderVersions($lastChangeUuid, $limit)
method returns old versions of stations from the last 30 days.
The ::getBrokenStations($offset, $limit)
method returns stations that did not pass the connection test.
All the methods in this section share the following parameters:
Parameter | Type | Default | Description |
---|---|---|---|
$order | string | 'name' | Possible values: name, url, homepage, favicon, tags, country, state, language, votes, codec, bitrate, lastcheckok, lastchecktime, clicktimestamp, clickcount, clicktrend, random. |
$reverse | bool | false | false = Ascending order. true = Descending order. |
$hideBroken | bool | false | Do not list stations that failed the connection test. |
$offset | int | 0 | |
$limit | int | 100000 |
The ::getStations($order, $reverse, $hideBroken, $offset, $limit)
method will return all stations.
The ::getStationsByName($name, $order, $reverse, $hideBroken, $offset, $limit)
method returns stations described with $name
.
The ::getStationsByExactName($name, $order, $rev...)
method returns stations described with an exact match of $name
.
The ::getStationsByCodec($codec, $order, $rev...)
method returns stations described with $codec
.
The ::getStationsByExactCodec($codec, $order, $rev...)
method returns stations described with an exact match of $codec
.
::getStationsByCountry($country, $order, $rev...)
::getStationsByExactCountry($country, $order, $rev...)
::getStationsByState($state, $order, $rev...)
::getStationsByExactState($state, $order, $rev...)
::getStationsByLanguage($language, $order, $rev...)
::getStationsByExactLanguage($language, $order, $rev...)
.
::getStationsByTag($tag, $order, $rev...)
::getStationsByExactTag($tag, $order, $rev...)
The ::searchStation($searchTerms)
method allow us to fine grain our search.
It receives a single associative array with the following keys available, all of which are optional:
Key | Type | Default | Description |
---|---|---|---|
name | string | null | |
nameExact | bool | false | |
country | string | null | |
countryExact | bool | false | |
countrycode | string | null | |
state | string | null | |
stateExact | bool | false | |
language | string | null | |
languageExact | bool | false | |
tag | string | null | |
tagExact | bool | false | |
tagList | string|array | null | A list of tags, either an array or a comma separated string. |
codec | string | null | |
bitrateMin | int | 0 | |
bitrateMax | int | 1000000 | |
order | string | name | Possible values: name, url, homepage, favicon, tags, country, state, language, votes, codec, bitrate, lastcheckok, lastchecktime, clicktimestamp, clickcount, clicktrend, random. |
reverse | bool | false | false = Ascending order. true = Descending order. |
offset | int | 0 | |
limit | int | 100000 |
The ::getStationCheckResults($stationUuid, $lastCheckUuid, $seconds, $limit)
method returns a list of station check results. If a station UUID is provided, the whole history will be returned, otherwise a list of all last checks of all stations will be sent (without older check results).
Parameter | Type | Default | Description |
---|---|---|---|
$stationUiid | 'string' | Optional. If set, only list check result of the matching station. | |
$lastCheckUuid | 'string' | If set, only list checks after the check with the given check. | |
$seconds | integer | 0 | if > 0, it will only return history entries from the last $seconds seconds. |
$limit | integer | 999999 |
The ::getStationClicks($stationUuid, $lastCheckUuid, $seconds)
method returns a list of station clicks. If a station UUID is provided, only clicks of the station will be returned, otherwise a list of all clicks of all stations will be sent (chunksize 10000).
Parameter | Type | Default | Description |
---|---|---|---|
$stationUiid | 'string' | Optional. If set, only list check result of the matching station. | |
$lastCheckUuid | 'string' | If set, only list checks after the check with the given check. | |
$seconds | integer | 0 | if > 0, it will only return history entries from the last $seconds seconds. |
The ::addStation($name, $url, $homePage, $favIcon, $countryCode, $state, $language, $tags, $geoLat, $geoLong)
method allow
us to insert new stations.
It receives a single associative array with the following keys available, all of which are optional:
Key | Type | Default | Description |
---|---|---|---|
$name | string | MANDATORY, the name of the radio station. Max 400 chars. | |
$rl | string | MANDATORY, the URL of the station. | |
$homePage | string | null | the homepage URL of the station. |
$favIcon | string | null | the URL of an image file (jpg or png). |
$countryCode | string | null | The 2 letter countrycode of the country where the radio station is located. |
$state | string | null | The name of the part of the country where the station is located. |
$language | string | null | The main language used in spoken text parts of the radio station. |
$tags | string | null | A list of tags separated by commas to describe the station. |
$geoLat | string | null | The latitude of the stream location. |
$geoLong | string | null | The longitude of the stream location. |
The ::clickStation($stationUuid)
method must be invoked every time a user starts playing a stream, this helps Radio Browser sort how popular each station is. IMPORTANT: Every call from the same IP address and for the same station only gets counted once per day.
The ::voteStation($stationUuid)
method increases the vote count by one. IMPORTANT: it can only be called once every 10 minutes for the same radio stations, from the same IP.
The methods bellow share the following parameters:
Parameter | Type | Default | Description |
---|---|---|---|
$filter | string | A string to be matched against. | |
$order | string | name | Possible values: name, stationcount. |
$reverse | bool | false | false = Ascending order. true = Descending order. |
$hideBroken | bool | false | Do not count stations that failed the connection test. |
The ::getCodecs($filter, $order, $reverse, $hideBroken)
method returns a list of codecs and a count of stations using them.
The ::getLanguages($filter, $ord...)
method returns a list of languages and a count of stations in this language.
The ::getTags($filter, $ord...)
method returns a list of tags and a count of stations described with them.
The ::getCountryCodes($filter, $ord...)
method returns a list of country codes and a count of stations described with them.
The ::getCountries($filter, $ord...)
method returns a list of countries and a count of stations described with them.
The ::getStates($filter, $country, $order, $reverse, $hideBroken)
return a list of states and a count of stations described with them.
Parameter | Type | Default | Description |
---|---|---|---|
$filter | string | A string to be matched against. | |
$country | string | null | The country that the state belongs to. |
$order | string | name | Possible values: name, stationcount. |
$reverse | bool | false | false = Ascending order. true = Descending order. |
$hideBroken | bool | false | Do not count stations that failed the connection test. |
::getServerStats()
::getServerMirrors()
::getServerConfig()
::getServerMetrics()
The ::getDnsRecords()
static method returns DNS information on available servers.
The ::getServerIps()
static method returns an array of IPs of available servers.
The ::getServers()
static method returns an array of URLs of available servers.
The ::pickAServer()
static method returns a random server's URL.
Use composer.
composer require adinan-cenci/radio-browser
MIT