@aws-cdk/aws-glue-alpha
Version:
The CDK Construct Library for AWS::Glue
309 lines • 35.7 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.DataFormat = exports.ClassificationString = exports.SerializationLibrary = exports.OutputFormat = exports.InputFormat = void 0;
const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
/**
* Absolute class name of the Hadoop `InputFormat` to use when reading table files.
*/
class InputFormat {
className;
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-glue-alpha.InputFormat", version: "2.225.0-alpha.0" };
/**
* InputFormat for Avro files.
*
* @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/ql/io/avro/AvroContainerInputFormat.html
*/
static AVRO = new InputFormat('org.apache.hadoop.hive.ql.io.avro.AvroContainerInputFormat');
/**
* InputFormat for Cloudtrail Logs.
*
* @see https://docs.aws.amazon.com/athena/latest/ug/cloudtrail.html
*/
static CLOUDTRAIL = new InputFormat('com.amazon.emr.cloudtrail.CloudTrailInputFormat');
/**
* InputFormat for Orc files.
*
* @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/ql/io/orc/OrcInputFormat.html
*/
static ORC = new InputFormat('org.apache.hadoop.hive.ql.io.orc.OrcInputFormat');
/**
* InputFormat for Parquet files.
*
* @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/ql/io/parquet/MapredParquetInputFormat.html
*/
static PARQUET = new InputFormat('org.apache.hadoop.hive.ql.io.parquet.MapredParquetInputFormat');
/**
* An InputFormat for plain text files. Files are broken into lines. Either linefeed or
* carriage-return are used to signal end of line. Keys are the position in the file, and
* values are the line of text.
* JSON & CSV files are examples of this InputFormat
*
* @see https://hadoop.apache.org/docs/stable/api/org/apache/hadoop/mapred/TextInputFormat.html
*/
static TEXT = new InputFormat('org.apache.hadoop.mapred.TextInputFormat');
constructor(className) {
this.className = className;
}
}
exports.InputFormat = InputFormat;
/**
* Absolute class name of the Hadoop `OutputFormat` to use when writing table files.
*/
class OutputFormat {
className;
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-glue-alpha.OutputFormat", version: "2.225.0-alpha.0" };
/**
* Writes text data with a null key (value only).
*
* @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/ql/io/HiveIgnoreKeyTextOutputFormat.html
*/
static HIVE_IGNORE_KEY_TEXT = new OutputFormat('org.apache.hadoop.hive.ql.io.HiveIgnoreKeyTextOutputFormat');
/**
* OutputFormat for Avro files.
*
* @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/ql/io/avro/AvroContainerOutputFormat.html
*/
static AVRO = new InputFormat('org.apache.hadoop.hive.ql.io.avro.AvroContainerOutputFormat');
/**
* OutputFormat for Orc files.
*
* @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/ql/io/orc/OrcOutputFormat.html
*/
static ORC = new InputFormat('org.apache.hadoop.hive.ql.io.orc.OrcOutputFormat');
/**
* OutputFormat for Parquet files.
*
* @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/ql/io/parquet/MapredParquetOutputFormat.html
*/
static PARQUET = new OutputFormat('org.apache.hadoop.hive.ql.io.parquet.MapredParquetOutputFormat');
constructor(className) {
this.className = className;
}
}
exports.OutputFormat = OutputFormat;
/**
* Serialization library to use when serializing/deserializing (SerDe) table records.
*
* @see https://cwiki.apache.org/confluence/display/Hive/SerDe
*/
class SerializationLibrary {
className;
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-glue-alpha.SerializationLibrary", version: "2.225.0-alpha.0" };
/**
* @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/serde2/avro/AvroSerDe.html
*/
static AVRO = new SerializationLibrary('org.apache.hadoop.hive.serde2.avro.AvroSerDe');
/**
* @see https://docs.aws.amazon.com/athena/latest/ug/cloudtrail.html
*/
static CLOUDTRAIL = new SerializationLibrary('com.amazon.emr.hive.serde.CloudTrailSerde');
/**
* @see https://docs.aws.amazon.com/athena/latest/ug/grok.html
*/
static GROK = new SerializationLibrary('com.amazonaws.glue.serde.GrokSerDe');
/**
* @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hive/hcatalog/data/JsonSerDe.html
*/
static HIVE_JSON = new SerializationLibrary('org.apache.hive.hcatalog.data.JsonSerDe');
/**
* @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/serde2/lazy/LazySimpleSerDe.html
*/
static LAZY_SIMPLE = new SerializationLibrary('org.apache.hadoop.hive.serde2.lazy.LazySimpleSerDe');
/**
* @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/serde2/OpenCSVSerde.html
*/
static OPEN_CSV = new SerializationLibrary('org.apache.hadoop.hive.serde2.OpenCSVSerde');
/**
* @see https://github.com/rcongiu/Hive-JSON-Serde
*/
static OPENX_JSON = new SerializationLibrary('org.openx.data.jsonserde.JsonSerDe');
/**
* @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/ql/io/orc/OrcSerde.html
*/
static ORC = new SerializationLibrary('org.apache.hadoop.hive.ql.io.orc.OrcSerde');
/**
* @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/ql/io/parquet/serde/ParquetHiveSerDe.html
*/
static PARQUET = new SerializationLibrary('org.apache.hadoop.hive.ql.io.parquet.serde.ParquetHiveSerDe');
/**
* @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/serde2/RegexSerDe.html
*/
static REGEXP = new SerializationLibrary('org.apache.hadoop.hive.serde2.RegexSerDe');
constructor(className) {
this.className = className;
}
}
exports.SerializationLibrary = SerializationLibrary;
/**
* Classification string given to tables with this data format.
*
* @see https://docs.aws.amazon.com/glue/latest/dg/add-classifier.html#classifier-built-in
*/
class ClassificationString {
value;
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-glue-alpha.ClassificationString", version: "2.225.0-alpha.0" };
/**
* @see https://docs.aws.amazon.com/glue/latest/dg/aws-glue-programming-etl-format.html#aws-glue-programming-etl-format-avro
*/
static AVRO = new ClassificationString('avro');
/**
* @see https://docs.aws.amazon.com/glue/latest/dg/aws-glue-programming-etl-format.html#aws-glue-programming-etl-format-csv
*/
static CSV = new ClassificationString('csv');
/**
* @see https://docs.aws.amazon.com/glue/latest/dg/aws-glue-programming-etl-format.html#aws-glue-programming-etl-format-json
*/
static JSON = new ClassificationString('json');
/**
* @see https://docs.aws.amazon.com/glue/latest/dg/aws-glue-programming-etl-format.html#aws-glue-programming-etl-format-xml
*/
static XML = new ClassificationString('xml');
/**
* @see https://docs.aws.amazon.com/glue/latest/dg/aws-glue-programming-etl-format.html#aws-glue-programming-etl-format-parquet
*/
static PARQUET = new ClassificationString('parquet');
/**
* @see https://docs.aws.amazon.com/glue/latest/dg/aws-glue-programming-etl-format.html#aws-glue-programming-etl-format-orc
*/
static ORC = new ClassificationString('orc');
constructor(value) {
this.value = value;
}
}
exports.ClassificationString = ClassificationString;
/**
* Defines the input/output formats and ser/de for a single DataFormat.
*/
class DataFormat {
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-glue-alpha.DataFormat", version: "2.225.0-alpha.0" };
/**
* DataFormat for Apache Web Server Logs. Also works for CloudFront logs
*
* @see https://docs.aws.amazon.com/athena/latest/ug/apache.html
*/
static APACHE_LOGS = new DataFormat({
inputFormat: InputFormat.TEXT,
outputFormat: OutputFormat.HIVE_IGNORE_KEY_TEXT,
serializationLibrary: SerializationLibrary.REGEXP,
});
/**
* DataFormat for Apache Avro
*
* @see https://docs.aws.amazon.com/athena/latest/ug/avro.html
*/
static AVRO = new DataFormat({
inputFormat: InputFormat.AVRO,
outputFormat: OutputFormat.AVRO,
serializationLibrary: SerializationLibrary.AVRO,
classificationString: ClassificationString.AVRO,
});
/**
* DataFormat for CloudTrail logs stored on S3
*
* @see https://docs.aws.amazon.com/athena/latest/ug/cloudtrail.html
*/
static CLOUDTRAIL_LOGS = new DataFormat({
inputFormat: InputFormat.CLOUDTRAIL,
outputFormat: OutputFormat.HIVE_IGNORE_KEY_TEXT,
serializationLibrary: SerializationLibrary.CLOUDTRAIL,
});
/**
* DataFormat for CSV Files
*
* @see https://docs.aws.amazon.com/athena/latest/ug/csv.html
*/
static CSV = new DataFormat({
inputFormat: InputFormat.TEXT,
outputFormat: OutputFormat.HIVE_IGNORE_KEY_TEXT,
serializationLibrary: SerializationLibrary.OPEN_CSV,
classificationString: ClassificationString.CSV,
});
/**
* Stored as plain text files in JSON format.
* Uses OpenX Json SerDe for serialization and deseralization.
*
* @see https://docs.aws.amazon.com/athena/latest/ug/json.html
*/
static JSON = new DataFormat({
inputFormat: InputFormat.TEXT,
outputFormat: OutputFormat.HIVE_IGNORE_KEY_TEXT,
serializationLibrary: SerializationLibrary.OPENX_JSON,
classificationString: ClassificationString.JSON,
});
/**
* DataFormat for Logstash Logs, using the GROK SerDe
*
* @see https://docs.aws.amazon.com/athena/latest/ug/grok.html
*/
static LOGSTASH = new DataFormat({
inputFormat: InputFormat.TEXT,
outputFormat: OutputFormat.HIVE_IGNORE_KEY_TEXT,
serializationLibrary: SerializationLibrary.GROK,
});
/**
* DataFormat for Apache ORC (Optimized Row Columnar)
*
* @see https://docs.aws.amazon.com/athena/latest/ug/orc.html
*/
static ORC = new DataFormat({
inputFormat: InputFormat.ORC,
outputFormat: OutputFormat.ORC,
serializationLibrary: SerializationLibrary.ORC,
classificationString: ClassificationString.ORC,
});
/**
* DataFormat for Apache Parquet
*
* @see https://docs.aws.amazon.com/athena/latest/ug/parquet.html
*/
static PARQUET = new DataFormat({
inputFormat: InputFormat.PARQUET,
outputFormat: OutputFormat.PARQUET,
serializationLibrary: SerializationLibrary.PARQUET,
classificationString: ClassificationString.PARQUET,
});
/**
* DataFormat for TSV (Tab-Separated Values)
*
* @see https://docs.aws.amazon.com/athena/latest/ug/lazy-simple-serde.html
*/
static TSV = new DataFormat({
inputFormat: InputFormat.TEXT,
outputFormat: OutputFormat.HIVE_IGNORE_KEY_TEXT,
serializationLibrary: SerializationLibrary.LAZY_SIMPLE,
});
/**
* `InputFormat` for this data format.
*/
inputFormat;
/**
* `OutputFormat` for this data format.
*/
outputFormat;
/**
* Serialization library for this data format.
*/
serializationLibrary;
/**
* Classification string given to tables with this data format.
*/
classificationString;
constructor(props) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_glue_alpha_DataFormatProps(props);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, DataFormat);
}
throw error;
}
this.inputFormat = props.inputFormat;
this.outputFormat = props.outputFormat;
this.serializationLibrary = props.serializationLibrary;
this.classificationString = props.classificationString;
}
}
exports.DataFormat = DataFormat;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-format.js","sourceRoot":"","sources":["data-format.ts"],"names":[],"mappings":";;;;;AAAA;;GAEG;AACH,MAAa,WAAW;IAuCM;;IAtC5B;;;;OAIG;IACI,MAAM,CAAU,IAAI,GAAG,IAAI,WAAW,CAAC,4DAA4D,CAAC,CAAC;IAE5G;;;;OAIG;IACI,MAAM,CAAU,UAAU,GAAG,IAAI,WAAW,CAAC,iDAAiD,CAAC,CAAC;IAEvG;;;;OAIG;IACI,MAAM,CAAU,GAAG,GAAG,IAAI,WAAW,CAAC,iDAAiD,CAAC,CAAC;IAEhG;;;;OAIG;IACI,MAAM,CAAU,OAAO,GAAG,IAAI,WAAW,CAAC,+DAA+D,CAAC,CAAC;IAElH;;;;;;;OAOG;IACI,MAAM,CAAU,IAAI,GAAG,IAAI,WAAW,CAAC,0CAA0C,CAAC,CAAC;IAE1F,YAA4B,SAAiB;QAAjB,cAAS,GAAT,SAAS,CAAQ;KAAI;;AAvCnD,kCAwCC;AAED;;GAEG;AACH,MAAa,YAAY;IA6BK;;IA5B5B;;;;OAIG;IACI,MAAM,CAAU,oBAAoB,GAAG,IAAI,YAAY,CAAC,4DAA4D,CAAC,CAAC;IAE7H;;;;OAIG;IACI,MAAM,CAAU,IAAI,GAAG,IAAI,WAAW,CAAC,6DAA6D,CAAC,CAAC;IAE7G;;;;OAIG;IACI,MAAM,CAAU,GAAG,GAAG,IAAI,WAAW,CAAC,kDAAkD,CAAC,CAAC;IAEjG;;;;OAIG;IACI,MAAM,CAAU,OAAO,GAAG,IAAI,YAAY,CAAC,gEAAgE,CAAC,CAAC;IAEpH,YAA4B,SAAiB;QAAjB,cAAS,GAAT,SAAS,CAAQ;KAAI;;AA7BnD,oCA8BC;AAED;;;;GAIG;AACH,MAAa,oBAAoB;IAmDH;;IAlD5B;;OAEG;IACI,MAAM,CAAU,IAAI,GAAG,IAAI,oBAAoB,CAAC,8CAA8C,CAAC,CAAC;IAEvG;;OAEG;IACI,MAAM,CAAU,UAAU,GAAG,IAAI,oBAAoB,CAAC,2CAA2C,CAAC,CAAC;IAE1G;;OAEG;IACI,MAAM,CAAU,IAAI,GAAG,IAAI,oBAAoB,CAAC,oCAAoC,CAAC,CAAC;IAE7F;;OAEG;IACI,MAAM,CAAU,SAAS,GAAG,IAAI,oBAAoB,CAAC,yCAAyC,CAAC,CAAC;IAEvG;;OAEG;IACI,MAAM,CAAU,WAAW,GAAG,IAAI,oBAAoB,CAAC,oDAAoD,CAAC,CAAC;IAEpH;;OAEG;IACI,MAAM,CAAU,QAAQ,GAAG,IAAI,oBAAoB,CAAC,4CAA4C,CAAC,CAAC;IAEzG;;OAEG;IACI,MAAM,CAAU,UAAU,GAAG,IAAI,oBAAoB,CAAC,oCAAoC,CAAC,CAAC;IAEnG;;OAEG;IACI,MAAM,CAAU,GAAG,GAAG,IAAI,oBAAoB,CAAC,2CAA2C,CAAC,CAAC;IAEnG;;OAEG;IACI,MAAM,CAAU,OAAO,GAAG,IAAI,oBAAoB,CAAC,6DAA6D,CAAC,CAAC;IAEzH;;OAEG;IACI,MAAM,CAAU,MAAM,GAAG,IAAI,oBAAoB,CAAC,0CAA0C,CAAC,CAAC;IAErG,YAA4B,SAAiB;QAAjB,cAAS,GAAT,SAAS,CAAQ;KAAI;;AAnDnD,oDAoDC;AAED;;;;GAIG;AACH,MAAa,oBAAoB;IA+BH;;IA9B5B;;OAEG;IACI,MAAM,CAAU,IAAI,GAAG,IAAI,oBAAoB,CAAC,MAAM,CAAC,CAAC;IAE/D;;OAEG;IACI,MAAM,CAAU,GAAG,GAAG,IAAI,oBAAoB,CAAC,KAAK,CAAC,CAAC;IAE7D;;OAEG;IACI,MAAM,CAAU,IAAI,GAAG,IAAI,oBAAoB,CAAC,MAAM,CAAC,CAAC;IAE/D;;OAEG;IACI,MAAM,CAAU,GAAG,GAAG,IAAI,oBAAoB,CAAC,KAAK,CAAC,CAAC;IAE7D;;OAEG;IACI,MAAM,CAAU,OAAO,GAAG,IAAI,oBAAoB,CAAC,SAAS,CAAC,CAAC;IAErE;;OAEG;IACI,MAAM,CAAU,GAAG,GAAG,IAAI,oBAAoB,CAAC,KAAK,CAAC,CAAC;IAE7D,YAA4B,KAAa;QAAb,UAAK,GAAL,KAAK,CAAQ;KAAI;;AA/B/C,oDAgCC;AA6BD;;GAEG;AACH,MAAa,UAAU;;IACrB;;;;OAIG;IACI,MAAM,CAAU,WAAW,GAAG,IAAI,UAAU,CAAC;QAClD,WAAW,EAAE,WAAW,CAAC,IAAI;QAC7B,YAAY,EAAE,YAAY,CAAC,oBAAoB;QAC/C,oBAAoB,EAAE,oBAAoB,CAAC,MAAM;KAClD,CAAC,CAAC;IAEH;;;;OAIG;IACI,MAAM,CAAU,IAAI,GAAG,IAAI,UAAU,CAAC;QAC3C,WAAW,EAAE,WAAW,CAAC,IAAI;QAC7B,YAAY,EAAE,YAAY,CAAC,IAAI;QAC/B,oBAAoB,EAAE,oBAAoB,CAAC,IAAI;QAC/C,oBAAoB,EAAE,oBAAoB,CAAC,IAAI;KAChD,CAAC,CAAC;IAEH;;;;OAIG;IACI,MAAM,CAAU,eAAe,GAAG,IAAI,UAAU,CAAC;QACtD,WAAW,EAAE,WAAW,CAAC,UAAU;QACnC,YAAY,EAAE,YAAY,CAAC,oBAAoB;QAC/C,oBAAoB,EAAE,oBAAoB,CAAC,UAAU;KACtD,CAAC,CAAC;IAEH;;;;OAIG;IACI,MAAM,CAAU,GAAG,GAAG,IAAI,UAAU,CAAC;QAC1C,WAAW,EAAE,WAAW,CAAC,IAAI;QAC7B,YAAY,EAAE,YAAY,CAAC,oBAAoB;QAC/C,oBAAoB,EAAE,oBAAoB,CAAC,QAAQ;QACnD,oBAAoB,EAAE,oBAAoB,CAAC,GAAG;KAC/C,CAAC,CAAC;IAEH;;;;;OAKG;IACI,MAAM,CAAU,IAAI,GAAG,IAAI,UAAU,CAAC;QAC3C,WAAW,EAAE,WAAW,CAAC,IAAI;QAC7B,YAAY,EAAE,YAAY,CAAC,oBAAoB;QAC/C,oBAAoB,EAAE,oBAAoB,CAAC,UAAU;QACrD,oBAAoB,EAAE,oBAAoB,CAAC,IAAI;KAChD,CAAC,CAAC;IAEH;;;;OAIG;IACI,MAAM,CAAU,QAAQ,GAAG,IAAI,UAAU,CAAC;QAC/C,WAAW,EAAE,WAAW,CAAC,IAAI;QAC7B,YAAY,EAAE,YAAY,CAAC,oBAAoB;QAC/C,oBAAoB,EAAE,oBAAoB,CAAC,IAAI;KAChD,CAAC,CAAC;IAEH;;;;OAIG;IACI,MAAM,CAAU,GAAG,GAAG,IAAI,UAAU,CAAC;QAC1C,WAAW,EAAE,WAAW,CAAC,GAAG;QAC5B,YAAY,EAAE,YAAY,CAAC,GAAG;QAC9B,oBAAoB,EAAE,oBAAoB,CAAC,GAAG;QAC9C,oBAAoB,EAAE,oBAAoB,CAAC,GAAG;KAC/C,CAAC,CAAC;IAEH;;;;OAIG;IACI,MAAM,CAAU,OAAO,GAAG,IAAI,UAAU,CAAC;QAC9C,WAAW,EAAE,WAAW,CAAC,OAAO;QAChC,YAAY,EAAE,YAAY,CAAC,OAAO;QAClC,oBAAoB,EAAE,oBAAoB,CAAC,OAAO;QAClD,oBAAoB,EAAE,oBAAoB,CAAC,OAAO;KACnD,CAAC,CAAC;IAEH;;;;OAIG;IACI,MAAM,CAAU,GAAG,GAAG,IAAI,UAAU,CAAC;QAC1C,WAAW,EAAE,WAAW,CAAC,IAAI;QAC7B,YAAY,EAAE,YAAY,CAAC,oBAAoB;QAC/C,oBAAoB,EAAE,oBAAoB,CAAC,WAAW;KACvD,CAAC,CAAC;IAEH;;OAEG;IACa,WAAW,CAAc;IAEzC;;OAEG;IACa,YAAY,CAAe;IAE3C;;OAEG;IACa,oBAAoB,CAAuB;IAE3D;;OAEG;IACa,oBAAoB,CAAwB;IAE5D,YAAmB,KAAsB;;;;;;+CA9H9B,UAAU;;;;QA+HnB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,WAAW,CAAC;QACrC,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,YAAY,CAAC;QACvC,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC,oBAAoB,CAAC;QACvD,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC,oBAAoB,CAAC;KACxD;;AAnIH,gCAoIC","sourcesContent":["/**\n * Absolute class name of the Hadoop `InputFormat` to use when reading table files.\n */\nexport class InputFormat {\n  /**\n   * InputFormat for Avro files.\n   *\n   * @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/ql/io/avro/AvroContainerInputFormat.html\n   */\n  public static readonly AVRO = new InputFormat('org.apache.hadoop.hive.ql.io.avro.AvroContainerInputFormat');\n\n  /**\n   * InputFormat for Cloudtrail Logs.\n   *\n   * @see https://docs.aws.amazon.com/athena/latest/ug/cloudtrail.html\n   */\n  public static readonly CLOUDTRAIL = new InputFormat('com.amazon.emr.cloudtrail.CloudTrailInputFormat');\n\n  /**\n   * InputFormat for Orc files.\n   *\n   * @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/ql/io/orc/OrcInputFormat.html\n   */\n  public static readonly ORC = new InputFormat('org.apache.hadoop.hive.ql.io.orc.OrcInputFormat');\n\n  /**\n   * InputFormat for Parquet files.\n   *\n   * @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/ql/io/parquet/MapredParquetInputFormat.html\n   */\n  public static readonly PARQUET = new InputFormat('org.apache.hadoop.hive.ql.io.parquet.MapredParquetInputFormat');\n\n  /**\n   * An InputFormat for plain text files. Files are broken into lines. Either linefeed or\n   * carriage-return are used to signal end of line. Keys are the position in the file, and\n   * values are the line of text.\n   * JSON & CSV files are examples of this InputFormat\n   *\n   * @see https://hadoop.apache.org/docs/stable/api/org/apache/hadoop/mapred/TextInputFormat.html\n   */\n  public static readonly TEXT = new InputFormat('org.apache.hadoop.mapred.TextInputFormat');\n\n  constructor(public readonly className: string) {}\n}\n\n/**\n * Absolute class name of the Hadoop `OutputFormat` to use when writing table files.\n */\nexport class OutputFormat {\n  /**\n   * Writes text data with a null key (value only).\n   *\n   * @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/ql/io/HiveIgnoreKeyTextOutputFormat.html\n   */\n  public static readonly HIVE_IGNORE_KEY_TEXT = new OutputFormat('org.apache.hadoop.hive.ql.io.HiveIgnoreKeyTextOutputFormat');\n\n  /**\n   * OutputFormat for Avro files.\n   *\n   * @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/ql/io/avro/AvroContainerOutputFormat.html\n   */\n  public static readonly AVRO = new InputFormat('org.apache.hadoop.hive.ql.io.avro.AvroContainerOutputFormat');\n\n  /**\n   * OutputFormat for Orc files.\n   *\n   * @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/ql/io/orc/OrcOutputFormat.html\n   */\n  public static readonly ORC = new InputFormat('org.apache.hadoop.hive.ql.io.orc.OrcOutputFormat');\n\n  /**\n   * OutputFormat for Parquet files.\n   *\n   * @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/ql/io/parquet/MapredParquetOutputFormat.html\n   */\n  public static readonly PARQUET = new OutputFormat('org.apache.hadoop.hive.ql.io.parquet.MapredParquetOutputFormat');\n\n  constructor(public readonly className: string) {}\n}\n\n/**\n * Serialization library to use when serializing/deserializing (SerDe) table records.\n *\n * @see https://cwiki.apache.org/confluence/display/Hive/SerDe\n */\nexport class SerializationLibrary {\n  /**\n   * @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/serde2/avro/AvroSerDe.html\n   */\n  public static readonly AVRO = new SerializationLibrary('org.apache.hadoop.hive.serde2.avro.AvroSerDe');\n\n  /**\n   * @see https://docs.aws.amazon.com/athena/latest/ug/cloudtrail.html\n   */\n  public static readonly CLOUDTRAIL = new SerializationLibrary('com.amazon.emr.hive.serde.CloudTrailSerde');\n\n  /**\n   * @see https://docs.aws.amazon.com/athena/latest/ug/grok.html\n   */\n  public static readonly GROK = new SerializationLibrary('com.amazonaws.glue.serde.GrokSerDe');\n\n  /**\n   * @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hive/hcatalog/data/JsonSerDe.html\n   */\n  public static readonly HIVE_JSON = new SerializationLibrary('org.apache.hive.hcatalog.data.JsonSerDe');\n\n  /**\n   * @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/serde2/lazy/LazySimpleSerDe.html\n   */\n  public static readonly LAZY_SIMPLE = new SerializationLibrary('org.apache.hadoop.hive.serde2.lazy.LazySimpleSerDe');\n\n  /**\n   * @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/serde2/OpenCSVSerde.html\n   */\n  public static readonly OPEN_CSV = new SerializationLibrary('org.apache.hadoop.hive.serde2.OpenCSVSerde');\n\n  /**\n   * @see https://github.com/rcongiu/Hive-JSON-Serde\n   */\n  public static readonly OPENX_JSON = new SerializationLibrary('org.openx.data.jsonserde.JsonSerDe');\n\n  /**\n   * @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/ql/io/orc/OrcSerde.html\n   */\n  public static readonly ORC = new SerializationLibrary('org.apache.hadoop.hive.ql.io.orc.OrcSerde');\n\n  /**\n   * @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/ql/io/parquet/serde/ParquetHiveSerDe.html\n   */\n  public static readonly PARQUET = new SerializationLibrary('org.apache.hadoop.hive.ql.io.parquet.serde.ParquetHiveSerDe');\n\n  /**\n   * @see https://svn.apache.org/repos/infra/websites/production/hive/content/javadocs/r3.1.3/api/org/apache/hadoop/hive/serde2/RegexSerDe.html\n   */\n  public static readonly REGEXP = new SerializationLibrary('org.apache.hadoop.hive.serde2.RegexSerDe');\n\n  constructor(public readonly className: string) {}\n}\n\n/**\n * Classification string given to tables with this data format.\n *\n * @see https://docs.aws.amazon.com/glue/latest/dg/add-classifier.html#classifier-built-in\n */\nexport class ClassificationString {\n  /**\n   * @see https://docs.aws.amazon.com/glue/latest/dg/aws-glue-programming-etl-format.html#aws-glue-programming-etl-format-avro\n   */\n  public static readonly AVRO = new ClassificationString('avro');\n\n  /**\n   * @see https://docs.aws.amazon.com/glue/latest/dg/aws-glue-programming-etl-format.html#aws-glue-programming-etl-format-csv\n   */\n  public static readonly CSV = new ClassificationString('csv');\n\n  /**\n   * @see https://docs.aws.amazon.com/glue/latest/dg/aws-glue-programming-etl-format.html#aws-glue-programming-etl-format-json\n   */\n  public static readonly JSON = new ClassificationString('json');\n\n  /**\n   * @see https://docs.aws.amazon.com/glue/latest/dg/aws-glue-programming-etl-format.html#aws-glue-programming-etl-format-xml\n   */\n  public static readonly XML = new ClassificationString('xml');\n\n  /**\n   * @see https://docs.aws.amazon.com/glue/latest/dg/aws-glue-programming-etl-format.html#aws-glue-programming-etl-format-parquet\n   */\n  public static readonly PARQUET = new ClassificationString('parquet');\n\n  /**\n   * @see https://docs.aws.amazon.com/glue/latest/dg/aws-glue-programming-etl-format.html#aws-glue-programming-etl-format-orc\n   */\n  public static readonly ORC = new ClassificationString('orc');\n\n  constructor(public readonly value: string) {}\n}\n\n/**\n * Properties of a DataFormat instance.\n */\nexport interface DataFormatProps {\n  /**\n   * `InputFormat` for this data format.\n   */\n  readonly inputFormat: InputFormat;\n\n  /**\n   * `OutputFormat` for this data format.\n   */\n  readonly outputFormat: OutputFormat;\n\n  /**\n   * Serialization library for this data format.\n   */\n  readonly serializationLibrary: SerializationLibrary;\n\n  /**\n   * Classification string given to tables with this data format.\n   *\n   * @default - No classification is specified.\n   */\n  readonly classificationString?: ClassificationString;\n}\n\n/**\n * Defines the input/output formats and ser/de for a single DataFormat.\n */\nexport class DataFormat {\n  /**\n   * DataFormat for Apache Web Server Logs. Also works for CloudFront logs\n   *\n   * @see https://docs.aws.amazon.com/athena/latest/ug/apache.html\n   */\n  public static readonly APACHE_LOGS = new DataFormat({\n    inputFormat: InputFormat.TEXT,\n    outputFormat: OutputFormat.HIVE_IGNORE_KEY_TEXT,\n    serializationLibrary: SerializationLibrary.REGEXP,\n  });\n\n  /**\n   * DataFormat for Apache Avro\n   *\n   * @see https://docs.aws.amazon.com/athena/latest/ug/avro.html\n   */\n  public static readonly AVRO = new DataFormat({\n    inputFormat: InputFormat.AVRO,\n    outputFormat: OutputFormat.AVRO,\n    serializationLibrary: SerializationLibrary.AVRO,\n    classificationString: ClassificationString.AVRO,\n  });\n\n  /**\n   * DataFormat for CloudTrail logs stored on S3\n   *\n   * @see https://docs.aws.amazon.com/athena/latest/ug/cloudtrail.html\n   */\n  public static readonly CLOUDTRAIL_LOGS = new DataFormat({\n    inputFormat: InputFormat.CLOUDTRAIL,\n    outputFormat: OutputFormat.HIVE_IGNORE_KEY_TEXT,\n    serializationLibrary: SerializationLibrary.CLOUDTRAIL,\n  });\n\n  /**\n   * DataFormat for CSV Files\n   *\n   * @see https://docs.aws.amazon.com/athena/latest/ug/csv.html\n   */\n  public static readonly CSV = new DataFormat({\n    inputFormat: InputFormat.TEXT,\n    outputFormat: OutputFormat.HIVE_IGNORE_KEY_TEXT,\n    serializationLibrary: SerializationLibrary.OPEN_CSV,\n    classificationString: ClassificationString.CSV,\n  });\n\n  /**\n   * Stored as plain text files in JSON format.\n   * Uses OpenX Json SerDe for serialization and deseralization.\n   *\n   * @see https://docs.aws.amazon.com/athena/latest/ug/json.html\n   */\n  public static readonly JSON = new DataFormat({\n    inputFormat: InputFormat.TEXT,\n    outputFormat: OutputFormat.HIVE_IGNORE_KEY_TEXT,\n    serializationLibrary: SerializationLibrary.OPENX_JSON,\n    classificationString: ClassificationString.JSON,\n  });\n\n  /**\n   * DataFormat for Logstash Logs, using the GROK SerDe\n   *\n   * @see https://docs.aws.amazon.com/athena/latest/ug/grok.html\n   */\n  public static readonly LOGSTASH = new DataFormat({\n    inputFormat: InputFormat.TEXT,\n    outputFormat: OutputFormat.HIVE_IGNORE_KEY_TEXT,\n    serializationLibrary: SerializationLibrary.GROK,\n  });\n\n  /**\n   * DataFormat for Apache ORC (Optimized Row Columnar)\n   *\n   * @see https://docs.aws.amazon.com/athena/latest/ug/orc.html\n   */\n  public static readonly ORC = new DataFormat({\n    inputFormat: InputFormat.ORC,\n    outputFormat: OutputFormat.ORC,\n    serializationLibrary: SerializationLibrary.ORC,\n    classificationString: ClassificationString.ORC,\n  });\n\n  /**\n   * DataFormat for Apache Parquet\n   *\n   * @see https://docs.aws.amazon.com/athena/latest/ug/parquet.html\n   */\n  public static readonly PARQUET = new DataFormat({\n    inputFormat: InputFormat.PARQUET,\n    outputFormat: OutputFormat.PARQUET,\n    serializationLibrary: SerializationLibrary.PARQUET,\n    classificationString: ClassificationString.PARQUET,\n  });\n\n  /**\n   * DataFormat for TSV (Tab-Separated Values)\n   *\n   * @see https://docs.aws.amazon.com/athena/latest/ug/lazy-simple-serde.html\n   */\n  public static readonly TSV = new DataFormat({\n    inputFormat: InputFormat.TEXT,\n    outputFormat: OutputFormat.HIVE_IGNORE_KEY_TEXT,\n    serializationLibrary: SerializationLibrary.LAZY_SIMPLE,\n  });\n\n  /**\n   * `InputFormat` for this data format.\n   */\n  public readonly inputFormat: InputFormat;\n\n  /**\n   * `OutputFormat` for this data format.\n   */\n  public readonly outputFormat: OutputFormat;\n\n  /**\n   * Serialization library for this data format.\n   */\n  public readonly serializationLibrary: SerializationLibrary;\n\n  /**\n   * Classification string given to tables with this data format.\n   */\n  public readonly classificationString?: ClassificationString;\n\n  public constructor(props: DataFormatProps) {\n    this.inputFormat = props.inputFormat;\n    this.outputFormat = props.outputFormat;\n    this.serializationLibrary = props.serializationLibrary;\n    this.classificationString = props.classificationString;\n  }\n}\n"]}