mirror of
				https://git.code.sf.net/p/seeddms/code
				synced 2025-10-26 18:51:20 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			323 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			323 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * Implementation of DocumentAccess 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 DocumentAccess 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_DocumentAccess extends SeedDMS_Theme_Style {
 | |
| 	function printAccessModeSelection($defMode) { /* {{{ */
 | |
| 		echo self::getAccessModeSelection($defMode);
 | |
| 	} /* }}} */
 | |
| 
 | |
| 	function getAccessModeSelection($defMode) { /* {{{ */
 | |
| 		$content = "<select name=\"mode\" class=\"form-control\">\n";
 | |
| 		$content .= "\t<option value=\"".M_NONE."\"" . (($defMode == M_NONE) ? " selected" : "") . ">" . getMLText("access_mode_none") . "</option>\n";
 | |
| 		$content .= "\t<option value=\"".M_READ."\"" . (($defMode == M_READ) ? " selected" : "") . ">" . getMLText("access_mode_read") . "</option>\n";
 | |
| 		$content .= "\t<option value=\"".M_READWRITE."\"" . (($defMode == M_READWRITE) ? " selected" : "") . ">" . getMLText("access_mode_readwrite") . "</option>\n";
 | |
| 		$content .= "\t<option value=\"".M_ALL."\"" . (($defMode == M_ALL) ? " selected" : "") . ">" . getMLText("access_mode_all") . "</option>\n";
 | |
| 		$content .= "</select>\n";
 | |
| 		return $content;
 | |
| 	} /* }}} */
 | |
| 
 | |
| 	function js() { /* {{{ */
 | |
| 		header('Content-Type: application/javascript; charset=UTF-8');
 | |
| ?>
 | |
| function checkForm()
 | |
| {
 | |
| 	msg = new Array();
 | |
| 	if ((document.form1.userid.options[document.form1.userid.selectedIndex].value == -1) && 
 | |
| 		(document.form1.groupid.options[document.form1.groupid.selectedIndex].value == -1))
 | |
| 			msg.push("<?php printMLText("js_select_user_or_group");?>");
 | |
| 	if (msg != "")
 | |
| 	{
 | |
|   	noty({
 | |
|   		text: msg.join('<br />'),
 | |
|   		type: 'error',
 | |
|       dismissQueue: true,
 | |
|   		layout: 'topRight',
 | |
|   		theme: 'defaultTheme',
 | |
| 			_timeout: 1500,
 | |
|   	});
 | |
| 		return false;
 | |
| 	}
 | |
| 	else
 | |
| 		return true;
 | |
| }
 | |
| 
 | |
| $(document).ready( function() {
 | |
| 	$('body').on('submit', '#form1', function(ev){
 | |
| 		if(checkForm()) return;
 | |
| 		ev.preventDefault();
 | |
| 	});
 | |
| });
 | |
| <?php
 | |
| 	} /* }}} */
 | |
| 
 | |
| 	function show() { /* {{{ */
 | |
| 		$dms = $this->params['dms'];
 | |
| 		$user = $this->params['user'];
 | |
| 		$document = $this->params['document'];
 | |
| 		$folder = $this->params['folder'];
 | |
| 		$allUsers = $this->params['allusers'];
 | |
| 		$allGroups = $this->params['allgroups'];
 | |
| 
 | |
| 
 | |
| 		$this->htmlStartPage(getMLText("document_title", array("documentname" => htmlspecialchars($document->getName()))));
 | |
| 		$this->globalNavigation($folder);
 | |
| 		$this->contentStart();
 | |
| 		$this->pageNavigation($this->getFolderPathHTML($folder, true, $document), "view_document", $document);
 | |
| 
 | |
| 		$this->contentHeading(getMLText("edit_document_access"));
 | |
| 		$this->rowStart();
 | |
| 		$this->columnStart(4);
 | |
| 
 | |
| 		if ($user->isAdmin()) {
 | |
| 
 | |
| ?>
 | |
| 	<form class="form-horizontal mb-4" action="../op/op.DocumentAccess.php">
 | |
|   <?php echo createHiddenFieldWithKey('documentaccess'); ?>
 | |
| 	<input type="Hidden" name="action" value="setowner">
 | |
| 	<input type="Hidden" name="documentid" value="<?php print $document->getId();?>">
 | |
| <?php
 | |
| 		$this->contentContainerStart();
 | |
| 		$owner = $document->getOwner();
 | |
| 		$options = array();
 | |
| 		foreach ($allUsers as $currUser) {
 | |
| 			if (!$currUser->isGuest())
 | |
| 				$options[] = array($currUser->getID(), htmlspecialchars($currUser->getLogin()), ($currUser->getID()==$owner->getID()), array(array('data-subtitle', htmlspecialchars($currUser->getFullName()))));
 | |
| 		}
 | |
| 		$this->formField(
 | |
| 			getMLText("set_owner"),
 | |
| 			array(
 | |
| 				'element'=>'select',
 | |
| 				'name'=>'ownerid',
 | |
| 				'class'=>'chzn-select',
 | |
| 				'options'=>$options
 | |
| 			)
 | |
| 		);
 | |
| 		$this->contentContainerEnd();
 | |
| 		$this->formSubmit("<i class=\"fa fa-save\"></i> ".getMLText('save'));
 | |
| ?>
 | |
| 	</form>
 | |
| <?php
 | |
| 		}
 | |
| 
 | |
| 		$this->contentHeading(getMLText("access_inheritance"));
 | |
| 
 | |
| 		if ($document->inheritsAccess()) {
 | |
| 			$this->infoMsg(getMLText("inherits_access_msg"));
 | |
| ?>
 | |
|   <p>
 | |
| 	<form action="../op/op.DocumentAccess.php" style="display: inline-block;">
 | |
|   <?php echo createHiddenFieldWithKey('documentaccess'); ?>
 | |
| 	<input type="hidden" name="documentid" value="<?php print $document->getId();?>">
 | |
| 	<input type="hidden" name="action" value="notinherit">
 | |
| 	<input type="hidden" name="mode" value="copy">
 | |
| 	<input type="submit" class="btn btn-primary" value="<?php printMLText("inherits_access_copy_msg")?>">
 | |
| 	</form>
 | |
| 	<form action="../op/op.DocumentAccess.php" style="display: inline-block;">
 | |
|   <?php echo createHiddenFieldWithKey('documentaccess'); ?>
 | |
| 	<input type="hidden" name="documentid" value="<?php print $document->getId();?>">
 | |
| 	<input type="hidden" name="action" value="notinherit">
 | |
| 	<input type="hidden" name="mode" value="empty">
 | |
| 	<input type="submit" class="btn btn-primary" value="<?php printMLText("inherits_access_empty_msg")?>">
 | |
| 	</form>
 | |
| 	</p>
 | |
| <?php
 | |
| 			$this->columnEnd();
 | |
| 			$this->rowEnd();
 | |
| 			$this->contentEnd();
 | |
| 			$this->htmlEndPage();
 | |
| 			return;
 | |
| 		}
 | |
| ?>
 | |
| 	<form action="../op/op.DocumentAccess.php">
 | |
|   <?php echo createHiddenFieldWithKey('documentaccess'); ?>
 | |
| 	<input type="hidden" name="documentid" value="<?php print $document->getId();?>">
 | |
| 	<input type="hidden" name="action" value="inherit">
 | |
| 	<input type="submit" class="btn btn-primary" value="<?php printMLText("does_not_inherit_access_msg")?>">
 | |
| 	</form>
 | |
| <?php
 | |
| 		$this->columnEnd();
 | |
| 		$this->columnStart(4);
 | |
| 
 | |
| 		$accessList = $document->getAccessList();
 | |
| 
 | |
| ?>
 | |
| <form class="form-horizontal mb-4" action="../op/op.DocumentAccess.php">
 | |
|   <?php echo createHiddenFieldWithKey('documentaccess'); ?>
 | |
| 	<input type="Hidden" name="documentid" value="<?php print $document->getId();?>">
 | |
| 	<input type="Hidden" name="action" value="setdefault">
 | |
| <?php
 | |
| 		$this->contentContainerStart();
 | |
| 		$this->formField(
 | |
| 			getMLText("default_access"),
 | |
| 			$this->getAccessModeSelection($document->getDefaultAccess())
 | |
| 		);
 | |
| 		$this->contentContainerEnd();
 | |
| 		$this->formSubmit("<i class=\"fa fa-save\"></i> ".getMLText('save'));
 | |
| ?>
 | |
| </form>
 | |
| 
 | |
| <form class="form-horizontal" action="../op/op.DocumentAccess.php" name="form1" id="form1">
 | |
| <?php echo createHiddenFieldWithKey('documentaccess'); ?>
 | |
| <input type="Hidden" name="documentid" value="<?php print $document->getId()?>">
 | |
| <input type="Hidden" name="action" value="addaccess">
 | |
| <?php
 | |
| 		$this->contentContainerStart();
 | |
| 		$memusers = array();
 | |
| 		foreach ($accessList["users"] as $userAccess) {
 | |
| 			$userObj = $userAccess->getUser();
 | |
| 			$memusers[] = $userObj->getID();
 | |
| 		}
 | |
| 		$options = array();
 | |
| 		$options[] = array(-1, getMLText('select_one'));
 | |
| 		foreach ($allUsers as $currUser) {
 | |
| 			if (!$currUser->isGuest() && !in_array($currUser->getID(), $memusers))
 | |
| 				$options[] = array($currUser->getID(), htmlspecialchars($currUser->getLogin()), false, array(array('data-subtitle', htmlspecialchars($currUser->getFullName()))));
 | |
| 		}
 | |
| 		$this->formField(
 | |
| 			getMLText("user"),
 | |
| 			array(
 | |
| 				'element'=>'select',
 | |
| 				'name'=>'userid',
 | |
| 				'class'=>'chzn-select',
 | |
| 				'options'=>$options
 | |
| 			)
 | |
| 		);
 | |
| 		$memgroups = array();
 | |
| 		foreach ($accessList["groups"] as $groupAccess) {
 | |
| 			$groupObj = $groupAccess->getGroup();
 | |
| 			$memgroups[] = $groupObj->getID();
 | |
| 		}
 | |
| 		$options = array();
 | |
| 		$options[] = array(-1, getMLText('select_one'));
 | |
| 		foreach ($allGroups as $groupObj) {
 | |
| 			if(!in_array($groupObj->getID(), $memgroups))
 | |
| 				$options[] = array($groupObj->getID(), htmlspecialchars($groupObj->getName()));
 | |
| 		}
 | |
| 		$this->formField(
 | |
| 			getMLText("group"),
 | |
| 			array(
 | |
| 				'element'=>'select',
 | |
| 				'name'=>'groupid',
 | |
| 				'class'=>'chzn-select',
 | |
| 				'attributes'=>array(array('data-placeholder', getMLText('select_group'))),
 | |
| 				'options'=>$options
 | |
| 			)
 | |
| 		);
 | |
| 		$this->formField(
 | |
| 			getMLText("access_mode"),
 | |
| 			$this->getAccessModeSelection(M_READ)
 | |
| 		);
 | |
| 		$this->contentContainerEnd();
 | |
| 		$this->formSubmit("<i class=\"fa fa-plus\"></i> ".getMLText('add'));
 | |
| ?>
 | |
| </form>
 | |
| <?php
 | |
| 		$this->columnEnd();
 | |
| 		$this->columnStart(4);
 | |
| 		/* memorize users with access rights */
 | |
| 		$memusers = array();
 | |
| 		/* memorize groups with access rights */
 | |
| 		$memgroups = array();
 | |
| 		if (count($accessList["users"]) != 0 || count($accessList["groups"]) != 0) {
 | |
| 
 | |
| 			print "<table class=\"table-condensed\">";
 | |
| 
 | |
| 			foreach ($accessList["users"] as $userAccess) {
 | |
| 				$userObj = $userAccess->getUser();
 | |
| 				$memusers[] = $userObj->getID();
 | |
| 				print "<tr>\n";
 | |
| 				print "<td><i class=\"fa fa-user\"></i></td>\n";
 | |
| 				print "<td>". htmlspecialchars($userObj->getFullName()) . "</td>\n";
 | |
| 				print "<form action=\"../op/op.DocumentAccess.php\">\n";
 | |
| 				print "<td>\n";
 | |
| 				$this->printAccessModeSelection($userAccess->getMode());
 | |
| 				print "</td>\n";
 | |
| 				print "<td>\n";
 | |
| 				echo createHiddenFieldWithKey('documentaccess')."\n";
 | |
| 				print "<input type=\"Hidden\" name=\"documentid\" value=\"".$document->getId()."\">\n";
 | |
| 				print "<input type=\"hidden\" name=\"action\" value=\"editaccess\">\n";
 | |
| 				print "<input type=\"hidden\" name=\"userid\" value=\"".$userObj->getID()."\">\n";
 | |
| 				print "<button type=\"submit\" class=\"btn btn-primary btn-mini btn-sm\"><i class=\"fa fa-save\"></i> ".getMLText("save")."</button>";
 | |
| 				print "</td>\n";
 | |
| 				print "</form>\n";
 | |
| 				print "<form action=\"../op/op.DocumentAccess.php\">\n";
 | |
| 				print "<td><span class=\"actions\">\n";
 | |
| 				echo createHiddenFieldWithKey('documentaccess')."\n";
 | |
| 				print "<input type=\"Hidden\" name=\"documentid\" value=\"".$document->getId()."\">\n";
 | |
| 				print "<input type=\"hidden\" name=\"action\" value=\"delaccess\">\n";
 | |
| 				print "<input type=\"hidden\" name=\"userid\" value=\"".$userObj->getID()."\">\n";
 | |
| 				print "<button type=\"submit\" class=\"btn btn-danger btn-mini btn-sm\"><i class=\"fa fa-remove\"></i> ".getMLText("delete")."</button>";
 | |
| 				print "<span></td>\n";
 | |
| 				print "</form>\n";
 | |
| 				print "</tr>\n";
 | |
| 			}
 | |
| 
 | |
| 			foreach ($accessList["groups"] as $groupAccess) {
 | |
| 				$groupObj = $groupAccess->getGroup();
 | |
| 				$memgroups[] = $groupObj->getID();
 | |
| 				$mode = $groupAccess->getMode();
 | |
| 				print "<tr>";
 | |
| 				print "<td><i class=\"fa fa-group\"></i></td>";
 | |
| 				print "<td>". htmlspecialchars($groupObj->getName()) . "</td>";
 | |
| 				print "<form action=\"../op/op.DocumentAccess.php\">";
 | |
| 				print "<td>";
 | |
| 				$this->printAccessModeSelection($groupAccess->getMode());
 | |
| 				print "</td>\n";
 | |
| 				print "<td><span class=\"actions\">\n";
 | |
| 				echo createHiddenFieldWithKey('documentaccess')."\n";
 | |
| 				print "<input type=\"hidden\" name=\"documentid\" value=\"".$document->getId()."\">";
 | |
| 				print "<input type=\"hidden\" name=\"action\" value=\"editaccess\">";
 | |
| 				print "<input type=\"hidden\" name=\"groupid\" value=\"".$groupObj->getID()."\">";
 | |
| 				print "<button type=\"submit\" class=\"btn btn-primary btn-mini btn-sm\"><i class=\"fa fa-save\"></i> ".getMLText("save")."</button>";
 | |
| 				print "</span></td>\n";
 | |
| 				print "</form>";
 | |
| 				print "<form action=\"../op/op.DocumentAccess.php\">\n";
 | |
| 				print "<td><span class=\"actions\">\n";
 | |
| 				echo createHiddenFieldWithKey('documentaccess')."\n";
 | |
| 				print "<input type=\"hidden\" name=\"documentid\" value=\"".$document->getId()."\">\n";
 | |
| 				print "<input type=\"hidden\" name=\"action\" value=\"delaccess\">\n";
 | |
| 				print "<input type=\"hidden\" name=\"groupid\" value=\"".$groupObj->getID()."\">\n";
 | |
| 				print "<button type=\"submit\" class=\"btn btn-danger btn-mini btn-sm\"\"><i class=\"fa fa-remove\"></i> ".getMLText("delete")."</button>";
 | |
| 				print "</form>";
 | |
| 				print "</span></td>\n";
 | |
| 				print "</tr>\n";
 | |
| 			}
 | |
| 			
 | |
| 			print "</table><br>";
 | |
| 		}
 | |
| 		$this->columnEnd();
 | |
| 		$this->rowEnd();
 | |
| 		$this->contentEnd();
 | |
| 		$this->htmlEndPage();
 | |
| 	} /* }}} */
 | |
| }
 | |
| ?>
 | 
