When accessing the base page of a project without a trailing slash, the regex to get the project in the request object was not matching, resulting in a missing project in the request object.
		
			
				
	
	
		
			116 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			116 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
/* -*- tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
 | 
						|
/*
 | 
						|
# ***** BEGIN LICENSE BLOCK *****
 | 
						|
# This file is part of InDefero, an open source project management application.
 | 
						|
# Copyright (C) 2008 Céondo Ltd and contributors.
 | 
						|
#
 | 
						|
# InDefero 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; either version 2 of the License, or
 | 
						|
# (at your option) any later version.
 | 
						|
#
 | 
						|
# InDefero 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; if not, write to the Free Software
 | 
						|
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 | 
						|
#
 | 
						|
# ***** END LICENSE BLOCK ***** */
 | 
						|
 | 
						|
/**
 | 
						|
 * Project middleware.
 | 
						|
 *
 | 
						|
 * It must be after the session middleware.
 | 
						|
 */
 | 
						|
class IDF_Middleware
 | 
						|
{
 | 
						|
    /**
 | 
						|
     * Process the request.
 | 
						|
     *
 | 
						|
     * When processing the request, check if matching a project. If
 | 
						|
     * so, directly set $request->project to the project.
 | 
						|
     *
 | 
						|
     * The url to match a project is in the format /p/(\w+)/whatever
 | 
						|
     * or /api/p/(\w+)/whatever. This means that it will not try to
 | 
						|
     * match on /login/ or /logout/.
 | 
						|
     *
 | 
						|
     * @param Pluf_HTTP_Request The request
 | 
						|
     * @return bool false or redirect.
 | 
						|
     */
 | 
						|
    function process_request(&$request)
 | 
						|
    {
 | 
						|
        $match = array();
 | 
						|
        if (preg_match('#^/(?:api/p|p)/([\-\w]+)/?#', $request->query, $match)) {
 | 
						|
            try {
 | 
						|
                $request->project = IDF_Project::getOr404($match[1]);
 | 
						|
            } catch (Pluf_HTTP_Error404 $e) {
 | 
						|
                return new Pluf_HTTP_Response_NotFound($request);
 | 
						|
            }
 | 
						|
            $request->conf = new IDF_Conf();
 | 
						|
            $request->conf->setProject($request->project);
 | 
						|
            self::setRights($request);
 | 
						|
        }
 | 
						|
        return false;
 | 
						|
    }
 | 
						|
 | 
						|
    public static function setRights(&$request)
 | 
						|
    {
 | 
						|
        $ak = array('downloads_access_rights' => 'hasDownloadsAccess',
 | 
						|
                    'wiki_access_rights' => 'hasWikiAccess',
 | 
						|
                    'review_access_rights' => 'hasReviewAccess',
 | 
						|
                    'source_access_rights' => 'hasSourceAccess',
 | 
						|
                    'issues_access_rights' => 'hasIssuesAccess');
 | 
						|
        $request->rights = array();
 | 
						|
        foreach ($ak as $key=>$val) {
 | 
						|
            $request->rights[$val] = (true === IDF_Precondition::accessTabGeneric($request, $key));
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Update the template tags and modifiers to not have them in the config.
 | 
						|
     *
 | 
						|
     * This is here at the moment because we do not want to put that
 | 
						|
     * in a IDF_Template class just for one method.
 | 
						|
     *
 | 
						|
     */
 | 
						|
    public static function updateTemplateTagsModifiers($sender, &$params)
 | 
						|
    {
 | 
						|
        $params['tags'] = array_merge($params['tags'],
 | 
						|
                                      array(
 | 
						|
                              'hotkey' => 'IDF_Template_HotKey',
 | 
						|
                              'issuetext' => 'IDF_Template_IssueComment',
 | 
						|
                              'timeline' => 'IDF_Template_TimelineFragment',
 | 
						|
                              'markdown' => 'IDF_Template_Markdown',
 | 
						|
                              'showuser' => 'IDF_Template_ShowUser',
 | 
						|
                              'ashowuser' => 'IDF_Template_AssignShowUser',
 | 
						|
                                            ));
 | 
						|
        $params['modifiers'] = array_merge($params['modifiers'],
 | 
						|
                                           array(
 | 
						|
                                   'size' => 'IDF_Views_Source_PrettySize',
 | 
						|
                                   'ssize' => 'IDF_Views_Source_PrettySizeSimple',
 | 
						|
                                                 ));
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
function IDF_Middleware_ContextPreProcessor($request)
 | 
						|
{
 | 
						|
    $c = array();
 | 
						|
    $c['request'] = $request;
 | 
						|
    $c['isAdmin'] = ($request->user->administrator or $request->user->staff);
 | 
						|
    if (isset($request->project)) {
 | 
						|
        $c['project'] = $request->project;
 | 
						|
        $c['isOwner'] = $request->user->hasPerm('IDF.project-owner', 
 | 
						|
                                                $request->project);
 | 
						|
        $c['isMember'] = $request->user->hasPerm('IDF.project-member', 
 | 
						|
                                                 $request->project);
 | 
						|
        $c = array_merge($c, $request->rights);
 | 
						|
    }
 | 
						|
    return $c;
 | 
						|
}
 | 
						|
 |