Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/luisvinicius167/godux
State Management for Go Backend application inspired in Redux.
https://github.com/luisvinicius167/godux
backend-applications golang redux state
Last synced: 6 days ago
JSON representation
State Management for Go Backend application inspired in Redux.
- Host: GitHub
- URL: https://github.com/luisvinicius167/godux
- Owner: luisvinicius167
- License: mit
- Created: 2016-05-31T01:34:33.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2020-10-04T12:49:00.000Z (over 4 years ago)
- Last Synced: 2025-01-09T10:14:49.868Z (13 days ago)
- Topics: backend-applications, golang, redux, state
- Language: Go
- Homepage:
- Size: 56.6 KB
- Stars: 258
- Watchers: 11
- Forks: 15
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# godux
[![Join the chat at https://gitter.im/luisvinicius167/godux](https://badges.gitter.im/luisvinicius167/godux.svg)](https://gitter.im/luisvinicius167/godux?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)
[![Go Report Card](https://goreportcard.com/badge/github.com/luisvinicius167/godux)](https://goreportcard.com/report/github.com/luisvinicius167/godux)
> State Management for Go Backend applications inspired by Redux.
╔═════════╗ ╔══════════╗ ╔═══════════╗ ╔═════════════════╗
║ Action ║──────>║ Reducer ║ ────> ║ Store ║ ────> ║ Application ║
╚═════════╝ ╚══════════╝ ╚═══════════╝ ╚═════════════════╝
^ │
└────────────────────────────────────────────────────────────┘### Install
* Go: ``` go get github.com/luisvinicius167/godux ```### Data Flow
**godux** gives go unidirectional data flow:* The Action returns a small map with specific directions that are dispatched to a Reducer.
* The Reducer is a pure function (pure functions don't change original arguments) if relevant to it returns a new Value.
* The Value becomes the new State of the Store.### Principles:
* Global application state is held in the Store, as a single map.
* State is ready-only (only *change* it only by *replacing* it with the Reducer).
* Changes are made with pure functions - Actions/Reducers that do not change the actual object but make a changed copy.### Store:
A Store is basically a container that holds your application state.```go
store := godux.NewStore()
store.Setstate("count", 1)
store.Setstate("Title", "I like godux!")
```#### Action
Actions are just pure functions which pass on their inputs when they're dispatched. Actions are stored on the `godux` map as `godux.Action`.```go
increment := func(number int) godux.Action {
return godux.Action{
Type: "INCREMENT",
Value: number,
}
}
```
### Reducers
As in Redux:
> "Actions describe the fact that something happened, but don’t specify how the application’s state changes in response. This is the job of a reducer".Reducers are *pure* functions that take in actions and the state of the store as inputs and leave them all as they came in (aka. pure)-- especially the original state of the store must not be modified (it's accessed by `store.GetState`)).
```go
// reducer function
reducer := func(action godux.Action) interface{} {
switch action.Type {
case "INCREMENT":
return store.GetState("count").(int) + action.Value.(int)
case "DECREMENT":
return action.Value.(int) - store.GetState("count").(int)
default:
return store.GetAllState()
}
}
// Add your reducer function to return new values basend on your state
store.Reducer(reducer)
```
#### Dispatch
Dispatching an action is very easy.
```go
// Receive new value
newCount := store.Dispatch(increment(1)) // return 2
```### API Reference
* #### Store:
* ` godux.newStore() `: Create a single store with the state of your application (should only be used once).
* ` godux.SetState(name string, value interface{}) `: Sets the state of the store.
* ` godux.GetState(name string) `: Return a state's value.
* ` godux.GetAllState() `: Return the whole state as a map.* ##### Reducer:
* ``` store.Reducer(func(action godux.Action)) ```: Adding a reducer function to your Store.* ##### Dispatch:
* ``` store.Dispatch(action godux.Action) ```: Dispatching an action to your Reducer.* #### Action:
* ``` godux.Action( Type string, Value interface{}) ```: Adding an easily available Action.### License
MIT License.