You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Johannes Zellner 2e05989ee3
Add Cloudron installation method (#292)
6 days ago
classes Remove references to avconv 2 weeks ago
config Remove references to avconv 2 weeks ago
controllers Move Video class to a separate library 2 weeks ago
css Stop using grunt and use grumphp and robo instead 7 months ago
i18n Move Video class to a separate library 2 weeks ago
img Remove Google Cast support since the JS library does not seem to be maintained anymore and it frequently breaks 3 years ago
resources Remove obsolete documentation 2 weeks ago
templates Add generator meta with the current version 2 weeks ago
templates_c Add templates_c to repo 5 years ago
tests Remove references to avconv 2 weeks ago
.dockerignore Docker build 4 years ago
.gitignore Don't include .git folder in Docker image (fixes #281) 2 weeks ago
.htaccess Check if mod_deflate is enabled (fixes #270) 3 months ago
.travis.yml "composer check-platform-reqs" on CI 2 weeks ago Create 2 years ago docs: Be more consistent and use "AllTube" everywhere 2 years ago
Dockerfile Call check-platform-reqs when building the Docker image 2 weeks ago Add YAML block for config in issue template 3 months ago
LICENSE Create LICENSE 5 years ago
Procfile Use Apache on Heroku 5 years ago Add Cloudron installation method (#292) 6 days ago
RoboFile.php Create release package cleanly from a temporary folder (#279) 2 weeks ago
app.json Remove CONVERT option on Heroku as ffmpeg will not be available 2 weeks ago
composer.json Stop installing ffmpeg and phantomjs with Composer 2 weeks ago
composer.lock Stop installing ffmpeg and phantomjs with Composer 2 weeks ago
grumphp.yml Remove obsolete phpstan rule 1 month ago
index.php Remove obsolete routes 2 weeks ago
phpunit.xml Lint 1 month ago
requirements.txt Use Python buildpack in order to have a recent Python version 3 years ago
robots.txt fix: Use HTTPS in robots.txt 2 years ago
runtime.txt Use Python 2.7.17 on Heroku 7 months ago

AllTube Download

Donate using Liberapay

HTML GUI for youtube-dl (



From a release package

You can download the latest release package here.

You just have to unzip it on your server and it should be ready to use.

From Git

In order to get AllTube working, you need to use Composer:

composer install

This will download all the required dependencies.

You should also ensure that the templates_c folder has the right permissions:

chmod 770 templates_c/

(You need to adapt this to your permission model. You can find more information about this in the Smarty documentation.)

If your web server is Apache, you need to set the AllowOverride setting to All or FileInfo.


When updating from Git, you need to run Composer again:

git pull
composer install

On Heroku


On Cloudron

Cloudron is a complete solution for running apps on your server and keeping them up-to-date and secure.


The source code for the package can be found here.


If you want to use a custom config, you need to create a config file:

cp config/config.example.yml config/config.yml

PHP requirements

You will need PHP 7.2 (or higher) and the following PHP modules:

  • intl
  • mbstring
  • gmp

Web server configuration


The following modules are recommended:

  • mod_mime
  • mod_rewrite
  • mod_expires
  • mod_filter
  • mod_deflate
  • mod_headers


Here is an example Nginx configuration:

server {
        server_name localhost;
        listen 443 ssl;

        root /var/www/path/to/alltube;
        index index.php;

        access_log  /var/log/nginx/alltube.access.log;
        error_log   /var/log/nginx/alltube.error.log;

        types {
                text/html   html htm shtml;
                text/css    css;
                text/xml    xml;
                application/x-web-app-manifest+json   webapp;

        # Deny access to dotfiles
        location ~ /\. {
                deny all;

        location / {
                try_files $uri /index.php?$args;

        location ~ \.php$ {
                try_files $uri /index.php?$args;

                fastcgi_param     PATH_INFO $fastcgi_path_info;
                fastcgi_param     PATH_TRANSLATED $document_root$fastcgi_path_info;
                fastcgi_param     SCRIPT_FILENAME $document_root$fastcgi_script_name;

                fastcgi_pass unix:/var/run/php5-fpm.sock;
                fastcgi_index index.php;
                fastcgi_split_path_info ^(.+\.php)(/.+)$;
                fastcgi_intercept_errors off;

                fastcgi_buffer_size 16k;
                fastcgi_buffers 4 16k;

                include fastcgi_params;

Other dependencies

You need ffmpeg in order to enable conversions. (Conversions are disabled by default.)

On Debian-based systems:

sudo apt-get install ffmpeg

If your ffmpeg binary is not installed at /usr/bin/ffmpeg, you also need to edit the ffmpeg variable in config.yml.

Use as a library

The Video class is now available as a separate package so that you can reuse it in your projects.


We also provide a JSON API that you can use like this: /json?

It returns a JSON object generated by youtube-dl. You can find a list of all the properties in the youtube-dl documentation.


Please read the FAQ before reporting any issue.


This software is available under the GNU General Public License.