210 lines
5.7 KiB
Go
210 lines
5.7 KiB
Go
package database
|
|
|
|
import (
|
|
"database/sql"
|
|
"errors"
|
|
"fmt"
|
|
"strings"
|
|
|
|
"AdaptixServer/core/utils/logs"
|
|
|
|
"github.com/Adaptix-Framework/axc2"
|
|
)
|
|
|
|
func (dbms *DBMS) DbCredentialsExist(credsId string) bool {
|
|
var id string
|
|
err := dbms.database.QueryRow("SELECT CredId FROM Credentials WHERE CredId = ? LIMIT 1;", credsId).Scan(&id)
|
|
return err == nil
|
|
}
|
|
|
|
func (dbms *DBMS) DbCredentialsAdd(credsData []*adaptix.CredsData) error {
|
|
ok := dbms.DatabaseExists()
|
|
if !ok {
|
|
return errors.New("database does not exist")
|
|
}
|
|
|
|
tx, err := dbms.database.Begin()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
insertQuery := `INSERT OR IGNORE INTO Credentials (CredId, Username, Password, Realm, Type, Tag, Date, Storage, AgentId, Host) values(?,?,?,?,?,?,?,?,?,?);`
|
|
stmt, err := tx.Prepare(insertQuery)
|
|
if err != nil {
|
|
_ = tx.Rollback()
|
|
return err
|
|
}
|
|
defer func(stmt *sql.Stmt) {
|
|
_ = stmt.Close()
|
|
}(stmt)
|
|
|
|
for _, creds := range credsData {
|
|
_, err = stmt.Exec(creds.CredId, creds.Username, creds.Password, creds.Realm, creds.Type,
|
|
creds.Tag, creds.Date, creds.Storage, creds.AgentId, creds.Host)
|
|
if err != nil {
|
|
logs.Error("", err.Error())
|
|
continue
|
|
}
|
|
}
|
|
|
|
return tx.Commit()
|
|
}
|
|
|
|
func (dbms *DBMS) DbCredentialsUpdate(credsData adaptix.CredsData) error {
|
|
ok := dbms.DatabaseExists()
|
|
if !ok {
|
|
return errors.New("database does not exist")
|
|
}
|
|
|
|
updateQuery := `UPDATE Credentials SET Username = ?, Password = ?, Realm = ?, Type = ?, Tag = ?, Storage = ?, Host = ? WHERE CredId = ?;`
|
|
result, err := dbms.database.Exec(updateQuery, credsData.Username, credsData.Password, credsData.Realm, credsData.Type,
|
|
credsData.Tag, credsData.Storage, credsData.Host, credsData.CredId)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
rows, _ := result.RowsAffected()
|
|
if rows == 0 {
|
|
return fmt.Errorf("creds %s does not exist", credsData.CredId)
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (dbms *DBMS) DbCredentialsDelete(credId string) error {
|
|
ok := dbms.DatabaseExists()
|
|
if !ok {
|
|
return errors.New("database does not exist")
|
|
}
|
|
|
|
deleteQuery := `DELETE FROM Credentials WHERE CredId = ?;`
|
|
_, err := dbms.database.Exec(deleteQuery, credId)
|
|
return err
|
|
}
|
|
|
|
func (dbms *DBMS) DbCredentialsDeleteBatch(credIds []string) error {
|
|
if len(credIds) == 0 {
|
|
return nil
|
|
}
|
|
|
|
ok := dbms.DatabaseExists()
|
|
if !ok {
|
|
return errors.New("database does not exist")
|
|
}
|
|
|
|
placeholders := make([]string, len(credIds))
|
|
args := make([]interface{}, len(credIds))
|
|
for i, id := range credIds {
|
|
placeholders[i] = "?"
|
|
args[i] = id
|
|
}
|
|
|
|
deleteQuery := fmt.Sprintf("DELETE FROM Credentials WHERE CredId IN (%s);", strings.Join(placeholders, ","))
|
|
_, err := dbms.database.Exec(deleteQuery, args...)
|
|
return err
|
|
}
|
|
|
|
func (dbms *DBMS) DbCredentialsUpdateBatch(credsData []adaptix.CredsData) error {
|
|
if len(credsData) == 0 {
|
|
return nil
|
|
}
|
|
|
|
ok := dbms.DatabaseExists()
|
|
if !ok {
|
|
return errors.New("database does not exist")
|
|
}
|
|
|
|
tx, err := dbms.database.Begin()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
updateQuery := `UPDATE Credentials SET Username = ?, Password = ?, Realm = ?, Type = ?, Tag = ?, Storage = ?, Host = ? WHERE CredId = ?;`
|
|
stmt, err := tx.Prepare(updateQuery)
|
|
if err != nil {
|
|
_ = tx.Rollback()
|
|
return err
|
|
}
|
|
defer func(stmt *sql.Stmt) {
|
|
_ = stmt.Close()
|
|
}(stmt)
|
|
|
|
for _, cred := range credsData {
|
|
_, err = stmt.Exec(cred.Username, cred.Password, cred.Realm, cred.Type, cred.Tag, cred.Storage, cred.Host, cred.CredId)
|
|
if err != nil {
|
|
_ = tx.Rollback()
|
|
return err
|
|
}
|
|
}
|
|
|
|
return tx.Commit()
|
|
}
|
|
|
|
func (dbms *DBMS) DbCredentialsFindDuplicate(username, realm, password string) bool {
|
|
if !dbms.DatabaseExists() {
|
|
return false
|
|
}
|
|
var id string
|
|
err := dbms.database.QueryRow("SELECT CredId FROM Credentials WHERE Username = ? AND Realm = ? AND Password = ? LIMIT 1;", username, realm, password).Scan(&id)
|
|
return err == nil
|
|
}
|
|
|
|
func (dbms *DBMS) DbCredentialById(credId string) (*adaptix.CredsData, error) {
|
|
if !dbms.DatabaseExists() {
|
|
return nil, errors.New("database does not exist")
|
|
}
|
|
cred := &adaptix.CredsData{}
|
|
selectQuery := `SELECT CredId, Username, Password, Realm, Type, Tag, Date, Storage, AgentId, Host FROM Credentials WHERE CredId = ?;`
|
|
err := dbms.database.QueryRow(selectQuery, credId).Scan(&cred.CredId, &cred.Username, &cred.Password, &cred.Realm, &cred.Type,
|
|
&cred.Tag, &cred.Date, &cred.Storage, &cred.AgentId, &cred.Host)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("creds %s not found", credId)
|
|
}
|
|
return cred, nil
|
|
}
|
|
|
|
func (dbms *DBMS) DbCredentialsSetTagBatch(credIds []string, tag string) error {
|
|
if len(credIds) == 0 {
|
|
return nil
|
|
}
|
|
if !dbms.DatabaseExists() {
|
|
return errors.New("database does not exist")
|
|
}
|
|
placeholders := make([]string, len(credIds))
|
|
args := make([]interface{}, 0, len(credIds)+1)
|
|
args = append(args, tag)
|
|
for i, id := range credIds {
|
|
placeholders[i] = "?"
|
|
args = append(args, id)
|
|
}
|
|
updateQuery := fmt.Sprintf("UPDATE Credentials SET Tag = ? WHERE CredId IN (%s);", strings.Join(placeholders, ","))
|
|
_, err := dbms.database.Exec(updateQuery, args...)
|
|
return err
|
|
}
|
|
|
|
func (dbms *DBMS) DbCredentialsAll() []*adaptix.CredsData {
|
|
var creds []*adaptix.CredsData
|
|
|
|
ok := dbms.DatabaseExists()
|
|
if ok {
|
|
selectQuery := `SELECT CredId, Username, Password, Realm, Type, Tag, Date, Storage, AgentId, Host FROM Credentials ORDER BY Date;`
|
|
query, err := dbms.database.Query(selectQuery)
|
|
if err != nil {
|
|
logs.Debug("", "Failed to query credentials: "+err.Error())
|
|
return creds
|
|
}
|
|
defer func(query *sql.Rows) {
|
|
_ = query.Close()
|
|
}(query)
|
|
|
|
for query.Next() {
|
|
credsData := &adaptix.CredsData{}
|
|
err = query.Scan(&credsData.CredId, &credsData.Username, &credsData.Password, &credsData.Realm, &credsData.Type,
|
|
&credsData.Tag, &credsData.Date, &credsData.Storage, &credsData.AgentId, &credsData.Host)
|
|
if err != nil {
|
|
continue
|
|
}
|
|
creds = append(creds, credsData)
|
|
}
|
|
}
|
|
return creds
|
|
}
|