diff --git a/config/postgres.go b/config/postgres.go index f5fc2917..f752d7c0 100644 --- a/config/postgres.go +++ b/config/postgres.go @@ -43,6 +43,8 @@ type PostgreSQLTable struct { OptionalPrimaryKeyValStart string `yaml:"optionalPrimaryKeyValStart,omitempty"` OptionalPrimaryKeyValEnd string `yaml:"optionalPrimaryKeyValEnd,omitempty"` ExcludeColumns []string `yaml:"excludeColumns,omitempty"` + // IncludeColumns - List of columns that should be included in the change event record. + IncludeColumns []string `yaml:"includeColumns,omitempty"` } func (p *PostgreSQLTable) GetBatchSize() uint { @@ -99,6 +101,11 @@ func (p *PostgreSQL) Validate() error { if table.Schema == "" { return fmt.Errorf("schema must be passed in") } + + // You should not be able to filter and exclude columns at the same time + if len(table.ExcludeColumns) > 0 && len(table.IncludeColumns) > 0 { + return fmt.Errorf("cannot exclude and include columns at the same time") + } } return nil diff --git a/config/postgres_test.go b/config/postgres_test.go index 55eeacc5..e5c42fce 100644 --- a/config/postgres_test.go +++ b/config/postgres_test.go @@ -117,6 +117,26 @@ func TestPostgreSQL_Validate(t *testing.T) { assert.ErrorContains(t, p.Validate(), "schema must be passed in") } + { + // Filtering and excluding at the same time + p := &PostgreSQL{ + Host: "host", + Port: 1, + Username: "username", + Password: "password", + Database: "database", + Tables: []*PostgreSQLTable{ + { + Name: "name", + Schema: "schema", + ExcludeColumns: []string{"a"}, + IncludeColumns: []string{"b"}, + }, + }, + } + + assert.ErrorContains(t, p.Validate(), "cannot exclude and include columns at the same time") + } { // Valid p := &PostgreSQL{