edgeboxctl/internal/tasks/tasks.go

49 lines
1.1 KiB
Go
Raw Normal View History

2021-02-13 16:06:13 +01:00
package tasks
import (
"database/sql"
2021-02-13 16:06:13 +01:00
_ "github.com/go-sql-driver/mysql" // Mysql Driver
)
2021-02-13 16:06:13 +01:00
// Dbhost : Database host (can be tweaked in makefile)
var Dbhost string
2021-02-13 16:06:13 +01:00
// Dbname : Database name (can be tweaked in makefile)
var Dbname string
2021-02-13 16:06:13 +01:00
// Dbuser : Database user (can be tweaked in makefile)
var Dbuser string
2021-02-13 16:06:13 +01:00
// Dbpass : Database password (can be tweaked in)
var Dbpass string
// PerformQuery : Performs a MySQL query over the device's Edgebox API
func PerformQuery() string {
// Will try to connect to API database, which should be running locally under WS.
db, err := sql.Open("mysql", Dbuser+":"+Dbpass+"@tcp("+Dbhost+")/"+Dbname)
// if there is an error opening the connection, handle it
if err != nil {
panic(err.Error())
}
// defer the close till after the main function has finished executing
defer db.Close()
// perform a db.Query insert
insert, err := db.Query("INSERT INTO options (name, value) VALUES ( 'TEST_OPTION_SYSCTL', 'TEST' );")
// if there is an error inserting, handle it
if err != nil {
panic(err.Error())
}
// be careful deferring Queries if you are using transactions
defer insert.Close()
return "OK"
}