public function HandleSelfRegistration(User $user, IRegistrationPage $page, ILoginContext $loginContext) { if ($user->StatusId() == AccountStatus::ACTIVE) { Log::Debug('PostRegistration - Handling activate user %s', $user->EmailAddress()); $this->authentication->Login($user->EmailAddress(), $loginContext); $page->Redirect(Pages::UrlFromId($user->Homepage())); } else { Log::Debug('PostRegistration - Handling pending user %s', $user->EmailAddress()); $this->activation->Notify($user); $page->Redirect(Pages::ACTIVATION); } }
/** * @param User $user * @return void */ public function Update(User $user) { $userId = $user->Id(); $db = ServiceLocator::GetDatabase(); $updateUserCommand = new UpdateUserCommand($user->Id(), $user->StatusId(), $user->encryptedPassword, $user->passwordSalt, $user->FirstName(), $user->LastName(), $user->EmailAddress(), $user->Username(), $user->Homepage(), $user->Timezone(), $user->LastLogin(), $user->GetIsCalendarSubscriptionAllowed(), $user->GetPublicId(), $user->Language(), $user->GetDefaultScheduleId()); $db->Execute($updateUserCommand); $removedPermissions = $user->GetRemovedPermissions(); foreach ($removedPermissions as $resourceId) { $db->Execute(new DeleteUserResourcePermission($userId, $resourceId)); } $addedPermissions = $user->GetAddedPermissions(); foreach ($addedPermissions as $resourceId) { $db->Execute(new AddUserResourcePermission($userId, $resourceId)); } if ($user->HaveAttributesChanged()) { $updateAttributesCommand = new UpdateUserAttributesCommand($userId, $user->GetAttribute(UserAttribute::Phone), $user->GetAttribute(UserAttribute::Organization), $user->GetAttribute(UserAttribute::Position)); $db->Execute($updateAttributesCommand); } $removedPreferences = $user->GetRemovedEmailPreferences(); foreach ($removedPreferences as $event) { $db->Execute(new DeleteEmailPreferenceCommand($userId, $event->EventCategory(), $event->EventType())); } $addedPreferences = $user->GetAddedEmailPreferences(); foreach ($addedPreferences as $event) { $db->Execute(new AddEmailPreferenceCommand($userId, $event->EventCategory(), $event->EventType())); } foreach ($user->GetRemovedAttributes() as $removed) { $db->Execute(new RemoveAttributeValueCommand($removed->AttributeId, $user->Id())); } foreach ($user->GetAddedAttributes() as $added) { $db->Execute(new AddAttributeValueCommand($added->AttributeId, $added->Value, $user->Id(), CustomAttributeCategory::USER)); } foreach ($user->GetPreferences()->AddedPreferences() as $added) { $db->Execute(new AddUserPreferenceCommand($user->Id(), $added, $user->GetPreference($added))); } foreach ($user->GetPreferences()->ChangedPreferences() as $updated) { $db->Execute(new UpdateUserPreferenceCommand($user->Id(), $updated, $user->GetPreference($updated))); } foreach ($user->GetRemovedGroups() as $removed) { $db->Execute(new DeleteUserGroupCommand($user->Id(), $removed->GroupId)); } foreach ($user->GetAddedGroups() as $added) { $db->Execute(new AddUserGroupCommand($user->Id(), $added->GroupId)); } }
/** * @param User $user * @param string $loginTime * @return UserSession */ private function GetUserSession(User $user, $loginTime) { $userSession = new UserSession($user->Id()); $userSession->Email = $user->EmailAddress(); $userSession->FirstName = $user->FirstName(); $userSession->LastName = $user->LastName(); $userSession->Timezone = $user->Timezone(); $userSession->HomepageId = $user->Homepage(); $userSession->LanguageCode = $user->Language(); $userSession->LoginTime = $loginTime; $userSession->PublicId = $user->GetPublicId(); $userSession->ScheduleId = $user->GetDefaultScheduleId(); $userSession->IsAdmin = $this->roleService->IsApplicationAdministrator($user); $userSession->IsGroupAdmin = $this->roleService->IsGroupAdministrator($user); $userSession->IsResourceAdmin = $this->roleService->IsResourceAdministrator($user); $userSession->IsScheduleAdmin = $this->roleService->IsScheduleAdministrator($user); $userSession->CSRFToken = base64_encode(md5(uniqid(rand(), true))); foreach ($user->Groups() as $group) { $userSession->Groups[] = $group->GroupId; } foreach ($user->GetAdminGroups() as $group) { $userSession->AdminGroups[] = $group->GroupId; } return $userSession; }