newgroup.php 8.27 KB
Newer Older
Evan Prodromou's avatar
Evan Prodromou committed
1 2
<?php
/**
3
 * StatusNet, the distributed open-source microblogging tool
Evan Prodromou's avatar
Evan Prodromou committed
4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
 *
 * Add a new group
 *
 * PHP version 5
 *
 * LICENCE: This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Affero General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * 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 Affero General Public License for more details.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 *
 * @category  Group
23
 * @package   StatusNet
24 25
 * @author    Evan Prodromou <evan@status.net>
 * @author    Sarven Capadisli <csarven@status.net>
26
 * @copyright 2008-2009 StatusNet, Inc.
Evan Prodromou's avatar
Evan Prodromou committed
27
 * @license   http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
28
 * @link      http://status.net/
Evan Prodromou's avatar
Evan Prodromou committed
29 30
 */

31
if (!defined('STATUSNET')) {
Evan Prodromou's avatar
Evan Prodromou committed
32 33 34 35 36 37 38 39 40
    exit(1);
}

/**
 * Add a new group
 *
 * This is the form for adding a new group
 *
 * @category Group
41
 * @package  StatusNet
42
 * @author   Evan Prodromou <evan@status.net>
Evan Prodromou's avatar
Evan Prodromou committed
43
 * @license  http://www.fsf.org/licensing/licenses/agpl-3.0.html GNU Affero General Public License version 3.0
44
 * @link     http://status.net/
Evan Prodromou's avatar
Evan Prodromou committed
45
 */
