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

io.cdap.plugin.common.SnapshotFileSetConfig Maven / Gradle / Ivy

There is a newer version: 2.12.3
Show newest version
/*
 * Copyright © 2015-2019 Cask Data, Inc.
 *
 * Licensed 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 io.cdap.plugin.common;

import io.cdap.cdap.api.annotation.Description;
import io.cdap.cdap.api.annotation.Macro;
import io.cdap.cdap.api.plugin.PluginConfig;

import javax.annotation.Nullable;

/**
 * {@link PluginConfig} for snapshot fileset sources and sinks.
 */
public abstract class SnapshotFileSetConfig extends PluginConfig {
  @Macro
  @Description("Name of the PartitionedFileset Dataset to which the records are written to. " +
    "If it doesn't exist, it will be created.")
  protected String name;

  @Macro
  @Nullable
  @Description("The path where the data will be recorded. " +
    "Defaults to the name of the dataset.")
  protected String basePath;

  @Macro
  @Nullable
  @Description("Advanced feature to specify any additional properties that should be used with the plugin, " +
    "specified as a JSON object of string to string. These properties are set on the dataset if one is created. " +
    "The properties are also passed to the dataset at runtime as arguments.")
  protected String fileProperties;

  public SnapshotFileSetConfig() {

  }

  public SnapshotFileSetConfig(String name, @Nullable String basePath, @Nullable String fileProperties) {
    this.name = name;
    this.basePath = basePath;
    this.fileProperties = fileProperties;
  }

  public String getName() {
    return name;
  }

  @Nullable
  public String getBasePath() {
    return basePath;
  }

  @Nullable
  public String getFileProperties() {
    return fileProperties;
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy