aboutsummaryrefslogtreecommitdiff
path: root/src/controllers/PasswordReminderController.php
diff options
context:
space:
mode:
Diffstat (limited to 'src/controllers/PasswordReminderController.php')
-rw-r--r--src/controllers/PasswordReminderController.php47
1 files changed, 47 insertions, 0 deletions
diff --git a/src/controllers/PasswordReminderController.php b/src/controllers/PasswordReminderController.php
new file mode 100644
index 0000000..bf9d959
--- /dev/null
+++ b/src/controllers/PasswordReminderController.php
@@ -0,0 +1,47 @@
+<?php
+/**
+ * Created by PhpStorm.
+ * User: camilstaps
+ * Date: 13-5-15
+ * Time: 13:13
+ */
+
+namespace CamilStaps\BotleaguesApi\Controllers;
+
+use CamilStaps\BotleaguesApi\Database\PasswordReminder;
+use CamilStaps\BotleaguesApi\Exception\ValidationException;
+use Illuminate\Support\Facades\Input;
+use Illuminate\Support\Facades\Validator;
+
+class PasswordReminderController extends BaseController {
+
+ protected $passwordReminder;
+
+ public function __construct(PasswordReminder $passwordReminder) {
+ $this->passwordReminder = $passwordReminder;
+ }
+
+ /**
+ * Set the userId and create a random token
+ */
+ public function store() {
+ $rules = [
+ 'user_id' => ['required']
+ ];
+ $payload = Input::only('user_id');
+ $validator = Validator::make($payload, $rules);
+ if ($validator->fails()) {
+ throw new ValidationException('Could not find user.', $validator->errors());
+ }
+
+ $this->passwordReminder->userId = Input::get('user_id');
+ $this->passwordReminder->token = base64_encode(openssl_random_pseudo_bytes(64));
+
+ if ($this->passwordReminder->save()) {
+ return $this->passwordReminder;
+ } else {
+ throw new \Dingo\Api\Exception\StoreResourceFailedException;
+ }
+ }
+
+} \ No newline at end of file