-
Notifications
You must be signed in to change notification settings - Fork 97
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Error codes #550
Comments
What if we consider using separated text tags e.g.
|
Sounds good! |
We're going to start improving the error structure with |
* Add and implement MmError * Add WithdrawError returned from 'MmCoin::withdraw' * Collect 'available' and 'required' info within GenerateTxError * Add other internal error types * Add BalanceError returned from my_balance * Add more error types * Add Web3RpcError, * Refactor the ordered_mature_unspents, list_unspent_ordered methods to return an extended error * Rename MmRpcError to UtxoRpcError * Refactor MmError mapping * Separate mm_error into several modules * Rename into_mm_and() to into_mm() * add into_mm_fut * Implement MarketMaker2 RPC protocol v2 * Add lp_protocol, dispatcher_v2, dispatcher_legacy modules * Change the coins::withdraw function signature * Add HttpStatusCode trait * Refactor test_withdraw_and_send to use v2 protocol * Add test_mm2rpc test_withdraw_legacy, test_withdraw_not_sufficient_balance * Upgrade the trade_preimage RPC call to the mmrpc 2.0 * Move lp_swap::trade_preimage and dependent types to the separated lp_swap::trade_preimage module * Change the trade_preimage_rpc function signature * Extend CheckBalanceError and move it to the separated check_balance module * Refactor test_maker_trade_preimage, test_taker_trade_preimage to use v2 protocol * Add test_trade_preimage_not_sufficient_balance, test_trade_preimage_legacy, test_trade_preimage_dynamic_fee_not_sufficient_balance tests * Remove boilerplate * Add lp_coinfind_or_err and CoinFindError * Replace lp_coinfind with lp_coinfind_or_err in coins::withdraw, trade_preimage_rpc * Move functions that check the trade balance to check_balance module * Move check_my_coin_balance_for_swap, check_other_coin_balance_for_swap, check_base_coin_balance_for_swap * Make a compile time checking if an error type is tagged * Add ser_error, ser_error_derive crates * Remove a runtime checking if an error type is tagged * Fill out the mm_error documentation with the examples * Fix rustfmt warnings * Add missing ser_error, ser_error_derive crates * Fix PR issues * Rename 'into_mm' to 'map_to_mm', 'into_mm_fut' to 'map_to_mm_fut' * Remove CoinFindError::NoCoinsContext error variant, replace it with the panic
@sergeyboyko0791 The PR is merged, please document the changes in the API 🙂 |
I guess we can close this issue? |
Yes 🙂 |
«we need a standardized error message format like {error: {code: 3, message: "This is the error message", backtrace: "backtrace info for mm2 devs"}} as opposed to random length strings that make it hard for GUI devs to parse around them in order to tell the user whats going on
So - don't assign a specific error code to every error - but please ensure the error output is in a proper format similar to the above proposal. It would be a huge help for us and other GUI devs.»
( discussion: https://discordapp.com/channels/@me/542973365846016001/625604148783480852 )
AG: We might want to
a) Add a macro that would be used across the board to emit an expected error.
For example:
ecode! (EL06, "No Electrum servers reachable")
.The macro emits a structure that implements
Display
. It should also be possible to use that structure with human-readable log and dashboard, where error code is printed as a log tag.b) Add a (build.rs) parser that will go over the source code and check the error code uniqueness, generating a file that lists all the error codes.
This file can then be used by the GUI developers as an extra source of information on the errors and codes and by the MM developers to help them select new error codes.
c) Patch the RPC error handler to parse the error string, separating backtrace and error code tags into the respective separate fields.
(Let's talk the advantages if there's a better approach)
The text was updated successfully, but these errors were encountered: