Newer
Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
<?php
namespace App\Http\Controllers;
use App\Organization;
use App\User;
use App\Mail\OrganizationUserInvitation;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Mail;
use Illuminate\Support\Facades\Validator;
use Illuminate\Support\Facades\Auth;
class OrganizationUserController extends Controller {
public function __construct() {
$this->middleware('auth');
}
public function index() {
}
/** Show form **/
public function create(Organization $organization) {
return view("organization.user.create", ["organization" => $organization]);
}
protected function validator(array $data) {
return Validator::make($data, [
'email' => 'required|string|email|max:255|unique:users',
]);
}
/** add user to organization **/
public function store(Organization $organization, Request $request) {
$current_user = Auth::user();
if (! $current_user->ownsOrganization($organization)) {
return redirect(route("dashboard"));
}
$user = User::findByEmail($request->input("email"));
if ($user == null) {
// create user
$this->validator($request->all())->validate();
$user = User::create([
'name' => $request->input("email"),
'email' => $request->input("email"),
'password' => bcrypt(str_random()),
]);
}
if ($user->ownsOrganization($organization)) {
// user is already part of organization...
return redirect(route("dashboard"));
}
Mail::to($user->email)->send(new OrganizationUserInvitation($organization, $user));
$organization->users()->attach($user->id);
return redirect(route("dashboard"));
}
public function show($id) {
}
public function edit($id) {
}
public function update($id) {
}
public function destroy($id) {
}
}