All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.netflix.spinnaker.gate.services.AuthenticationService Maven / Gradle / Ivy

There is a newer version: 6.64.1
Show newest version
/*
 * Copyright 2023 Apple, Inc.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *
 */

package com.netflix.spinnaker.gate.services;

import com.netflix.spinnaker.fiat.shared.FiatPermissionEvaluator;
import com.netflix.spinnaker.fiat.shared.FiatService;
import com.netflix.spinnaker.fiat.shared.FiatStatus;
import com.netflix.spinnaker.security.AuthenticatedRequest;
import io.micrometer.core.annotation.Counted;
import java.util.Collection;
import java.util.Set;
import lombok.RequiredArgsConstructor;
import lombok.Setter;
import lombok.extern.log4j.Log4j2;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.security.core.GrantedAuthority;
import org.springframework.security.core.userdetails.UsernameNotFoundException;
import org.springframework.stereotype.Service;

/** Facade for logging in an authenticated user and obtaining Fiat authorities. */
@Log4j2
@Service
@RequiredArgsConstructor
public class AuthenticationService {
  private final FiatStatus fiatStatus;
  private final FiatService fiatService;
  private final FiatPermissionEvaluator permissionEvaluator;

  @Setter(
      onParam_ = {@Qualifier("fiatLoginService")},
      onMethod_ = {@Autowired(required = false)})
  private FiatService fiatLoginService;

  private FiatService getFiatServiceForLogin() {
    return fiatLoginService != null ? fiatLoginService : fiatService;
  }

  @Counted("fiat.login")
  public Collection login(String userid) {
    if (!fiatStatus.isEnabled()) {
      return Set.of();
    }

    return AuthenticatedRequest.allowAnonymous(
        () -> {
          getFiatServiceForLogin().loginUser(userid, "");
          return resolveAuthorities(userid);
        });
  }

  @Counted("fiat.login")
  public Collection loginWithRoles(
      String userid, Collection roles) {
    if (!fiatStatus.isEnabled()) {
      return Set.of();
    }

    return AuthenticatedRequest.allowAnonymous(
        () -> {
          getFiatServiceForLogin().loginWithRoles(userid, roles);
          return resolveAuthorities(userid);
        });
  }

  @Counted("fiat.logout")
  public void logout(String userid) {
    if (!fiatStatus.isEnabled()) {
      return;
    }

    getFiatServiceForLogin().logoutUser(userid);
    permissionEvaluator.invalidatePermission(userid);
  }

  private Collection resolveAuthorities(String userid) {
    permissionEvaluator.invalidatePermission(userid);
    var permission = permissionEvaluator.getPermission(userid);
    if (permission == null) {
      throw new UsernameNotFoundException(
          String.format("No user found in Fiat named '%s'", userid));
    }
    return permission.toGrantedAuthorities();
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy