2022-05-11 22:47:31 +00:00
|
|
|
package handler
|
|
|
|
|
|
|
|
import (
|
2023-02-27 07:21:40 +00:00
|
|
|
"database/sql"
|
2022-05-11 22:47:31 +00:00
|
|
|
"encoding/json"
|
|
|
|
"fmt"
|
|
|
|
"net/http"
|
|
|
|
|
|
|
|
"npm/internal/acme"
|
|
|
|
c "npm/internal/api/context"
|
|
|
|
h "npm/internal/api/http"
|
|
|
|
"npm/internal/api/middleware"
|
|
|
|
"npm/internal/entity/certificateauthority"
|
|
|
|
"npm/internal/logger"
|
|
|
|
)
|
|
|
|
|
|
|
|
// GetCertificateAuthorities will return a list of Certificate Authorities
|
|
|
|
// Route: GET /certificate-authorities
|
|
|
|
func GetCertificateAuthorities() func(http.ResponseWriter, *http.Request) {
|
|
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
pageInfo, err := getPageInfoFromRequest(r)
|
|
|
|
if err != nil {
|
|
|
|
h.ResultErrorJSON(w, r, http.StatusBadRequest, err.Error(), nil)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
certificates, err := certificateauthority.List(pageInfo, middleware.GetFiltersFromContext(r))
|
|
|
|
if err != nil {
|
|
|
|
h.ResultErrorJSON(w, r, http.StatusBadRequest, err.Error(), nil)
|
|
|
|
} else {
|
|
|
|
h.ResultResponseJSON(w, r, http.StatusOK, certificates)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetCertificateAuthority will return a single Certificate Authority
|
|
|
|
// Route: GET /certificate-authorities/{caID}
|
|
|
|
func GetCertificateAuthority() func(http.ResponseWriter, *http.Request) {
|
|
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
var err error
|
2023-05-26 01:04:43 +00:00
|
|
|
var caID uint
|
2022-05-11 22:47:31 +00:00
|
|
|
if caID, err = getURLParamInt(r, "caID"); err != nil {
|
|
|
|
h.ResultErrorJSON(w, r, http.StatusBadRequest, err.Error(), nil)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-02-27 07:21:40 +00:00
|
|
|
item, err := certificateauthority.GetByID(caID)
|
|
|
|
switch err {
|
|
|
|
case sql.ErrNoRows:
|
|
|
|
h.NotFound(w, r)
|
|
|
|
case nil:
|
|
|
|
h.ResultResponseJSON(w, r, http.StatusOK, item)
|
|
|
|
default:
|
2022-05-11 22:47:31 +00:00
|
|
|
h.ResultErrorJSON(w, r, http.StatusBadRequest, err.Error(), nil)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// CreateCertificateAuthority will create a Certificate Authority
|
|
|
|
// Route: POST /certificate-authorities
|
|
|
|
func CreateCertificateAuthority() func(http.ResponseWriter, *http.Request) {
|
|
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
bodyBytes, _ := r.Context().Value(c.BodyCtxKey).([]byte)
|
|
|
|
|
|
|
|
var newCA certificateauthority.Model
|
|
|
|
err := json.Unmarshal(bodyBytes, &newCA)
|
|
|
|
if err != nil {
|
|
|
|
h.ResultErrorJSON(w, r, http.StatusBadRequest, h.ErrInvalidPayload.Error(), nil)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if err = newCA.Check(); err != nil {
|
|
|
|
h.ResultErrorJSON(w, r, http.StatusBadRequest, err.Error(), nil)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if err = newCA.Save(); err != nil {
|
|
|
|
h.ResultErrorJSON(w, r, http.StatusBadRequest, fmt.Sprintf("Unable to save Certificate Authority: %s", err.Error()), nil)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if err = acme.CreateAccountKey(&newCA); err != nil {
|
|
|
|
logger.Error("CreateAccountKeyError", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
h.ResultResponseJSON(w, r, http.StatusOK, newCA)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// UpdateCertificateAuthority updates a ca
|
|
|
|
// Route: PUT /certificate-authorities/{caID}
|
|
|
|
func UpdateCertificateAuthority() func(http.ResponseWriter, *http.Request) {
|
|
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
var err error
|
2023-05-26 01:04:43 +00:00
|
|
|
var caID uint
|
2022-05-11 22:47:31 +00:00
|
|
|
if caID, err = getURLParamInt(r, "caID"); err != nil {
|
|
|
|
h.ResultErrorJSON(w, r, http.StatusBadRequest, err.Error(), nil)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
ca, err := certificateauthority.GetByID(caID)
|
2023-02-27 07:21:40 +00:00
|
|
|
switch err {
|
|
|
|
case sql.ErrNoRows:
|
|
|
|
h.NotFound(w, r)
|
|
|
|
case nil:
|
2022-05-11 22:47:31 +00:00
|
|
|
bodyBytes, _ := r.Context().Value(c.BodyCtxKey).([]byte)
|
|
|
|
err := json.Unmarshal(bodyBytes, &ca)
|
|
|
|
if err != nil {
|
|
|
|
h.ResultErrorJSON(w, r, http.StatusBadRequest, h.ErrInvalidPayload.Error(), nil)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if err = ca.Check(); err != nil {
|
|
|
|
h.ResultErrorJSON(w, r, http.StatusBadRequest, err.Error(), nil)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if err = ca.Save(); err != nil {
|
|
|
|
h.ResultErrorJSON(w, r, http.StatusBadRequest, err.Error(), nil)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
h.ResultResponseJSON(w, r, http.StatusOK, ca)
|
2023-02-27 07:21:40 +00:00
|
|
|
default:
|
|
|
|
h.ResultErrorJSON(w, r, http.StatusBadRequest, err.Error(), nil)
|
2022-05-11 22:47:31 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// DeleteCertificateAuthority deletes a ca
|
|
|
|
// Route: DELETE /certificate-authorities/{caID}
|
|
|
|
func DeleteCertificateAuthority() func(http.ResponseWriter, *http.Request) {
|
|
|
|
return func(w http.ResponseWriter, r *http.Request) {
|
|
|
|
var err error
|
2023-05-26 01:04:43 +00:00
|
|
|
var caID uint
|
2022-05-11 22:47:31 +00:00
|
|
|
if caID, err = getURLParamInt(r, "caID"); err != nil {
|
|
|
|
h.ResultErrorJSON(w, r, http.StatusBadRequest, err.Error(), nil)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2023-02-27 07:21:40 +00:00
|
|
|
item, err := certificateauthority.GetByID(caID)
|
|
|
|
switch err {
|
|
|
|
case sql.ErrNoRows:
|
|
|
|
h.NotFound(w, r)
|
|
|
|
case nil:
|
|
|
|
h.ResultResponseJSON(w, r, http.StatusOK, item.Delete())
|
|
|
|
default:
|
2022-05-11 22:47:31 +00:00
|
|
|
h.ResultErrorJSON(w, r, http.StatusBadRequest, err.Error(), nil)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|