Web GUI for yt-dlp
Find a file
Kumi 3d39af7a98
fix(download): improve stream selection logic
Added a check to ensure remux stream is selected only when there are multiple video URLs and no 'entries' in the video object. This prevents unnecessary remuxing when entries exist, optimizing resource usage and maintaining proper stream handling.
2024-11-04 18:51:54 +01:00
.github Stop supporting PHP 7.3 (#430) 2023-03-21 20:07:08 +01:00
classes fix(download): improve stream selection logic 2024-11-04 18:51:54 +01:00
config fix(config): simplify genericFormats options in example config 2024-09-18 15:17:09 +02:00
css Generate <img> tags with Smarty 2022-02-06 19:17:05 +01:00
i18n Update (redo) zh_CN translation (#369) 2022-04-07 22:14:08 +02:00
img Remove Google Cast support since the JS library does not seem to be maintained anymore and it frequently breaks 2017-07-03 10:19:50 +02:00
resources Remove every reference to alltubedownload.net (#422) 2022-10-16 15:22:47 +02:00
templates feat(playlist): enhance display and action buttons for entries 2024-09-20 14:16:23 +02:00
templates_c Add templates_c to repo 2015-06-28 19:53:18 +02:00
tests ucfirst Smarty modifier is deprecated 2023-03-21 20:25:47 +01:00
.dockerignore Docker build 2015-12-04 11:08:47 +01:00
.gitignore chore: update .gitignore to exclude composer.phar 2024-07-21 08:47:29 +02:00
.htaccess Remove every reference to alltubedownload.net (#422) 2022-10-16 15:22:47 +02:00
app.json Remove every reference to alltubedownload.net (#422) 2022-10-16 15:22:47 +02:00
CODE_OF_CONDUCT.md Create CODE_OF_CONDUCT.md 2017-07-30 14:46:41 +02:00
composer.json chore(deps): update PHPStan to v1.8 2024-07-21 11:18:10 +02:00
composer.lock chore(deps): update package dependencies 2024-09-20 13:32:01 +02:00
CONTRIBUTING.md Add some rules for pull requests 2020-09-27 17:52:27 +02:00
Dockerfile fixup! fix dockerfile permission issue (#426) 2023-03-21 20:07:31 +01:00
grumphp.yml Use phpmnd to detect magic numbers 2022-01-27 00:03:37 +01:00
heroku.yml heroku-docker-fix (#318) 2020-10-13 20:37:31 +02:00
index.php Don't redirect to REQUEST_URI when browsing to index.php 2022-02-20 13:28:57 +01:00
LICENSE Create LICENSE 2015-01-07 11:08:17 +01:00
phpunit.xml Upgrade phpunit to 9.5 2021-10-17 21:14:39 +02:00
Procfile Use Apache on Heroku 2015-06-04 20:34:41 +02:00
README.md Remove every reference to alltubedownload.net (#422) 2022-10-16 15:22:47 +02:00
requirements.txt Use Python buildpack in order to have a recent Python version 2016-12-22 13:30:53 +01:00
runtime.txt Use Python 3.8.12 on Heroku 2022-02-22 23:10:54 +01:00
SECURITY.md Add security policy 2022-02-19 20:47:53 +01:00

AllTube Download

HTML GUI for youtube-dl

Screenshot

Setup

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.

Update

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

git pull
composer install

On Heroku

Deploy

On Cloudron

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

Install

The source code for the package can be found here.

Config

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

If you want to serve the application under a basepath and/or with a different internal than external port (scenario: nginx->docker setup) Alltube supports the following X-Forwarded headers:

  • X-Forwarded-Host (ex. another.domain.com)
  • X-Forwarded-Path (ex: /alltube)
  • X-Forwarded-Port (ex: 5555)
  • X-Forwarded-Proto (ex: https)

Apache

The following modules are recommended:

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

Nginx

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.

JSON API

We also provide a JSON API that you can use like this: /json?url=https%3A%2F%2Fwww.youtube.com%2Fwatch%3Fv%3DdQw4w9WgXcQ

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

FAQ

Please read the FAQ before reporting any issue.

License

This software is available under the GNU General Public License.