You've already forked openaccounting-server
mirror of
https://github.com/openaccounting/oa-server.git
synced 2025-12-09 09:00:42 +13:00
82 lines
1.2 KiB
Go
82 lines
1.2 KiB
Go
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
|
|
BudgetInterface
|
|
}
|
|
|
|
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'
|
|
break
|
|
case '%':
|
|
escape = '%'
|
|
}
|
|
|
|
if escape != 0 {
|
|
dest = append(dest, '\\', escape)
|
|
} else {
|
|
dest = append(dest, c)
|
|
}
|
|
}
|
|
|
|
return string(dest)
|
|
}
|