mirror of
https://github.com/kaspanet/kaspad.git
synced 2025-06-15 18:46:39 +00:00

* [NOD-289] Implemented database isCurrent checking and connection. * [NOD-289] Added GetChainFromBlock to RPCClient. * [NOD-289] Limited the amount of blocks in GetChainFromBlockResponse. * [NOD-289] Fixed various issues that were keeping GetChainFromBlocks from working properly. * [NOD-289] Created blockloop.go. * [NOD-289] Updated go.mod after merge. * [NOD-289] Implemented collection of current selected parent chain. * [NOD-289] Fixed test. Reverted not deleting utxoDiffData from the DB. * [NOD-289] Implemented GetBlocks. * [NOD-289] Added comment to BlockHashesFrom. * [NOD-289] Added GetBlocks to rpcclient. * [NOD-289] Added verboseBlocks to GetBlocks. * [NOD-289] Implemented block insertion. * [NOD-289] Added AUTO_INCREMENT to tables that were missing it. * [NOD-289] Made gasLimit in subnetwork nullable. * [NOD-289] Renamed transactions_outputs to transaction_outputs. * [NOD-289] Fixed weird coinbase behavior in vin. * [NOD-289] Made collectCurrentBlocks start from the most recent startHash. * [NOD-289] Added IsChainBlock to GetBlockVerboseResult. * [NOD-289] Implemented adding a block from onBlockAdded. * [NOD-289] Added removedParentChainHashes to getChainFromBlock. * [NOD-289] Implemented updating the selected parent chain from onChainChanged. * [NOD-289] Implemented some initial logic for updating the UTXO. * [NOD-289] Fixed merge errors. * [NOD-326] Fixed some more merge errors. * [NOD-289] Added error handling for missing required records. * [NOD-289] Implemented handling removedChainHashes. * [NOD-289] Implemented handling addedChainBlocks. * [NOD-289] Fixed incorrect coinbase check. * [NOD-289] Implemented inserting the transaction output address. * [NOD-289] Added updating block.IsChainBlock. * [NOD-289] Split insertBlock into many small functions. * [NOD-289] Split updateSelectedParentChain into smaller functions. * [NOD-289] Fixed pointer errors. * [NOD-289] Fixed a bad exists check. * [NOD-289] Fixed a couple of small bugs. * [NOD-289] Fixed a TxID/Hash mixup. * [NOD-289] Added block/tx mass to getBlockVerboseResponse. * [NOD-289] Renamed blockLoop.go to sync.go. Added comments. * [NOD-289] Deleted apiserver README. * [NOD-289] Fixed golint errors. * [NOD-289] Renamed findMostRecentBlockHash to findHashOfBluestBlock. * [NOD-289] Fixed style in syncBlocks and fixed a comment. * [NOD-289] Copied NewErrorFromDBErrors over from NOD-324. * [NOD-289] Created a couple of utils to make error handling with gorm slightly less painful. * [NOD-289] Added error handling for database calls. * [NOD-289] Fixed some more style/comments. * [NOD-289] Fixed comments. * [NOD-289] Renamed TransactionInput.TransactionOutput to TransactionInput.PreviousTransactionOutput. * [NOD-289] Added a commends about pagination in getBlocks and getChainFromBlock. * [NOD-289] Removed the coinbase field from Vin. * [NOD-289] Deferred handling chainChangedMsgs until we have the appropriate data. * [NOD-289] Optimized queries in updateRemovedChainHashes and updateAddedChainBlocks. * [NOD-289] Optimized queries in insertBlockParents. * [NOD-289] Optimized queries in insertTransactionInput. * [NOD-289] Split Where calls to separate lines. * [NOD-289] Fixed merge errors. * [NOD-289] Exited early from insertBlockParents if we're the genesis block. * [NOD-289] Improved nextChainChangedChan mechanism. * [NOD-289] Fixed the above sync mechanism a bit. * [NOD-289] Renamed IsDBRecordNotFoundError to HasDBRecordNotFoundError and IsDBError to HasDBError. * [NOD-289] Replaced old error handling for db errors with the lovely new stuff. * [NOD-289] Exited early if we already inserted a block. This saves us checking if a record already exists for some record types. * [NOD-289] Decoupled syncBlocks from syncSelectedParentChain. * [NOD-289] Made a comment more explicit. * [NOD-289] Extracted net resolution to a separate function. * [NOD-289] Extracted syncing to a separate function. * [NOD-289] Fixed a comment. * [NOD-289] Fixed merge erros. * [NOD-289] Fixed a couple of bugs. * [NOD-289] Fixed another bug. * [NOD-289] Extracted ChainChangedMsg conversion to a separate function. * [NOD-289] Optimized queries in canHandleChainChangedMsg. * [NOD-289] Moved the sync function closer to its call site. * [NOD-289] Renamed HasDBRecordNotFoundError to IsDBRecordNotFoundError. * [NOD-289] Used count instead of first. * [NOD-289] Renamed address to hexAddress.
75 lines
2.5 KiB
Go
75 lines
2.5 KiB
Go
package utils
|
|
|
|
import (
|
|
"fmt"
|
|
"github.com/jinzhu/gorm"
|
|
"net/http"
|
|
"strings"
|
|
)
|
|
|
|
// HandlerError is an error returned from
|
|
// a rest route handler or a middleware.
|
|
type HandlerError struct {
|
|
Code int
|
|
Message string
|
|
ClientMessage string
|
|
}
|
|
|
|
func (hErr *HandlerError) Error() string {
|
|
return hErr.Message
|
|
}
|
|
|
|
// NewHandlerError returns a HandlerError with the given code and message.
|
|
func NewHandlerError(code int, message string) *HandlerError {
|
|
return &HandlerError{
|
|
Code: code,
|
|
Message: message,
|
|
ClientMessage: message,
|
|
}
|
|
}
|
|
|
|
// NewHandlerErrorWithCustomClientMessage returns a HandlerError with
|
|
// the given code, message and client error message.
|
|
func NewHandlerErrorWithCustomClientMessage(code int, message, clientMessage string) *HandlerError {
|
|
return &HandlerError{
|
|
Code: code,
|
|
Message: message,
|
|
ClientMessage: clientMessage,
|
|
}
|
|
}
|
|
|
|
// NewInternalServerHandlerError returns a HandlerError with
|
|
// the given message, and the http.StatusInternalServerError
|
|
// status text as client message.
|
|
func NewInternalServerHandlerError(message string) *HandlerError {
|
|
return NewHandlerErrorWithCustomClientMessage(http.StatusInternalServerError, message, http.StatusText(http.StatusInternalServerError))
|
|
}
|
|
|
|
// NewErrorFromDBErrors takes a slice of database errors and a prefix, and
|
|
// returns an error with all of the database errors formatted to one string with
|
|
// the given prefix
|
|
func NewErrorFromDBErrors(prefix string, dbErrors []error) error {
|
|
dbErrorsStrings := make([]string, len(dbErrors))
|
|
for i, dbErr := range dbErrors {
|
|
dbErrorsStrings[i] = fmt.Sprintf("\"%s\"", dbErr)
|
|
}
|
|
return fmt.Errorf("%s [%s]", prefix, strings.Join(dbErrorsStrings, ","))
|
|
}
|
|
|
|
// NewHandlerErrorFromDBErrors takes a slice of database errors and a prefix, and
|
|
// returns an HandlerError with error code http.StatusInternalServerError with
|
|
// all of the database errors formatted to one string with the given prefix
|
|
func NewHandlerErrorFromDBErrors(prefix string, dbErrors []error) *HandlerError {
|
|
return NewInternalServerHandlerError(NewErrorFromDBErrors(prefix, dbErrors).Error())
|
|
}
|
|
|
|
// IsDBRecordNotFoundError returns true if the given dbErrors contains only a RecordNotFound error
|
|
func IsDBRecordNotFoundError(dbErrors []error) bool {
|
|
return len(dbErrors) == 1 && gorm.IsRecordNotFoundError(dbErrors[0])
|
|
}
|
|
|
|
// HasDBError returns true if the given dbErrors contain any errors that aren't RecordNotFound
|
|
func HasDBError(dbErrors []error) bool {
|
|
return !IsDBRecordNotFoundError(dbErrors) && len(dbErrors) > 0
|
|
}
|