Merge pull request #62 from ZonD80/master

new translate function
This commit is contained in:
Serghey Rodin 2013-01-25 13:10:57 -08:00
commit 91923879fa
7 changed files with 79 additions and 28 deletions

View file

@ -64,15 +64,15 @@ if ($_SESSION['user'] == 'admin') {
exec (VESTA_CMD."v-change-user-language ".$v_username." ".$v_language, $output, $return_var); exec (VESTA_CMD."v-change-user-language ".$v_username." ".$v_language, $output, $return_var);
if (!empty($v_notify)) { if (!empty($v_notify)) {
$to = $_POST['v_notify']; $to = $_POST['v_notify'];
$subject = _("Welcome to Vesta Control Panel"); $subject = _translate($v_language,"Welcome to Vesta Control Panel");
$hostname = exec('hostname'); $hostname = exec('hostname');
$from = _('MAIL_FROM',$hostname); $from = _translate($v_language,'MAIL_FROM',$hostname);
if (!empty($_POST['v_fname'])) { if (!empty($_POST['v_fname'])) {
$mailtext = _('GREETINGS_GORDON_FREEMAN',$_POST['v_fname'],$_POST['v_lname']); $mailtext = _translate($v_language,'GREETINGS_GORDON_FREEMAN',$_POST['v_fname'],$_POST['v_lname']);
} else { } else {
$mailtext = _('GREETINGS'); $mailtext = _translate($v_language,'GREETINGS');
} }
$mailtext .= _('ACCOUNT_READY',$_SERVER['HTTP_HOST'],$_POST['v_username'],$_POST['v_password']); $mailtext .= _translate($v_language,'ACCOUNT_READY',$_SERVER['HTTP_HOST'],$_POST['v_username'],$_POST['v_password']);
send_email($to, $subject, $mailtext, $from); send_email($to, $subject, $mailtext, $from);
} }

View file

@ -7,7 +7,7 @@
if (!defined('LANGUAGE')) die('Direct access not allowed'); if (!defined('LANGUAGE')) die('Direct access not allowed');
$LANG = array( $LANG['en'] = array(
'yes' => 'yes', 'yes' => 'yes',
'no' => 'no', 'no' => 'no',
'none' => 'нет', 'none' => 'нет',

View file

@ -7,7 +7,7 @@
if (!defined('LANGUAGE')) die('Direct access not allowed'); if (!defined('LANGUAGE')) die('Direct access not allowed');
$LANG = array( $LANG['ru'] = array(
'yes' => 'да', 'yes' => 'да',
'no' => 'нет', 'no' => 'нет',
'none' => 'нет', 'none' => 'нет',

View file

@ -1,25 +1,71 @@
<?php <?php
// need to be moved to user settings /**
define('LANGUAGE','ru'); * Translates string by a given key in first parameter to current session language. Works like sprintf
* @global array $LANG Associative array of language pharses
require_once($_SERVER['DOCUMENT_ROOT'].'/inc/i18n/'.LANGUAGE.'.php'); * @return string Translated string
* @see _translate()
// works like sprintf if more than one arguments called */
function _() { function _() {
global $LANG;
$args = func_get_args(); $args = func_get_args();
$key = $args[0]; array_unshift($args,$_SESSION['language']);
if (!isset($LANG[$key])) $text=$key; else return call_user_func_array("_translate",$args);
$text=$LANG[$key]; }
/**
* Translates string to given language in first parameter, key given in second parameter (dynamically loads required language). Works like spritf from second parameter
* @global array $LANG Associative array of language pharses
* @return string Translated string
*/
function _translate() {
global $LANG;
$args = func_get_args();
$l = $args[0];
if (!$l) return 'NO LANGUAGE DEFINED';
$key = $args[1];
if (!isset($LANG[$l])) {
define('LANGUAGE',true);
require_once($_SERVER['DOCUMENT_ROOT'].'/inc/i18n/'.$l.'.php');
}
if (!isset($LANG[$l][$key])) $text=$key; else
$text=$LANG[$l][$key];
array_shift($args);
if (count($args)>1) { $args[0] = $text; if (count($args)>1) { $args[0] = $text;
return call_user_func_array("sprintf",$args); return call_user_func_array("sprintf",$args);
} }
else return $text; else return $text;
} }
// Check user session
define('VESTA_CMD', '/usr/bin/sudo /usr/local/vesta/bin/');
$i = 0;
// setting language here
$ls['command'] = VESTA_CMD."v-list-sys-languages json";
exec ($ls['command'], $ls['output'], $ls['return_var']);
$ls['langs'] = json_decode(implode('', $ls['output']), true);
if (isset($_SESSION['language'])&&!in_array($_SESSION['language'],$ls['langs'])) {
$ls['browserlang'] = strtolower(substr($_SERVER['HTTP_ACCEPT_LANGUAGE'],0,2));
if (!in_array($ls['browserlang'],$ls['langs'])) {
unset($ls);
$ls['command'] = VESTA_CMD."v-list-sys-config json";
exec ($ls['command'], $ls['output'], $ls['return_var']);
$ls['langs'] = json_decode(implode('',$ls['output']),true);
$_SESSION['language'] = $ls['langs']['config']['LANGUAGE'];
} else {
$_SESSION['language'] = $ls['browserlang'];
}
}
unset($ls);
if ((!isset($_SESSION['user'])) && (!isset($api_mode))&&!defined('NO_AUTH_REQUIRED')) { if ((!isset($_SESSION['user'])) && (!isset($api_mode))&&!defined('NO_AUTH_REQUIRED')) {
$_SESSION['request_uri'] = $_SERVER['REQUEST_URI']; $_SESSION['request_uri'] = $_SERVER['REQUEST_URI'];
header("Location: /login/"); header("Location: /login/");
@ -32,10 +78,6 @@ if (isset($_SESSION['look']) && ( $_SESSION['look'] != 'admin' )) {
$user = $_SESSION['user']; $user = $_SESSION['user'];
} }
define('VESTA_CMD', '/usr/bin/sudo /usr/local/vesta/bin/');
$i = 0;
// Define functions // Define functions
function check_error($return_var){ function check_error($return_var){
if ( $return_var > 0 ) { if ( $return_var > 0 ) {

View file

@ -1,5 +1,11 @@
<?php <?php
session_start(); session_start();
define('NO_AUTH_REQUIRED',true);
include($_SERVER['DOCUMENT_ROOT']."/inc/main.php");
if (isset($_SESSION['user'])) { if (isset($_SESSION['user'])) {
header("Location: /list/user"); header("Location: /list/user");
} else { } else {

View file

@ -2,7 +2,6 @@
session_start(); session_start();
define('NO_AUTH_REQUIRED',true); define('NO_AUTH_REQUIRED',true);
define('NO_LANG', true);
include($_SERVER['DOCUMENT_ROOT']."/inc/main.php"); include($_SERVER['DOCUMENT_ROOT']."/inc/main.php");
@ -12,14 +11,10 @@ if (isset($_GET['logout'])) {
$TAB = 'LOGIN'; $TAB = 'LOGIN';
exec (VESTA_CMD."v-list-sys-config json", $output, $return_var);
if ($return_var != 0) { if ($return_var != 0) {
header("Location: /error/"); header("Location: /error/");
exit; exit;
} }
$data = json_decode(implode('', $output), true);
unset($output);
//$LANGUAGE = $data['config']['LANGUAGE'];
if (isset($_SESSION['user'])) { if (isset($_SESSION['user'])) {
if ($_SESSION['user'] == 'admin' && !empty($_GET['loginas'])) { if ($_SESSION['user'] == 'admin' && !empty($_GET['loginas'])) {

8
web/setlang.php Normal file
View file

@ -0,0 +1,8 @@
<?php
/*
* Just sets language
*/
session_start();
$_SESSION['language'] = strtolower(substr((string)$_GET['l'],0,2));
header("Location: /");
?>