2024-10-02 17:49:33 +02:00
package sql
import (
2024-10-26 14:56:17 +02:00
"github.com/semaphoreui/semaphore/db"
2024-10-02 17:49:33 +02:00
"strconv"
"strings"
)
func ( d * SqlDb ) GetTemplateVaults ( projectID int , templateID int ) ( vaults [ ] db . TemplateVault , err error ) {
2024-10-03 21:41:36 +02:00
vaults = [ ] db . TemplateVault { }
2024-10-07 11:35:20 +02:00
_ , err = d . selectAll ( & vaults , "select * from project__template_vault where project_id=? and template_id=?" , projectID , templateID )
2024-10-02 17:49:33 +02:00
if err != nil {
return
}
2024-10-07 11:35:20 +02:00
for i := range vaults {
err = db . FillTemplateVault ( d , projectID , & vaults [ i ] )
2024-10-02 17:49:33 +02:00
if err != nil {
return
}
}
return
}
2024-10-03 21:41:36 +02:00
func ( d * SqlDb ) CreateTemplateVault ( vault db . TemplateVault ) ( newVault db . TemplateVault , err error ) {
insertID , err := d . insert (
"id" ,
2024-10-22 21:50:31 +02:00
"insert into project__template_vault (project_id, template_id, vault_key_id, name, type, script) values (?, ?, ?, ?, ?, ?)" ,
2024-10-03 21:41:36 +02:00
vault . ProjectID ,
vault . TemplateID ,
vault . VaultKeyID ,
2024-10-22 21:50:31 +02:00
vault . Name ,
vault . Type ,
vault . Script )
2024-10-03 21:41:36 +02:00
if err != nil {
return
}
newVault = vault
newVault . ID = insertID
return
}
2024-10-02 17:49:33 +02:00
func ( d * SqlDb ) UpdateTemplateVaults ( projectID int , templateID int , vaults [ ] db . TemplateVault ) ( err error ) {
if vaults == nil {
vaults = [ ] db . TemplateVault { }
}
var vaultIDs [ ] string
for _ , vault := range vaults {
2024-10-22 21:50:31 +02:00
switch vault . Type {
case "password" :
vault . Script = nil
case "script" :
vault . VaultKeyID = nil
}
2024-10-02 17:49:33 +02:00
if vault . ID == 0 {
// Insert new vaults
var vaultId int
2024-10-22 21:50:31 +02:00
vaultId , err = d . insert ( "id" , "insert into project__template_vault (project_id, template_id, vault_key_id, name, type, script) values (?, ?, ?, ?, ?, ?)" , projectID , templateID , vault . VaultKeyID , vault . Name , vault . Type , vault . Script )
2024-10-02 17:49:33 +02:00
if err != nil {
return
}
vaultIDs = append ( vaultIDs , strconv . Itoa ( vaultId ) )
} else {
// Update existing vaults
2024-10-22 21:50:31 +02:00
_ , err = d . exec ( "update project__template_vault set project_id=?, template_id=?, vault_key_id=?, name=?, type=?, script=? where id=?" , projectID , templateID , vault . VaultKeyID , vault . Name , vault . Type , vault . Script , vault . ID )
2024-10-02 17:49:33 +02:00
vaultIDs = append ( vaultIDs , strconv . Itoa ( vault . ID ) )
}
if err != nil {
return
}
}
// Delete removed vaults
if len ( vaultIDs ) == 0 {
_ , err = d . exec ( "delete from project__template_vault where project_id=? and template_id=?" , projectID , templateID )
} else {
_ , err = d . exec ( "delete from project__template_vault where project_id=? and template_id=? and id not in (" + strings . Join ( vaultIDs , "," ) + ")" , projectID , templateID )
}
return
}