X-Git-Url: http://git.shiar.net/minimedit.git/blobdiff_plain/2f8daf093a4587ca30630d2aaa7e0a373d4afb45..48ed0c25121f1335889d969266ed76dd0905bad6:/login/edit.php diff --git a/login/edit.php b/login/edit.php index 0a90e0e..75811ed 100644 --- a/login/edit.php +++ b/login/edit.php @@ -1,21 +1,19 @@ "profile/$username", + 'name' => $username, ]; - if (!is_writable($user['dir'])) { - print "
Het is niet mogelijk om de gebruiker {$user['name']} aan te passen.
\n\n"; - return; - } } $cols = [ + 'name' => ['label' => 'volledige naam'], 'email' => ['label' => 'e-mailadres', 'type' => 'email'], ]; @@ -24,7 +22,7 @@ foreach ($cols as $col => &$colconf) { if (file_exists($colpath)) { $colconf['value'] = file_get_contents($colpath); } - if (!is_writable($user['dir'])) { + if (file_exists($user['dir']) and !is_writable($user['dir'])) { continue; # locked parent directory } if (isset($colconf['value']) and !is_writable($colpath)) { @@ -33,8 +31,16 @@ foreach ($cols as $col => &$colconf) { $colconf['target'] = $colpath; # editing allowed } +$cols = [ + 'login' => ['label' => 'login', 'value' => $user['name'], 'target' => NULL], +] + $cols; + $colwarn = []; if ($_POST) { + if (!file_exists($user['dir']) and !@mkdir($user['dir'])) { + print "Fout bij het aanmaken van gebruikersprofiel voor {$user['name']}.
\n\n"; + return; + } foreach ($_POST as $col => $val) { if (!isset($cols[$col])) { continue; # unknown @@ -47,11 +53,18 @@ if ($_POST) { $colwarn[$col] = "Kan niet worden aangepast."; continue; } - if (!file_put_contents($cols[$col]['target'], $val)) { + if (file_put_contents($cols[$col]['target'], $val) === FALSE) { $colwarn[$col] = "Fout bij opslaan."; } } + if (!empty($_POST['newpass'])) { + require_once('login/pass.inc.php'); + if ($error = passform($user, $_POST)) { + $colwarn['pass'] = $error; + } + } + if ($colwarn) { print "Instellingen zijn niet (volledig) opgeslagen. Probeer het later nog eens.
\n\n"; } @@ -61,29 +74,51 @@ if ($_POST) { } ?> -