user) as $project) { $otags = array_merge($otags, $project->getTagIdsByStatus('open')); } if (count($otags) == 0) $otags[] = 0; if ($working) { $title = __('Your Dashboard - Working Issues'); $f_sql = new Pluf_SQL('owner=%s AND status IN ('.implode(', ', $otags).')', array($request->user->id)); } else { $title = __('Your Dashboard - Submitted Issues'); $f_sql = new Pluf_SQL('submitter=%s AND status IN ('.implode(', ', $otags).')', array($request->user->id)); } // Get stats about the issues $sql = new Pluf_SQL('submitter=%s AND status IN ('.implode(', ', $otags).')', array($request->user->id)); $nb_submit = Pluf::factory('IDF_Issue')->getCount(array('filter'=>$sql->gen())); $sql = new Pluf_SQL('owner=%s AND status IN ('.implode(', ', $otags).')', array($request->user->id)); $nb_owner = Pluf::factory('IDF_Issue')->getCount(array('filter'=>$sql->gen())); // Paginator to paginate the issues $pag = new Pluf_Paginator(new IDF_Issue()); $pag->class = 'recent-issues'; $pag->item_extra_props = array('current_user' => $request->user); $pag->summary = __('This table shows the open issues.'); $pag->forced_where = $f_sql; $pag->action = ($working) ? 'idf_dashboard' : 'idf_dashboard_submit'; $pag->sort_order = array('modif_dtime', 'ASC'); // will be reverted $pag->sort_reverse_order = array('modif_dtime'); $list_display = array( 'id' => __('Id'), array('project', 'Pluf_Paginator_FkToString', __('Project')), array('summary', 'IDF_Views_IssueSummaryAndLabels', __('Summary')), array('status', 'IDF_Views_Issue_ShowStatus', __('Status')), array('modif_dtime', 'Pluf_Paginator_DateAgo', __('Last Updated')), ); $pag->configure($list_display, array(), array('status', 'modif_dtime')); $pag->items_per_page = 10; $pag->no_results_text = ($working) ? __('No issues are assigned to you, yeah!') : __('All the issues you submitted are fixed, yeah!'); $pag->setFromRequest($request); return Pluf_Shortcuts_RenderToResponse('idf/user/dashboard.html', array( 'page_title' => $title, 'nb_submit' => $nb_submit, 'nb_owner' => $nb_owner, 'issues' => $pag, ), $request); } /** * Simple management of the base info of the user. */ public $myAccount_precond = array('Pluf_Precondition::loginRequired'); public function myAccount($request, $match) { // As the password is salted, we can directly take the sha1 of // the salted password. $api_key = sha1($request->user->password); $ext_pass = substr(sha1($request->user->password.Pluf::f('secret_key')), 0, 8); $params = array('user' => $request->user); if ($request->method == 'POST') { $form = new IDF_Form_UserAccount(array_merge( (array)$request->POST, (array)$request->FILES ), $params); if ($form->isValid()) { $user = $form->save(); $url = Pluf_HTTP_URL_urlForView('IDF_Views_User::myAccount'); $request->session->setData('pluf_language', $user->language); $request->user->setMessage(__('Your personal information has been updated.')); return new Pluf_HTTP_Response_Redirect($url); } } else { $data = $request->user->getData(); unset($data['password']); $form = new IDF_Form_UserAccount(null, $params); } $keys = $request->user->get_idf_key_list(); $mailaddrs = Pluf::factory('IDF_EmailAddress')->get_email_addresses_for_user($request->user); return Pluf_Shortcuts_RenderToResponse('idf/user/myaccount.html', array('page_title' => __('Your Account'), 'api_key' => $api_key, 'ext_pass' => $ext_pass, 'keys' => $keys, 'mailaddrs' => $mailaddrs, 'form' => $form), $request); } /** * Delete a public key. * * This is redirecting to the preferences */ public $deleteKey_precond = array('Pluf_Precondition::loginRequired'); public function deleteKey($request, $match) { $url = Pluf_HTTP_URL_urlForView('IDF_Views_User::myAccount'); if ($request->method == 'POST') { $key = Pluf_Shortcuts_GetObjectOr404('IDF_Key', $match[1]); if ($key->user != $request->user->id) { return new Pluf_HTTP_Response_Forbidden($request); } $key->delete(); $request->user->setMessage(__('The public key has been deleted.')); } return new Pluf_HTTP_Response_Redirect($url); } /** * Delete a mail address. * * This is redirecting to the preferences */ public $deleteMail_precond = array('Pluf_Precondition::loginRequired'); public function deleteMail($request, $match) { $url = Pluf_HTTP_URL_urlForView('IDF_Views_User::myAccount'); if ($request->method == 'POST') { $address = Pluf_Shortcuts_GetObjectOr404('IDF_EmailAddress', $match[1]); if ($address->user != $request->user->id) { return new Pluf_HTTP_Response_Forbidden($request); } $address->delete(); $request->user->setMessage(__('The address has been deleted.')); } return new Pluf_HTTP_Response_Redirect($url); } /** * Enter the key to change an email address. * * This is redirecting to changeEmailDo */ public $changeEmailInputKey_precond = array('Pluf_Precondition::loginRequired'); public function changeEmailInputKey($request, $match) { if ($request->method == 'POST') { $form = new IDF_Form_UserChangeEmail($request->POST); if ($form->isValid()) { $url = $form->save(); return new Pluf_HTTP_Response_Redirect($url); } } else { $form = new IDF_Form_UserChangeEmail(); } return Pluf_Shortcuts_RenderToResponse('idf/user/changeemail.html', array('page_title' => __('Confirm The Email Change'), 'form' => $form), $request); } /** * Really change the email address. */ public $changeEmailDo_precond = array('Pluf_Precondition::loginRequired'); public function changeEmailDo($request, $match) { $key = $match[1]; $url = Pluf_HTTP_URL_urlForView('IDF_Views_User::changeEmailInputKey'); try { list($email, $id, $time, $type) = IDF_Form_UserChangeEmail::validateKey($key); } catch (Pluf_Form_Invalid $e) { return new Pluf_HTTP_Response_Redirect($url); } if ($id != $request->user->id) { return new Pluf_HTTP_Response_Redirect($url); } // Now we have a change link coming from the right user. if ($type == "primary") { $request->user->email = $email; $request->user->update(); } else { $mailaddress = new IDF_EmailAddress(); $mailaddress->user = $request->user; $mailaddress->address = $email; $mailaddress->create(); } $request->user->setMessage(sprintf(__('Your new email address "%s" has been validated. Thank you!'), Pluf_esc($email))); $url = Pluf_HTTP_URL_urlForView('IDF_Views_User::myAccount'); return new Pluf_HTTP_Response_Redirect($url); } /** * Public profile of a user. */ public function view($request, $match) { $sql = new Pluf_SQL('login=%s', array($match[1])); $users = Pluf::factory('Pluf_User')->getList(array('filter'=>$sql->gen())); if (count($users) != 1 or !$users[0]->active) { throw new Pluf_HTTP_Error404(); } $user = $users[0]; $user_data = IDF_UserData::factory($user); return Pluf_Shortcuts_RenderToResponse('idf/user/public.html', array('page_title' => (string) $user, 'member' => $user, 'user_data' => $user_data, ), $request); } } /** * Display the summary of an issue, then on a new line, display the * list of labels with a link to a view "by label only". * * The summary of the issue is linking to the issue. */ function IDF_Views_IssueSummaryAndLabels($field, $issue, $extra='') { $project = $issue->get_project(); $edit = Pluf_HTTP_URL_urlForView('IDF_Views_Issue::view', array($project->shortname, $issue->id)); $tags = array(); foreach ($issue->get_tags_list() as $tag) { $url = Pluf_HTTP_URL_urlForView('IDF_Views_Issue::listLabel', array($project->shortname, $tag->id, 'open')); $tags[] = sprintf('%s', $url, Pluf_esc((string) $tag)); } $out = ''; if (count($tags)) { $out = '
'.implode(', ', $tags).''; } return sprintf('%s', $edit, Pluf_esc($issue->summary)).$out; }