UNPKG

avro-typescript

Version:

TypeScript code generator for Apache Avro types

102 lines (101 loc) 4.33 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.convertFieldDec = exports.convertType = exports.convertEnum = exports.convertRecord = exports.avroToTypeScript = exports.convertPrimitive = exports.isRecordType = exports.isOptional = exports.isMapType = exports.isLogicalType = exports.isEnumType = exports.isArrayType = void 0; var model_1 = require("./model"); Object.defineProperty(exports, "isArrayType", { enumerable: true, get: function () { return model_1.isArrayType; } }); Object.defineProperty(exports, "isEnumType", { enumerable: true, get: function () { return model_1.isEnumType; } }); Object.defineProperty(exports, "isLogicalType", { enumerable: true, get: function () { return model_1.isLogicalType; } }); Object.defineProperty(exports, "isMapType", { enumerable: true, get: function () { return model_1.isMapType; } }); Object.defineProperty(exports, "isOptional", { enumerable: true, get: function () { return model_1.isOptional; } }); Object.defineProperty(exports, "isRecordType", { enumerable: true, get: function () { return model_1.isRecordType; } }); var model_2 = require("./model"); /** Convert a primitive type from avro to TypeScript */ function convertPrimitive(avroType) { switch (avroType) { case "long": case "int": case "double": case "float": return "number"; case "bytes": return "Buffer"; case "null": return "null | undefined"; case "boolean": return "boolean"; default: return null; } } exports.convertPrimitive = convertPrimitive; /** Converts an Avro record type to a TypeScript file */ function avroToTypeScript(schema) { var output = []; if (model_2.isEnumType(schema)) convertEnum(schema, output); else if (model_2.isRecordType(schema)) convertRecord(schema, output); else throw "Unknown top level type " + schema["type"]; return output.join("\n"); } exports.avroToTypeScript = avroToTypeScript; /** Convert an Avro Record type. Return the name, but add the definition to the file */ function convertRecord(recordType, fileBuffer) { var buffer = "export interface " + recordType.name + " {\n"; for (var _i = 0, _a = recordType.fields; _i < _a.length; _i++) { var field = _a[_i]; buffer += convertFieldDec(field, fileBuffer) + "\n"; } buffer += "}\n"; fileBuffer.push(buffer); return recordType.name; } exports.convertRecord = convertRecord; /** Convert an Avro Enum type. Return the name, but add the definition to the file */ function convertEnum(enumType, fileBuffer) { var enumDef = "export enum " + enumType.name + " { " + enumType.symbols.join(", ") + " };\n"; fileBuffer.push(enumDef); return enumType.name; } exports.convertEnum = convertEnum; function convertType(type, buffer) { // if it's just a name, then use that if (typeof type === "string") { return convertPrimitive(type) || type; } else if (type instanceof Array) { // array means a Union. Use the names and call recursively return type.map(function (t) { return convertType(t, buffer); }).join(" | "); } else if (model_2.isRecordType(type)) { //} type)) { // record, use the name and add to the buffer return convertRecord(type, buffer); } else if (model_2.isArrayType(type)) { // array, call recursively for the array element type return convertType(type.items, buffer) + "[]"; } else if (model_2.isMapType(type)) { // Dictionary of types, string as key return "{ [index:string]:" + convertType(type.values, buffer) + " }"; } else if (model_2.isEnumType(type)) { // array, call recursively for the array element type return convertEnum(type, buffer); } else if (model_2.isLogicalType(type)) { return convertType(type.type, buffer); } else { console.error("Cannot work out type", type); return "UNKNOWN"; } } exports.convertType = convertType; function convertFieldDec(field, buffer) { // Union Type return "\t" + field.name + (model_2.isOptional(field.type) ? "?" : "") + ": " + convertType(field.type, buffer) + ";"; } exports.convertFieldDec = convertFieldDec;