Moving to GitHub.
[platal.git] / admin / user.tpl
... / ...
CommitLineData
1{**************************************************************************}
2{* *}
3{* Copyright (C) 2003-2010 Polytechnique.org *}
4{* http://opensource.polytechnique.org/ *}
5{* *}
6{* This program is free software; you can redistribute it and/or modify *}
7{* it under the terms of the GNU General Public License as published by *}
8{* the Free Software Foundation; either version 2 of the License, or *}
9{* (at your option) any later version. *}
10{* *}
11{* This program is distributed in the hope that it will be useful, *}
12{* but WITHOUT ANY WARRANTY; without even the implied warranty of *}
13{* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *}
14{* GNU General Public License for more details. *}
15{* *}
16{* You should have received a copy of the GNU General Public License *}
17{* along with this program; if not, write to the Free Software *}
18{* Foundation, Inc., *}
19{* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA *}
20{* *}
21{**************************************************************************}
22
23
24{if t($smarty.post.delete_account)}
25<form method="post" action="admin/user/{$user->login()}">
26 {xsrf_token_field}
27 <div class="center">
28 <input type="hidden" name="uid" value="{$smarty.request.uid}" />
29 Confirmer la suppression de l'utilisateur {$user->fullName()} (uid&nbsp;: {$smarty.request.uid}).<br />
30 <input type="submit" name="account_deletion_confirmation" value="Confirmer" />
31 </div>
32</form>
33{elseif $user}
34{literal}
35
36<script type="text/javascript">
37//<![CDATA[
38function del_alias(alias) {
39 document.forms.alias.del_alias.value = alias;
40 document.forms.alias.submit();
41}
42
43function del_profile(pid) {
44 document.forms.profiles.del_profile.value = pid;
45 document.forms.profiles.submit();
46}
47
48function del_fwd(fwd) {
49 document.forms.fwds.del_fwd.value = fwd;
50 document.forms.fwds.submit();
51}
52
53function del_openid(id) {
54 document.forms.openid.del_openid.value = id;
55 document.forms.openid.submit();
56}
57
58function act_fwd(fwd, activate) {
59 if (activate)
60 document.forms.fwds.activate_fwd.value = fwd;
61 else
62 document.forms.fwds.deactivate_fwd.value = fwd;
63 document.forms.fwds.submit();
64}
65function clean_fwd(fwd) {
66 document.forms.fwds.clean_fwd.value = fwd;
67 document.forms.fwds.submit();
68}
69function ban_write()
70{
71 document.forms.bans.write_perm.value = "!xorg.*";
72}
73function ban_read()
74{
75 document.forms.bans.read_perm.value = "!xorg.*";
76}
77
78$(document).ready(function() {
79 $('#tabs > ul').tabs();
80 $('.ui-tabs-nav li').width('24%')
81 .click(function() { $(this).children('a').click() });
82});
83
84// ]]>
85</script>
86{/literal}
87
88<div id="tabs">
89 <ul style="margin-top: 0">
90 <li><a href="{$platal->pl_self()}#account"><span >Compte de {$user->login()}</span></a></li>
91 <li><a href="{$platal->pl_self()}#emails"><span>Emails</span></a></li>
92 <li><a href="{$platal->pl_self()}#authext"><span>OpenID</span></a></li>
93 <li><a href="{$platal->pl_self()}#forums"><span>Forums</span></a></li>
94 </ul>
95</div>
96
97<div id="account">
98<form id="auth" method="post" action="admin/user/{$user->login()}#account">
99 {xsrf_token_field}
100 <h1>Informations sur le compte</h1>
101 <p class="smaller">
102 Dernière connexion le <strong>{$lastlogin|date_format:"%d %B %Y, %T"}</strong>
103 depuis <strong>{$host}</strong>.
104 </p>
105
106 <table class="bicol">
107 <tr>
108 <th colspan="2">
109 <div style="float: right; text-align: right">
110 {if $user->state eq 'pending'}
111 Non-inscrit
112 {else}
113 Inscrit le {$user->registration_date|date_format}
114 {/if}
115 </div>
116 <div style="float: left; text-align: left">
117 {icon name=user_gray} {$user->hruid} (uid {$user->id()})
118 </div>
119 <input type="hidden" name="uid" value="{$user->id()}" />
120 </th>
121 </tr>
122 <tr>
123 <td class="titre">Nom complet</td>
124 <td>{if $hasProfile}{$user->fullName()}{else}<input type="text" name="full_name" maxlength="255" value="{$user->fullName()}" />{/if}</td>
125 </tr>
126 <tr>
127 <td class="titre">Nom annuaire</td>
128 <td>{if $hasProfile}{$user->directoryName()}{else}<input type="text" name="directory_name" maxlength="255" value="{$user->directoryName()}" />{/if}</td>
129 </tr>
130 <tr>
131 <td class="titre">Nom affiché</td>
132 <td>{if $hasProfile}{$user->displayName()}{else}<input type="text" name="display_name" maxlength="255" value="{$user->displayName()}" />{/if}</td>
133 </tr>
134 <tr>
135 <td class="titre">Sexe</td>
136 <td>
137 <label>femme <input type="radio" name="sex" value="female" {if $user->isFemale()}checked="checked"{/if} /></label>
138 <label><input type="radio" name="sex" value="male" {if !$user->isFemale()}checked="checked"{/if} /> homme</label>
139 </td>
140 </tr>
141 <tr class="impair">
142 <td class="titre">Mot de passe</td>
143 <td>
144 <div style="float: left">
145 <input type="text" name="new_plain_password" size="10" maxlength="256" value="********" />
146 <input type="hidden" name="pwhash" value="" />
147 </div>
148 <div style="float: left; margin-top: 5px;">
149 {checkpasswd prompt="new_plain_password" submit="dummy_none"}
150 </div>
151 </td>
152 </tr>
153 <tr class="impair">
154 <td class="titre">Mot de passe SMTP</td>
155 <td>
156 <div style="float: left">
157 <input type="password" name="weak_password" size="10" maxlength="256" value="" />
158 {if $user->weak_access}
159 <input type="submit" name="disable_weak_access" value="Supprimer" />
160 {/if}
161 </div>
162 </td>
163 </tr>
164 <tr class="impair">
165 <td class="titre">Accès RSS</td>
166 <td>
167 <label>
168 <input type="checkbox" name="token_access" {if $user->token_access}checked="checked"{/if} value="1" />
169 activer l'accès
170 </label>
171 </td>
172 </tr>
173 <tr class="impair">
174 <td class="titre">Skin</td>
175 <td>
176 <select name="skin">
177 <option value="" {if !$user->skin}selected="selected"{/if}>Aucune (défaut du système)</option>
178 {iterate from=$skins item=skin}
179 <option value="{$skin.id}" {if $user->skin eq $skin.id}selected="selected"{/if}>{$skin.name}</option>
180 {/iterate}
181 </select>
182 </td>
183 </tr>
184 <tr class="pair">
185 <td class="titre">Etat du compte</td>
186 <td>
187 <select name="state">
188 <option value="pending" {if $user->state eq 'pending'}selected="selected"{/if}>pending (Non-inscrit)</option>
189 <option value="active" {if $user->state eq 'active'}selected="selected"{/if}>active (Inscrit, peut se logguer)</option>
190 <option value="disabled" {if $user->state eq 'disabled'}selected="selected"{/if}>disabled (Inscrit, accès interdit)</option>
191 </select><br />
192 <label>
193 <input type="checkbox" name="is_admin" value="1" {if $user->is_admin}checked="checked"{/if} />
194 administrateur du site
195 </label>
196 </td>
197 </tr>
198 <tr class="pair">
199 <td class="titre">Type de compte</td>
200 <td>
201 <select name="type">
202 {iterate from=$account_types item=type}
203 <option value="{$type.type}" {if $user->type eq $type.type}selected="selected"{/if}>{$type.type} ({$type.perms})</option>
204 {/iterate}
205 </select>
206 <a href="admin/account/types">{icon name=wrench title=Gérer} gérer</a>
207 </td>
208 </tr>
209 <tr class="pair">
210 <td class="titre">
211 Surveillance
212 </td>
213 <td>
214 <label><input type="checkbox" name="watch" {if $user->watch}checked="checked"{/if} value="1" />
215 Surveiller l'activité de ce compte</label><br />
216 <span class="smaller">Cette option permet d'avoir des logs complets de l'activité
217 du compte via le logger, et d'être alerté lors des connexions de l'utilisateur.</span>
218 </td>
219 </tr>
220 <tr class="pair">
221 <td class="titre">
222 Commentaire
223 </td>
224 <td>
225 <input type="text" name="comment" size="40" maxlength="64" value="{$user->comment}" />
226 </td>
227 </tr>
228 <tr class="impair">
229 <td colspan="2" class="center">
230 <input type="submit" name="update_account" value="Mettre à jour" onclick="return hashResponse('new_plain_password', false, false);" />
231 <input type="submit" name="su_account" value="Prendre l'identité" />
232 <input type="submit" name="log_account" value="Consulter les logs" />
233 <input type="submit" name="delete_account" value="Supprimer le compte" />
234 </td>
235 </tr>
236 </table>
237</form>
238
239<h1>Fiches associées au compte</h1>
240
241<form id="profiles" method="post" action="admin/user/{$user->login()}#account">
242 {xsrf_token_field}
243 <table class="bicol">
244 <tr>
245 <th></th>
246 <th>Identifiant de la fiche</th>
247 <th></th>
248 </tr>
249 {iterate from=$profiles item=profile}
250 <tr>
251 <td><input type="radio" name="owner" value="{$profile.pid}" {if $profile.owner}checked="checked"{/if}
252 onclick="this.form.submit()" /></td>
253 <td>{$profile.hrpid} (pid {$profile.pid})</td>
254 <td class="right">
255 <a href="profile/edit/{$profile.hrpid}">{icon name=user_edit}</a>
256 <a href="profile/{$profile.hrpid}" class="popup2">{icon name=user_suit}</a>
257 <a href="javascript:del_profile({$profile.pid})">{icon name=cross}</a>
258 </td>
259 </tr>
260 {/iterate}
261 <tr>
262 <td>
263 <input type="radio" name="owner" value="0" onclick="this.form.submit()" />
264 </td>
265 <td>None</td>
266 <td></td>
267 </tr>
268 <tr class="pair">
269 <td colspan="3">
270 <input type="hidden" name="del_profile" value="" />
271 <input type="text" maxlength="64" name="new_profile" />
272 <input type="submit" name="add_profile" value="Ajouter" />
273 </td>
274 </tr>
275 </table>
276</form>
277
278</div>
279
280<div id="emails">
281<h1>Gestion de l'adresse X.org</h1>
282
283<form id="alias" method="post" action="admin/user/{$user->login()}#emails">
284 {xsrf_token_field}
285 <table class="bicol" cellpadding="2" cellspacing="0">
286 <tr>
287 <th class="alias" colspan="3">
288 Alias email de l'utilisateur
289 </th>
290 </tr>
291 {iterate from=$aliases item=a}
292 <tr class="{cycle values="impair,pair"}">
293 <td>
294 <input type="radio" name='best' {if $a.best}checked="checked"{/if} value='{$a.alias}' onclick="this.form.submit()" />
295 </td>
296 <td>
297 {if $a.for_life}<strong>{$a.alias}</strong>{else}{$a.alias}{/if}
298 {if $a.expire}<span class='erreur'>(expire le {$a.expire|date_format})</span>{/if}
299 </td>
300 {if $a.for_life}
301 <td>garanti à vie*</td>
302 {else}
303 <td class="action">
304 <a href="javascript:del_alias('{$a.alias}')">{icon name=cross}</a>
305 </td>
306 {/if}
307 </tr>
308 {/iterate}
309 <tr class="{cycle values="impair,pair"}">
310 <td colspan="2" class="detail">
311 <input type="text" name="email" size="29" maxlength="60" value="" />
312 </td>
313 <td class="action">
314 <input type="hidden" name="uid" value="{$user->id()}" />
315 <input type="hidden" name="del_alias" value="" />
316 <input type="submit" name="add_alias" value="Ajouter" />
317 </td>
318 </tr>
319 <tr class="{cycle values="impair,pair"}">
320 <td colspan="3" class="desc">
321 <strong>* à ne modifier qu'avec l'accord express de l'utilisateur !!!</strong>
322 </td>
323 </tr>
324 </table>
325</form>
326
327<br />
328
329<form id="fwds" method="post" action="admin/user/{$user->login()}#emails">
330 {xsrf_token_field}
331 <table class="bicol" cellpadding="2" cellspacing="0">
332 <tr>
333 <th colspan="4">
334 Redirections
335 </th>
336 </tr>
337 {assign var=actives value=false}
338 {assign var=disabled value=false}
339 {foreach item=mail from=$emails}
340 {cycle assign=class values="impair,pair"}
341 <tr class="{$class}">
342 {if $mail->active && $mail->has_disable()}
343 {assign var=actives value=true}
344 {elseif $mail->disabled && $mail->has_disable()}
345 {assign var=disabled value=true}
346 {/if}
347 <td class="titre">
348 {if $mail->active}active{elseif $mail->disabled}suspendue{/if}
349 </td>
350 <td>
351 <span class="smaller">
352 {if !$mail->disabled}
353 <a href="javascript:act_fwd('{$mail->email}',{if $mail->active}false{else}true{/if})">
354 {if $mail->active}des{elseif $mail->broken}ré{/if}activer
355 </a>
356 {/if}
357 </span>
358 </td>
359 <td>
360 {if $mail->broken}<span style="color: #f00">{/if}
361 {if $mail->email == 'googleapps'}<a href="admin/googleapps/user/{$user->login()}">{/if}
362 {$mail->display_email}
363 {if $mail->email == 'googleapps'}</a>{/if}
364 {if $mail->broken}<em> (en panne)</em></span>{/if}
365 </td>
366 <td class="action">
367 {if $mail->is_removable()}
368 <a href="javascript:del_fwd('{$mail->email}')">{icon name=cross}</a>
369 {/if}
370 </td>
371 </tr>
372 {if $mail->panne && $mail->panne neq "0000-00-00"}
373 <tr class="{$class}">
374 <td colspan="3" class="smaller" style="color: #f00">
375 {icon name=error title="Panne"}
376 Panne de {$mail->display_email} le {$mail->panne|date_format}
377 {if $mail->panne neq $mail->last}confirmée le {$mail->last|date_format}{/if}
378 </td>
379 <td class="action">
380 <a href="javascript:clean_fwd('{$mail->email}')">effacer les pannes</a>
381 </td>
382 </tr>
383 {/if}
384 {/foreach}
385 {cycle assign=class values="impair,pair"}
386 <tr class="{$class}">
387 <td class="titre" colspan="2">
388 Ajouter une adresse
389 </td>
390 <td>
391 <input type="text" name="email" size="29" maxlength="60" value="" />
392 </td>
393 <td class="action">
394 <input type="hidden" name="uid" value="{$user->id()}" />
395 <input type="hidden" name="del_fwd" value="" />
396 <input type="hidden" name="clean_fwd" value="" />
397 <input type="hidden" name="activate_fwd" value="" />
398 <input type="hidden" name="deactivate_fwd" value="" />
399 <input type="submit" name="add_fwd" value="Ajouter" />
400 </td>
401 </tr>
402 <tr class="{$class}">
403 <td colspan="4" class="center">
404 {if $actives}
405 <input type="submit" name="disable_fwd" value="Désactiver la redirection des emails" />
406 {/if}
407 {if $disabled}
408 <input type="submit" name="enable_fwd" value="Réactiver la redirection des emails" />
409 {/if}
410 </td>
411 </tr>
412 </table>
413</form>
414
415{javascript name="ajax"}
416{test_email hruid=$user->login()}
417
418<h1>Autres adresses de l'utilisateur</h1>
419
420<table class="bicol">
421 <tr>
422 <th>Virtual aliases auquel l'utilisateur appartient</th>
423 </tr>
424 {foreach from=$virtuals item=virtual}
425 <tr class="{cycle values="impair,pair"}">
426 <td>{$virtual}</td>
427 </tr>
428 {/foreach}
429</table>
430</div>
431
432<div id="authext">
433<h1>Gestion des autorisations d'authentification externe</h1>
434
435<form id="openid" method="post" action="admin/user/{$user->login()}#authext">
436 {xsrf_token_field}
437 <table class="bicol">
438 <tr>
439 <th colspan="2">Sites de confiance</th>
440 </tr>
441 {iterate from=$openid item=site}
442 <tr class="{cycle values="pair,impair"}">
443 <td><a href="{$site.url}">{$site.url}</a></td>
444 <td><a href="javascript:del_openid({$site.id})">{icon name=cross}</a></td>
445 </tr>
446 {/iterate}
447 </table>
448 <div><input type="hidden" name="del_openid"/></div>
449</form>
450</div>
451
452<div id="forums">
453<h1>Gestion de l'accès au forums</h1>
454
455<form id="bans" method="post" action="admin/user/{$user->login()}#forums">
456 {xsrf_token_field}
457 <table class="bicol">
458 <tr>
459 <th colspan="4">
460 Permissions sur les forums
461 </th>
462 </tr>
463 <tr class="impair">
464 <td class="titre">
465 Poster
466 </td>
467 <td>
468 <input type="text" name="write_perm" size="32" maxlength="255" value="{$bans.write_perm}" />
469 </td>
470 <td class="action">
471 <a href="javascript:ban_write()">Bannir</a>
472 </td>
473 </tr>
474 <tr class="pair">
475 <td class="titre">
476 Lire
477 </td>
478 <td>
479 <input type="text" name="read_perm" size="32" maxlength="255" value="{$bans.read_perm}" />
480 </td>
481 <td class="action">
482 <a href="javascript:ban_read()">Bannir</a>
483 </td>
484 </tr>
485 <tr class="impair">
486 <td class="titre">
487 Commentaire
488 </td>
489 <td colspan="2">
490 <input type="text" name="comment" size="40" maxlength="255" value="{$bans.comment}" />
491 </td>
492 </tr>
493 <tr class="center">
494 <td colspan="3">
495 <input type="hidden" name="uid" value="{$user->id()}" />
496 <input type="submit" name="b_edit" value="Modifier" />
497 </td>
498 </tr>
499 </table>
500</form>
501</div>
502
503{else}
504
505{literal}
506<script type="text/javascript">
507/* <![CDATA[ */
508 function add_user_to_url(f) {
509 f.action += '/' + f.login.value;
510 }
511/* ]]> */
512</script>
513{/literal}
514<form method="post" action="admin/user" onsubmit="add_user_to_url(this); return true">
515 {xsrf_token_field}
516 <table class="tinybicol" cellspacing="0" cellpadding="2">
517 <tr>
518 <th>
519 Administrer
520 </th>
521 </tr>
522 <tr class="pair">
523 <td class="center">
524 Il est possible d'entrer ici n'importe quelle adresse mail&nbsp;: redirection, melix, ou alias.
525 </td>
526 </tr>
527 <tr>
528 <td class="center">
529 <input type="text" name="login" size="40" maxlength="255"
530 value="{if t($smarty.request.login)}{$smarty.request.login}{/if}" />
531 </td>
532 </tr>
533 <tr>
534 <td class="center">
535 <input type="submit" name="select" value=" edit " /> &nbsp;&nbsp;
536 <input type="submit" name="su_account" value=" su " /> &nbsp;&nbsp;
537 <input type="submit" name="log_account" value=" logs " />
538 </td>
539 </tr>
540 </table>
541</form>
542{/if}
543
544{* vim:set et sw=2 sts=2 sws=2 enc=utf-8: *}