rosetta-lbry/services/errors.go

205 lines
5.6 KiB
Go
Raw Normal View History

2020-09-16 21:03:14 +02:00
// Copyright 2020 Coinbase, Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package services
import (
"github.com/coinbase/rosetta-sdk-go/types"
)
var (
// Errors contains all errors that could be returned
// by this Rosetta implementation.
Errors = []*types.Error{
ErrUnimplemented,
ErrUnavailableOffline,
ErrNotReady,
ErrBitcoind,
ErrBlockNotFound,
ErrUnableToDerive,
ErrUnclearIntent,
ErrUnableToParseIntermediateResult,
ErrScriptPubKeysMissing,
ErrInvalidCoin,
ErrUnableToDecodeAddress,
ErrUnableToDecodeScriptPubKey,
ErrUnableToCalculateSignatureHash,
ErrUnsupportedScriptType,
ErrUnableToComputePkScript,
ErrUnableToGetCoins,
ErrTransactionNotFound,
ErrCouldNotGetFeeRate,
2020-10-27 18:25:02 +01:00
ErrUnableToGetBalance,
2020-09-16 21:03:14 +02:00
}
// ErrUnimplemented is returned when an endpoint
// is called that is not implemented.
ErrUnimplemented = &types.Error{
Code: 0, //nolint
Message: "Endpoint not implemented",
}
// ErrUnavailableOffline is returned when an endpoint
// is called that is not available offline.
ErrUnavailableOffline = &types.Error{
Code: 1, //nolint
Message: "Endpoint unavailable offline",
}
// ErrNotReady is returned when bitcoind is not
// yet ready to serve queries.
ErrNotReady = &types.Error{
2020-10-27 18:25:02 +01:00
Code: 2, //nolint
Message: "Bitcoind is not ready",
Retriable: true,
2020-09-16 21:03:14 +02:00
}
// ErrBitcoind is returned when bitcoind
// errors on a request.
ErrBitcoind = &types.Error{
Code: 3, //nolint
Message: "Bitcoind error",
}
// ErrBlockNotFound is returned when a block
// is not available in the indexer.
ErrBlockNotFound = &types.Error{
Code: 4, //nolint
Message: "Block not found",
}
// ErrUnableToDerive is returned when an address
// cannot be derived from a provided public key.
ErrUnableToDerive = &types.Error{
Code: 5, //nolint
Message: "Unable to derive address",
}
// ErrUnclearIntent is returned when operations
// provided in /construction/preprocess or /construction/payloads
// are not valid.
ErrUnclearIntent = &types.Error{
Code: 6, //nolint
Message: "Unable to parse intent",
}
// ErrUnableToParseIntermediateResult is returned
// when a data structure passed between Construction
// API calls is not valid.
ErrUnableToParseIntermediateResult = &types.Error{
Code: 7, //nolint
Message: "Unable to parse intermediate result",
}
// ErrScriptPubKeysMissing is returned when
// the indexer cannot populate the required
// bitcoin.ScriptPubKeys to construct a transaction.
ErrScriptPubKeysMissing = &types.Error{
Code: 8, //nolint
Message: "Missing ScriptPubKeys",
}
// ErrInvalidCoin is returned when a *types.Coin
// cannot be parsed during construction.
ErrInvalidCoin = &types.Error{
Code: 9, //nolint
Message: "Coin is invalid",
}
// ErrUnableToDecodeAddress is returned when an address
// cannot be parsed during construction.
ErrUnableToDecodeAddress = &types.Error{
Code: 10, //nolint
Message: "Unable to decode address",
}
// ErrUnableToDecodeScriptPubKey is returned when a
// bitcoin.ScriptPubKey cannot be parsed during construction.
ErrUnableToDecodeScriptPubKey = &types.Error{
Code: 11, //nolint
Message: "Unable to decode ScriptPubKey",
}
// ErrUnableToCalculateSignatureHash is returned
// when some payload to sign cannot be generated.
ErrUnableToCalculateSignatureHash = &types.Error{
Code: 12, //nolint
Message: "Unable to calculate signature hash",
}
// ErrUnsupportedScriptType is returned when
// trying to sign an input with an unsupported
// script type.
ErrUnsupportedScriptType = &types.Error{
Code: 13, //nolint
Message: "Script type is not supported",
}
// ErrUnableToComputePkScript is returned
// when trying to compute the PkScript in
// ConsructionParse.
ErrUnableToComputePkScript = &types.Error{
Code: 14, //nolint
Message: "Unable to compute PK script",
}
// ErrUnableToGetCoins is returned by the indexer
// when it is not possible to get the coins
// owned by a *types.AccountIdentifier.
ErrUnableToGetCoins = &types.Error{
Code: 15, //nolint
Message: "Unable to get coins",
}
// ErrTransactionNotFound is returned by the indexer
// when it is not possible to find a transaction.
ErrTransactionNotFound = &types.Error{
Code: 16, // nolint
Message: "Transaction not found",
}
// ErrCouldNotGetFeeRate is returned when the fetch
// to get the suggested fee rate fails.
ErrCouldNotGetFeeRate = &types.Error{
Code: 17, // nolint
Message: "Could not get suggested fee rate",
}
2020-10-27 18:25:02 +01:00
// ErrUnableToGetBalance is returned by the indexer
// when it is not possible to get the balance
// of a *types.AccountIdentifier.
ErrUnableToGetBalance = &types.Error{
Code: 18, //nolint
Message: "Unable to get balance",
}
2020-09-16 21:03:14 +02:00
)
// wrapErr adds details to the types.Error provided. We use a function
// to do this so that we don't accidentially overrwrite the standard
// errors.
func wrapErr(rErr *types.Error, err error) *types.Error {
newErr := &types.Error{
2020-10-27 18:25:02 +01:00
Code: rErr.Code,
Message: rErr.Message,
2020-09-30 14:57:43 +02:00
Retriable: rErr.Retriable,
2020-09-16 21:03:14 +02:00
}
if err != nil {
newErr.Details = map[string]interface{}{
"context": err.Error(),
}
}
return newErr
}