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

com.arangodb.shaded.vertx.ext.auth.impl.ChainAuthImpl Maven / Gradle / Ivy

There is a newer version: 7.8.0
Show newest version
/*
 * Copyright 2014 Red Hat, Inc.
 *
 *  All rights reserved. This program and the accompanying materials
 *  are made available under the terms of the Eclipse Public License v1.0
 *  and Apache License v2.0 which accompanies this distribution.
 *
 *  The Eclipse Public License is available at
 *  http://www.eclipse.org/legal/epl-v10.html
 *
 *  The Apache License v2.0 is available at
 *  http://www.opensource.org/licenses/apache2.0.php
 *
 *  You may elect to redistribute this code under either of these licenses.
 */
package com.arangodb.shaded.vertx.ext.auth.impl;

import com.arangodb.shaded.vertx.core.AsyncResult;
import com.arangodb.shaded.vertx.core.Future;
import com.arangodb.shaded.vertx.core.Handler;
import com.arangodb.shaded.vertx.core.json.JsonObject;
import com.arangodb.shaded.vertx.ext.auth.ChainAuth;
import com.arangodb.shaded.vertx.ext.auth.User;
import com.arangodb.shaded.vertx.ext.auth.authentication.AuthenticationProvider;
import com.arangodb.shaded.vertx.ext.auth.authentication.CredentialValidationException;
import com.arangodb.shaded.vertx.ext.auth.authentication.Credentials;

import java.util.ArrayList;
import java.util.List;

public class ChainAuthImpl implements ChainAuth {

  private final List providers = new ArrayList<>();
  private final boolean all;

  public ChainAuthImpl(boolean all) {
    this.all = all;
  }

  @Override
  public ChainAuth add(AuthenticationProvider other) {
    providers.add(other);
    return this;
  }

  @Override
  public void authenticate(JsonObject credentials, Handler> resultHandler) {
    authenticate(credentials)
      .onComplete(resultHandler);
  }

  @Override
  public Future authenticate(Credentials credentials) {
    try {
      credentials.checkValid(null);
    } catch (CredentialValidationException e) {
      return Future.failedFuture(e);
    }
    return authenticate(credentials.toJson());
  }

  @Override
  public Future authenticate(final JsonObject authInfo) {
    if (providers.size() == 0) {
      return Future.failedFuture("No providers in the auth chain.");
    } else {
      return iterate(0, authInfo, null);
    }
  }

  private Future iterate(final int idx, final JsonObject authInfo, final User previousUser) {
    // stop condition
    if (idx >= providers.size()) {
      if (!all) {
        // no more providers, means that we failed to find a provider capable of performing this operation
        return Future.failedFuture("No more providers in the auth chain.");
      } else {
        // if ALL then a success completes
        return Future.succeededFuture(previousUser);
      }
    }

    // attempt to perform operation
    return providers.get(idx)
      .authenticate(authInfo)
      .compose(user -> {
        if (!all) {
          // if ANY then a success completes
          return Future.succeededFuture(user);
        } else {
          // if ALL then a success check the next one
          return iterate(idx + 1, authInfo, previousUser == null ? user : previousUser.merge(user));
        }
      })
      .recover(err -> {
        // try again with next provider
        if (!all) {
          // try again with next provider
          return iterate(idx + 1, authInfo, null);
        } else {
          // short circuit when ALL is used a failure is enough to terminate
          // no more providers, means that we failed to find a provider capable of performing this operation
          return Future.failedFuture(err);
        }
      });
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy