Includes middleware that logs all your store and actions on exception to Sentry with raven-js
Install redux-sentry
package from npm:
npm i --save redux-sentry
redux-sentry
can be used in cases:
- Raven has been initialized before
/* store.js */
import { SENTRY_SETTINGS, VERSION } from './constants';
import { createStore, applyMiddleware, compose, combineReducers } from 'redux';
import createSentryMiddleware from 'redux-sentry';
const sentryMiddleware = createSentryMiddleware();
// Add sentry middleware to your list of middlewares
const middlewares = [ sentryMiddleware ];
// Enhance your store by using sentry's enhancer
const toEnhance = [
applyMiddleware(...middlewares)
];
// Put it all together
const enhancer = compose(...toEnhance);
const reducers = combineReducers({
// combined reducers
});
const initialState = {}
const store = createStore(reducers, initialState, enhancer);
export default store;
- Raven hasn't been initialized. It should be configured by params
/* store.js */
import { SENTRY_SETTINGS, VERSION } from './constants';
import { createStore, applyMiddleware, compose, combineReducers } from 'redux';
import createSentryMiddleware from 'redux-sentry';
const sentryMiddleware = createSentryMiddleware({
dsn: SENTRY_SETTINGS.DSN,
configuration: {
release: VERSION,
collectWindowErrors: true
},
username: parse(document.cookie).login
});
// Add sentry middleware to your list of middlewares
const middlewares = [ sentryMiddleware ];
// Enhance your store by using sentry's enhancer
const toEnhance = [
applyMiddleware(...middlewares)
];
// Put it all together
const enhancer = compose(...toEnhance);
const reducers = combineReducers({
// combined reducers
});
const initialState = {}
const store = createStore(reducers, initialState, enhancer);
export default store;
import createSentryMiddleware from 'redux-sentry';
Middleware that logs all your store and actions on exception to Sentry with raven-js
DSN
– Data Source Name. Unique name generated for the project by you Sentry.
Raven configuration object. Full list of keys can be found here.
Default: Guest
username
used for setting user context.
Raven.setUserContext({ username });
Default:
{
actionTransform: a => a,
stateTransform: a => a.toJS()
}
Functions used for cooking action object, store for Raven's extra
field.
stateTransform
uses toJS from immutable.js to convert state back to raw JavaScript object.
- Provide conventional commit messages by using
npm run commit
instead ofgit commit
. - Core contributors: use GitHub's Rebase and merge as a default way of merging PRs.
MIT © AuRu