Skip to content
Snippets Groups Projects
Commit edfc625e authored by itanael's avatar itanael
Browse files

add password column for user account

parent fd523bc6
No related branches found
No related tags found
No related merge requests found
...@@ -14,14 +14,36 @@ class CreateUserAction extends UserAction ...@@ -14,14 +14,36 @@ class CreateUserAction extends UserAction
*/ */
protected function action(): Response protected function action(): Response
{ {
$message = null;
$parsedRequestBody = (array)$this->request->getParsedBody(); $parsedRequestBody = (array)$this->request->getParsedBody();
$username = $parsedRequestBody['username']; $username = $parsedRequestBody['username'];
$firstname = $parsedRequestBody['firstname']; $firstname = $parsedRequestBody['firstname'];
$lastname = $parsedRequestBody['lastname']; $lastname = $parsedRequestBody['lastname'];
$mail = $parsedRequestBody['mail']; $mail = $parsedRequestBody['mail'];
$password = $parsedRequestBody['password'];
$user = new User(null, $username, $firstname, $lastname, $mail, 0, null); $confirmPassword = $parsedRequestBody['confirmpassword'];
if ($password != $confirmPassword) {
$message = "Passwords don't match";
return $this->twig->render(
$this->response, "/user/create_user.twig",
[
"username" => $username,
"firstname" => $firstname,
"lastname" => $lastname,
"mail" => $mail,
"password" => null,
"confirmpassword" => null,
"message" => $message
]
);
}
$user = new User(null, $username, $firstname, $lastname, $mail, 0, null, $password);
$this->em->persist($user); $this->em->persist($user);
$this->em->flush(); $this->em->flush();
......
...@@ -56,6 +56,12 @@ class User implements JsonSerializable ...@@ -56,6 +56,12 @@ class User implements JsonSerializable
*/ */
private $contaminated; private $contaminated;
/**
* @var string
* @ORM\Column(type="string")
*/
private $password;
/** /**
* @param int|null $id * @param int|null $id
* @param string $username * @param string $username
...@@ -64,7 +70,9 @@ class User implements JsonSerializable ...@@ -64,7 +70,9 @@ class User implements JsonSerializable
* @param string $mail * @param string $mail
* @param int $group_id * @param int $group_id
* @param bool $contaminated * @param bool $contaminated
* @param string $password
*/ */
public function __construct( public function __construct(
?int $id, ?int $id,
string $username, string $username,
...@@ -72,12 +80,14 @@ class User implements JsonSerializable ...@@ -72,12 +80,14 @@ class User implements JsonSerializable
string $lastName, string $lastName,
string $mail, string $mail,
?int $group_id, ?int $group_id,
?bool $contaminated ?bool $contaminated,
string $password
) { ) {
$this->id = $id; $this->id = $id;
$this->username = strtolower($username); $this->username = strtolower($username);
$this->firstName = ucfirst($firstName); $this->firstName = ucfirst($firstName);
$this->lastName = ucfirst($lastName); $this->lastName = ucfirst($lastName);
$this->password = $password;
$this->mail = strtolower($mail); $this->mail = strtolower($mail);
$this->group_id = $group_id; $this->group_id = $group_id;
$this->contaminated = (bool)$contaminated; $this->contaminated = (bool)$contaminated;
...@@ -107,6 +117,15 @@ class User implements JsonSerializable ...@@ -107,6 +117,15 @@ class User implements JsonSerializable
return $this->firstName; return $this->firstName;
} }
/**
* @return string
*/
public function getPassword(): string
{
return $this->password;
}
/** /**
* @return string * @return string
*/ */
...@@ -150,6 +169,7 @@ class User implements JsonSerializable ...@@ -150,6 +169,7 @@ class User implements JsonSerializable
'username' => $this->username, 'username' => $this->username,
'firstName' => $this->firstName, 'firstName' => $this->firstName,
'lastName' => $this->lastName, 'lastName' => $this->lastName,
'password' => $this->password,
'mail' => $this->mail, 'mail' => $this->mail,
'group_id' => $this->group_id, 'group_id' => $this->group_id,
'contaminated' => (bool)$this->contaminated, 'contaminated' => (bool)$this->contaminated,
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment