gluecf

package
v1.0.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Mar 25, 2020 License: AGPL-3.0, Apache-2.0 Imports: 11 Imported by: 0

Documentation

Overview

Package gluecf generates CloudFormation from Go objects to create AWS GlueTableMetadata objects.

Index

Constants

View Source
const GlueTimestampType = "timestamp"

Glue tables typ for timestamps that we will re-map Go times

Variables

View Source
var (
	CatalogIDRef = cfngen.Ref{Ref: "AWS::AccountId"} // macro expand to accountId for CF

	// GlueMappings for custom Panther types.
	GlueMappings = []CustomMapping{
		{
			From: reflect.TypeOf(timestamp.RFC3339{}),
			To:   GlueTimestampType,
		},
		{
			From: reflect.TypeOf(timestamp.ANSICwithTZ{}),
			To:   GlueTimestampType,
		},
		{
			From: reflect.TypeOf(timestamp.UnixMillisecond{}),
			To:   GlueTimestampType,
		},
		{
			From: reflect.TypeOf(parsers.PantherAnyString{}),
			To:   "array<string>",
		},
		{
			From: reflect.TypeOf(jsoniter.RawMessage{}),
			To:   "string",
		},
		{
			From: reflect.TypeOf(*new(numerics.Integer)),
			To:   "bigint",
		},
	}

	// RuleMatchColumns are columns added by the rules engine
	RuleMatchColumns = []Column{
		{
			Name:    "p_rule_id",
			Type:    "string",
			Comment: "Rule id",
		},
		{
			Name:    "p_alert_id",
			Type:    "string",
			Comment: "Alert id",
		},
		{
			Name:    "p_alert_creation_time",
			Type:    "timestamp",
			Comment: "The time the alert was initially created (first match)",
		},
		{
			Name:    "p_alert_update_time",
			Type:    "timestamp",
			Comment: "The time the alert last updated (last match)",
		},
	}
)

Functions

func GenerateTables added in v0.3.0

func GenerateTables(tables []*awsglue.GlueTableMetadata) (cf []byte, err error)

Output CloudFormation for all 'tables'

Types

type Column

type Column struct {
	Name    string
	Type    string
	Comment string `json:",omitempty"`
}

func InferJSONColumns

func InferJSONColumns(obj interface{}, customMappings ...CustomMapping) (cols []Column)

Walk object, create columns using JSON Serde expected types, allow optional custom mappings

type CustomMapping

type CustomMapping struct {
	From reflect.Type // type to map (result of reflect.TypeOf() )
	To   string       // glue type to emit
}

type Database

type Database struct {
	Type       string
	DependsOn  []string `json:",omitempty"`
	Properties DatabaseProperties
}

func NewDatabase

func NewDatabase(catalogID interface{}, name, description string) (db *Database)

type DatabaseInput

type DatabaseInput struct {
	Name        interface{}
	Description string `json:",omitempty"`
}

Matches CF structure

type DatabaseProperties

type DatabaseProperties struct {
	CatalogID     interface{} `json:"CatalogId"` // required, string or Ref{}, need json tag to keep linter happy
	DatabaseInput DatabaseInput
}

type NewTableInput

type NewTableInput struct {
	CatalogID     interface{}
	DatabaseName  interface{}
	Name          interface{}
	Description   interface{}
	Location      interface{}
	Columns       []Column
	PartitionKeys []Column
}

inputs to table generation functions

type SerdeInfo

type SerdeInfo struct {
	SerializationLibrary string                 `json:",omitempty"`
	Parameters           map[string]interface{} `json:",omitempty"`
}

type StorageDescriptor

type StorageDescriptor struct {
	InputFormat            string
	OutputFormat           string
	Compressed             bool        `json:",omitempty"`
	Location               interface{} // required
	BucketColumns          []Column    `json:",omitempty"`
	SortColumns            []Column    `json:",omitempty"`
	StoredAsSubDirectories bool        `json:",omitempty"`
	SerdeInfo              SerdeInfo
	Columns                []Column
}

type Table

type Table struct {
	Type       string
	DependsOn  []string `json:",omitempty"`
	Properties TableProperties
}

func NewJSONLTable

func NewJSONLTable(input *NewTableInput) (db *Table)

func NewParquetTable

func NewParquetTable(input *NewTableInput) (db *Table)

type TableInput

type TableInput struct {
	TableType         string
	Name              interface{}
	Description       interface{} `json:",omitempty"`
	StorageDescriptor StorageDescriptor
	PartitionKeys     []Column `json:",omitempty"`
}

type TableProperties

type TableProperties struct {
	CatalogID    interface{} `json:"CatalogId"` // required,  string or Ref{}, need json tag to keep linter happy
	DatabaseName interface{}
	TableInput   TableInput
}

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL