示例#1
0
 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);
     }
 }
示例#2
0
 /**
  * @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));
     }
 }
示例#3
0
 /**
  * @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;
 }