mirror of
https://git.code.sf.net/p/seeddms/code
synced 2025-10-24 17:51:20 +00:00
169 lines
5.4 KiB
PHP
169 lines
5.4 KiB
PHP
<?php
|
|
/**
|
|
* Implementation of MyAccount view
|
|
*
|
|
* @category DMS
|
|
* @package SeedDMS
|
|
* @license GPL 2
|
|
* @version @version@
|
|
* @author Uwe Steinmann <uwe@steinmann.cx>
|
|
* @copyright Copyright (C) 2002-2005 Markus Westphal,
|
|
* 2006-2008 Malcolm Cowe, 2010 Matteo Lucarelli,
|
|
* 2010-2012 Uwe Steinmann
|
|
* @version Release: @package_version@
|
|
*/
|
|
|
|
/**
|
|
* Include parent class
|
|
*/
|
|
//require_once("class.Bootstrap.php");
|
|
|
|
/**
|
|
* Class which outputs the html page for MyAccount view
|
|
*
|
|
* @category DMS
|
|
* @package SeedDMS
|
|
* @author Markus Westphal, Malcolm Cowe, Uwe Steinmann <uwe@steinmann.cx>
|
|
* @copyright Copyright (C) 2002-2005 Markus Westphal,
|
|
* 2006-2008 Malcolm Cowe, 2010 Matteo Lucarelli,
|
|
* 2010-2012 Uwe Steinmann
|
|
* @version Release: @package_version@
|
|
*/
|
|
class SeedDMS_View_MyAccount extends SeedDMS_Theme_Style {
|
|
|
|
function js() { /* {{{ */
|
|
header('Content-Type: application/javascript');
|
|
?>
|
|
$(document).ready( function() {
|
|
$('#qrcode').hide();
|
|
$( "#toggleqrcode" ).click(function() {
|
|
$('#qrcode').toggle();
|
|
});
|
|
});
|
|
<?php
|
|
} /* }}} */
|
|
|
|
function show() { /* {{{ */
|
|
$dms = $this->params['dms'];
|
|
$user = $this->params['user'];
|
|
$enableuserimage = $this->params['enableuserimage'];
|
|
$passwordexpiration = $this->params['passwordexpiration'];
|
|
$enable2factauth = $this->params['enable2factauth'];
|
|
$httproot = $this->params['httproot'];
|
|
$quota = $this->params['quota'];
|
|
|
|
$this->htmlStartPage(getMLText("my_account"));
|
|
$this->globalNavigation();
|
|
$this->contentStart();
|
|
$this->pageNavigation(getMLText("my_account"), "my_account");
|
|
|
|
if($quota > 0) {
|
|
if(($remain = checkQuota($user)) < 0) {
|
|
$this->warningMsg(getMLText('quota_warning', array('bytes'=>SeedDMS_Core_File::format_filesize(abs($remain)))));
|
|
}
|
|
}
|
|
$this->contentHeading(getMLText("user_info"));
|
|
$this->contentContainerStart();
|
|
|
|
|
|
$this->rowStart();
|
|
if ($enableuserimage){
|
|
$this->columnStart(2);
|
|
print ($user->hasImage() ? "<img class=\"userImage\" src=\"".$httproot . "out/out.UserImage.php?userid=".$user->getId()."\">" : getMLText("no_user_image"))."\n";
|
|
$this->columnEnd();
|
|
$this->columnStart(10);
|
|
} else {
|
|
$this->columnStart(12);
|
|
}
|
|
|
|
print "<table class=\"table-condensed\">\n";
|
|
print "<tr>\n";
|
|
print "<td>".getMLText("name")." : </td>\n";
|
|
print "<td>".htmlspecialchars($user->getFullName()).($user->isAdmin() ? " (".getMLText("admin").")" : "")."</td>\n";
|
|
print "</tr>\n<tr>\n";
|
|
print "<td>".getMLText("user_login")." : </td>\n";
|
|
print "<td>".$user->getLogin()."</td>\n";
|
|
print "</tr>\n<tr>\n";
|
|
print "<td>".getMLText("email")." : </td>\n";
|
|
print "<td>".htmlspecialchars($user->getEmail())."</td>\n";
|
|
print "</tr>\n<tr>\n";
|
|
print "<td>".getMLText("comment")." : </td>\n";
|
|
print "<td>".htmlspecialchars($user->getComment())."</td>\n";
|
|
print "</tr>\n";
|
|
if($passwordexpiration > 0) {
|
|
print "<tr>\n";
|
|
print "<td>".getMLText("password_expiration")." : </td>\n";
|
|
print "<td>".htmlspecialchars($user->getPwdExpiration())."</td>\n";
|
|
print "</tr>\n";
|
|
}
|
|
print "<tr>\n";
|
|
print "<td>".getMLText("used_discspace")." : </td>\n";
|
|
print "<td>".SeedDMS_Core_File::format_filesize($user->getUsedDiskSpace())."</td>\n";
|
|
print "</tr>\n";
|
|
if($quota > 0) {
|
|
print "<tr>\n";
|
|
print "<td>".getMLText("quota")." : </td>\n";
|
|
print "<td>".SeedDMS_Core_File::format_filesize($user->getQuota())."</td>\n";
|
|
print "</tr>\n";
|
|
if($user->getQuota() > $user->getUsedDiskSpace()) {
|
|
$used = (int) ($user->getUsedDiskSpace()/$user->getQuota()*100.0+0.5);
|
|
$free = 100-$used;
|
|
} else {
|
|
$free = 0;
|
|
$used = 100;
|
|
}
|
|
print "<tr>\n";
|
|
print "<td>\n";
|
|
print "</td>\n";
|
|
print "<td>\n";
|
|
?>
|
|
<div class="progress">
|
|
<div class="bar bar-danger" style="width: <?php echo $used; ?>%;"></div>
|
|
<div class="bar bar-success" style="width: <?php echo $free; ?>%;"></div>
|
|
</div>
|
|
<?php
|
|
print "</td>\n";
|
|
print "</tr>\n";
|
|
if($enable2factauth) {
|
|
require "vendor/robthree/twofactorauth/lib/Providers/Qr/IQRCodeProvider.php";
|
|
require "vendor/robthree/twofactorauth/lib/Providers/Qr/BaseHTTPQRCodeProvider.php";
|
|
require "vendor/robthree/twofactorauth/lib/Providers/Qr/GoogleQRCodeProvider.php";
|
|
require "vendor/robthree/twofactorauth/lib/Providers/Rng/IRNGProvider.php";
|
|
require "vendor/robthree/twofactorauth/lib/Providers/Rng/MCryptRNGProvider.php";
|
|
require "vendor/robthree/twofactorauth/lib/TwoFactorAuthException.php";
|
|
require "vendor/robthree/twofactorauth/lib/TwoFactorAuth.php";
|
|
$tfa = new \RobThree\Auth\TwoFactorAuth('SeedDMS');
|
|
|
|
print "<tr>\n";
|
|
print "<td>\n";
|
|
echo getMLText('2_factor_auth');
|
|
print "</td>\n";
|
|
$secret = $user->getSecret();
|
|
if(!$secret) {
|
|
print "<td>\n";
|
|
echo '<a class="btn btn-default" href="../out/out.Setup2Factor.php">'.getMLText('setup_2_fact_auth').'</a>';
|
|
print "</td>\n";
|
|
} else {
|
|
print "<td>\n";
|
|
echo '<button class="btn btn-default" id="toggleqrcode">'.getMLText('toggle_qrcode').'</button>';
|
|
echo '<div id="qrcode">';
|
|
echo 'Code is: '.$code = $tfa->getCode($secret)."<br />";
|
|
echo 'Secret: '.$secret."<br />";
|
|
echo '<img src="' . $tfa->getQRCodeImageAsDataUri('My label', $secret) . '">';
|
|
echo "</div>";
|
|
print "</td>\n";
|
|
}
|
|
print "</tr>\n";
|
|
}
|
|
}
|
|
print "</table>\n";
|
|
$this->columnEnd();
|
|
$this->rowEnd();
|
|
|
|
$this->contentContainerEnd();
|
|
$this->contentEnd();
|
|
$this->htmlEndPage();
|
|
} /* }}} */
|
|
}
|
|
?>
|