package io.vertx.ext.healthchecks;

import io.vertx.codegen.annotations.Fluent;
import io.vertx.codegen.annotations.VertxGen;
import io.vertx.core.Handler;
import io.vertx.core.Promise;
import io.vertx.core.Vertx;
import io.vertx.ext.auth.AuthProvider;
import io.vertx.ext.healthchecks.impl.HealthCheckHandlerImpl;
import io.vertx.ext.web.RoutingContext;

A Vert.x Web handler on which you register health check procedure. It computes the outcome status (`UP` or `DOWN`) . When the handler process a HTTP request, it computes the global outcome and build a HTTP response as follows:

  • 204 - status is `UP` but no procedures installed (no payload)
  • 200 - status is `UP`, the payload contains the result of the installed procedures
  • 503 - status is `DOWN`, the payload contains the result of the installed procedures
  • 500 - status is `DOWN`, the payload contains the result of the installed procedures, one of the procedure has failed
Author:Clement Escoffier
/** * A Vert.x Web handler on which you register health check procedure. It computes the outcome status (`UP` or `DOWN`) * . When the handler process a HTTP request, it computes the global outcome and build a HTTP response as follows: * <p> * <ul> * <li>204 - status is `UP` but no procedures installed (no payload)</li> * <li>200 - status is `UP`, the payload contains the result of the installed procedures</li> * <li>503 - status is `DOWN`, the payload contains the result of the installed procedures</li> * <li>500 - status is `DOWN`, the payload contains the result of the installed procedures, one of the * procedure has failed</li> * </ul> * * @author <a href="http://escoffier.me">Clement Escoffier</a> */
@VertxGen public interface HealthCheckHandler extends Handler<RoutingContext> {
Creates an instance of the default implementation of the HealthCheckHandler. This function creates a new instance of HealthChecks.
Params:
  • vertx – the Vert.x instance, must not be null
  • provider – the Authentication provider used to authenticate the HTTP request
Returns:the created instance
/** * Creates an instance of the default implementation of the {@link HealthCheckHandler}. * This function creates a new instance of {@link HealthChecks}. * * @param vertx the Vert.x instance, must not be {@code null} * @param provider the Authentication provider used to authenticate the HTTP request * @return the created instance */
static HealthCheckHandler create(Vertx vertx, AuthProvider provider) { return new HealthCheckHandlerImpl(vertx, provider); }
Creates an instance of the default implementation of the HealthCheckHandler. This function creates a new instance of HealthChecks.
Params:
  • vertx – the Vert.x instance, must not be null
Returns:the created instance
/** * Creates an instance of the default implementation of the {@link HealthCheckHandler}. * This function creates a new instance of {@link HealthChecks}. * * @param vertx the Vert.x instance, must not be {@code null} * @return the created instance */
static HealthCheckHandler create(Vertx vertx) { return create(vertx, null); }
Creates an instance of the default implementation of the HealthCheckHandler.
Params:
  • hc – the health checks object to use, must not be null
Returns:the created instance
/** * Creates an instance of the default implementation of the {@link HealthCheckHandler}. * * @param hc the health checks object to use, must not be {@code null} * @return the created instance */
static HealthCheckHandler createWithHealthChecks(HealthChecks hc, AuthProvider provider) { return new HealthCheckHandlerImpl(hc, provider); }
Creates an instance of the default implementation of the HealthCheckHandler.
Params:
  • hc – the health checks object to use
Returns:the created instance
/** * Creates an instance of the default implementation of the {@link HealthCheckHandler}. * * @param hc the health checks object to use * @return the created instance */
static HealthCheckHandler createWithHealthChecks(HealthChecks hc) { return createWithHealthChecks(hc, null); }
Registers a health check procedure.

The procedure is a Handler taking a Promise of Status as parameter. Procedures are asynchronous, and must complete or fail the given Promise. If the future object is failed, the procedure outcome is considered as `DOWN`. If the future is completed without any object, the procedure outcome is considered as `UP`. If the future is completed with a (not-null) Status, the procedure outcome is the received status.

This method uses a 1s timeout. To configure the timeout use register(String, long, Handler<Promise<Status>>).

Params:
  • name – the name of the procedure, must not be null or empty
  • procedure – the procedure, must not be null
Returns:the current HealthCheckHandler
/** * Registers a health check procedure. * <p> * The procedure is a {@link Handler} taking a {@link Promise} of {@link Status} as parameter. Procedures are * asynchronous, and <strong>must</strong> complete or fail the given {@link Promise}. If the future object is * failed, the procedure outcome is considered as `DOWN`. If the future is completed without any object, the * procedure outcome is considered as `UP`. If the future is completed with a (not-null) {@link Status}, the * procedure outcome is the received status. * <p> * This method uses a 1s timeout. To configure the timeout use {@link #register(String, long, Handler)}. * * @param name the name of the procedure, must not be {@code null} or empty * @param procedure the procedure, must not be {@code null} * @return the current {@link HealthCheckHandler} */
@Fluent HealthCheckHandler register(String name, Handler<Promise<Status>> procedure);
Registers a health check procedure.

The procedure is a Handler taking a Promise of Status as parameter. Procedures are asynchronous, and must complete or fail the given Promise. If the future object is failed, the procedure outcome is considered as `DOWN`. If the future is completed without any object, the procedure outcome is considered as `UP`. If the future is completed with a (not-null) Status, the procedure outcome is the received status.

Params:
  • name – the name of the procedure, must not be null or empty
  • timeout – the procedure timeout
  • procedure – the procedure, must not be null
Returns:the current HealthCheckHandler
/** * Registers a health check procedure. * <p> * The procedure is a {@link Handler} taking a {@link Promise} of {@link Status} as parameter. Procedures are * asynchronous, and <strong>must</strong> complete or fail the given {@link Promise}. If the future object is * failed, the procedure outcome is considered as `DOWN`. If the future is completed without any object, the * procedure outcome is considered as `UP`. If the future is completed with a (not-null) {@link Status}, the * procedure outcome is the received status. * * @param name the name of the procedure, must not be {@code null} or empty * @param timeout the procedure timeout * @param procedure the procedure, must not be {@code null} * @return the current {@link HealthCheckHandler} */
@Fluent HealthCheckHandler register(String name, long timeout, Handler<Promise<Status>> procedure);
Unregisters a procedure.
Params:
  • name – the name of the procedure
Returns:the current HealthCheckHandler
/** * Unregisters a procedure. * * @param name the name of the procedure * @return the current {@link HealthCheckHandler} */
@Fluent HealthCheckHandler unregister(String name); }