authorize('addTeamMember', $organization); // TODO: refactor after owner refactoring $this->validate($organization, $email, $role); $newOrganizationMember = User::query() ->where('email', $email) ->where('is_placeholder', '=', false) ->firstOrFail(); app(MemberService::class)->addMember($newOrganizationMember, $organization, Role::from($role)); } /** * Validate the add member operation. */ protected function validate(Organization $organization, string $email, ?string $role): void { Validator::make([ 'email' => $email, 'role' => $role, ], $this->rules())->after( $this->ensureUserIsNotAlreadyOnTeam($organization, $email) )->validateWithBag('addTeamMember'); } /** * Get the validation rules for adding a team member. * * @return array> */ protected function rules(): array { return array_filter([ 'email' => [ 'required', 'email', ExistsEloquent::make(User::class, 'email', function (Builder $builder) { /** @var Builder $builder */ return $builder->where('is_placeholder', '=', false); })->withMessage(__('We were unable to find a registered user with this email address.')), ], 'role' => [ 'required', 'string', Rule::in([ Role::Admin->value, Role::Manager->value, Role::Employee->value, ]), ], ]); } /** * Ensure that the user is not already on the team. */ protected function ensureUserIsNotAlreadyOnTeam(Organization $team, string $email): Closure { return function ($validator) use ($team, $email): void { $validator->errors()->addIf( $team->hasRealUserWithEmail($email), 'email', __('This user already belongs to the team.') ); }; } }