2019-05-20 07:37:41 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
|
|
|
|
use App\User;
|
|
|
|
use Validator;
|
|
|
|
use Illuminate\Http\Request;
|
2020-01-13 22:24:14 +01:00
|
|
|
use Illuminate\Support\Facades\DB;
|
2019-05-20 07:37:41 +02:00
|
|
|
use App\Http\Controllers\Controller;
|
|
|
|
use Illuminate\Support\Facades\Auth;
|
|
|
|
|
|
|
|
class UserController extends Controller
|
|
|
|
{
|
|
|
|
|
2019-05-29 11:04:12 +02:00
|
|
|
/**
|
|
|
|
* log a user in
|
|
|
|
* @return [type] [description]
|
|
|
|
*/
|
2020-01-09 11:14:39 +01:00
|
|
|
public function login(Request $request)
|
2019-05-20 07:37:41 +02:00
|
|
|
{
|
2020-01-09 11:14:39 +01:00
|
|
|
$validator = Validator::make($request->all(), [
|
|
|
|
'email' => 'required|exists:users,email',
|
|
|
|
'password' => 'required',
|
2020-01-12 19:55:17 +01:00
|
|
|
]);
|
2020-01-09 11:14:39 +01:00
|
|
|
|
|
|
|
if ($validator->fails()) {
|
2020-01-13 23:10:32 +01:00
|
|
|
return response()->json(['validation' => $validator->errors()], 400);
|
2020-01-09 11:14:39 +01:00
|
|
|
}
|
|
|
|
|
2019-05-20 07:37:41 +02:00
|
|
|
$credentials = [
|
|
|
|
'email' => request('email'),
|
|
|
|
'password' => request('password')
|
|
|
|
];
|
|
|
|
|
|
|
|
if (Auth::attempt($credentials)) {
|
|
|
|
$success['token'] = Auth::user()->createToken('MyApp')->accessToken;
|
2019-05-28 17:29:15 +02:00
|
|
|
$success['name'] = Auth::user()->name;
|
2019-05-20 07:37:41 +02:00
|
|
|
|
2020-01-14 11:49:35 +01:00
|
|
|
return response()->json(['message' => $success], 200);
|
2019-05-20 07:37:41 +02:00
|
|
|
}
|
|
|
|
|
2020-01-14 11:49:35 +01:00
|
|
|
return response()->json(['message' => 'unauthorised'], 401);
|
2019-05-20 07:37:41 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-05-29 11:04:12 +02:00
|
|
|
/**
|
|
|
|
* log out current user
|
|
|
|
* @param Request $request
|
|
|
|
* @return json
|
|
|
|
*/
|
|
|
|
public function logout()
|
|
|
|
{
|
|
|
|
$accessToken = Auth::user()->token();
|
|
|
|
$accessToken->revoke();
|
|
|
|
|
2020-01-14 11:49:35 +01:00
|
|
|
return response()->json(['message' => 'signed out']);
|
2019-05-29 11:04:12 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-01-13 22:24:14 +01:00
|
|
|
/**
|
|
|
|
* check if a user exists
|
|
|
|
* @param Request $request [description]
|
|
|
|
* @return json
|
|
|
|
*/
|
|
|
|
public function checkUser()
|
|
|
|
{
|
|
|
|
|
|
|
|
$count = DB::table('users')->count();
|
|
|
|
|
|
|
|
return response()->json(['userCount' => $count], 200);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-05-29 11:04:12 +02:00
|
|
|
/**
|
|
|
|
* register new user
|
|
|
|
* @param Request $request [description]
|
|
|
|
* @return json
|
|
|
|
*/
|
2019-05-20 07:37:41 +02:00
|
|
|
public function register(Request $request)
|
|
|
|
{
|
2020-01-13 22:24:14 +01:00
|
|
|
|
|
|
|
// check if a user already exists
|
|
|
|
$count = DB::table('users')->count();
|
|
|
|
|
|
|
|
if( $count > 0 ) {
|
2020-01-14 11:49:35 +01:00
|
|
|
return response()->json(['message' => __('errors.already_one_user_registered')], 400);
|
2020-01-13 22:24:14 +01:00
|
|
|
}
|
|
|
|
|
2019-05-20 07:37:41 +02:00
|
|
|
$validator = Validator::make($request->all(), [
|
|
|
|
'name' => 'required',
|
|
|
|
'email' => 'required|email',
|
2020-01-09 11:14:39 +01:00
|
|
|
'password' => 'required|confirmed',
|
2019-05-20 07:37:41 +02:00
|
|
|
]);
|
|
|
|
|
|
|
|
if ($validator->fails()) {
|
2020-01-13 23:10:32 +01:00
|
|
|
return response()->json(['validation' => $validator->errors()], 400);
|
2019-05-20 07:37:41 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
$input = $request->all();
|
|
|
|
$input['password'] = bcrypt($input['password']);
|
|
|
|
|
|
|
|
$user = User::create($input);
|
|
|
|
$success['token'] = $user->createToken('MyApp')->accessToken;
|
|
|
|
$success['name'] = $user->name;
|
|
|
|
|
2020-01-14 11:49:35 +01:00
|
|
|
return response()->json(['message' => $success]);
|
2019-05-20 07:37:41 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-05-29 11:04:12 +02:00
|
|
|
/**
|
|
|
|
* get detailed information about a user
|
|
|
|
* @return [type] [description]
|
|
|
|
*/
|
2019-05-20 07:37:41 +02:00
|
|
|
public function getDetails()
|
|
|
|
{
|
2019-05-29 11:04:12 +02:00
|
|
|
return response()->json(Auth::user(), 200);
|
2019-05-20 07:37:41 +02:00
|
|
|
}
|
|
|
|
}
|