2019-03-03 17:54:43 +01:00
|
|
|
package generator
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"database/sql"
|
|
|
|
|
_ "github.com/lib/pq"
|
2019-03-04 19:35:49 +01:00
|
|
|
"github.com/sub0Zero/go-sqlbuilder/generator/metadata"
|
|
|
|
|
"path"
|
2019-03-03 17:54:43 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
type DbConnectInfo struct {
|
|
|
|
|
host string
|
|
|
|
|
port int
|
|
|
|
|
user string
|
|
|
|
|
password string
|
|
|
|
|
dbname string
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func Generate(folderPath string, connectString string, databaseName, schemaName string) error {
|
2019-04-03 14:18:58 +02:00
|
|
|
|
2019-03-04 19:35:49 +01:00
|
|
|
err := cleanUpGeneratedFiles(path.Join(folderPath, databaseName, schemaName))
|
2019-03-03 17:54:43 +01:00
|
|
|
|
2019-03-04 19:35:49 +01:00
|
|
|
if err != nil {
|
|
|
|
|
return err
|
2019-03-03 17:54:43 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
db, err := sql.Open("postgres", connectString)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
defer db.Close()
|
|
|
|
|
|
|
|
|
|
err = db.Ping()
|
|
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
2019-03-04 19:35:49 +01:00
|
|
|
databaseInfo, err := metadata.GetDatabaseInfo(db, databaseName, schemaName)
|
2019-03-03 17:54:43 +01:00
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
2019-03-04 19:35:49 +01:00
|
|
|
err = generateSqlBuilderModel(databaseInfo, folderPath)
|
2019-03-03 17:54:43 +01:00
|
|
|
|
|
|
|
|
if err != nil {
|
2019-03-04 19:35:49 +01:00
|
|
|
return err
|
2019-03-03 17:54:43 +01:00
|
|
|
}
|
|
|
|
|
|
2019-03-04 19:35:49 +01:00
|
|
|
err = generateDataModel(databaseInfo, folderPath)
|
2019-03-03 17:54:43 +01:00
|
|
|
|
|
|
|
|
if err != nil {
|
2019-03-04 19:35:49 +01:00
|
|
|
return err
|
2019-03-03 17:54:43 +01:00
|
|
|
}
|
|
|
|
|
|
2019-04-03 19:21:46 +02:00
|
|
|
err = generateEnumTypes(databaseInfo, folderPath)
|
|
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
|
return err
|
|
|
|
|
}
|
|
|
|
|
|
2019-03-04 19:35:49 +01:00
|
|
|
return nil
|
2019-03-03 17:54:43 +01:00
|
|
|
}
|