2014-01-30 10:51:10 +01:00
|
|
|
<?php
|
2015-02-04 10:46:36 +01:00
|
|
|
/* Icinga Web 2 | (c) 2013-2015 Icinga Development Team | GPLv2+ */
|
2014-01-30 10:51:10 +01:00
|
|
|
|
|
|
|
namespace Icinga\Module\Translation\Cli;
|
|
|
|
|
2014-08-27 15:51:49 +02:00
|
|
|
use Exception;
|
2014-01-30 10:51:10 +01:00
|
|
|
use Icinga\Cli\Command;
|
2014-08-27 16:03:15 +02:00
|
|
|
use Icinga\Exception\IcingaException;
|
2015-07-30 15:47:35 +02:00
|
|
|
use Icinga\Module\Translation\Util\GettextTranslationHelper;
|
2014-01-30 10:51:10 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Base class for translation commands
|
|
|
|
*/
|
|
|
|
class TranslationCommand extends Command
|
|
|
|
{
|
2015-07-30 15:47:35 +02:00
|
|
|
/**
|
|
|
|
* Get the gettext translation helper
|
|
|
|
*
|
|
|
|
* @param string $locale
|
|
|
|
*
|
|
|
|
* @return GettextTranslationHelper
|
|
|
|
*/
|
|
|
|
public function getTranslationHelper($locale)
|
|
|
|
{
|
|
|
|
$helper = new GettextTranslationHelper($this->app, $locale);
|
|
|
|
$helper->setConfig($this->Config());
|
|
|
|
return $helper;
|
|
|
|
}
|
|
|
|
|
2014-01-30 10:51:10 +01:00
|
|
|
/**
|
|
|
|
* Check whether the given locale code is valid
|
|
|
|
*
|
|
|
|
* @param string $code The locale code to validate
|
|
|
|
*
|
|
|
|
* @return string The validated locale code
|
|
|
|
*
|
|
|
|
* @throws Exception In case the locale code is invalid
|
|
|
|
*/
|
|
|
|
public function validateLocaleCode($code)
|
|
|
|
{
|
2014-08-21 10:06:53 +02:00
|
|
|
if (! preg_match('@[a-z]{2}_[A-Z]{2}@', $code)) {
|
2014-08-27 16:03:15 +02:00
|
|
|
throw new IcingaException(
|
|
|
|
'Locale code \'%s\' is not valid. Expected format is: ll_CC',
|
|
|
|
$code
|
|
|
|
);
|
2014-01-30 10:51:10 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return $code;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Check whether the given module is available and enabled
|
|
|
|
*
|
|
|
|
* @param string $name The module name to validate
|
|
|
|
*
|
|
|
|
* @return string The validated module name
|
|
|
|
*
|
|
|
|
* @throws Exception In case the given module is not available or not enabled
|
|
|
|
*/
|
|
|
|
public function validateModuleName($name)
|
|
|
|
{
|
|
|
|
$enabledModules = $this->app->getModuleManager()->listEnabledModules();
|
|
|
|
|
2015-07-30 15:47:35 +02:00
|
|
|
if (! in_array($name, $enabledModules)) {
|
2014-08-27 16:03:15 +02:00
|
|
|
throw new IcingaException(
|
|
|
|
'Module with name \'%s\' not found or is not enabled',
|
|
|
|
$name
|
|
|
|
);
|
2014-01-30 10:51:10 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return $name;
|
|
|
|
}
|
|
|
|
}
|