}
$cols = [
- 'name' => ['label' => 'volledige naam'],
- 'email' => ['label' => 'e-mailadres', 'type' => 'email'],
+ 'name' => [
+ 'label' => 'volledige naam',
+ 'explain' => "Alleen zichtbaar voor andere leden.",
+ ],
+ 'email' => [
+ 'label' => 'e-mailadres',
+ 'type' => 'email',
+ 'explain' => "Voor contact van of met deze site. Wij zullen dit nooit vrij- of doorgeven.",
+ ],
'avatar' => [
'label' => 'portretfoto',
'type' => 'file',
}
$cols = [
- 'login' => ['label' => 'login', 'value' => $user['name'], 'target' => NULL],
+ 'login' => [
+ 'label' => 'login',
+ 'value' => $user['name'],
+ 'target' => NULL,
+ 'pattern' => "[a-z0-9-]+",
+ ],
] + $cols;
+$tagdir = 'profile/.tags';
+if (file_exists($tagdir)) {
+ $tags = [];
+ foreach (glob("$tagdir/*") as $tag) {
+ $tagname = pathinfo($tag, PATHINFO_BASENAME);
+ $target = "$tag/{$user['name']}";
+ $val = file_exists($target);
+ $tags[$tagname] = ['value' => $val];
+ if (empty($User['admin'])) {
+ continue; # forbidden
+ }
+ if (!is_writable($tag)) {
+ continue; # locked tag directory
+ }
+ if ($val and !is_writable($target)) {
+ continue; # existing file locked
+ }
+ $tags[$tagname]['target'] = $target;
+ }
+
+ if ($tags) {
+ $options = '';
+ foreach ($tags as $tag => $val) {
+ $options .= sprintf(
+ "\n\t\t" .
+ '<input type="hidden" name="tags[%1$s]" value="" />' .
+ '<input type="checkbox" name="tags[%s]" value="1"%s%s /> %s',
+ $tag,
+ $val['value'] ? ' checked' : '',
+ isset($val['target']) ? '' : ' readonly',
+ ucfirst($tag)
+ );
+ }
+
+ $cols['tags'] = [
+ 'label' => 'groepen',
+ 'input' => $options,
+ 'values' => $tags,
+ ];
+ }
+}
+
+if (isset($user['pass'])) {
+ $cols['newpass'] = [
+ 'label' => 'wachtwoord',
+ 'input' => <<<'EOT'
+ <input type="password" name="oldpass" value="" placeholder="Huidig wachtwoord" />
+ <input type="password" id="newpass" name="newpass" value="" placeholder="Nieuw wachtwoord" />
+ <input type="password" name="passconf" value="" placeholder="Nogmaals" />
+EOT
+ ,
+ 'hide' => 'pass',
+ ];
+}
+
$colwarn = [];
if ($_POST) {
if (!file_exists($user['dir']) and !@mkdir($user['dir'])) {
}
}
+ if (isset($cols['tags']) and !empty($_POST['tags'])) {
+ $tagok = [];
+ foreach ($_POST['tags'] as $col => $val) {
+ $tag = $cols['tags']['values'][$col];
+ if (!isset($tag['target'])) {
+ $tagok[$col] = 'forbidden';
+ }
+ if ($tag['value'] === !empty($val)) {
+ $tagok[$col] = NULL; # unaltered
+ }
+ elseif (empty($val)) {
+ $tagok[$col] = !@unlink($tag['target']);
+ }
+ else {
+ $tagok[$col] = !@symlink("../../{$user['name']}", $tag['target']);
+ }
+ }
+ if ($tagok = array_filter($tagok)) {
+ $colwarn['tags'] = "Wijziging niet opgeslagen voor "
+ . implode(', ', array_keys($tagok));
+ }
+ }
+
foreach ($_FILES as $col => $val) {
if (!isset($cols[$col]) and @$cols[$col]['type'] == 'file') {
continue; # unknown
if (!empty($_POST['newpass'])) {
require_once('login/pass.inc.php');
if ($error = passform($user, $_POST)) {
- $colwarn['pass'] = $error;
+ $colwarn['newpass'] = $error;
}
}
?>
<form method="post" enctype="multipart/form-data">
- <p>
- Geef een e-mailadres op waarmee we u kunnen bereiken indien nodig.
- Wij zullen dit adres nooit vrij- of doorgeven.
- </p>
<ul class="grid">
<?php
foreach ($cols as $col => &$colconf) {
200, $colconf['target'], filemtime($colconf['target'])
);
}
- print "<input";
- if (empty($colconf['target'])) print ' readonly';
- printf(' type="%s" name="%s" id="%2$s" value="%s"',
- @$colconf['type'] ?: 'text',
- $col,
- htmlspecialchars(@$colconf['value'])
- );
- if (@$colconf['type'] == 'file') {
- printf(' accept="%s"', 'image/jpeg');
+
+ if ($hide = @$colconf['hide'] and empty($_POST[$col])) {
+ printf('<a onclick="%s">Wijzigen</a><span id="%s" hidden>',
+ "document.getElementById('$hide').removeAttribute('hidden'); this.remove()",
+ $hide
+ );
}
- print ' placeholder="Niet ingesteld"';
- print " />";
- if ($error = @$colwarn[$col]) {
- print " <span class=warn>$error</span>\n";
+ if (isset($colconf['input'])) {
+ print $colconf['input'];
}
- print "</li>\n";
-}
+ else {
+ $attrs = [
+ 'type' => @$colconf['type'] ?: 'text',
+ 'name' => $col,
+ 'id' => $col,
+ 'value' => htmlspecialchars(@$colconf['value']),
+ 'placeholder' => "Niet ingesteld",
+ 'readonly' => empty($colconf['target']),
+ 'pattern' => @$colconf['pattern'] ?: FALSE,
+ ];
+ if (@$colconf['type'] == 'file') {
+ $attrs['accept'] = "image/jpeg";
+ }
-if (isset($user['pass'])) {
- $hide = empty($_POST['newpass']);
-?>
- <li id="pass"<?php if ($hide) print ' hidden style="display:none"'; ?>>
- <label for="newpass">Wachtwoord:</label>
- <input type="password" name="oldpass" value="" placeholder="Huidig wachtwoord" />
- <input type="password" name="newpass" value="" placeholder="Nieuw wachtwoord" />
- <input type="password" name="passconf" value="" placeholder="Nogmaals" />
-<?php
- if ($error = @$colwarn['pass']) {
+ print '<input';
+ foreach ($attrs as $attr => $attrval) {
+ if ($attrval === FALSE) {
+ continue;
+ }
+ print ' ' . $attr;
+ if ($attrval !== TRUE) {
+ printf('="%s"', $attrval);
+ }
+ }
+ print ' />';
+ }
+ if (!empty($colconf['explain'])) {
+ printf(' <span>(%s)</span>', $colconf['explain']);
+ }
+
+ if ($hide) {
+ print '</span>';
+ }
+
+ if ($error = @$colwarn[$col]) {
print " <span class=warn>$error</span>\n";
}
-?>
- </li>
-<?php
+ print "</li>\n";
}
?>
</ul>
- <input type="submit" value="Opslaan" />
+ <p><input type="submit" value="Opslaan" /></p>
</form>
-
-<?php
- if ($hide) {
-?>
- <p><a onclick="document.getElementById('pass').removeAttribute('style'); this.remove()">Wachtwoord wijzigen</a></p>
-<?php
- }