alltube/classes/Config.php

251 lines
5.3 KiB
PHP
Raw Normal View History

2015-10-31 15:42:25 +01:00
<?php
/**
2016-09-08 00:28:28 +02:00
* Config class.
2016-08-01 13:29:13 +02:00
*/
2016-12-05 13:12:27 +01:00
2015-10-31 15:42:25 +01:00
namespace Alltube;
2016-03-30 01:49:08 +02:00
use Exception;
2015-10-31 15:42:25 +01:00
use Symfony\Component\Yaml\Yaml;
2016-03-30 01:49:08 +02:00
2015-10-31 15:42:25 +01:00
/**
2016-09-08 00:28:28 +02:00
* Manage config parameters.
2016-08-01 13:29:13 +02:00
*/
2016-03-30 01:49:08 +02:00
class Config
2015-10-31 15:42:25 +01:00
{
2016-08-01 13:29:13 +02:00
/**
2016-09-08 00:28:28 +02:00
* Singleton instance.
*
* @var Config|null
2016-08-01 13:29:13 +02:00
*/
2016-03-30 01:49:08 +02:00
private static $instance;
2015-10-31 15:42:25 +01:00
2016-08-01 13:29:13 +02:00
/**
2016-09-08 00:28:28 +02:00
* youtube-dl binary path.
*
2016-08-01 13:29:13 +02:00
* @var string
*/
2015-10-31 15:56:00 +01:00
public $youtubedl = 'vendor/rg3/youtube-dl/youtube_dl/__main__.py';
2016-08-01 13:29:13 +02:00
/**
2016-09-08 00:28:28 +02:00
* python binary path.
*
2016-08-01 13:29:13 +02:00
* @var string
*/
2015-10-31 15:42:25 +01:00
public $python = '/usr/bin/python';
2016-08-01 13:29:13 +02:00
/**
2016-09-08 00:28:28 +02:00
* youtube-dl parameters.
*
2016-08-01 13:29:13 +02:00
* @var array
*/
public $params = ['--no-warnings', '--ignore-errors', '--flat-playlist', '--restrict-filenames', '--no-playlist'];
2016-08-01 13:29:13 +02:00
/**
2016-09-08 00:28:28 +02:00
* Enable audio conversion.
*
2016-08-01 13:29:13 +02:00
* @var bool
*/
2015-10-31 15:42:25 +01:00
public $convert = false;
2016-08-01 13:29:13 +02:00
/**
* Enable advanced conversion mode.
*
* @var bool
*/
public $convertAdvanced = false;
/**
* List of formats available in advanced conversion mode.
*
* @var array
*/
public $convertAdvancedFormats = ['mp3', 'avi', 'flv', 'wav'];
2016-08-01 13:29:13 +02:00
/**
2016-09-08 00:28:28 +02:00
* avconv or ffmpeg binary path.
*
2016-08-01 13:29:13 +02:00
* @var string
*/
2015-11-21 20:54:38 +01:00
public $avconv = 'vendor/bin/ffmpeg';
2016-08-01 13:29:13 +02:00
/**
* Path to the directory that contains the phantomjs binary.
*
* @var string
*/
public $phantomjsDir = 'vendor/bin/';
/**
* Disable URL rewriting.
2017-01-10 23:39:58 +01:00
*
* @var bool
*/
public $uglyUrls = false;
/**
* Stream downloaded files trough server?
2017-01-16 12:11:37 +01:00
*
* @var bool
*/
public $stream = false;
2017-04-25 00:40:24 +02:00
/**
* Allow to remux video + audio?
*
* @var bool
*/
public $remux = false;
/**
2017-11-10 23:52:04 +01:00
* MP3 bitrate when converting (in kbit/s).
*
* @var int
*/
public $audioBitrate = 128;
/**
* avconv/ffmpeg logging level.
2017-12-09 23:57:21 +01:00
* Must be one of these: quiet, panic, fatal, error, warning, info, verbose, debug.
*
* @var string
*/
public $avconvVerbosity = 'error';
/**
2019-01-06 17:00:12 +01:00
* App name.
*
* @var string
*/
public $appName = 'AllTube Download';
2016-09-06 00:36:47 +02:00
/**
2016-09-08 00:28:28 +02:00
* YAML config file path.
*
2016-09-06 00:36:47 +02:00
* @var string
*/
private $file;
2016-08-19 01:07:51 +02:00
2015-10-31 15:50:32 +01:00
/**
2016-09-08 00:28:28 +02:00
* Config constructor.
2016-09-06 00:36:47 +02:00
*
* @param array $options Options
2015-10-31 15:50:32 +01:00
*/
private function __construct(array $options = [])
{
$this->applyOptions($options);
$this->getEnv();
}
/**
* Throw an exception if some of the options are invalid.
*
* @throws Exception If youtube-dl is missing
* @throws Exception If Python is missing
2019-04-21 18:35:24 +02:00
*
* @return void
*/
private function validateOptions()
{
/*
We don't translate these exceptions because they usually occur before Slim can catch them
so they will go to the logs.
*/
if (!is_file($this->youtubedl)) {
throw new Exception("Can't find youtube-dl at ".$this->youtubedl);
} elseif (!Video::checkCommand([$this->python, '--version'])) {
throw new Exception("Can't find Python at ".$this->python);
}
}
/**
* Apply the provided options.
*
* @param array $options Options
*
* @return void
*/
private function applyOptions(array $options)
2015-10-31 15:50:32 +01:00
{
foreach ($options as $option => $value) {
if (isset($this->$option) && isset($value)) {
$this->$option = $value;
2015-10-31 15:42:25 +01:00
}
}
}
/**
* Override options from environement variables.
* Supported environment variables: CONVERT, PYTHON, AUDIO_BITRATE.
*
* @return void
*/
private function getEnv()
{
foreach (['CONVERT', 'PYTHON', 'AUDIO_BITRATE', 'STREAM'] as $var) {
$env = getenv($var);
if ($env) {
$prop = lcfirst(str_replace('_', '', ucwords(strtolower($var), '_')));
$this->$prop = $env;
}
}
2015-10-31 15:42:25 +01:00
}
2015-10-31 15:50:32 +01:00
/**
* Get Config singleton instance.
2016-09-06 00:36:47 +02:00
*
2015-10-31 15:50:32 +01:00
* @return Config
*/
public static function getInstance()
2015-10-31 15:50:32 +01:00
{
if (!isset(self::$instance)) {
self::$instance = new self();
2015-10-31 15:42:25 +01:00
}
2016-09-08 00:28:28 +02:00
2016-03-30 01:49:08 +02:00
return self::$instance;
2015-10-31 15:42:25 +01:00
}
/**
* Set options from a YAML file.
*
* @param string $file Path to the YAML file
*/
public static function setFile($file)
{
if (is_file($file)) {
$options = Yaml::parse(file_get_contents($file));
self::$instance = new self($options);
self::$instance->validateOptions();
} else {
throw new Exception("Can't find config file at ".$file);
}
}
/**
* Manually set some options.
*
2019-04-21 18:35:24 +02:00
* @param array $options Options (see `config/config.example.yml` for available options)
* @param bool $update True to update an existing instance
*/
public static function setOptions(array $options, $update = true)
{
if ($update) {
$config = self::getInstance();
$config->applyOptions($options);
$config->validateOptions();
} else {
self::$instance = new self($options);
}
}
2016-08-01 13:29:13 +02:00
/**
2016-09-08 00:28:28 +02:00
* Destroy singleton instance.
*
2016-08-01 13:29:13 +02:00
* @return void
*/
public static function destroyInstance()
{
self::$instance = null;
}
2015-10-31 15:42:25 +01:00
}