Semaphore/api/user.go
2023-09-19 15:35:59 +02:00

80 lines
1.8 KiB
Go

package api
import (
"crypto/rand"
"encoding/base64"
"github.com/ansible-semaphore/semaphore/api/helpers"
"github.com/ansible-semaphore/semaphore/db"
"github.com/ansible-semaphore/semaphore/util"
"github.com/gorilla/context"
"github.com/gorilla/mux"
"io"
"net/http"
"strings"
)
func getUser(w http.ResponseWriter, r *http.Request) {
if u, exists := context.GetOk(r, "_user"); exists {
helpers.WriteJSON(w, http.StatusOK, u)
return
}
var user struct {
db.User
CanCreateProject bool `json:"can_create_project"`
Billing bool `json:"billing"`
}
user.User = *context.Get(r, "user").(*db.User)
user.CanCreateProject = user.Admin || util.Config.NonAdminCanCreateProject
user.Billing = util.Config.BillingEnabled
helpers.WriteJSON(w, http.StatusOK, user)
}
func getAPITokens(w http.ResponseWriter, r *http.Request) {
user := context.Get(r, "user").(*db.User)
tokens, err := helpers.Store(r).GetAPITokens(user.ID)
if err != nil {
w.WriteHeader(http.StatusInternalServerError)
return
}
helpers.WriteJSON(w, http.StatusOK, tokens)
}
func createAPIToken(w http.ResponseWriter, r *http.Request) {
user := context.Get(r, "user").(*db.User)
tokenID := make([]byte, 32)
if _, err := io.ReadFull(rand.Reader, tokenID); err != nil {
panic(err)
}
token, err := helpers.Store(r).CreateAPIToken(db.APIToken{
ID: strings.ToLower(base64.URLEncoding.EncodeToString(tokenID)),
UserID: user.ID,
Expired: false,
})
if err != nil {
panic(err)
}
helpers.WriteJSON(w, http.StatusCreated, token)
}
func expireAPIToken(w http.ResponseWriter, r *http.Request) {
user := context.Get(r, "user").(*db.User)
tokenID := mux.Vars(r)["token_id"]
err := helpers.Store(r).ExpireAPIToken(user.ID, tokenID)
if err != nil {
helpers.WriteError(w, err)
return
}
w.WriteHeader(http.StatusNoContent)
}