YTuner is a simple project inspired by YCast but rewritten from scratch and greatly improved. Designed to replace vTuner internet radio service and dedicated to all users of AVRs made by Yamaha, Denon, Onkyo, Marantz, Grundig and others with built-in vTuner support. If you own one (or even more) of the vTuner-enabled AVRs mentioned above and want to enjoy free internet radio stations on your device as before, and be sure that your device's streaming service won't suddenly end, you should consider using YTuner.
YCast is a great project, but my goal was to run a similar service on a very low-spec platform where python along with packages turned out to be too heavy and too slow. Now, with YTuner you can enjoy improved functionality at full speed of ultra lightweight native app on operating systems such as:
- Windows, Linux, macOS, BSD, Solaris, Raspberry Pi OS
and with selected CPU architecture:
- Intel i386, AMD64/x86_64, ARM/ARM64, PowerPC/PowerPC64, SPARC/SPARC64
or any others powered by cross-build abilities of Free Pascal Compiler.
YTuner supports :
- Custom stations list files (aka MyStations) : YAML files (YCast compatible) or INI files.
- Great Radio-browser.info functionality.
- AVR bookmarks. Single bookmark for many AVRs or dedicated bookmark for each AVR (if you own more then one) with support of "add" and "del" operations sent from AVR devices.
- Easy application configuration with ini files.
- Optional SSL support for YTuner HTTPS web request.
- Radio stations logo images conversion/resize on the fly with couple of supported image formats (JPG,PNG,GIF,TIFF-optional)
- Radio stations logo images optional cache.
- Radio-browser extensive caching with many options and auto refresh
- UUIDs, data structures and stations cache (based on files or RAM storage).
- Local DB based full cache of Radio-browser resources.
- Radio-browser advanced filtering and sorting (single config for many AVRs or dedicated configs for each AVR (if you own more then one))
- Radio-browser menu/submenu translator (for non-English users)
YTuner also has build in :
- Web service to support AVR requests.
- Optional DNS proxy service to intercept vtuner.com related DNS queries and others if needed.
- Maintenance service.
Theoretically, YTuner should work with most AVRs that support vTuner.
Now, the list of supported and tested devices below is short, but I hope it will expand with your help.
Please test YTuner with your AVR and give me your feedback.
- Yamaha
- Yamaha RX-V671
- Yamaha RX-V673
- Yamaha RX-V675 (Tested by seldam. Thank you.)
- Yamaha RX-V677 (Tested by Jordan / jordandalley. Thank you.)
- Yamaha RX-V777 (Confirmed by Jordan / jordandalley. Thank you.)
- Yamaha RX-V3900 (Tested by BeryBurnout. Thank you.)
- Yamaha RX-A820 (Tested by Prideland. Thank you.)
- Yamaha RX-V500D (Tested by qsm101. Thank you.)
- Yamaha DSP-Z7 (Tested by Beatrice / TheBossME. Thank you.)
- Yamaha NP-S2000 (Tested by Ice64zzz / Ice64zzz. Thank you.)
- Marantz
- Marantz NR1607 (Tested by brietman. Thank you.)
- Denon
- Denon AVR-X1000 (Tested by badekappe. Thank you.)
- Denon AVR-X1300W (Tested by gibsnicht. Thank you.)
- Denon AVR-X3200W (Tested by Larsvb0. Thank you.)
- Denon AVR-X3300W (Tested by citronalco. Thank you.)
- Denon AVR-2313 (Tested by Stijn-Daniels. Thank you.)
- Denon RCD-N7 (Tested by breml. Thank you.)
- Denon RCD-N9 CEOL (Tested by xaanur. Thank you.)
- Denon S-32 (Tested by xaanur. Thank you.)
- Pioneer
- Pioneer N-30 (Tested by stokifan. Thank you.)
- Noxon
- Noxon iRadio 300 (Tested by xaanur. Thank you.)
- ReVox
- ReVox M51 (Tested by roland68. Thank you.)
YTuner is a standalone application and in most cases it does not require additional services, frameworks, packages, virtual machines, libraries or tools to run properly (except optional OpenSSL and/or SQLite3 libraries). You can download from Releases a file specific to your operating system and CPU architecture or build YTuner from source (look at Build section).
After download (or build) save and extract files into prepared directory with granted read/write/execute privileges. Remember that the credentials who will run YTuner must also have permission to open TCP port 80 and optionally UDP 53 (note below).
Now, you should have directory with some of the following subdirectories and files :
-- ytuner
|-- config (subdir for config files)
|-- stations.ini (if you want to use a ini file with your favorite radio stations)
|-- stations.yaml (if you want to use a yaml/yml file with your favorite radio stations)
|-- avr.ini (common configuration file for all your AVRs)
|-- bookmark.xml (common bookmark file for all your AVRs - only if one of your AVR support bookmark)
|-- ...... (AVRs dedicated bookmark and config files)
|-- cache (subdir for cache files)
|-- rbuuids.txt (Radio browser UUIDs cache file)
|-- ...... (other cache files)
|-- db (subdir for databse cache file)
|-- rb.db (Radio browser database cache file)
|-- ytuner (or ytuner.exe for Windows)
|-- ytuner.ini (YTuner important config file)
Do not forget to add execute privileges to ytuner
on linux/*nix systems with a command like chmod +x ytuner
.
If you want to use SSL to support YTuner HTTPS web request you have to get OpenSSL libraries.
- Most linux/*nix systems install OpenSSL by default. Otherwise, use your favorite package manager to get OpenSSL libraries or download them from Github or visit OpenSSL Wiki for binary distributions source.
- Windows users can download them from Github (follow NOTES-WINDOWS.md instructions) or visit OpenSSL Wiki for binary distributions source.
Make sure to get/build the correct version of the OpenSSL libraries with the correct bit length for your OS. 32-bit libraries are needed if you chose to use the 32-bit version of YTuner or 64-bit for the AMD64/x86_64 version of YTuner.
Finally, you should have 2 files:
- OpenSSL 1.0.2 and earlier:
ssleay32.dll
(orlibssl32.dll
) andlibeay32.dll
- OpenSSL 1.1.x:
- 64-bit:
libssl-1_1-x64.dll
andlibcrypto-1_1-x64.dll
- 32-bit:
libssl-1_1.dll
andlibcrypto-1_1.dll
- 64-bit:
- OpenSSL 3.x.x:
- 64-bit:
libssl-3-x64.dll
andlibcrypto-3-x64.dll
- 32-bit:
libssl-3.dll
andlibcrypto-3.dll
- 64-bit:
- OpenSSL 1.0.2 and earlier:
and place them in your ytuner
directory or anywhere in your system PATH
.
Make sure your system has valid CA certificates.
Tip: The YTuner should work with LibreSSL libraries as well.
If you want to forget about potential connection problems with Radio-browser.info
while using YTuner and listening to your favorite stations, use one of the options [catDB, catMemDB, catPermMemDB]
of the RBCacheType
parameter in the ytuner.ini
file to download the full contents of the Radio-browser.info
resources once and store it in your local SQLite3 database.
Of course, only data that is useful for YTuner and AVR devices is downloaded and stored locally.
Due to the use of the very popular SQLite database, YTuner will need to use the library provided by the SQLite development team.
! Important ! : Minimal version of SQLite library is 3.33.0 (2020-08-14)
Tip: If you faced problems with the SQLite library, read this description.
Your YTuner machine and AVR(s) have to have internet access. Make sure your firewall is properly configured if necessary.
Set all DNS servers on your AVR config to your YTuner machine IP address.
Make sure that your YTuner machine is assigned a static IPv4 address.
Regardless of what operating system you use, you need to make sure that TCP port 80 is not being used by another application. YTuner has a built-in multi-threaded web server that listens on TCP port 80 so you don't have to worry about its configuration and performance.
Tip: In some special cases, it may be necessary to change the default TCP port 80 to another. You can do this by editing the YTuner ini file. See Application configuration section below.
YTuner has a built-in multi-threaded DNS proxy server that listens on UDP port 53. This feature is optional and you can simple disable it and/or configure by editing configuration .ini file ytuner.ini
(See Application configuration section below).
You can also use your favorite DNS server like dnsmasq
.
Most important is to point *.vtuner.com
domain to you YTuner machine and set all DNS servers on your AVR config to your YTuner machine IP address.
Tip: In some special cases, it may be necessary to change the default UDP port 53 to another. You can do this by editing the YTuner ini file. See Application configuration section below.
YTuner has a built-in maintenance service for diagnostic and future goals. At this moment you can use it to shut down YTuner service only.
Tip: In most cases, you will not need this functionality. See Application configuration section below.
YTuner is configured by simple ytuner.ini
file.
This file has the following capabilities:
Lines 1 to 165 in 9657077
YTuner's filtering and sorting functionality can be oriented by AVR device.
You can decide about it with CommonAVRini
setting of ytuner.ini
.
Common AVR config file avr.ini
or other AVRs dedicated config files have the following capabilities:
Lines 1 to 163 in 95c8f9d
Please read the descriptions in both .ini
files carefully.
You can enable support for the stations list local file. Two types of files are supported:
- .ini file :
[Category one name]
Station one name=http://url-of-station-one|http://url-of-station-one-logo
Station two name=http://url-of-station-two|http://url-of-station-two-logo
[Category two name]
Station three name=http://url-of-station-three|http://url-of-station-three-logo
Station four name=http://url-of-station-four|http://url-of-station-four-logo
- .yaml / .yml file :
Category one name:
Station one name: http://url-of-station-one|http://url-of-station-one-logo
Station two name: http://url-of-station-two|http://url-of-station-two-logo
Category two name:
Station three name: http://url-of-station-three|http://url-of-station-three-logo
Station four name: http://url-of-station-four|http://url-of-station-four-logo
YTuner can convert and resize on the fly logo image from JPEG, PNG, GIFF and TIFF (optionaly) to JPEG (default) or PNG format.
Tip: URLs with logo station images are optional.
What is the Bookmark
? Bookmark
is what is mentioned in the AVR user's manual. Bookmark
is operated only from the AVR device using the remote control. When you listen to a new station you can decide to put it into the Bookmark
or want to remove it from it. All stations added in this way are visible in the Bookmark
submenu of the AVR receiver.
If you AVR support Bookmark
you can enable and use this YTuner functionality.
You can configure YTuner to use one common bookmark file (bookmark.xml
) for all your AVR devices (if you have more then one) or each AVR will own its own bookmark file.
See Application configuration section above.
Simply execute ytuner.exe
.
If you credentials meet all requirements mentioned above just go to your ytuner directory and start application or simple use sudo
to execute application:
$ sudo ./ytuner
If you are not familiar with building Docker containers you can read this.
You can use fpcupdeluxe or CodeTyphon Studio or Lazarus Free Pascal RAD IDE to build YTuner.
Use the latest versions of these IDE and FPC. Relevant project files are included.
YTuner uses Indy - Internet Direct library to build its own binary files. Of course, YTuner binaries no longer need any additional libraries beyond the optional OpenSSL and/or SQLite3.
Important: Use the latest version of Indy library to build YTuner.
If you found this project useful, please star it. ⭐
YTuner is licensed under MIT license. See the license.txt file for more details.