mirror of
				https://git.code.sf.net/p/seeddms/code
				synced 2025-10-26 10:41:18 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			299 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			299 lines
		
	
	
		
			10 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_Bootstrap_Style {
 | |
| 
 | |
| 	function printAccessModeSelection($defMode) { /* {{{ */
 | |
| 		print "<select name=\"mode\">\n";
 | |
| 		print "\t<option value=\"".M_NONE."\"" . (($defMode == M_NONE) ? " selected" : "") . ">" . getMLText("access_mode_none") . "</option>\n";
 | |
| 		print "\t<option value=\"".M_READ."\"" . (($defMode == M_READ) ? " selected" : "") . ">" . getMLText("access_mode_read") . "</option>\n";
 | |
| 		print "\t<option value=\"".M_READWRITE."\"" . (($defMode == M_READWRITE) ? " selected" : "") . ">" . getMLText("access_mode_readwrite") . "</option>\n";
 | |
| 		print "\t<option value=\"".M_ALL."\"" . (($defMode == M_ALL) ? " selected" : "") . ">" . getMLText("access_mode_all") . "</option>\n";
 | |
| 		print "</select>\n";
 | |
| 	} /* }}} */
 | |
| 
 | |
| 	function js() { /* {{{ */
 | |
| 		header('Content-Type: application/javascript');
 | |
| ?>
 | |
| 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;
 | |
| 		event.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->contentContainerStart();
 | |
| 
 | |
| 		if ($user->isAdmin()) {
 | |
| 
 | |
| 			$this->contentSubHeading(getMLText("set_owner"));
 | |
| ?>
 | |
| 	<form class="form-inline" 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();?>">
 | |
| 	<select name="ownerid">
 | |
| 	<?php
 | |
| 	$owner = $document->getOwner();
 | |
| 	foreach ($allUsers as $currUser) {
 | |
| 		if ($currUser->isGuest())
 | |
| 			continue;
 | |
| 		print "<option value=\"".$currUser->getID()."\"";
 | |
| 		if ($currUser->getID() == $owner->getID())
 | |
| 			print " selected";
 | |
| 		print ">" . htmlspecialchars($currUser->getLogin() . " - " . $currUser->getFullname()) . "</option>\n";
 | |
| 	}
 | |
| 	?>
 | |
| 	</select>
 | |
| 	<button type="submit" class="btn"><i class="icon-save"></i> <?php printMLText("save")?></button>
 | |
| 	</form>
 | |
| <?php
 | |
| 
 | |
| }
 | |
| 		$this->contentSubHeading(getMLText("access_inheritance"));
 | |
| 
 | |
| 		if ($document->inheritsAccess()) {
 | |
| 			printMLText("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" 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" value="<?php printMLText("inherits_access_empty_msg")?>">
 | |
| 	</form>
 | |
| 	</p>
 | |
| <?php
 | |
| 		$this->contentContainerEnd();
 | |
| 		$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" value="<?php printMLText("does_not_inherit_access_msg")?>">
 | |
| 	</form>
 | |
| <?php
 | |
| 	$accessList = $document->getAccessList();
 | |
| 
 | |
| 	$this->contentSubHeading(getMLText("default_access"));
 | |
| ?>
 | |
| <form class="form-inline" 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->printAccessModeSelection($document->getDefaultAccess()); ?>
 | |
| 	<button type="submit" class="btn"><i class="icon-save"></i> <?php printMLText("save")?></button>
 | |
| </form>
 | |
| 
 | |
| <?php
 | |
| 
 | |
| 		$this->contentSubHeading(getMLText("edit_existing_access"));
 | |
| 
 | |
| 		/* 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=\"icon-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-mini\"><i class=\"icon-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-mini\"><i class=\"icon-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=\"icon-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-mini\"><i class=\"icon-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-mini\"\"><i class=\"icon-remove\"></i> ".getMLText("delete")."</button>";
 | |
| 				print "</form>";
 | |
| 				print "</span></td>\n";
 | |
| 				print "</tr>\n";
 | |
| 			}
 | |
| 			
 | |
| 			print "</table><br>";
 | |
| 		}
 | |
| ?>
 | |
| <form 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">
 | |
| <table>
 | |
| <tr>
 | |
| <td><?php printMLText("user");?>:</td>
 | |
| <td>
 | |
| <select name="userid">
 | |
| <option value="-1"><?php printMLText("select_one");?></option>
 | |
| <?php
 | |
| 		foreach ($allUsers as $userObj) {
 | |
| 			if ($userObj->isGuest() || in_array($userObj->getID(), $memusers)) {
 | |
| 				continue;
 | |
| 			}
 | |
| 			print "<option value=\"".$userObj->getID()."\">" . htmlspecialchars($userObj->getLogin() . " - " . $userObj->getFullName()) . "</option>\n";
 | |
| 		}
 | |
| ?>
 | |
| </select>
 | |
| </td>
 | |
| </tr>
 | |
| <tr>
 | |
| <td><?php printMLText("group");?>:</td>
 | |
| <td>
 | |
| <select name="groupid">
 | |
| <option value="-1"><?php printMLText("select_one");?></option>
 | |
| <?php
 | |
| 		foreach ($allGroups as $groupObj) {
 | |
| 			if(in_array($groupObj->getID(), $memgroups))
 | |
| 				continue;
 | |
| 			print "<option value=\"".$groupObj->getID()."\">" . htmlspecialchars($groupObj->getName()) . "</option>\n";
 | |
| 		}
 | |
| ?>
 | |
| </select>
 | |
| </td>
 | |
| </tr>
 | |
| <tr>
 | |
| <td><?php printMLText("access_mode");?>:</td>
 | |
| <td>
 | |
| <?php
 | |
| 		$this->printAccessModeSelection(M_READ);
 | |
| ?>
 | |
| </td>
 | |
| </tr>
 | |
| <tr>
 | |
| <td></td>
 | |
| <td><input type="submit" class="btn" value="<?php printMLText("add");?>"></td>
 | |
| </tr>
 | |
| </table>
 | |
| </form>
 | |
| 
 | |
| <?php
 | |
| 		$this->contentContainerEnd();
 | |
| 		$this->htmlEndPage();
 | |
| 	} /* }}} */
 | |
| }
 | |
| ?>
 | 
