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

com.englishtown.vertx.jersey.JerseyServer Maven / Gradle / Ivy

Go to download

Allows creating JAX-RS jersey resources that will handle incoming http requests to vert.x

There is a newer version: 4.7.0
Show newest version
/*
 * The MIT License (MIT)
 * Copyright © 2013 Englishtown 
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the “Software”), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 */

package com.englishtown.vertx.jersey;

import com.englishtown.vertx.jersey.inject.Nullable;
import io.vertx.core.AsyncResult;
import io.vertx.core.Handler;
import io.vertx.core.http.HttpServer;

/**
 * Represents a jersey server running in vert.x
 */
public interface JerseyServer {

    /**
     * Creates a vert.x {@link HttpServer} with a jersey handler
     *
     * @param options http server and jersey configuration settings
     * @deprecated Use start() instead
     */
    @Deprecated
    default void init(JerseyOptions options) {
        start();
    }

    /**
     * Creates a vert.x {@link HttpServer} with a jersey handler
     *
     * @param options     http server and jersey configuration settings
     * @param doneHandler the optional callback for when initialization has completed
     * @deprecated Use start(doneHandler) instead
     */
    @Deprecated
    default void init(JerseyOptions options, Handler> doneHandler) {
        start(doneHandler);
    }

    /**
     * Creates a vert.x {@link HttpServer} with a jersey handler
     */
    default void start() {
        start(null);
    }

    /**
     * Creates a vert.x {@link HttpServer} with a jersey handler
     *
     * @param doneHandler the optional callback for when initialization has completed
     */
    default void start(@Nullable Handler> doneHandler) {
        start(null, null, doneHandler);
    }

    /**
     * Creates a vert.x {@link HttpServer} with a jersey handler with options
     *
     * @param options
     * @param jerseyOptions
     * @param doneHandler
     */
    void start(@Nullable JerseyServerOptions options, @Nullable JerseyOptions jerseyOptions, @Nullable Handler> doneHandler);

    /**
     * Allows custom setup during initialization before the http server is listening (add custom routes, etc.)
     *
     * @param handler the handler invoked with the http server
     */
    void setupHandler(Handler handler);

    /**
     * Returns the JerseyHandler instance for the JerseyServer
     *
     * @return the JerseyHandler instance
     */
    JerseyHandler getHandler();

    /**
     * Returns the internal vert.x {@link io.vertx.core.http.HttpServer}
     *
     * @return the vert.x http server instance
     */
    HttpServer getHttpServer();

    /**
     * Shutdown jersey server and release resources
     */
    void stop();

    /**
     * Release resources
     */
    default void close() {
        stop();
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy