config

package
v1.45.2 Latest Latest
Warning

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

Go to latest
Published: Nov 26, 2020 License: MIT Imports: 16 Imported by: 4

Documentation

Index

Constants

View Source
const DefaultDocPath = "dbdoc"
View Source
const DefaultERFormat = "svg"

DefaultERFormat is the default ER diagram format

Variables

View Source
var DefaultConfigFilePaths = []string{".tbls.yml", "tbls.yml"}
View Source
var DefaultDistance = 1

DefaultDistance is the default distance between tables that display relations in the ER

Functions

func SelectNamingStrategy added in v1.45.0

func SelectNamingStrategy(name string) bool

SelectNamingStrategy sets the naming strategy

func ToParentColumnName added in v1.45.0

func ToParentColumnName(name string) string

ToParentColumnName convert string to column name

func ToParentTableName added in v1.45.0

func ToParentTableName(name string) string

ToParentTableName convert string to table name

Types

type AdditionalComment

type AdditionalComment struct {
	Table              string            `yaml:"table"`
	TableComment       string            `yaml:"tableComment,omitempty"`
	ColumnComments     map[string]string `yaml:"columnComments,omitempty"`
	IndexComments      map[string]string `yaml:"indexComments,omitempty"`
	ConstraintComments map[string]string `yaml:"constraintComments,omitempty"`
	TriggerComments    map[string]string `yaml:"triggerComments,omitempty"`
	Labels             []string          `yaml:"labels,omitempty"`
}

AdditionalComment is the struct for table relation from yaml

type AdditionalRelation

type AdditionalRelation struct {
	Table         string   `yaml:"table"`
	Columns       []string `yaml:"columns"`
	ParentTable   string   `yaml:"parentTable"`
	ParentColumns []string `yaml:"parentColumns"`
	Def           string   `yaml:"def,omitempty"`
}

AdditionalRelation is the struct for table relation from yaml

type ColumnCount added in v1.8.0

type ColumnCount struct {
	Enabled bool     `yaml:"enabled"`
	Max     int      `yaml:"max"`
	Exclude []string `yaml:"exclude"`
}

ColumnCount checks table column count

func (ColumnCount) Check added in v1.8.0

func (r ColumnCount) Check(s *schema.Schema, exclude []string) []RuleWarn

Check table column count

func (ColumnCount) IsEnabled added in v1.8.0

func (r ColumnCount) IsEnabled() bool

IsEnabled return Rule is enabled or not

type Config

type Config struct {
	Name                   string                 `yaml:"name"`
	Desc                   string                 `yaml:"desc,omitempty"`
	Labels                 []string               `yaml:"labels,omitempty"`
	DSN                    DSN                    `yaml:"dsn"`
	DocPath                string                 `yaml:"docPath"`
	Format                 Format                 `yaml:"format,omitempty"`
	ER                     ER                     `yaml:"er,omitempty"`
	Include                []string               `yaml:"include,omitempty"`
	Exclude                []string               `yaml:"exclude,omitempty"`
	Lint                   Lint                   `yaml:"lint,omitempty"`
	LintExclude            []string               `yaml:"lintExclude,omitempty"`
	Relations              []AdditionalRelation   `yaml:"relations,omitempty"`
	Comments               []AdditionalComment    `yaml:"comments,omitempty"`
	Dict                   dict.Dict              `yaml:"dict,omitempty"`
	Templates              Templates              `yaml:"templates,omitempty"`
	DetectVirtualRelations DetectVirtualRelations `yaml:"detectVirtualRelations,omitempty"`
	MergedDict             dict.Dict              `yaml:"-"`
	Path                   string                 `yaml:"-"`

	BaseUrl string `yaml:"baseUrl,omitempty"`
	// contains filtered or unexported fields
}

Config is tbls config

func New added in v1.29.2

func New() (*Config, error)

New return Config

func (*Config) FilterTables added in v1.28.0

func (c *Config) FilterTables(s *schema.Schema) error

FilterTables filter tables from schema.Schema

func (*Config) Load added in v1.9.0

func (c *Config) Load(configPath string, options ...Option) error

Load load config with all method

func (*Config) LoadConfig added in v1.37.4

func (c *Config) LoadConfig(in []byte) error

LoadConfig load config from []byte

func (*Config) LoadConfigFile

func (c *Config) LoadConfigFile(path string) error

LoadConfigFile load config file

func (*Config) LoadEnviron added in v1.9.0

func (c *Config) LoadEnviron() error

LoadEnviron load environment variables

func (*Config) LoadOption added in v1.40.0

func (c *Config) LoadOption(options ...Option) error

LoadOptions load options

func (*Config) MaskedDSN added in v1.10.0

func (c *Config) MaskedDSN() (string, error)

MaskedDSN return DSN mask password

func (*Config) MergeAdditionalData added in v1.8.0

func (c *Config) MergeAdditionalData(s *schema.Schema) error

MergeAdditionalData merge relations: comments: to schema.Schema

func (*Config) ModifySchema added in v1.12.0

func (c *Config) ModifySchema(s *schema.Schema) error

ModifySchema modify schema.Schema by config

type DSN added in v1.10.0

type DSN struct {
	URL     string            `yaml:"url"`
	Headers map[string]string `yaml:"headers,omitempty"`
}

func (DSN) MarshalYAML added in v1.29.3

func (d DSN) MarshalYAML() ([]byte, error)

func (*DSN) UnmarshalYAML added in v1.29.3

func (d *DSN) UnmarshalYAML(data []byte) error

type DetectVirtualRelations added in v1.45.0

type DetectVirtualRelations struct {
	Enabled  bool   `yaml:"enabled,omitempty"`
	Strategy string `yaml:"strategy,omitempty"`
}

type Dot added in v1.44.0

type Dot struct {
	Schema string `yaml:"schema,omitempty"`
	Table  string `yaml:"table,omitempty"`
}

Dot holds the paths to the dot template files. If populated the files are used to override the default ones.

type DuplicateRelations added in v1.19.0

type DuplicateRelations struct {
	Enabled bool `yaml:"enabled"`
}

DuplicateRelations checks duplicate table relations

func (DuplicateRelations) Check added in v1.19.0

func (r DuplicateRelations) Check(s *schema.Schema, exclude []string) []RuleWarn

Check duplicate table relations

func (DuplicateRelations) IsEnabled added in v1.19.0

func (r DuplicateRelations) IsEnabled() bool

IsEnabled return Rule is enabled or not

type ER added in v1.10.0

type ER struct {
	Skip     bool   `yaml:"skip,omitempty"`
	Format   string `yaml:"format,omitempty"`
	Comment  bool   `yaml:"comment,omitempty"`
	Distance *int   `yaml:"distance,omitempty"`
	Font     string `yaml:"font,omitempty"`
}

ER is er setting

type Format added in v1.10.0

type Format struct {
	Adjust bool `yaml:"adjust,omitempty"`
	Sort   bool `yaml:"sort,omitempty"`
}

Format is document format setting

type LabelStyleBigQuery added in v1.32.0

type LabelStyleBigQuery struct {
	Enabled bool     `yaml:"enabled"`
	Exclude []string `yaml:"exclude"`
}

LabelStyleBigQuery checks if labels are in BigQuery style ( https://cloud.google.com/resource-manager/docs/creating-managing-labels#requirements )

func (LabelStyleBigQuery) Check added in v1.32.0

func (r LabelStyleBigQuery) Check(s *schema.Schema, exclude []string) []RuleWarn

Check if labels are in BigQuery style

func (LabelStyleBigQuery) IsEnabled added in v1.32.0

func (r LabelStyleBigQuery) IsEnabled() bool

IsEnabled return Rule is enabled or not

type Lint added in v1.8.0

type Lint struct {
	RequireTableComment      RequireTableComment      `yaml:"requireTableComment"`
	RequireColumnComment     RequireColumnComment     `yaml:"requireColumnComment"`
	RequireIndexComment      RequireIndexComment      `yaml:"requireIndexComment"`
	RequireConstraintComment RequireConstraintComment `yaml:"requireConstraintComment"`
	RequireTriggerComment    RequireTriggerComment    `yaml:"requireTriggerComment"`
	UnrelatedTable           UnrelatedTable           `yaml:"unrelatedTable"`
	ColumnCount              ColumnCount              `yaml:"columnCount"`
	RequireColumns           RequireColumns           `yaml:"requireColumns"`
	DuplicateRelations       DuplicateRelations       `yaml:"duplicateRelations"`
	RequireForeignKeyIndex   RequireForeignKeyIndex   `yaml:"requireForeignKeyIndex"`
	LabelStyleBigQuery       LabelStyleBigQuery       `yaml:"labelStyleBigQuery"`
}

Lint is the struct for lint config

type MD added in v1.44.0

type MD struct {
	Index string `yaml:"index,omitempty"`
	Table string `yaml:"table,omitempty"`
}

MD holds the paths to the markdown template files. If populated the files are used to override the default ones.

type Namer added in v1.45.0

type Namer func(string) string

Namer is a function type which is given a string and return a string

type NamingStrategy added in v1.45.0

type NamingStrategy struct {
	ParentTable  Namer
	ParentColumn Namer
}

NamingStrategy represents naming strategies

func (*NamingStrategy) ParentColumnName added in v1.45.0

func (ns *NamingStrategy) ParentColumnName(name string) string

ParentColumnName alters the given name by Column

func (*NamingStrategy) ParentTableName added in v1.45.0

func (ns *NamingStrategy) ParentTableName(name string) string

ParentTableName alters the given name by Table

type Option added in v1.10.0

type Option func(*Config) error

Option function change Config

func Adjust added in v1.10.0

func Adjust(adjust bool) Option

Adjust return Option set Config.Format.Adjust

func BaseUrl added in v1.45.0

func BaseUrl(baseUrl string) Option

BaseUrl return Option set Config.BaseUrl

func DSNURL added in v1.29.3

func DSNURL(dsn string) Option

DSNURL return Option set Config.DSN.URL

func Distance added in v1.27.0

func Distance(distance int) Option

Distance return Option set Config.ER.Distance

func DocPath added in v1.10.0

func DocPath(docPath string) Option

DocPath return Option set Config.DocPath

func ERFormat added in v1.10.0

func ERFormat(erFormat string) Option

ERFormat return Option set Config.ER.Format

func ERSkip added in v1.10.0

func ERSkip(skip bool) Option

ERSkip return Option set Config.ER.Skip

func Sort added in v1.10.0

func Sort(sort bool) Option

Sort return Option set Config.Format.Sort

type PUML added in v1.44.0

type PUML struct {
	Schema string `yaml:"schema,omitempty"`
	Table  string `yaml:"table,omitempty"`
}

PUML holds the paths to the PlantUML template files. If populated the files are used to override the default ones.

type RequireColumnComment added in v1.8.0

type RequireColumnComment struct {
	Enabled       bool     `yaml:"enabled"`
	AllOrNothing  bool     `yaml:"allOrNothing"`
	Exclude       []string `yaml:"exclude"`
	ExcludeTables []string `yaml:"excludeTables"`
}

RequireColumnComment checks column comment

func (RequireColumnComment) Check added in v1.8.0

func (r RequireColumnComment) Check(s *schema.Schema, exclude []string) []RuleWarn

Check column comment

func (RequireColumnComment) IsEnabled added in v1.8.0

func (r RequireColumnComment) IsEnabled() bool

IsEnabled return Rule is enabled or not

type RequireColumns added in v1.12.0

type RequireColumns struct {
	Enabled bool                   `yaml:"enabled"`
	Columns []RequireColumnsColumn `yaml:"columns"`
}

RequireColumns checks if the table has specified columns

func (RequireColumns) Check added in v1.12.0

func (r RequireColumns) Check(s *schema.Schema, exclude []string) []RuleWarn

Check the existence of a table columns

func (RequireColumns) IsEnabled added in v1.12.0

func (r RequireColumns) IsEnabled() bool

IsEnabled return Rule is enabled or not

type RequireColumnsColumn added in v1.12.0

type RequireColumnsColumn struct {
	Name    string   `yaml:"name"`
	Exclude []string `yaml:"exclude"`
}

RequireColumnsColumn is required column

type RequireConstraintComment added in v1.37.0

type RequireConstraintComment struct {
	Enabled       bool     `yaml:"enabled"`
	AllOrNothing  bool     `yaml:"allOrNothing"`
	Exclude       []string `yaml:"exclude"`
	ExcludeTables []string `yaml:"excludeTables"`
}

RequireConstraintComment checks constraint comment

func (RequireConstraintComment) Check added in v1.37.0

func (r RequireConstraintComment) Check(s *schema.Schema, exclude []string) []RuleWarn

Check constraint comment

func (RequireConstraintComment) IsEnabled added in v1.37.0

func (r RequireConstraintComment) IsEnabled() bool

IsEnabled return Rule is enabled or not

type RequireForeignKeyIndex added in v1.20.0

type RequireForeignKeyIndex struct {
	Enabled bool     `yaml:"enabled"`
	Exclude []string `yaml:"exclude"`
}

RequireForeignKeyIndex checks if the foreign key columns have an index

func (RequireForeignKeyIndex) Check added in v1.20.0

func (r RequireForeignKeyIndex) Check(s *schema.Schema, exclude []string) []RuleWarn

Check if the foreign key columns have an index

func (RequireForeignKeyIndex) IsEnabled added in v1.20.0

func (r RequireForeignKeyIndex) IsEnabled() bool

IsEnabled return Rule is enabled or not

type RequireIndexComment added in v1.37.0

type RequireIndexComment struct {
	Enabled       bool     `yaml:"enabled"`
	AllOrNothing  bool     `yaml:"allOrNothing"`
	Exclude       []string `yaml:"exclude"`
	ExcludeTables []string `yaml:"excludeTables"`
}

RequireIndexComment checks index comment

func (RequireIndexComment) Check added in v1.37.0

func (r RequireIndexComment) Check(s *schema.Schema, exclude []string) []RuleWarn

Check index comment

func (RequireIndexComment) IsEnabled added in v1.37.0

func (r RequireIndexComment) IsEnabled() bool

IsEnabled return Rule is enabled or not

type RequireTableComment added in v1.8.0

type RequireTableComment struct {
	Enabled      bool     `yaml:"enabled"`
	AllOrNothing bool     `yaml:"allOrNothing"`
	Exclude      []string `yaml:"exclude"`
}

RequireTableComment checks table comment

func (RequireTableComment) Check added in v1.8.0

func (r RequireTableComment) Check(s *schema.Schema, exclude []string) []RuleWarn

Check table comment

func (RequireTableComment) IsEnabled added in v1.8.0

func (r RequireTableComment) IsEnabled() bool

IsEnabled return Rule is enabled or not

type RequireTriggerComment added in v1.37.0

type RequireTriggerComment struct {
	Enabled       bool     `yaml:"enabled"`
	AllOrNothing  bool     `yaml:"allOrNothing"`
	Exclude       []string `yaml:"exclude"`
	ExcludeTables []string `yaml:"excludeTables"`
}

RequireTriggerComment checks trigger comment

func (RequireTriggerComment) Check added in v1.37.0

func (r RequireTriggerComment) Check(s *schema.Schema, exclude []string) []RuleWarn

Check trigger comment

func (RequireTriggerComment) IsEnabled added in v1.37.0

func (r RequireTriggerComment) IsEnabled() bool

IsEnabled return Rule is enabled or not

type Rule added in v1.8.0

type Rule interface {
	IsEnabled() bool
	Check(schema *schema.Schema, exclude []string) []RuleWarn
}

Rule is interfece of `tbls lint` cop

type RuleWarn added in v1.8.0

type RuleWarn struct {
	Target  string
	Message string
}

RuleWarn is struct of Rule error

type Templates added in v1.44.0

type Templates struct {
	MD   MD   `yaml:"md,omitempty"`
	Dot  Dot  `yaml:"dot,omitempty"`
	PUML PUML `yaml:"puml,omitempty"`
}

Templates holds the configurations to override the default templates used to render the schema and the docs.

type UnrelatedTable added in v1.8.2

type UnrelatedTable struct {
	Enabled      bool     `yaml:"enabled"`
	AllOrNothing bool     `yaml:"allOrNothing"`
	Exclude      []string `yaml:"exclude"`
}

UnrelatedTable checks isolated table

func (UnrelatedTable) Check added in v1.8.2

func (r UnrelatedTable) Check(s *schema.Schema, exclude []string) []RuleWarn

Check table relation

func (UnrelatedTable) IsEnabled added in v1.8.2

func (r UnrelatedTable) IsEnabled() bool

IsEnabled return Rule is enabled or not

Jump to

Keyboard shortcuts

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