-
-
Notifications
You must be signed in to change notification settings - Fork 3.6k
/
Users.php
84 lines (71 loc) · 2.28 KB
/
Users.php
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
75
76
77
78
79
80
81
82
83
84
<?php
namespace Directus\API\Routes\A1;
use Directus\Application\Route;
use Directus\Database\TableGateway\DirectusUsersTableGateway;
use Directus\Mail\Mail;
use Directus\Util\ArrayUtils;
use Directus\Util\DateUtils;
use Directus\Util\StringUtils;
use Directus\Util\Validator;
use Directus\View\JsonView;
class Users extends Route
{
// /1.1/users
public function all()
{
$entries = new Entries($this->app);
return $entries->rows('directus_users');
}
// /1.1/users/:id
public function get($id)
{
$entries = new Entries($this->app);
return $entries->row('directus_users', $id);
}
// /1.1/users/invitation
public function invite()
{
$email = $this->app->request()->post('email');
$emails = explode(',', $email);
foreach ($emails as $email) {
$this->sendInvitationTo($email);
}
return $this->app->response([
'success' => true
]);
}
protected function sendInvitationTo($email)
{
if (!Validator::email($email)) {
// FIXME: incorrect method overwritten
$this->app->response()->setStatus(400);
return $this->app->response(([
'success' => false,
'error' => [
'code' => 'invalid_email',
'message' => 'invalid_email'
]
]));
}
// @TODO: Builder/Service to get table gateway
// $usersRepository = $repositoryCollection->get('users');
// $usersRepository->add();
$ZendDb = $this->app->container->get('zenddb');
$acl = $this->app->container->get('acl');
$auth = $this->app->container->get('auth');
$tableGateway = new DirectusUsersTableGateway($ZendDb, $acl);
$token = StringUtils::randomString(128);
$result = $tableGateway->insert([
'status' => STATUS_DRAFT_NUM,
'email' => $email,
'token' => StringUtils::randomString(32),
'invite_token' => $token,
'invite_date' => DateUtils::now(),
'invite_sender' => $auth->getUserInfo('id'),
'invite_accepted' => 0
]);
if ($result) {
send_user_invitation_email($email, $token);
}
}
}