2021-02-17 07:20:19 +03:00
package settings
import (
"fmt"
2021-06-16 14:44:15 +03:00
"github.com/hasura/graphql-engine/cli/v2/internal/hasura"
2021-02-17 07:20:19 +03:00
)
type StateStoreHdbTable struct {
2021-03-08 14:59:35 +03:00
client hasura . PGSourceOps
2021-05-28 09:04:36 +03:00
sourceName string
2021-02-17 07:20:19 +03:00
schema , table string
}
2021-05-28 09:04:36 +03:00
func NewStateStoreHdbTable ( client hasura . PGSourceOps , sourceName , schema , table string ) * StateStoreHdbTable {
return & StateStoreHdbTable { client , sourceName , schema , table }
2021-02-17 07:20:19 +03:00
}
func ( s * StateStoreHdbTable ) GetSetting ( name string ) ( value string , err error ) {
2021-03-08 14:59:35 +03:00
query := hasura . PGRunSQLInput {
2021-05-28 09:04:36 +03:00
Source : s . sourceName ,
SQL : ` SELECT value from ` + fmt . Sprintf ( "%s.%s" , s . schema , s . table ) + ` where setting=' ` + name + ` ' ` ,
2021-02-17 07:20:19 +03:00
}
2021-03-08 14:59:35 +03:00
resp , err := s . client . PGRunSQL ( query )
2021-02-17 07:20:19 +03:00
if err != nil {
return value , err
}
if resp . ResultType != hasura . TuplesOK {
return value , fmt . Errorf ( "invalid result Type %s" , resp . ResultType )
}
if len ( resp . Result ) < 2 {
for _ , setting := range Settings {
if setting . GetName ( ) == name {
return setting . GetDefaultValue ( ) , nil
}
}
return value , fmt . Errorf ( "invalid setting name: %s" , name )
}
return resp . Result [ 1 ] [ 0 ] , nil
}
func ( s * StateStoreHdbTable ) GetAllSettings ( ) ( map [ string ] string , error ) {
2021-03-08 14:59:35 +03:00
query := hasura . PGRunSQLInput {
2021-05-28 09:04:36 +03:00
Source : s . sourceName ,
SQL : ` SELECT setting, value from ` + fmt . Sprintf ( "%s.%s" , s . schema , s . table ) + ` ; ` ,
2021-02-17 07:20:19 +03:00
}
2021-03-08 14:59:35 +03:00
resp , err := s . client . PGRunSQL ( query )
2021-02-17 07:20:19 +03:00
if err != nil {
return nil , err
}
if resp . ResultType != hasura . TuplesOK {
return nil , fmt . Errorf ( "invalid result Type %s" , resp . ResultType )
}
var settings = map [ string ] string { }
for idx , row := range resp . Result {
if idx == 0 {
continue
}
if len ( row ) == 2 {
settings [ row [ 0 ] ] = row [ 1 ]
}
}
return settings , nil
}
func ( s * StateStoreHdbTable ) UpdateSetting ( name string , value string ) error {
2021-03-08 14:59:35 +03:00
query := hasura . PGRunSQLInput {
2021-05-28 09:04:36 +03:00
Source : s . sourceName ,
SQL : ` INSERT INTO ` + fmt . Sprintf ( "%s.%s" , s . schema , s . table ) + ` (setting, value) VALUES (' ` + name + ` ', ' ` + value + ` ') ON CONFLICT (setting) DO UPDATE SET value=' ` + value + ` ' ` ,
2021-02-17 07:20:19 +03:00
}
2021-03-08 14:59:35 +03:00
resp , err := s . client . PGRunSQL ( query )
2021-02-17 07:20:19 +03:00
if err != nil {
return err
}
if resp . ResultType != hasura . CommandOK {
return fmt . Errorf ( "cannot set setting %s to %s" , name , value )
}
return nil
}
func ( s * StateStoreHdbTable ) PrepareSettingsDriver ( ) error {
// check if migration table exists
2021-03-08 14:59:35 +03:00
query := hasura . PGRunSQLInput {
2021-05-28 09:04:36 +03:00
Source : s . sourceName ,
SQL : ` SELECT COUNT(1) FROM information_schema.tables WHERE table_name = ' ` + s . table + ` ' AND table_schema = ' ` + s . schema + ` ' LIMIT 1 ` ,
2021-02-17 07:20:19 +03:00
}
2021-03-08 14:59:35 +03:00
resp , err := s . client . PGRunSQL ( query )
2021-02-17 07:20:19 +03:00
if err != nil {
return err
}
if resp . ResultType != hasura . TuplesOK {
return fmt . Errorf ( "invalid result Type %s" , resp . ResultType )
}
if resp . Result [ 1 ] [ 0 ] != "0" {
return nil
}
// Now Create the table
2021-03-08 14:59:35 +03:00
query = hasura . PGRunSQLInput {
2021-05-28 09:04:36 +03:00
Source : s . sourceName ,
SQL : ` CREATE TABLE ` + fmt . Sprintf ( "%s.%s" , s . schema , s . table ) + ` (setting text not null primary key, value text not null) ` ,
2021-02-17 07:20:19 +03:00
}
2021-03-08 14:59:35 +03:00
resp , err = s . client . PGRunSQL ( query )
2021-02-17 07:20:19 +03:00
if err != nil {
return err
}
if resp . ResultType != hasura . CommandOK {
return fmt . Errorf ( "creating Version table failed %s" , resp . ResultType )
}
return s . setDefaults ( )
}
func ( s * StateStoreHdbTable ) setDefaults ( ) error {
var sql string
for _ , setting := range Settings {
sql += ` INSERT INTO ` + fmt . Sprintf ( "%s.%s" , s . schema , s . table ) + ` (setting, value) VALUES (' ` + fmt . Sprintf ( "%s" , setting . GetName ( ) ) + ` ', ' ` + fmt . Sprintf ( "%s" , setting . GetDefaultValue ( ) ) + ` '); `
}
2021-03-08 14:59:35 +03:00
query := hasura . PGRunSQLInput {
2021-05-28 09:04:36 +03:00
Source : s . sourceName ,
SQL : sql ,
2021-02-17 07:20:19 +03:00
}
2021-03-08 14:59:35 +03:00
_ , err := s . client . PGRunSQL ( query )
2021-02-17 07:20:19 +03:00
if err != nil {
return err
}
return nil
}