/*
* Copyright (c) 2011-2016 The original author or authors
*
* 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 io.vertx.servicediscovery.spi;
import io.vertx.codegen.annotations.VertxGen;
import io.vertx.core.Future;
import io.vertx.core.Handler;
import io.vertx.core.Promise;
import io.vertx.core.Vertx;
import io.vertx.core.json.JsonObject;
import io.vertx.servicediscovery.Record;
The service importer allows integrate other discovery technologies with the Vert.x service discovery. It maps entries from another technology to a Record
and maps Record
to a publication in this other technology. The importer is one side of a service discovery bridge. Author: Clement Escoffier
/**
* The service importer allows integrate other discovery technologies with the Vert.x service discovery. It maps
* entries from another technology to a {@link Record} and maps {@link Record} to a publication in this other
* technology. The importer is one side of a service discovery bridge.
*
* @author <a href="http://escoffier.me">Clement Escoffier</a>
*/
@VertxGen
public interface ServiceImporter {
Starts the importer.
Params: - vertx – the vertx instance
- publisher – the service publisher instance
- configuration – the bridge configuration if any
- future – a future on which the bridge must report the completion of the starting
/**
* Starts the importer.
*
* @param vertx the vertx instance
* @param publisher the service publisher instance
* @param configuration the bridge configuration if any
* @param future a future on which the bridge must report the completion of the starting
*/
void start(Vertx vertx, ServicePublisher publisher, JsonObject configuration,
Promise<Void> future);
Closes the importer
Params: - closeHandler – the handle to be notified when importer is closed, may be
null
/**
* Closes the importer
*
* @param closeHandler the handle to be notified when importer is closed, may be {@code null}
*/
default void close(Handler<Void> closeHandler) {
closeHandler.handle(null);
}
}