io.debezium.connector.sqlserver.rest.DebeziumSqlServerConnectorResource Maven / Gradle / Ivy
/*
* Copyright Debezium Authors.
*
* Licensed under the Apache Software License version 2.0, available at http://www.apache.org/licenses/LICENSE-2.0
*/
package io.debezium.connector.sqlserver.rest;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
import javax.management.MalformedObjectNameException;
import javax.ws.rs.Consumes;
import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;
import org.apache.kafka.connect.health.ConnectClusterState;
import io.debezium.config.Configuration;
import io.debezium.connector.sqlserver.Module;
import io.debezium.connector.sqlserver.SqlServerConnector;
import io.debezium.rest.ConnectionValidationResource;
import io.debezium.rest.FilterValidationResource;
import io.debezium.rest.MetricsResource;
import io.debezium.rest.SchemaResource;
import io.debezium.rest.model.DataCollection;
import io.debezium.rest.model.MetricsDescriptor;
/**
* A JAX-RS Resource class defining endpoints of the Debezium SQL Server Connect REST Extension
*
*/
@Path(DebeziumSqlServerConnectorResource.BASE_PATH)
@Produces(MediaType.APPLICATION_JSON)
@Consumes(MediaType.APPLICATION_JSON)
public class DebeziumSqlServerConnectorResource
implements SchemaResource, ConnectionValidationResource, FilterValidationResource, MetricsResource {
public static final String BASE_PATH = "/debezium/sqlserver";
public static final String VERSION_ENDPOINT = "/version";
private final ConnectClusterState connectClusterState;
public DebeziumSqlServerConnectorResource(ConnectClusterState connectClusterState) {
this.connectClusterState = connectClusterState;
}
@GET
@Path(VERSION_ENDPOINT)
public String getConnectorVersion() {
return Module.version();
}
@Override
public SqlServerConnector getConnector() {
return new SqlServerConnector();
}
@Override
public MetricsDescriptor getMetrics(String connectorName)
throws MalformedObjectNameException {
Map connectorConfig = connectClusterState.connectorConfig(connectorName);
return queryMetrics(connectorConfig, connectorName, Module.contextName().toLowerCase(), "streaming");
}
@Override
public String getSchemaFilePath() {
return "/META-INF/resources/sqlserver.json";
}
@Override
public List getMatchingCollections(Configuration configuration) {
return getConnector().getMatchingCollections(configuration).stream()
.map(tableId -> new DataCollection(tableId.catalog(), tableId.schema(), tableId.table()))
.collect(Collectors.toList());
}
}