package Friends
|
|
|
|
import (
|
|
"encoding/json"
|
|
"net/http"
|
|
"net/url"
|
|
"strings"
|
|
|
|
"git.tovijaeschke.xyz/tovi/Envelope/Backend/Api/Auth"
|
|
"git.tovijaeschke.xyz/tovi/Envelope/Backend/Database"
|
|
"git.tovijaeschke.xyz/tovi/Envelope/Backend/Models"
|
|
)
|
|
|
|
func EncryptedFriendRequestList(w http.ResponseWriter, r *http.Request) {
|
|
var (
|
|
userSession Models.Session
|
|
friends []Models.FriendRequest
|
|
returnJson []byte
|
|
err error
|
|
)
|
|
|
|
userSession, err = Auth.CheckCookie(r)
|
|
if err != nil {
|
|
http.Error(w, "Forbidden", http.StatusUnauthorized)
|
|
return
|
|
}
|
|
|
|
friends, err = Database.GetFriendRequestsByUserId(userSession.UserID.String())
|
|
if err != nil {
|
|
http.Error(w, "Error", http.StatusInternalServerError)
|
|
return
|
|
}
|
|
|
|
returnJson, err = json.MarshalIndent(friends, "", " ")
|
|
if err != nil {
|
|
http.Error(w, "Error", http.StatusInternalServerError)
|
|
return
|
|
}
|
|
|
|
w.WriteHeader(http.StatusOK)
|
|
w.Write(returnJson)
|
|
}
|
|
|
|
func EncryptedFriendList(w http.ResponseWriter, r *http.Request) {
|
|
var (
|
|
friends []Models.Friend
|
|
query url.Values
|
|
friendIds []string
|
|
returnJson []byte
|
|
ok bool
|
|
err error
|
|
)
|
|
|
|
query = r.URL.Query()
|
|
friendIds, ok = query["friend_ids"]
|
|
if !ok {
|
|
http.Error(w, "Invalid Data", http.StatusBadGateway)
|
|
return
|
|
}
|
|
|
|
// TODO: Fix error handling here
|
|
friendIds = strings.Split(friendIds[0], ",")
|
|
|
|
friends, err = Database.GetFriendsByIds(friendIds)
|
|
if err != nil {
|
|
http.Error(w, "Error", http.StatusInternalServerError)
|
|
return
|
|
}
|
|
|
|
returnJson, err = json.MarshalIndent(friends, "", " ")
|
|
if err != nil {
|
|
http.Error(w, "Error", http.StatusInternalServerError)
|
|
return
|
|
}
|
|
|
|
w.WriteHeader(http.StatusOK)
|
|
w.Write(returnJson)
|
|
}
|