mirror of
https://github.com/silicoflare/envy.git
synced 2026-05-26 19:57:59 +05:30
refactor: move db related functions to db.go
This commit is contained in:
@@ -1,6 +1,7 @@
|
||||
package utils
|
||||
|
||||
import (
|
||||
"errors"
|
||||
"path"
|
||||
|
||||
"gorm.io/driver/sqlite"
|
||||
@@ -40,3 +41,59 @@ func MigrateDb() {
|
||||
panic(err)
|
||||
}
|
||||
}
|
||||
|
||||
func GetProjects(name string) ([]Project, error) {
|
||||
InitDb()
|
||||
|
||||
var dbProjects []Project
|
||||
result := DB.Where("name = ?", name).Find(&dbProjects)
|
||||
|
||||
if result.Error != nil {
|
||||
return nil, errors.New("Some error occured: " + result.Error.Error())
|
||||
}
|
||||
return dbProjects, nil
|
||||
}
|
||||
|
||||
func GetProject(name string) (Project, error) {
|
||||
InitDb()
|
||||
|
||||
var dbProject Project
|
||||
result := DB.Where("name = ?", name).First(&dbProject)
|
||||
|
||||
if result.Error != nil {
|
||||
if errors.Is(result.Error, gorm.ErrRecordNotFound) {
|
||||
return Project{}, errors.New("Project with the name " + name + " not found in the database")
|
||||
} else {
|
||||
return Project{}, errors.New("Some error occured: " + result.Error.Error())
|
||||
}
|
||||
}
|
||||
return dbProject, nil
|
||||
}
|
||||
|
||||
func GetEnvironments(project uint) ([]Environment, error) {
|
||||
InitDb()
|
||||
|
||||
var dbEnvs []Environment
|
||||
result := DB.Where("project_id = ?", project).Find(&dbEnvs)
|
||||
|
||||
if result.Error != nil {
|
||||
return nil, errors.New("Some error occured: " + result.Error.Error())
|
||||
}
|
||||
return dbEnvs, nil
|
||||
}
|
||||
|
||||
func GetEnvironment(project uint, environment string) (Environment, error) {
|
||||
InitDb()
|
||||
|
||||
var dbEnv Environment
|
||||
result := DB.Where("project_id = ? AND name = ?", project, environment).First(&dbEnv)
|
||||
|
||||
if result.Error != nil {
|
||||
if errors.Is(result.Error, gorm.ErrRecordNotFound) {
|
||||
return Environment{}, errors.New("Environment with the name " + environment + " not found in the database")
|
||||
} else {
|
||||
return Environment{}, errors.New("Some error occured: " + result.Error.Error())
|
||||
}
|
||||
}
|
||||
return dbEnv, nil
|
||||
}
|
||||
|
||||
@@ -9,7 +9,6 @@ import (
|
||||
"strings"
|
||||
|
||||
"github.com/pelletier/go-toml"
|
||||
"gorm.io/gorm"
|
||||
)
|
||||
|
||||
func StopIfErr(err error) {
|
||||
@@ -71,50 +70,6 @@ func WriteEnvy(tree *toml.Tree) error {
|
||||
return nil
|
||||
}
|
||||
|
||||
func GetProject(name string) (Project, error) {
|
||||
InitDb()
|
||||
|
||||
var dbProject Project
|
||||
result := DB.Where("name = ?", name).First(&dbProject)
|
||||
|
||||
if result.Error != nil {
|
||||
if errors.Is(result.Error, gorm.ErrRecordNotFound) {
|
||||
return Project{}, errors.New("Project with the name " + name + " not found in the database")
|
||||
} else {
|
||||
return Project{}, errors.New("Some error occured: " + result.Error.Error())
|
||||
}
|
||||
}
|
||||
return dbProject, nil
|
||||
}
|
||||
|
||||
func GetEnvironments(project uint) ([]Environment, error) {
|
||||
InitDb()
|
||||
|
||||
var dbEnvs []Environment
|
||||
result := DB.Where("project_id = ?", project).Find(&dbEnvs)
|
||||
|
||||
if result.Error != nil {
|
||||
return nil, errors.New("Some error occured: " + result.Error.Error())
|
||||
}
|
||||
return dbEnvs, nil
|
||||
}
|
||||
|
||||
func GetEnvironment(project uint, environment string) (Environment, error) {
|
||||
InitDb()
|
||||
|
||||
var dbEnv Environment
|
||||
result := DB.Where("project_id = ? AND name = ?", project, environment).First(&dbEnv)
|
||||
|
||||
if result.Error != nil {
|
||||
if errors.Is(result.Error, gorm.ErrRecordNotFound) {
|
||||
return Environment{}, errors.New("Environment with the name " + environment + " not found in the database")
|
||||
} else {
|
||||
return Environment{}, errors.New("Some error occured: " + result.Error.Error())
|
||||
}
|
||||
}
|
||||
return dbEnv, nil
|
||||
}
|
||||
|
||||
func ParseEnv(env string) string {
|
||||
re := regexp.MustCompile(`^\s*(#?)\s*([A-Z0-9_]+)\s*=\s*(?:"([^"\n]+)"|([^"\n]+))$`)
|
||||
|
||||
|
||||
Reference in New Issue
Block a user