46
class NewgroupAction extends FormAction
Evan Prodromou's avatar
Evan Prodromou committed
47 48 49
{
    function title()
    {
Siebrand Mazeland's avatar
Siebrand Mazeland committed
50
        // TRANS: Title for form to create a group.
Evan Prodromou's avatar
Evan Prodromou committed
51 52 53 54 55 56
        return _('New group');
    }

    /**
     * Prepare to run
     */
57
    protected function prepare($args)
Evan Prodromou's avatar
Evan Prodromou committed
58 59 60 61
    {
        parent::prepare($args);

        if (!common_logged_in()) {
Siebrand Mazeland's avatar
Siebrand Mazeland committed
62
            // TRANS: Client error displayed trying to create a group while not logged in.
Evan Prodromou's avatar
Evan Prodromou committed
63 64 65 66
            $this->clientError(_('You must be logged in to create a group.'));
            return false;
        }

67 68
        // $this->scoped is the current user profile
        if (!$this->scoped->hasRight(Right::CREATEGROUP)) {
69 70 71 72
            // TRANS: Client exception thrown when a user tries to create a group while banned.
            throw new ClientException(_('You are not allowed to create groups on this site.'), 403);
        }

Evan Prodromou's avatar
Evan Prodromou committed
73 74 75
        return true;
    }

76
    public function showContent()
Evan Prodromou's avatar
Evan Prodromou committed
77 78 79 80 81
    {
        $form = new GroupEditForm($this);
        $form->show();
    }

82
    public function showInstructions()
Evan Prodromou's avatar
Evan Prodromou committed
83
    {
84 85 86
        $this->element('p', 'instructions',
                       // TRANS: Form instructions for group create form.
                       _('Use this form to create a new group.'));
Evan Prodromou's avatar
Evan Prodromou committed
87 88
    }

89
    protected function handlePost()
Evan Prodromou's avatar
Evan Prodromou committed
90
    {
91 92
        parent::handlePost();

93
        if (Event::handle('StartGroupSaveForm', array($this))) {
94 95
            $nickname = Nickname::normalize($this->trimmed('newnickname'));

96 97 98 99
            $fullname    = $this->trimmed('fullname');
            $homepage    = $this->trimmed('homepage');
            $description = $this->trimmed('description');
            $location    = $this->trimmed('location');
100
            $private     = $this->boolean('private');
101
            $aliasstring = $this->trimmed('aliases');
102

103
            if ($this->nicknameExists($nickname)) {
Siebrand Mazeland's avatar
Siebrand Mazeland committed
104
                // TRANS: Group create form validation error.
105
                throw new ClientException(_('Nickname already in use. Try another one.'));
106 107
            } else if (!User_group::allowedNickname($nickname)) {
                // TRANS: Group create form validation error.
108
                throw new ClientException(_('Not a valid nickname.'));
109 110 111 112 113
            } else if (!is_null($homepage) && (strlen($homepage) > 0) &&
                       !Validate::uri($homepage,
                                      array('allowed_schemes' =>
                                            array('http', 'https')))) {
                // TRANS: Group create form validation error.
114
                throw new ClientException(_('Homepage is not a valid URL.'));
115 116
            } else if (!is_null($fullname) && mb_strlen($fullname) > 255) {
                // TRANS: Group create form validation error.
117
                throw new ClientException(_('Full name is too long (maximum 255 characters).'));
118 119 120
            } else if (User_group::descriptionTooLong($description)) {
                // TRANS: Group create form validation error.
                // TRANS: %d is the maximum number of allowed characters.
121
                throw new ClientException(sprintf(_m('Description is too long (maximum %d character).',
122 123 124 125 126
                                           'Description is too long (maximum %d characters).',
                                           User_group::maxDescription()),
                                        User_group::maxDescription()));
            } else if (!is_null($location) && mb_strlen($location) > 255) {
                // TRANS: Group create form validation error.
127
                throw new ClientException(_('Location is too long (maximum 255 characters).'));
128
            }
129 130 131 132 133 134 135 136

            if (!empty($aliasstring)) {
                $aliases = array_map('common_canonical_nickname', array_unique(preg_split('/[\s,]+/', $aliasstring)));
            } else {
                $aliases = array();
            }

            if (count($aliases) > common_config('group', 'maxaliases')) {
Siebrand Mazeland's avatar
Siebrand Mazeland committed
137
                // TRANS: Group create form validation error.
138
                // TRANS: %d is the maximum number of allowed aliases.
139
                throw new ClientException(sprintf(_m('Too many aliases! Maximum %d allowed.',
140 141 142
                                           'Too many aliases! Maximum %d allowed.',
                                           common_config('group', 'maxaliases')),
                                        common_config('group', 'maxaliases')));
143 144 145
                return;
            }

146 147 148 149
            foreach ($aliases as $alias) {
                if (!Nickname::isValid($alias)) {
                    // TRANS: Group create form validation error.
                    // TRANS: %s is the invalid alias.
150
                    throw new ClientException(sprintf(_('Invalid alias: "%s"'), $alias));
151 152 153
                }
                if ($this->nicknameExists($alias)) {
                    // TRANS: Group create form validation error. %s is the already used alias.
154
                    throw new ClientException(sprintf(_('Alias "%s" already in use. Try another one.'),
155 156 157 158 159
                                            $alias));
                }
                // XXX assumes alphanum nicknames
                if (strcmp($alias, $nickname) == 0) {
                    // TRANS: Group create form validation error.
160
                    throw new ClientException(_('Alias cannot be the same as nickname.'));
161 162 163
                }
            }

164 165 166 167 168 169 170 171
            if ($private) {
                $force_scope = 1;
                $join_policy = User_group::JOIN_POLICY_MODERATE;
            } else {
                $force_scope = 0;
                $join_policy = User_group::JOIN_POLICY_OPEN;
            }

172 173
            // This is set up in parent->prepare and checked in self->prepare
            assert(!is_null($this->scoped));
Evan Prodromou's avatar
Evan Prodromou committed
174

175 176 177 178 179 180
            $group = User_group::register(array('nickname' => $nickname,
                                                'fullname' => $fullname,
                                                'homepage' => $homepage,
                                                'description' => $description,
                                                'location' => $location,
                                                'aliases'  => $aliases,
181
                                                'userid'   => $this->scoped->id,
182
                                                'join_policy' => $join_policy,
183
                                                'force_scope' => $force_scope,
184
                                                'local'    => true));
Evan Prodromou's avatar
Evan Prodromou committed
185

186 187 188 189 190 191
            $this->group = $group;

            Event::handle('EndGroupSaveForm', array($this));

            common_redirect($group->homeUrl(), 303);
        }
Evan Prodromou's avatar
Evan Prodromou committed
192 193 194 195
    }

    function nicknameExists($nickname)
    {
196
        $local = Local_group::getKV('nickname', $nickname);
197

198
        if (!empty($local)) {
199 200 201
            return true;
        }

202
        $alias = Group_alias::getKV('alias', $nickname);
203 204 205 206 207 208

        if (!empty($alias)) {
            return true;
        }

        return false;
Evan Prodromou's avatar
Evan Prodromou committed
209
    }
210
}