Create Api Key added
This commit is contained in:
@ -1,7 +1,11 @@
|
||||
package handlers
|
||||
|
||||
import (
|
||||
"backend/models"
|
||||
"crypto/rand"
|
||||
"encoding/hex"
|
||||
"log"
|
||||
"net/http"
|
||||
|
||||
"github.com/gin-gonic/gin"
|
||||
)
|
||||
@ -10,3 +14,52 @@ func (r *NodeHandler) LoginHandler(c *gin.Context) {
|
||||
log.Println("trying to login")
|
||||
r.Repo.LoginHandler(c)
|
||||
}
|
||||
|
||||
func GenerateSecureKey() (string, error) {
|
||||
bytes := make([]byte, 32) // 256 bits
|
||||
if _, err := rand.Read(bytes); err != nil {
|
||||
return "", err
|
||||
}
|
||||
return hex.EncodeToString(bytes), nil
|
||||
}
|
||||
|
||||
func (r *NodeHandler) CreateApiKeyHandler(c *gin.Context) {
|
||||
|
||||
log.Println("trying to create key")
|
||||
newApiKey, err := GenerateSecureKey()
|
||||
|
||||
if err != nil {
|
||||
log.Printf("Generate API key error: %v", err)
|
||||
c.JSON(http.StatusInternalServerError, gin.H{"error": "key creation error"})
|
||||
return
|
||||
}
|
||||
|
||||
var key models.CreateApiKeyResponse
|
||||
|
||||
key, err = r.Repo.CreateApiKeyHandler(c, newApiKey)
|
||||
|
||||
if err != nil {
|
||||
log.Printf("CreateApiKeyHandler error: %v", err)
|
||||
c.JSON(http.StatusInternalServerError, gin.H{"error": "insert new api key error"})
|
||||
return
|
||||
}
|
||||
|
||||
c.JSON(http.StatusOK, key)
|
||||
}
|
||||
|
||||
func (h *NodeHandler) HandleRetrieveApiKeys(c *gin.Context) {
|
||||
|
||||
log.Println("All nodes retrieved request")
|
||||
|
||||
registeredNodes, err := h.Repo.RetriveNodeList()
|
||||
|
||||
if err != nil {
|
||||
log.Printf("Request error on retrieving all nodes: %v", err)
|
||||
c.JSON(http.StatusInternalServerError, gin.H{"error": "Impossible de récupérer la liste des nœuds"})
|
||||
return
|
||||
}
|
||||
|
||||
log.Printf("nb nodes: %v", len(registeredNodes))
|
||||
|
||||
c.JSON(http.StatusOK, registeredNodes)
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user