Mailspring/internal_packages/keybase/lib
Juan Tejada 1e34a2e33b 🎨 Fix unhandled api rejections/Prefer promises over success option for api requests
Summary:
This commit modifies the api of NylasAPIRequest to /not/ take `success`
or `error` callback options at all, and only returns a Promise which you
can `then` and `catch` to handle the api response.

The fact that it returned a promise, and /also/ took `success` and
`error` callback options made it really confusing to use.

Additionaly, when using the callbacks intead of a promise, any errors
would be unhandled and reported to Sentry because even though the `error`
callback was being passed, the promise returned by `run()` still rejected and
no one was handling that reject, so it reached the `unhandledRejection` event
listener. This is undesirable because if you passed an `error` callback, it
means that you intended to handle it.

An example of this is calling the clearbit API, which will more often than
not return a 404, and even though we had an error handler which ignored the 404,
it still unecessarilly reported to Sentry, flooding it with events

Test Plan: manually check all updated codepaths still work

Reviewers: halla, spang, evan

Reviewed By: evan

Differential Revision: https://phab.nylas.com/D3869
2017-02-09 09:19:55 -08:00
..
decrypt-button.cjsx
decryption-preprocess.coffee
email-popover.cjsx
encrypt-button.cjsx
identity.coffee
key-adder.cjsx
key-manager.cjsx
keybase-search.cjsx 🎨 Fix unhandled api rejections/Prefer promises over success option for api requests 2017-02-09 09:19:55 -08:00
keybase-user.cjsx
keybase.coffee
main.es6
modal-key-recommender.cjsx fix(db): Return; preventing ThreadSearch indexing 2016-10-19 16:54:00 -07:00
passphrase-popover.cjsx
pgp-key-store.cjsx
preferences-keybase.cjsx
private-key-popover.cjsx
recipient-key-chip.cjsx