mirror of
https://github.com/jc21/nginx-proxy-manager.git
synced 2024-08-30 18:22:48 +00:00
Prevent deleting certificate that is use
This commit is contained in:
parent
88b46ef9ef
commit
7ea64c46e9
@ -1,6 +1,7 @@
|
|||||||
package handler
|
package handler
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"database/sql"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"fmt"
|
"fmt"
|
||||||
"net/http"
|
"net/http"
|
||||||
@ -10,6 +11,7 @@ import (
|
|||||||
"npm/internal/api/middleware"
|
"npm/internal/api/middleware"
|
||||||
"npm/internal/api/schema"
|
"npm/internal/api/schema"
|
||||||
"npm/internal/entity/certificate"
|
"npm/internal/entity/certificate"
|
||||||
|
"npm/internal/entity/host"
|
||||||
"npm/internal/jobqueue"
|
"npm/internal/jobqueue"
|
||||||
"npm/internal/logger"
|
"npm/internal/logger"
|
||||||
)
|
)
|
||||||
@ -141,11 +143,20 @@ func DeleteCertificate() func(http.ResponseWriter, *http.Request) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
cert, err := certificate.GetByID(certificateID)
|
item, err := certificate.GetByID(certificateID)
|
||||||
if err != nil {
|
switch err {
|
||||||
|
case sql.ErrNoRows:
|
||||||
|
h.ResultErrorJSON(w, r, http.StatusNotFound, "Not found", nil)
|
||||||
|
case nil:
|
||||||
|
// Ensure that this upstream isn't in use by a host
|
||||||
|
cnt := host.GetCertificateUseCount(certificateID)
|
||||||
|
if cnt > 0 {
|
||||||
|
h.ResultErrorJSON(w, r, http.StatusBadRequest, "Cannot delete certificate that is in use by at least 1 host", nil)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
h.ResultResponseJSON(w, r, http.StatusOK, item.Delete())
|
||||||
|
default:
|
||||||
h.ResultErrorJSON(w, r, http.StatusBadRequest, err.Error(), nil)
|
h.ResultErrorJSON(w, r, http.StatusBadRequest, err.Error(), nil)
|
||||||
} else {
|
|
||||||
h.ResultResponseJSON(w, r, http.StatusOK, cert.Delete())
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -213,6 +213,21 @@ func GetUpstreamUseCount(upstreamID int) int {
|
|||||||
return totalRows
|
return totalRows
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GetCertificateUseCount returns the number of hosts that are using
|
||||||
|
// a certificate, and have not been deleted.
|
||||||
|
func GetCertificateUseCount(certificateID int) int {
|
||||||
|
db := database.GetInstance()
|
||||||
|
query := fmt.Sprintf("SELECT COUNT(*) FROM %s WHERE certificate_id = ? AND is_deleted = ?", tableName)
|
||||||
|
countRow := db.QueryRowx(query, certificateID, 0)
|
||||||
|
var totalRows int
|
||||||
|
queryErr := countRow.Scan(&totalRows)
|
||||||
|
if queryErr != nil && queryErr != sql.ErrNoRows {
|
||||||
|
logger.Debug("%s", query)
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
return totalRows
|
||||||
|
}
|
||||||
|
|
||||||
// AddPendingJobs is intended to be used at startup to add
|
// AddPendingJobs is intended to be used at startup to add
|
||||||
// anything pending to the JobQueue just once, based on
|
// anything pending to the JobQueue just once, based on
|
||||||
// the database row status
|
// the database row status
|
||||||
|
Loading…
Reference in New Issue
Block a user