public function __construct(IRestServer $server, User $user, IEntityAttributeList $attributes) { $userId = $user->Id(); $this->id = $userId; $this->emailAddress = $user->EmailAddress(); $this->firstName = $user->FirstName(); $this->lastName = $user->LastName(); $this->language = $user->Language(); $this->lastLogin = Date::FromDatabase($user->LastLogin())->ToIso(); $this->organization = $user->GetAttribute(UserAttribute::Organization); $this->phoneNumber = $user->GetAttribute(UserAttribute::Phone); $this->position = $user->GetAttribute(UserAttribute::Position); $this->statusId = $user->StatusId(); $this->timezone = $user->Timezone(); $this->username = $user->Username(); $attributeValues = $attributes->GetAttributes($userId); if (!empty($attributeValues)) { foreach ($attributeValues as $av) { $this->customAttributes[] = new CustomAttributeResponse($server, $av->Id(), $av->Label(), $av->Value()); } } foreach ($user->AllowedResourceIds() as $allowedResourceId) { $this->permissions[] = new ResourceItemResponse($server, $allowedResourceId, ''); } foreach ($user->Groups() as $group) { $this->groups[] = new GroupItemResponse($server, $group->GroupId, $group->GroupName); } if ($user->GetIsCalendarSubscriptionAllowed()) { $url = new CalendarSubscriptionUrl($user->GetPublicId(), null, null); $this->icsUrl = $url->__toString(); } }
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)); } }
public function testUpdateSetsUserProperties() { $userId = 987; $loginTime = '2010-01-01'; $language = 'en_gb'; $user = new User(); $user->WithId($userId); $password = '******'; $salt = 'salt'; $homepageId = 19; $fname = 'f'; $lname = 'l'; $email = 'e'; $username = '******'; $timezone = 'America/New_York'; $scheduleId = 99; $user->ChangePassword($password, $salt); $user->ChangeName($fname, $lname); $user->ChangeEmailAddress($email); $user->ChangeUsername($username); $user->ChangeDefaultHomePage($homepageId); $user->ChangeTimezone($timezone); $user->EnableSubscription(); $user->Login($loginTime, $language); $user->ChangeDefaultSchedule($scheduleId); $publicId = $user->GetPublicId(); $command = new UpdateUserCommand($userId, $user->StatusId(), $password, $salt, $fname, $lname, $email, $username, $homepageId, $timezone, $loginTime, true, $publicId, $language, $scheduleId); $repo = new UserRepository(); $repo->Update($user); $this->assertTrue($this->db->ContainsCommand($command)); }