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

org.apache.paimon.flink.procedure.ProcedureBase Maven / Gradle / Ivy

The newest version!
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.apache.paimon.flink.procedure;

import org.apache.paimon.catalog.Catalog;
import org.apache.paimon.catalog.Identifier;
import org.apache.paimon.factories.Factory;
import org.apache.paimon.flink.action.ActionBase;
import org.apache.paimon.table.Table;
import org.apache.paimon.utils.StringUtils;

import org.apache.flink.configuration.PipelineOptions;
import org.apache.flink.configuration.ReadableConfig;
import org.apache.flink.core.execution.JobClient;
import org.apache.flink.streaming.api.environment.StreamExecutionEnvironment;
import org.apache.flink.table.api.TableException;
import org.apache.flink.table.procedure.ProcedureContext;
import org.apache.flink.table.procedures.Procedure;

import javax.annotation.Nullable;

import java.util.Collections;
import java.util.HashMap;
import java.util.Map;

import static org.apache.flink.table.api.config.TableConfigOptions.TABLE_DML_SYNC;
import static org.apache.paimon.utils.ParameterUtils.parseKeyValueString;

/** Base implementation for flink {@link Procedure}. */
public abstract class ProcedureBase implements Procedure, Factory {

    protected Catalog catalog;

    public ProcedureBase withCatalog(Catalog catalog) {
        this.catalog = catalog;
        return this;
    }

    protected Table table(String tableId) throws Catalog.TableNotExistException {
        return catalog.getTable(Identifier.fromString(tableId));
    }

    protected String notnull(@Nullable String arg) {
        return arg == null ? "" : arg;
    }

    @Nullable
    protected String nullable(String arg) {
        return StringUtils.isNullOrWhitespaceOnly(arg) ? null : arg;
    }

    protected String[] execute(
            ProcedureContext procedureContext, ActionBase action, String defaultJobName)
            throws Exception {
        StreamExecutionEnvironment env = procedureContext.getExecutionEnvironment();
        action.withStreamExecutionEnvironment(env);
        action.build();

        return execute(env, defaultJobName);
    }

    protected String[] execute(ProcedureContext procedureContext, JobClient jobClient) {
        StreamExecutionEnvironment env = procedureContext.getExecutionEnvironment();
        ReadableConfig conf = env.getConfiguration();
        return execute(jobClient, conf.get(TABLE_DML_SYNC));
    }

    protected String[] execute(StreamExecutionEnvironment env, String defaultJobName)
            throws Exception {
        ReadableConfig conf = env.getConfiguration();
        String name = conf.getOptional(PipelineOptions.NAME).orElse(defaultJobName);
        return execute(env.executeAsync(name), conf.get(TABLE_DML_SYNC));
    }

    private String[] execute(JobClient jobClient, boolean dmlSync) {
        String jobId = jobClient.getJobID().toString();
        if (dmlSync) {
            try {
                jobClient.getJobExecutionResult().get();
            } catch (Exception e) {
                throw new TableException(String.format("Failed to wait job '%s' finish", jobId), e);
            }
            return new String[] {"Success"};
        } else {
            return new String[] {"JobID=" + jobId};
        }
    }

    protected Map optionalConfigMap(String configStr) {
        if (StringUtils.isNullOrWhitespaceOnly(configStr)) {
            return Collections.emptyMap();
        }

        Map config = new HashMap<>();
        for (String kvString : configStr.split(";")) {
            parseKeyValueString(config, kvString);
        }
        return config;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy