@aws-cdk/aws-glue-alpha
Version:
The CDK Construct Library for AWS::Glue
192 lines • 17 kB
JavaScript
;
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.Schema = void 0;
const jsiiDeprecationWarnings = require("../.warnings.jsii.js");
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const aws_cdk_lib_1 = require("aws-cdk-lib");
/**
* @see https://docs.aws.amazon.com/athena/latest/ug/data-types.html
*/
class Schema {
/**
* Creates a decimal type.
*
* TODO: Bounds
*
* @param precision the total number of digits
* @param scale the number of digits in fractional part, the default is 0
*/
static decimal(precision, scale) {
return {
isPrimitive: true,
inputString: scale !== undefined ? `decimal(${precision},${scale})` : `decimal(${precision})`,
};
}
/**
* Fixed length character data, with a specified length between 1 and 255.
*
* @param length length between 1 and 255
*/
static char(length) {
if (length <= 0 || length > 255) {
throw new aws_cdk_lib_1.UnscopedValidationError(`char length must be (inclusively) between 1 and 255, but was ${length}`);
}
if (length % 1 !== 0) {
throw new aws_cdk_lib_1.UnscopedValidationError(`char length must be a positive integer, was ${length}`);
}
return {
isPrimitive: true,
inputString: `char(${length})`,
};
}
/**
* Variable length character data, with a specified length between 1 and 65535.
*
* @param length length between 1 and 65535.
*/
static varchar(length) {
if (length <= 0 || length > 65535) {
throw new aws_cdk_lib_1.UnscopedValidationError(`varchar length must be (inclusively) between 1 and 65535, but was ${length}`);
}
if (length % 1 !== 0) {
throw new aws_cdk_lib_1.UnscopedValidationError(`varchar length must be a positive integer, was ${length}`);
}
return {
isPrimitive: true,
inputString: `varchar(${length})`,
};
}
/**
* Creates an array of some other type.
*
* @param itemType type contained by the array.
*/
static array(itemType) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_glue_alpha_Type(itemType);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.array);
}
throw error;
}
return {
isPrimitive: false,
inputString: `array<${itemType.inputString}>`,
};
}
/**
* Creates a map of some primitive key type to some value type.
*
* @param keyType type of key, must be a primitive.
* @param valueType type fo the value indexed by the key.
*/
static map(keyType, valueType) {
try {
jsiiDeprecationWarnings._aws_cdk_aws_glue_alpha_Type(keyType);
jsiiDeprecationWarnings._aws_cdk_aws_glue_alpha_Type(valueType);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, this.map);
}
throw error;
}
if (!keyType.isPrimitive) {
throw new aws_cdk_lib_1.UnscopedValidationError(`the key type of a 'map' must be a primitive, but was ${keyType.inputString}`);
}
return {
isPrimitive: false,
inputString: `map<${keyType.inputString},${valueType.inputString}>`,
};
}
/**
* Creates a nested structure containing individually named and typed columns.
*
* @param columns the columns of the structure.
*/
static struct(columns) {
return {
isPrimitive: false,
inputString: `struct<${columns.map(column => {
if (column.comment === undefined) {
return `${column.name}:${column.type.inputString}`;
}
else {
return `${column.name}:${column.type.inputString} COMMENT '${column.comment}'`;
}
}).join(',')}>`,
};
}
}
exports.Schema = Schema;
_a = JSII_RTTI_SYMBOL_1;
Schema[_a] = { fqn: "@aws-cdk/aws-glue-alpha.Schema", version: "2.218.0-alpha.0" };
Schema.BOOLEAN = {
isPrimitive: true,
inputString: 'boolean',
};
Schema.BINARY = {
isPrimitive: true,
inputString: 'binary',
};
/**
* A 64-bit signed INTEGER in two’s complement format, with a minimum value of -2^63 and a maximum value of 2^63-1.
*/
Schema.BIG_INT = {
isPrimitive: true,
inputString: 'bigint',
};
Schema.DOUBLE = {
isPrimitive: true,
inputString: 'double',
};
Schema.FLOAT = {
isPrimitive: true,
inputString: 'float',
};
/**
* A 32-bit signed INTEGER in two’s complement format, with a minimum value of -2^31 and a maximum value of 2^31-1.
*/
Schema.INTEGER = {
isPrimitive: true,
inputString: 'int',
};
/**
* A 16-bit signed INTEGER in two’s complement format, with a minimum value of -2^15 and a maximum value of 2^15-1.
*/
Schema.SMALL_INT = {
isPrimitive: true,
inputString: 'smallint',
};
/**
* A 8-bit signed INTEGER in two’s complement format, with a minimum value of -2^7 and a maximum value of 2^7-1
*/
Schema.TINY_INT = {
isPrimitive: true,
inputString: 'tinyint',
};
/**
* Date type.
*/
Schema.DATE = {
isPrimitive: true,
inputString: 'date',
};
/**
* Timestamp type (date and time).
*/
Schema.TIMESTAMP = {
isPrimitive: true,
inputString: 'timestamp',
};
/**
* Arbitrary-length string type.
*/
Schema.STRING = {
isPrimitive: true,
inputString: 'string',
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"schema.js","sourceRoot":"","sources":["schema.ts"],"names":[],"mappings":";;;;;;AAAA,6CAAsD;AAuCtD;;GAEG;AACH,MAAa,MAAM;IA6EjB;;;;;;;OAOG;IACI,MAAM,CAAC,OAAO,CAAC,SAAiB,EAAE,KAAc;QACrD,OAAO;YACL,WAAW,EAAE,IAAI;YACjB,WAAW,EAAE,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,WAAW,SAAS,IAAI,KAAK,GAAG,CAAC,CAAC,CAAC,WAAW,SAAS,GAAG;SAC9F,CAAC;KACH;IAED;;;;OAIG;IACI,MAAM,CAAC,IAAI,CAAC,MAAc;QAC/B,IAAI,MAAM,IAAI,CAAC,IAAI,MAAM,GAAG,GAAG,EAAE,CAAC;YAChC,MAAM,IAAI,qCAAuB,CAAC,gEAAgE,MAAM,EAAE,CAAC,CAAC;QAC9G,CAAC;QACD,IAAI,MAAM,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;YACrB,MAAM,IAAI,qCAAuB,CAAC,+CAA+C,MAAM,EAAE,CAAC,CAAC;QAC7F,CAAC;QACD,OAAO;YACL,WAAW,EAAE,IAAI;YACjB,WAAW,EAAE,QAAQ,MAAM,GAAG;SAC/B,CAAC;KACH;IAED;;;;OAIG;IACI,MAAM,CAAC,OAAO,CAAC,MAAc;QAClC,IAAI,MAAM,IAAI,CAAC,IAAI,MAAM,GAAG,KAAK,EAAE,CAAC;YAClC,MAAM,IAAI,qCAAuB,CAAC,qEAAqE,MAAM,EAAE,CAAC,CAAC;QACnH,CAAC;QACD,IAAI,MAAM,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;YACrB,MAAM,IAAI,qCAAuB,CAAC,kDAAkD,MAAM,EAAE,CAAC,CAAC;QAChG,CAAC;QACD,OAAO;YACL,WAAW,EAAE,IAAI;YACjB,WAAW,EAAE,WAAW,MAAM,GAAG;SAClC,CAAC;KACH;IAED;;;;OAIG;IACI,MAAM,CAAC,KAAK,CAAC,QAAc;;;;;;;;;;QAChC,OAAO;YACL,WAAW,EAAE,KAAK;YAClB,WAAW,EAAE,SAAS,QAAQ,CAAC,WAAW,GAAG;SAC9C,CAAC;KACH;IAED;;;;;OAKG;IACI,MAAM,CAAC,GAAG,CAAC,OAAa,EAAE,SAAe;;;;;;;;;;;QAC9C,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;YACzB,MAAM,IAAI,qCAAuB,CAAC,wDAAwD,OAAO,CAAC,WAAW,EAAE,CAAC,CAAC;QACnH,CAAC;QACD,OAAO;YACL,WAAW,EAAE,KAAK;YAClB,WAAW,EAAE,OAAO,OAAO,CAAC,WAAW,IAAI,SAAS,CAAC,WAAW,GAAG;SACpE,CAAC;KACH;IAED;;;;OAIG;IACI,MAAM,CAAC,MAAM,CAAC,OAAiB;QACpC,OAAO;YACL,WAAW,EAAE,KAAK;YAClB,WAAW,EAAE,UAAU,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE;gBAC1C,IAAI,MAAM,CAAC,OAAO,KAAK,SAAS,EAAE,CAAC;oBACjC,OAAO,GAAG,MAAM,CAAC,IAAI,IAAI,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;gBACrD,CAAC;qBAAM,CAAC;oBACN,OAAO,GAAG,MAAM,CAAC,IAAI,IAAI,MAAM,CAAC,IAAI,CAAC,WAAW,aAAa,MAAM,CAAC,OAAO,GAAG,CAAC;gBACjF,CAAC;YACH,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG;SAChB,CAAC;KACH;;AA5KH,wBA6KC;;;AA5KwB,cAAO,GAAS;IACrC,WAAW,EAAE,IAAI;IACjB,WAAW,EAAE,SAAS;CACvB,CAAC;AAEqB,aAAM,GAAS;IACpC,WAAW,EAAE,IAAI;IACjB,WAAW,EAAE,QAAQ;CACtB,CAAC;AAEF;;GAEG;AACoB,cAAO,GAAS;IACrC,WAAW,EAAE,IAAI;IACjB,WAAW,EAAE,QAAQ;CACtB,CAAC;AAEqB,aAAM,GAAS;IACpC,WAAW,EAAE,IAAI;IACjB,WAAW,EAAE,QAAQ;CACtB,CAAC;AAEqB,YAAK,GAAS;IACnC,WAAW,EAAE,IAAI;IACjB,WAAW,EAAE,OAAO;CACrB,CAAC;AAEF;;GAEG;AACoB,cAAO,GAAS;IACrC,WAAW,EAAE,IAAI;IACjB,WAAW,EAAE,KAAK;CACnB,CAAC;AAEF;;GAEG;AACoB,gBAAS,GAAS;IACvC,WAAW,EAAE,IAAI;IACjB,WAAW,EAAE,UAAU;CACxB,CAAC;AAEF;;GAEG;AACoB,eAAQ,GAAS;IACtC,WAAW,EAAE,IAAI;IACjB,WAAW,EAAE,SAAS;CACvB,CAAC;AAEF;;GAEG;AACoB,WAAI,GAAS;IAClC,WAAW,EAAE,IAAI;IACjB,WAAW,EAAE,MAAM;CACpB,CAAC;AAEF;;GAEG;AACoB,gBAAS,GAAS;IACvC,WAAW,EAAE,IAAI;IACjB,WAAW,EAAE,WAAW;CACzB,CAAC;AAEF;;GAEG;AACoB,aAAM,GAAS;IACpC,WAAW,EAAE,IAAI;IACjB,WAAW,EAAE,QAAQ;CACtB,CAAC","sourcesContent":["import { UnscopedValidationError } from 'aws-cdk-lib';\n\n/**\n * A column of a table.\n */\nexport interface Column {\n  /**\n   * Name of the column.\n   */\n  readonly name: string;\n\n  /**\n   * Type of the column.\n   */\n  readonly type: Type;\n\n  /**\n   * Coment describing the column.\n   *\n   * @default none\n   */\n  readonly comment?: string;\n}\n\n/**\n * Represents a type of a column in a table schema.\n */\nexport interface Type {\n  /**\n   * Indicates whether this type is a primitive data type.\n   */\n  readonly isPrimitive: boolean;\n\n  /**\n   * Glue InputString for this type.\n   */\n  readonly inputString: string;\n}\n\n/**\n * @see https://docs.aws.amazon.com/athena/latest/ug/data-types.html\n */\nexport class Schema {\n  public static readonly BOOLEAN: Type = {\n    isPrimitive: true,\n    inputString: 'boolean',\n  };\n\n  public static readonly BINARY: Type = {\n    isPrimitive: true,\n    inputString: 'binary',\n  };\n\n  /**\n   * A 64-bit signed INTEGER in two’s complement format, with a minimum value of -2^63 and a maximum value of 2^63-1.\n   */\n  public static readonly BIG_INT: Type = {\n    isPrimitive: true,\n    inputString: 'bigint',\n  };\n\n  public static readonly DOUBLE: Type = {\n    isPrimitive: true,\n    inputString: 'double',\n  };\n\n  public static readonly FLOAT: Type = {\n    isPrimitive: true,\n    inputString: 'float',\n  };\n\n  /**\n   * A 32-bit signed INTEGER in two’s complement format, with a minimum value of -2^31 and a maximum value of 2^31-1.\n   */\n  public static readonly INTEGER: Type = {\n    isPrimitive: true,\n    inputString: 'int',\n  };\n\n  /**\n   * A 16-bit signed INTEGER in two’s complement format, with a minimum value of -2^15 and a maximum value of 2^15-1.\n   */\n  public static readonly SMALL_INT: Type = {\n    isPrimitive: true,\n    inputString: 'smallint',\n  };\n\n  /**\n   * A 8-bit signed INTEGER in two’s complement format, with a minimum value of -2^7 and a maximum value of 2^7-1\n   */\n  public static readonly TINY_INT: Type = {\n    isPrimitive: true,\n    inputString: 'tinyint',\n  };\n\n  /**\n   * Date type.\n   */\n  public static readonly DATE: Type = {\n    isPrimitive: true,\n    inputString: 'date',\n  };\n\n  /**\n   * Timestamp type (date and time).\n   */\n  public static readonly TIMESTAMP: Type = {\n    isPrimitive: true,\n    inputString: 'timestamp',\n  };\n\n  /**\n   * Arbitrary-length string type.\n   */\n  public static readonly STRING: Type = {\n    isPrimitive: true,\n    inputString: 'string',\n  };\n\n  /**\n   * Creates a decimal type.\n   *\n   * TODO: Bounds\n   *\n   * @param precision the total number of digits\n   * @param scale the number of digits in fractional part, the default is 0\n   */\n  public static decimal(precision: number, scale?: number): Type {\n    return {\n      isPrimitive: true,\n      inputString: scale !== undefined ? `decimal(${precision},${scale})` : `decimal(${precision})`,\n    };\n  }\n\n  /**\n   * Fixed length character data, with a specified length between 1 and 255.\n   *\n   * @param length length between 1 and 255\n   */\n  public static char(length: number): Type {\n    if (length <= 0 || length > 255) {\n      throw new UnscopedValidationError(`char length must be (inclusively) between 1 and 255, but was ${length}`);\n    }\n    if (length % 1 !== 0) {\n      throw new UnscopedValidationError(`char length must be a positive integer, was ${length}`);\n    }\n    return {\n      isPrimitive: true,\n      inputString: `char(${length})`,\n    };\n  }\n\n  /**\n   * Variable length character data, with a specified length between 1 and 65535.\n   *\n   * @param length length between 1 and 65535.\n   */\n  public static varchar(length: number): Type {\n    if (length <= 0 || length > 65535) {\n      throw new UnscopedValidationError(`varchar length must be (inclusively) between 1 and 65535, but was ${length}`);\n    }\n    if (length % 1 !== 0) {\n      throw new UnscopedValidationError(`varchar length must be a positive integer, was ${length}`);\n    }\n    return {\n      isPrimitive: true,\n      inputString: `varchar(${length})`,\n    };\n  }\n\n  /**\n   * Creates an array of some other type.\n   *\n   * @param itemType type contained by the array.\n   */\n  public static array(itemType: Type): Type {\n    return {\n      isPrimitive: false,\n      inputString: `array<${itemType.inputString}>`,\n    };\n  }\n\n  /**\n   * Creates a map of some primitive key type to some value type.\n   *\n   * @param keyType type of key, must be a primitive.\n   * @param valueType type fo the value indexed by the key.\n   */\n  public static map(keyType: Type, valueType: Type): Type {\n    if (!keyType.isPrimitive) {\n      throw new UnscopedValidationError(`the key type of a 'map' must be a primitive, but was ${keyType.inputString}`);\n    }\n    return {\n      isPrimitive: false,\n      inputString: `map<${keyType.inputString},${valueType.inputString}>`,\n    };\n  }\n\n  /**\n   * Creates a nested structure containing individually named and typed columns.\n   *\n   * @param columns the columns of the structure.\n   */\n  public static struct(columns: Column[]): Type {\n    return {\n      isPrimitive: false,\n      inputString: `struct<${columns.map(column => {\n        if (column.comment === undefined) {\n          return `${column.name}:${column.type.inputString}`;\n        } else {\n          return `${column.name}:${column.type.inputString} COMMENT '${column.comment}'`;\n        }\n      }).join(',')}>`,\n    };\n  }\n}\n"]}