Location: PHPKode > projects > iF.SVNAdmin > svnadmin/permissionassign.php
<?php
/**
 * iF.SVNAdmin
 * Copyright (c) 2010 by Manuel Freiholz
 * http://www.insanefactory.com/
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License
 * as published by the Free Software Foundation; version 2
 * of the License.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.
 */
include("include/config.inc.php");
if( !$appEngine->isAccessPathViewActive() || ( !$appEngine->isUserViewActive() && !$appEngine->isGroupViewActive() ) )
{
  $appEngine->forwardInvalidModule( true );
}
$appEngine->checkUserAuthentication(true, ACL_MOD_ACCESSPATH, ACL_ACTION_ASSIGN);
$appTR->loadModule("permissionassign");


// Form request.
$assign = check_request_var('assign');
if( $assign )
{
  $appEngine->handleAction('assign_usergrouptoaccesspath');
}

// Basic view data.
if ($appEngine->isUserViewActive() && $appEngine->checkUserAuthentication(false, ACL_MOD_USER, ACL_ACTION_VIEW))
{
  $users = $appEngine->getUserViewProvider()->getUsers();
  usort( $users, array("\svnadmin\core\entities\User","compare") );
  $appTemplate->addReplacement( "users", $users );
}

if ($appEngine->isGroupViewActive() && $appEngine->checkUserAuthentication(false, ACL_MOD_GROUP, ACL_ACTION_VIEW))
{
  $groups = $appEngine->getGroupViewProvider()->getGroups();
  usort( $groups, array("\svnadmin\core\entities\Group","compare") );
  $appTemplate->addReplacement( "groups", $groups );
}

// All paths.
$list = $appEngine->getAccessPathViewProvider()->getPaths();

// Filter access-paths for project-managers.
if ($appEngine->isAuthenticationActive())
{
  $currentUsername = $appEngine->getSessionUsername();
  if ($appEngine->getAclManager()->isUserAccessPathManager($currentUsername))
    $list = $appEngine->getAclManager()->filterAccessPathsList($currentUsername, $list);
}

usort( $list, array("\svnadmin\core\entities\AccessPath","compare") );
$appTemplate->addReplacement( "paths", $list );

// Set available permissions.
$appTemplate->addReplacement("PERM_NONE", \svnadmin\core\entities\Permission::$PERM_NONE);
$appTemplate->addReplacement("PERM_READ", \svnadmin\core\entities\Permission::$PERM_READ);
$appTemplate->addReplacement("PERM_READWRITE", \svnadmin\core\entities\Permission::$PERM_READWRITE);

$appTemplate->loadFromFile( new \IF_File("templates/permissionassign.html") );
$appTemplate->processTemplate();
?>
Return current item: iF.SVNAdmin