2024-10-31 15:53:42 +00:00
|
|
|
package server
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net/http"
|
|
|
|
|
2024-11-04 06:48:46 +00:00
|
|
|
"github.com/google/jsonapi"
|
2024-10-31 15:53:42 +00:00
|
|
|
"github.com/rs/zerolog/hlog"
|
2024-11-04 06:48:46 +00:00
|
|
|
"gitlab.com/mstarongitlab/goutils/other"
|
|
|
|
"gitlab.com/mstarongitlab/linstrom/storage"
|
2024-10-31 15:53:42 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// No create account. That happens during passkey registration
|
|
|
|
// and remote accounts are getting created at fetch time
|
|
|
|
func linstromGetAccount(w http.ResponseWriter, r *http.Request) {
|
|
|
|
store := StorageFromRequest(r)
|
|
|
|
log := hlog.FromRequest(r)
|
2024-11-04 06:48:46 +00:00
|
|
|
accId := AccountIdFromRequest(r)
|
|
|
|
acc, err := store.FindAccountById(accId)
|
|
|
|
switch err {
|
|
|
|
case nil:
|
|
|
|
// Ok, do nothing
|
|
|
|
case storage.ErrEntryNotFound:
|
|
|
|
other.HttpErr(w, HttpErrIdNotFound, "account not found", http.StatusNotFound)
|
|
|
|
return
|
|
|
|
default:
|
|
|
|
log.Error().Err(err).Str("account-id", accId).Msg("Failed to get account from storage")
|
|
|
|
other.HttpErr(
|
|
|
|
w,
|
|
|
|
HttpErrIdDbFailure,
|
|
|
|
"Failed to get account from storage",
|
|
|
|
http.StatusInternalServerError,
|
|
|
|
)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
// TODO: Check if caller is actually allowed to view the account requested.
|
2024-10-31 15:53:42 +00:00
|
|
|
|
2024-11-04 06:48:46 +00:00
|
|
|
outAccount, err := convertAccountStorageToLinstrom(acc, store)
|
|
|
|
if err != nil {
|
|
|
|
log.Error().
|
|
|
|
Err(err).
|
|
|
|
Msg("Failed to convert storage account (and attached data) into linstrom API representation")
|
|
|
|
other.HttpErr(
|
|
|
|
w,
|
|
|
|
HttpErrIdConverionFailure,
|
|
|
|
"Failed to convert storage account and attached data into API representation",
|
|
|
|
http.StatusInternalServerError,
|
|
|
|
)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
err = jsonapi.MarshalPayload(w, outAccount)
|
|
|
|
if err != nil {
|
|
|
|
log.Error().Err(err).Any("account", outAccount).Msg("Failed to marshal and write account")
|
|
|
|
}
|
2024-10-31 15:53:42 +00:00
|
|
|
}
|
2024-11-04 06:48:46 +00:00
|
|
|
|
2024-10-31 15:53:42 +00:00
|
|
|
func linstromUpdateAccount(w http.ResponseWriter, r *http.Request) {}
|
|
|
|
func linstromDeleteAccount(w http.ResponseWriter, r *http.Request) {}
|
|
|
|
|
|
|
|
func linstromIsFollowingAccount(w http.ResponseWriter, r *http.Request) {}
|
|
|
|
func linstromFollowAccount(w http.ResponseWriter, r *http.Request) {}
|
|
|
|
func linstromUnfollowAccount(w http.ResponseWriter, r *http.Request) {}
|
|
|
|
|
|
|
|
func linstromIsBlockingAccount(w http.ResponseWriter, r *http.Request) {}
|
|
|
|
func linstromBlockAccount(w http.ResponseWriter, r *http.Request) {}
|
|
|
|
func linstromUnblockAccount(w http.ResponseWriter, r *http.Request) {}
|
|
|
|
|
|
|
|
func linstromIsMutedAccount(w http.ResponseWriter, r *http.Request) {}
|
|
|
|
func linstromMuteAccount(w http.ResponseWriter, r *http.Request) {}
|
|
|
|
func linstromUnmuteAccount(w http.ResponseWriter, r *http.Request) {}
|
|
|
|
|
|
|
|
func linstromReportAccount(w http.ResponseWriter, r *http.Request) {}
|
|
|
|
func linstromRetractReportAccount(w http.ResponseWriter, r *http.Request) {}
|
|
|
|
|
|
|
|
func linstromAdminAddRoleAccount(w http.ResponseWriter, r *http.Request) {}
|
|
|
|
func linstromAdminRemoveRoleAccount(w http.ResponseWriter, r *http.Request) {}
|
|
|
|
func linstromAdminWarnAccount(w http.ResponseWriter, r *http.Request) {}
|
|
|
|
|
|
|
|
func linstromGetRole(w http.ResponseWriter, r *http.Request) {}
|
|
|
|
func linstromCreateRole(w http.ResponseWriter, r *http.Request) {}
|
|
|
|
func linstromUpdateRole(w http.ResponseWriter, r *http.Request) {}
|
|
|
|
func linstromDeleteRole(w http.ResponseWriter, r *http.Request) {}
|