/*
 * Copyright (c) 2011-2019 Contributors to the Eclipse Foundation
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License 2.0 which is available at
 * http://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0
 * which is available at https://www.apache.org/licenses/LICENSE-2.0.
 *
 * SPDX-License-Identifier: EPL-2.0 OR Apache-2.0
 */
package io.vertx.core.http.impl;

import io.vertx.core.AsyncResult;
import io.vertx.core.Handler;
import io.vertx.core.impl.ContextInternal;
import io.vertx.core.net.impl.clientconnection.Endpoint;
import io.vertx.core.spi.metrics.ClientMetrics;

Author:Julien Viet
/** * @author <a href="mailto:julien@julienviet.com">Julien Viet</a> */
abstract class ClientHttpEndpointBase extends Endpoint<HttpClientConnection> { private final Object metric; private final int port; private final String host; private final ClientMetrics metrics; // Shall be removed later combining the PoolMetrics with HttpClientMetrics ClientHttpEndpointBase(ClientMetrics metrics, int port, String host, Object metric, Runnable dispose) { super(dispose); this.port = port; this.host = host; this.metric = metric; this.metrics = metrics; } @Override public final void requestConnection(ContextInternal ctx, Handler<AsyncResult<HttpClientConnection>> handler) { if (metrics != null) { Object metric; if (metrics != null) { metric = metrics.enqueueRequest(); } else { metric = null; } Handler<AsyncResult<HttpClientConnection>> next = handler; handler = ar -> { if (metrics != null) { metrics.dequeueRequest(metric); } next.handle(ar); }; } requestConnection2(ctx, handler); } protected abstract void requestConnection2(ContextInternal ctx, Handler<AsyncResult<HttpClientConnection>> handler); @Override protected void dispose() { if (metrics != null) { metrics.close(); } } @Override public void close(HttpClientConnection connection) { connection.close(); } }