Indefero

Indefero Git Source Tree


Root/src/IDF/Middleware.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;
}

Archive Download this file

Page rendered in 0.07978s using 11 queries.