AzuraCast is a self-hosted web radio management suite, including turnkey installer tools and an easy-to-use web app to manage your stations. http://azuracast.com/
Go to file
Buster "Silver Eagle" Neece 2bdc233997 Change cache dir for Travis. 2019-01-31 14:48:17 -06:00
.github Emphasize the importance of logs in the bug template. 2018-10-30 03:05:21 -05:00
config Code and PHPDoc cleanup to green-light level 2 static analysis. 2019-01-31 11:54:17 -06:00
plugins Begin work on custom code plugins support. 2018-09-21 07:04:05 -05:00
resources Move templates folder to default. 2019-01-27 14:14:01 -06:00
src More minor code fixes, add linting to CI and docker.sh script. 2019-01-31 14:29:45 -06:00
templates #1115 -- Make DJ mount point configurable. 2019-01-29 18:25:41 -06:00
tests Code and PHPDoc cleanup to green-light level 2 static analysis. 2019-01-31 11:54:17 -06:00
util Create PHPStan bootstrap file, integrate into Travis CI. 2019-01-30 21:36:07 -06:00
web #1113 -- Add history API endpoint to the official docs. 2019-01-29 16:32:32 -06:00
.editorconfig Add .editorconfig 2018-06-13 06:31:18 -05:00
.env #968 -- Modify documentation regarding port mapping 2018-11-19 10:26:22 -06:00
.gitattributes #972 -- Make the repository friendlier to people using release builds. 2018-11-19 22:53:15 -06:00
.gitignore More minor code fixes, add linting to CI and docker.sh script. 2019-01-31 14:29:45 -06:00
.phplint.yml Change cache dir for Travis. 2019-01-31 14:48:17 -06:00
.travis.yml Expand aliases for Travis CI so it isn't so wordy 2019-01-31 14:37:42 -06:00
CODE_OF_CONDUCT.md Add Contributor Covenant Code of Conduct 2018-09-11 19:00:30 -05:00
CONTRIBUTING.md Move documentation back into the main repo. 2018-10-19 21:47:22 -05:00
LICENSE.txt Update casing on files, add SUPPORT.md with common solutions. [skip ci] 2017-07-20 20:33:08 -05:00
README.md Update the readme to add features. 2018-12-17 19:27:49 -06:00
SUPPORT.md #968 -- Modify documentation regarding port mapping 2018-11-19 10:26:22 -06:00
ansible.cfg Run composer as azuracast user and update permissions accordingly. 2017-10-21 00:05:26 -05:00
azuracast.dev.env Update the Docker Compose file to use an external .env file for settings. 2018-10-18 23:27:30 -05:00
azuracast.sample.env Update the Docker Compose file to use an external .env file for settings. 2018-10-18 23:27:30 -05:00
codeception.yml Architecture change: Integrate common AzuraCore code (#944) 2018-11-12 10:59:15 -06:00
composer.json More minor code fixes, add linting to CI and docker.sh script. 2019-01-31 14:29:45 -06:00
composer.lock More minor code fixes, add linting to CI and docker.sh script. 2019-01-31 14:29:45 -06:00
crowdin.yaml Update Crowdin configuration file 2018-11-24 12:15:08 -06:00
docker-compose.dev.yml Move to a unified Web container. 2019-01-14 05:36:17 -06:00
docker-compose.migrate.yml Move to a unified Web container. 2019-01-14 05:36:17 -06:00
docker-compose.sample.yml Fix LE connect and renewal functions and path of SSL certs in stations container. 2019-01-14 10:14:24 -06:00
docker-compose.static.yml Bring back containerized static asset builds, but better! 2019-01-29 15:23:38 -06:00
docker-compose.testing.yml Move to a unified Web container. 2019-01-14 05:36:17 -06:00
docker-migrate.sh Move to a unified Web container. 2019-01-14 05:36:17 -06:00
docker.sh More minor code fixes, add linting to CI and docker.sh script. 2019-01-31 14:29:45 -06:00
install.sh Add support for --release flag on traditional updates. 2018-12-17 22:23:52 -06:00
phpstan.neon More minor code fixes, add linting to CI and docker.sh script. 2019-01-31 14:29:45 -06:00
uninstall.sh #423 -- Update Ansible compliance, build uninstaller and migrator scripts (#442) 2018-02-19 17:35:43 -06:00
update.sh Implement message queue and worker for media processing/import tasks. 2018-12-30 04:18:48 -06:00

README.md

AzuraCast: A Self-Hosted Web Radio Manager

Build Status Apache 2.0 License Docker Pulls Twitter Follow

AzuraCast is a self-hosted, all-in-one web radio management suite. Using its easy installer and powerful but intuitive web interface, you can start up a fully working web radio station in a few quick minutes.

AzuraCast works for web radio stations of all types and sizes, and is built to run on even the most affordable VPS web hosts. AzuraCast's mascot is Azura Ruisselante, created by Tyson Tan.

AzuraCast is currently in beta. Many web radio stations already run AzuraCast, but keeping your server up-to-date with the latest code from the GitHub repository is strongly recommended for security, bug fixes and new feature releases. It's unlikely, but updates may result in unexpected issues or data loss, so always make sure to keep your station's media files backed up in a second location.

To install AzuraCast, you should have a basic understanding of the Linux shell terminal. Once installed, every aspect of your radio station can be managed via AzuraCast's web interface.

Live Demo

Want to see AzuraCast for yourself? Check out screenshots or visit our demo site at demo.azuracast.com:

  • Username: demo@azuracast.com
  • Password: demo

Install AzuraCast

  • Docker Installation (Recommended): Docker offers an easy-to-use experience with prebuilt images. Updates are simple and AzuraCast won't interfere with other software on your server. You should use this method whenever possible.

  • Traditional Installation: For advanced users, if you want more customizability or need to run a leaner installation, you can use the Traditional installation method to install AzuraCast on Ubuntu servers.

Features

For Radio Stations

  • Rich Media Management: Upload songs, edit metadata, preview songs and organize music into folders from your browser.
  • Playlists: Add music to standard-rotation playlists (in sequential or shuffled playback order) or schedule a playlist to play at a scheduled time, or once per x songs/minutes/etc.
  • Live DJs: Set up individual DJ/streamer accounts and see who's currently streaming from your station's profile page.
  • Web DJ: Broadcast live directly from your browser, with no extra software needed, with AzuraCast's built-in Web DJ tool.
  • Public Pages: AzuraCast includes embeddable public pages that you can integrate into your existing web page or use as the basis for your own customized player.
  • Listener Requests: Let your listeners request specific songs from your playlists, both via an API and a simple public-facing listener page.
  • Remote Relays: Broadcast your radio signal (including live DJs) to any remote server running Icecast or SHOUTcast.
  • Web Hooks: Integrate your station with Slack, Discord, TuneIn, Twitter and more by setting up web hooks that connect to third-party services.
  • Detailed Analytics and Reports: Keep track of every aspect of your station's listeners over time. View reports of each song's impact on your listener count. You can also generate a report that's compatible with SoundExchange for US web radio royalties.

For Server Administrators

  • Role-based User Management: Assign global and per-station permissions to a role, then add users to those roles to control access.
  • Custom Branding: Modify every aspect of both the internal and public-facing AzuraCast pages by supplying your own custom CSS and JavaScript.
  • Authenticated RESTful API: Individual users in the system can create API keys which have the same permissions they have in the system. The AzuraCast API is a powerful and well-documented tool for interacting with installations.
  • Web Log Viewing: Quickly diagnose problems affecting any part of the AzuraCast system through the system-wide web log viewer.
  • Automatic Radio Proxies: Many users can't connect directly to radio station ports (i.e. 8000) by default, so AzuraCast includes an automatic nginx proxy that lets listeners connect via the http (80) and https (443) ports. These proxies are also compatible with services like CloudFlare.

What's Included

Whether you're using the traditional installer or Docker containers, AzuraCast will automatically retrieve and install these components for you:

Radio Software

  • Liquidsoap as the always-playing "AutoDJ"
  • Icecast 2.4 as a radio broadcasting frontend (Icecast-KH installed on supported platforms)

For x86/x64 installations, SHOUTcast 2 DNAS can also be used as a broadcasting frontend. SHOUTcast is non-free software and does not come bundled with AzuraCast, but can be installed via the administration panel after AzuraCast has been installed.

Supporting Software

  • NGINX for serving web pages and the radio proxy
  • MariaDB as the primary database
  • PHP 7.2 powering the web application
  • InfluxDB for time-series based statistics
  • Redis for sessions, database and general caching

AzuraCast API

Once installed and running, AzuraCast exposes an API that allows you to monitor and interact with your stations. Documentation about this API and its endpoints are available on the AzuraCast API Documentation.

License

AzuraCast is licensed under the Apache license, version 2.0. This project is free and open-source software, and pull requests are always welcome.

Questions? Comments? Feedback?

AzuraCast is a volunteer project, and we depend on your support and feedback to keep growing. Issues for this codebase are tracked in this repository's Issues section on GitHub. Anyone can create a new issue for the project, and you are encouraged to do so.

Friends of AzuraCast

We would like to thank the following organizations for their support of AzuraCast's ongoing development:

  • DigitalOcean for generously providing the server resources we use for our demonstration instance, our staging and testing environments, and more
  • JetBrains for making our development faster, easier and more productive with tools like PhpStorm
  • CrowdIn for giving us a simple and powerful tool to help translate our application for users around the world
  • The creators and maintainers of the many free and open-source tools that AzuraCast is built on, who have done so much to help move FOSS forward

Support AzuraCast Development

AzuraCast will always be available free of charge, but if you find the software useful and would like to support the project's lead developer, visit either of the links below. Your support is greatly appreciated.

Buy Me a Coffee at ko-fi.com