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

io.edurt.datacap.plugin.jdbc.presto.PrestoPlugin Maven / Gradle / Ivy

package io.edurt.datacap.plugin.jdbc.presto;

import edu.umd.cs.findbugs.annotations.SuppressFBWarnings;
import io.edurt.datacap.spi.Plugin;
import io.edurt.datacap.spi.PluginType;
import io.edurt.datacap.spi.adapter.JdbcAdapter;
import io.edurt.datacap.spi.connection.JdbcConfigure;
import io.edurt.datacap.spi.connection.JdbcConnection;
import io.edurt.datacap.spi.model.Configure;
import io.edurt.datacap.spi.model.Response;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.beanutils.BeanUtils;
import org.apache.commons.lang3.ObjectUtils;

@Slf4j
@SuppressFBWarnings(value = {"EI_EXPOSE_REP"})
public class PrestoPlugin
        implements Plugin
{
    private JdbcConfigure jdbcConfigure;
    private JdbcConnection jdbcConnection;
    private Response response;

    @Override
    public String validator()
    {
        return "SELECT node_version AS version\n" +
                "FROM system.runtime.nodes\n" +
                "LIMIT 1";
    }

    @Override
    public String name()
    {
        return "Presto";
    }

    @Override
    public String description()
    {
        return "Integrate Presto data sources";
    }

    @Override
    public PluginType type()
    {
        return PluginType.JDBC;
    }

    @Override
    public void connect(Configure configure)
    {
        try {
            this.response = new Response();
            this.jdbcConfigure = new JdbcConfigure();
            BeanUtils.copyProperties(this.jdbcConfigure, configure);
            this.jdbcConfigure.setJdbcDriver("io.prestosql.jdbc.PrestoDriver");
            this.jdbcConfigure.setJdbcType("presto");
            this.jdbcConnection = new JdbcConnection(this.jdbcConfigure, this.response);
        }
        catch (Exception ex) {
            this.response.setIsConnected(Boolean.FALSE);
            this.response.setMessage(ex.getMessage());
        }
    }

    @Override
    public Response execute(String content)
    {
        if (ObjectUtils.isNotEmpty(this.jdbcConnection)) {
            log.info("Execute plugin logic started");
            this.response = this.jdbcConnection.getResponse();
            JdbcAdapter processor = new PrestoAdapter(this.jdbcConnection);
            this.response = processor.handlerExecute(content);
            log.info("Execute plugin logic end");
        }
        return this.response;
    }

    @Override
    public void destroy()
    {
        if (ObjectUtils.isNotEmpty(this.jdbcConnection)) {
            this.jdbcConnection.destroy();
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy