Code Coverage
 
Classes and Traits
Functions and Methods
Lines
Total
0.00% covered (danger)
0.00%
0 / 1
33.33% covered (danger)
33.33%
1 / 3
CRAP
64.71% covered (warning)
64.71%
11 / 17
username
0.00% covered (danger)
0.00%
0 / 1
33.33% covered (danger)
33.33%
1 / 3
18.33
64.71% covered (warning)
64.71%
11 / 17
 getName
0.00% covered (danger)
0.00%
0 / 1
2.00
0.00% covered (danger)
0.00%
0 / 1
 getFunctions
100.00% covered (success)
100.00%
1 / 1
1
100.00% covered (success)
100.00%
1 / 1
 get_username
0.00% covered (danger)
0.00%
0 / 1
13.70
66.67% covered (warning)
66.67%
10 / 15
<?php
/**
 *
 * This file is part of the phpBB Forum Software package.
 *
 * @copyright (c) phpBB Limited <https://www.phpbb.com>
 * @license GNU General Public License, version 2 (GPL-2.0)
 *
 * For full copyright and license information, please see
 * the docs/CREDITS.txt file.
 *
 */
namespace phpbb\template\twig\extension;
class username extends \Twig_Extension
{
    /**
     * Get the name of this extension
     *
     * @return string
     */
    public function getName()
    {
        return 'username';
    }
    /**
     * Returns a list of global functions to add to the existing list.
     *
     * @return array An array of global functions
     */
    public function getFunctions()
    {
        return array(
            new \Twig\TwigFunction('username', array($this, 'get_username')),
        );
    }
    /**
     * Get username details for placing into templates.
     *
     * How to use in a template:
     * - {{ username('mode', user_id, username, user_colour, guest_username, custom_profile_url) }}
     * - {{ username('mode', user_row, guest_username, custom_profile_url) }}
     * It's possible to provide the user identifier, name and colour separately,
     * or provide the entire user row at once as an array.
     *
     * The mode, user_id and username are required (separately or through a user row).
     * The other fields (user_colour|guest_username|custom_profile_url) are optional.
     *
     * @uses \get_username_string()
     *
     * @return string        A string based on what is wanted depending on $mode
     */
    public function get_username()
    {
        $args = func_get_args();
        $mode = $args[0];
        $user = $args[1];
        // If the entire user row is provided
        if (is_array($user))
        {
            $user_id = isset($user['user_id']) ? $user['user_id'] : '';
            $username = isset($user['username']) ? $user['username'] : '';
            $user_colour = isset($user['user_colour']) ? $user['user_colour'] : '';
            $guest_username = isset($args[2]) ? $args[2] : false;
            $custom_profile_url = isset($args[3]) ? $args[3] : false;
        }
        else
        {
            // Options are provided separately
            $user_id = $user;
            $username = $args[2];
            $user_colour = isset($args[3]) ? $args[3] : '';
            $guest_username = isset($args[4]) ? $args[4] : false;
            $custom_profile_url = isset($args[5]) ? $args[5] : false;
        }
        return get_username_string($mode, $user_id, $username, $user_colour, $guest_username, $custom_profile_url);
    }
}