Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tucnak/store
A dead simple configuration manager for Go applications
https://github.com/tucnak/store
Last synced: about 1 month ago
JSON representation
A dead simple configuration manager for Go applications
- Host: GitHub
- URL: https://github.com/tucnak/store
- Owner: tucnak
- License: mit
- Created: 2015-10-03T19:17:28.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2023-07-14T15:44:13.000Z (11 months ago)
- Last Synced: 2024-01-08T14:33:02.180Z (5 months ago)
- Language: Go
- Size: 12.7 KB
- Stars: 275
- Watchers: 7
- Forks: 22
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Lists
- awesome-go - store - Lightweight configuration manager for Go. (Configuration / Standard CLI)
- awesome-go - store - Lightweight configuration manager for Go. (Configuration / Standard CLI)
- awesome-go-extra - store - 10-03T19:17:28Z|2017-09-05T11:38:35Z| (Configuration / Advanced Console UIs)
- awesome-go - store - Lightweight configuration manager for Go. (Configuration / Standard CLI)
- awesome-go - store - Lightweight configuration manager for Go. (Configuration / Advanced Console UIs)
- awesome-go - store - Lightweight configuration manager for Go. (Configuration / Standard CLI)
- fucking-awesome-go - :octocat: store - A lightweight configuration manager for Go :star: 41 :fork_and_knife: 2 (Configuration / Advanced Console UIs)
- awesome-go - store - Lightweight configuration manager for Go. (Configuration / Advanced Console UIs)
- awesome-go-projects - store - Lightweight configuration manager for Go. (Configuration / Standard CLI)
- awesome-go - store
- awesome-go - store - A lightweight configuration manager for Go (Configuration / Advanced Console UIs)
- awesome-go-with-framework - store - Lightweight configuration manager for Go. (Configuration / Advanced Console UIs)
- awesome-go - store - Lightweight configuration manager for Go. (Configuration / Standard CLI)
- awesome-go-cn - store
- awesome-go - store - Lightweight configuration manager for Go. (Configuration / Advanced Console UIs)
- awesome-go - store - Go的轻量级配置管理器。 (<span id="组态-configuration">组态 Configuration</span> / <span id="高级控制台用户界面-advanced-console-uis">高级控制台用户界面 Advanced Console UIs</span>)
- awesome-go. - store - Lightweight configuration manager for Go. (Configuration / Advanced Console UIs)
- awesome-go-zh - store
- awesome-go-cn - store - 轻量级配置管理 (配置 / 高级控制台界面)
- awesome-go-with-stars - store - Lightweight configuration manager for Go. (Configuration / Standard CLI)
- awesome-go - store - Lightweight configuration manager for Go. (Configuration / Advanced Console UIs)
- repo-1316-awesome-go-cn - store
- repo-1211-awesome-go-cn - store
- awesome-Char - store - Lightweight configuration manager for Go. (Configuration / Advanced Console UIs)
- awesome-reader - store - Lightweight configuration manager for Go. (Configuration / Advanced Console UIs)
- awesome-go - store - Lightweight configuration manager for Go. (Configuration / Advanced Console UIs)
- Go-awesome - store - Lightweight configuration manager for Go. (Configuration / Standard CLI)
- awesome-go-cn - store
- awesome-go-cn - store
- awesome-go - store - A lightweight configuration manager for Go (Configuration / Advanced Console UIs)
- awesome-go-handwritten - store - Lightweight configuration manager for Go. (Configuration / Advanced Console UIs)
- awesome-go - store - 輕量級配置管理 (配置 / 高級控制台界面)
- awesome-go - store - Lightweight configuration manager for Go. (Configuration / Standard CLI)
- awesome-go2 - store - Lightweight configuration manager for Go. (Configuration / Advanced Console UIs)
- awesome-go - store - Lightweight configuration manager for Go. (Configuration / Advanced Console UIs)
- awesome-go - store - Lightweight configuration manager for Go. - :arrow_down:1 - :star:202 (Configuration / Advanced Console UIs)
- awesome-go - store - Lightweight configuration manager for Go. (Configuration / Advanced Console UIs)
- awesome-go - store - A lightweight configuration manager for Go (Configuration / Advanced Console UIs)
- awesome-go-stars - store(stars: 276) - Lightweight configuration manager for Go. (Configuration / Standard CLI)
- awesome-go-cn - store
- awesome-go - store - A dead simple configuration manager for Go applications - ★ 235 (Configuration)
- awesome-go - store - Lightweight configuration manager for Go. (Configuration / Standard CLI)
- awesome-go - store - Lightweight configuration manager for Go. (Configuration / Standard CLI)
- awesome-go-cn - store
README
# Store
>Store is a dead simple configuration manager for Go applications.[![GoDoc](https://godoc.org/github.com/tucnak/store?status.svg)](https://godoc.org/github.com/tucnak/store)
I didn't like existing configuration management solutions like [globalconf](https://github.com/rakyll/globalconf), [tachyon](https://github.com/vektra/tachyon) or [viper](https://github.com/spf13/viper). First two just don't feel right and viper, imo, a little overcomplicated—definitely offering too much for small things. Store supports either JSON, TOML or YAML out-of-the-box and lets you register practically any other configuration format. It persists all of your configurations in either $XDG_CONFIG_HOME or $HOME on Linux and in %APPDATA%
on Windows.Look, when I say it's dead simple, I actually mean it:
```go
package mainimport (
"log"
"time""github.com/tucnak/store"
)func init() {
// You must init store with some truly unique path first!
store.Init("cats-n-dogs/project-hotel")
}type Cat struct {
Name string `toml:"naym"`
Clever bool `toml:"ayy"`
}type Hotel struct {
Name string
Cats []Cat `toml:"guests"`Opens *time.Time
Closes *time.Time
}func main() {
var hotel Hotelif err := store.Load("hotel.toml", &hotel); err != nil {
log.Println("failed to load the cat hotel:", err)
return
}// ...
if err := store.Save("hotel.toml", &hotel); err != nil {
log.Println("failed to save the cat hotel:", err)
return
}
}
```Store supports any other formats via the handy registration system: register the format once and you'd be able to Load and Save files in it afterwards:
```go
store.Register("ini", ini.Marshal, ini.Unmarshal)err := store.Load("configuration.ini", &object)
// ...
```