2024-03-18 15:40:28 +00:00
|
|
|
package db
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"fmt"
|
|
|
|
"os/exec"
|
|
|
|
"syscall"
|
|
|
|
|
|
|
|
"git.faercol.me/faercol/polyculeconnect/polyculeconnect/cmd/utils"
|
|
|
|
"git.faercol.me/faercol/polyculeconnect/polyculeconnect/config"
|
|
|
|
"github.com/spf13/cobra"
|
|
|
|
)
|
|
|
|
|
|
|
|
// connectCmd represents the db connect command
|
|
|
|
var connectCmd = &cobra.Command{
|
|
|
|
Use: "connect",
|
|
|
|
Short: "Connect to the database",
|
|
|
|
Long: `Connect to the database.`,
|
|
|
|
Run: func(cmd *cobra.Command, args []string) {
|
|
|
|
conf := utils.InitConfig("")
|
|
|
|
if err := connectToDB(conf); err != nil {
|
|
|
|
utils.Failf("Failed to connect to DB: %s", err.Error())
|
|
|
|
}
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2024-10-20 15:31:00 +00:00
|
|
|
func connectSQLite(conf config.StorageConfig) error {
|
2024-03-18 15:40:28 +00:00
|
|
|
path, err := exec.LookPath("sqlite3")
|
|
|
|
if err != nil {
|
|
|
|
if errors.Is(err, exec.ErrNotFound) {
|
|
|
|
return errors.New("sqlite3 not installed")
|
|
|
|
}
|
|
|
|
return fmt.Errorf("failed to find sqlite3 executable: %w", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if err := syscall.Exec(path, []string{path, conf.File}, nil); err != nil {
|
|
|
|
return fmt.Errorf("failed to run sqlite3 command: %w", err)
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func connectToDB(conf *config.AppConfig) error {
|
|
|
|
switch conf.StorageType {
|
|
|
|
case string(config.Memory):
|
|
|
|
return errors.New("no DB associated with memory storage")
|
|
|
|
case string(config.SQLite):
|
|
|
|
return connectSQLite(conf.StorageConfig)
|
|
|
|
default:
|
|
|
|
return fmt.Errorf("unsupported storage type %q", conf.StorageType)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
dbCmd.AddCommand(connectCmd)
|
|
|
|
}
|