
Research
PyPI Package Disguised as Instagram Growth Tool Harvests User Credentials
A deceptive PyPI package posing as an Instagram growth tool collects user credentials and sends them to third-party bot services.
redux-async-initial-state
Advanced tools
It is simple redux middleware that helps you load redux initial state asynchronously
Redux middleware for async loading of initial app state.
npm install --save redux-async-initial-state
With redux it is quite simple to synchronously load initial state, i.e. from localStorage:
...
const initialState = JSON.parse(localStorage.getItem('state'));
const store = storeCreator(reducer, initialState);
But it becomes quite complicated to do it asynchronously, i.e. from server or from async storage, like in React Native. This middleware do it for you.
npm install --save redux-async-initial-state
before:
import { createStore } from 'redux'
import * as reducers from 'reducers'
const reducer = combineReducers(reducers)
const store = createStore(reducer)
After
import { createStore, applyMiddleware } from 'redux';
import * as reducers from 'reducers';
import { * as asyncInitialState } from 'redux-async-initial-state';
// We need outerReducer to replace full state as soon as it loaded
const reducer = asyncInitialState.outerReducer(combineReducers({
...reducers,
// We need innerReducer to store loading state, i.e. for showing loading spinner
// If you don't need to handle loading state you may skip it
asyncInitialState: asyncInitialState.innerReducer,
}));
// Load state function
// Should return promise that resolves application state
const loadStore = () => {
return new Promise(resolve => {
fetch('/store')
.then(response => response.json())
.then(resolve);
});
}
const storeCreator = applyMiddleware(asyncInitialState.middleware(loadStore));
const store = storeCreator(reducer);
The shape of innerReducer
is:
{
loaded: false,
loading: false,
error: false
}
You can add it to you reducer if you want to handle loading state, i.e. to show loading spinner. Here is React example (it uses reducer, described above):
import { connect } from 'react-redux';
@connect(state => ({
loading: state.asyncInitialState.loading,
}))
class MyComponent extends React.Component {
render() {
if (this.props.loading) {
return <div>Loading...</div>
}
return ...;
}
}
FAQs
It is simple redux middleware that helps you load redux initial state asynchronously
The npm package redux-async-initial-state receives a total of 7,748 weekly downloads. As such, redux-async-initial-state popularity was classified as popular.
We found that redux-async-initial-state demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
A deceptive PyPI package posing as an Instagram growth tool collects user credentials and sends them to third-party bot services.
Product
Socket now supports pylock.toml, enabling secure, reproducible Python builds with advanced scanning and full alignment with PEP 751's new standard.
Security News
Research
Socket uncovered two npm packages that register hidden HTTP endpoints to delete all files on command.