mirror of
https://gitlab.com/pulsechaincom/prysm-pulse.git
synced 2025-01-08 02:31:19 +00:00
43 lines
1.6 KiB
Go
43 lines
1.6 KiB
Go
package shared
|
|
|
|
import (
|
|
"net/http"
|
|
|
|
"github.com/prysmaticlabs/prysm/v4/beacon-chain/rpc/lookup"
|
|
"github.com/prysmaticlabs/prysm/v4/consensus-types/blocks"
|
|
"github.com/prysmaticlabs/prysm/v4/consensus-types/interfaces"
|
|
"github.com/prysmaticlabs/prysm/v4/network/httputil"
|
|
)
|
|
|
|
// WriteStateFetchError writes an appropriate error based on the supplied argument.
|
|
// The argument error should be a result of fetching state.
|
|
func WriteStateFetchError(w http.ResponseWriter, err error) {
|
|
if _, ok := err.(*lookup.StateNotFoundError); ok {
|
|
httputil.HandleError(w, "State not found", http.StatusNotFound)
|
|
return
|
|
}
|
|
if parseErr, ok := err.(*lookup.StateIdParseError); ok {
|
|
httputil.HandleError(w, "Invalid state ID: "+parseErr.Error(), http.StatusBadRequest)
|
|
return
|
|
}
|
|
httputil.HandleError(w, "Could not get state: "+err.Error(), http.StatusInternalServerError)
|
|
}
|
|
|
|
// WriteBlockFetchError writes an appropriate error based on the supplied argument.
|
|
// The argument error should be a result of fetching block.
|
|
func WriteBlockFetchError(w http.ResponseWriter, blk interfaces.ReadOnlySignedBeaconBlock, err error) bool {
|
|
if invalidBlockIdErr, ok := err.(*lookup.BlockIdParseError); ok {
|
|
httputil.HandleError(w, "Invalid block ID: "+invalidBlockIdErr.Error(), http.StatusBadRequest)
|
|
return false
|
|
}
|
|
if err != nil {
|
|
httputil.HandleError(w, "Could not get block from block ID: "+err.Error(), http.StatusInternalServerError)
|
|
return false
|
|
}
|
|
if err = blocks.BeaconBlockIsNil(blk); err != nil {
|
|
httputil.HandleError(w, "Could not find requested block: "+err.Error(), http.StatusNotFound)
|
|
return false
|
|
}
|
|
return true
|
|
}
|