Files

82 lines
1.2 KiB
Go
Raw Permalink Normal View History

2018-10-19 15:31:41 -04:00
package db
import (
"database/sql"
_ "github.com/go-sql-driver/mysql"
)
type DB struct {
*sql.DB
}
type Datastore interface {
Escape(string) string
UserInterface
OrgInterface
AccountInterface
TransactionInterface
PriceInterface
SessionInterface
ApiKeyInterface
SystemHealthInteface
2020-01-14 14:14:16 -05:00
BudgetInterface
2018-10-19 15:31:41 -04:00
}
func NewDB(dataSourceName string) (*DB, error) {
var err error
db, err := sql.Open("mysql", dataSourceName)
if err != nil {
return nil, err
}
if err = db.Ping(); err != nil {
return nil, err
}
return &DB{db}, nil
}
func (db *DB) Escape(sql string) string {
dest := make([]byte, 0, 2*len(sql))
var escape byte
for i := 0; i < len(sql); i++ {
c := sql[i]
escape = 0
switch c {
case 0: /* Must be escaped for 'mysql' */
escape = '0'
break
case '\n': /* Must be escaped for logs */
escape = 'n'
break
case '\r':
escape = 'r'
break
case '\\':
escape = '\\'
break
case '\'':
escape = '\''
break
case '"': /* Better safe than sorry */
escape = '"'
break
case '\032': /* This gives problems on Win32 */
escape = 'Z'
2018-12-27 15:31:50 -05:00
break
case '%':
escape = '%'
2018-10-19 15:31:41 -04:00
}
if escape != 0 {
dest = append(dest, '\\', escape)
} else {
dest = append(dest, c)
}
}
return string(dest)
}