io.gravitee.am.gateway.handler.vertx.auth.provider.ClientAuthenticationProvider.java Source code

Java tutorial

Introduction

Here is the source code for io.gravitee.am.gateway.handler.vertx.auth.provider.ClientAuthenticationProvider.java

Source

/**
 * Copyright (C) 2015 The Gravitee team (http://gravitee.io)
 *
 * 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 io.gravitee.am.gateway.handler.vertx.auth.provider;

import io.gravitee.am.gateway.handler.oauth2.client.ClientService;
import io.gravitee.am.gateway.handler.oauth2.exception.BadClientCredentialsException;
import io.gravitee.am.gateway.handler.vertx.auth.user.Client;
import io.vertx.core.AsyncResult;
import io.vertx.core.Future;
import io.vertx.core.Handler;
import io.vertx.core.json.JsonObject;
import io.vertx.ext.auth.AuthProvider;
import io.vertx.ext.auth.User;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * @author David BRASSELY (david.brassely at graviteesource.com)
 * @author GraviteeSource Team
 */
public class ClientAuthenticationProvider implements AuthProvider {

    private final Logger logger = LoggerFactory.getLogger(ClientAuthenticationProvider.class);
    private static final String USERNAME_FIELD = "username";
    private static final String PASSWORD_FIELD = "password";

    private ClientService clientService;

    public ClientAuthenticationProvider() {
    }

    public ClientAuthenticationProvider(ClientService clientService) {
        this.clientService = clientService;
    }

    @Override
    public void authenticate(JsonObject credentials, Handler<AsyncResult<User>> authHandler) {
        String clientId = credentials.getString(USERNAME_FIELD);
        String clientSecret = credentials.getString(PASSWORD_FIELD);

        logger.debug("Trying to authenticate a client: clientId[{}]", clientId);

        clientService.findByClientId(clientId).subscribe(client -> {
            if (client.getClientSecret().equals(clientSecret)) {
                authHandler.handle(Future.succeededFuture(new Client(client)));
            } else {
                authHandler.handle(Future.failedFuture(new BadClientCredentialsException()));
            }
        }, error -> {
            logger.error("Unexpected error while looking for a client: clientId[{}]", clientId, error);
            authHandler.handle(Future.failedFuture(error));
        }, () -> authHandler.handle(Future.failedFuture(new BadClientCredentialsException())));
    }

    public void setClientService(ClientService clientService) {
        this.clientService = clientService;
    }
}