Merge branch 'master' of https://github.com/yosssi/boltstore
This commit is contained in:
commit
3602e5dd2b
1 changed files with 14 additions and 19 deletions
33
README.md
33
README.md
|
@ -32,49 +32,44 @@ import (
|
||||||
var db *bolt.DB
|
var db *bolt.DB
|
||||||
|
|
||||||
func handler(w http.ResponseWriter, r *http.Request) {
|
func handler(w http.ResponseWriter, r *http.Request) {
|
||||||
if r.URL.Path[1:] == "favicon.ico" {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
// Fetch a new store.
|
// Fetch a new store.
|
||||||
str, err := store.New(
|
str, err := store.New(db, store.Config{}, []byte("secret-key"))
|
||||||
db,
|
if err != nil {
|
||||||
store.Config{
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
||||||
SessionOptions: sessions.Options{
|
}
|
||||||
MaxAge: 60 * 60 * 24 * 30, // 30days
|
|
||||||
},
|
|
||||||
},
|
|
||||||
[]byte("secret-key"),
|
|
||||||
)
|
|
||||||
|
|
||||||
// Get a session.
|
// Get a session.
|
||||||
session, err := str.Get(r, "session-key")
|
session, err := str.Get(r, "session-key")
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Add a value.
|
// Add a value on the session.
|
||||||
session.Values["foo"] = "bar"
|
session.Values["foo"] = "bar"
|
||||||
|
|
||||||
// Save the session.
|
// Save the session.
|
||||||
if err := sessions.Save(r, w); err != nil {
|
if err := sessions.Save(r, w); err != nil {
|
||||||
panic(err)
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Delete the session.
|
// Delete the session.
|
||||||
session.Options.MaxAge = -1
|
session.Options.MaxAge = -1
|
||||||
if err := sessions.Save(r, w); err != nil {
|
if err := sessions.Save(r, w); err != nil {
|
||||||
panic(err)
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
||||||
}
|
}
|
||||||
|
|
||||||
fmt.Fprintf(w, "Hello BoltStore")
|
fmt.Fprintf(w, "Hello BoltStore")
|
||||||
}
|
}
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
|
var err error
|
||||||
// Open a Bolt database.
|
// Open a Bolt database.
|
||||||
db, _ = bolt.Open("./sessions.db", 0666)
|
db, err = bolt.Open("./sessions.db", 0666)
|
||||||
|
if err != nil {
|
||||||
|
panic(err)
|
||||||
|
}
|
||||||
defer db.Close()
|
defer db.Close()
|
||||||
// Invoke a reaper which removes expired sessions.
|
// Invoke a reaper which checks and removes expired sessions periodically.
|
||||||
defer reaper.Quit(reaper.Run(db, reaper.Options{}))
|
defer reaper.Quit(reaper.Run(db, reaper.Options{}))
|
||||||
http.HandleFunc("/", handler)
|
http.HandleFunc("/", handler)
|
||||||
http.ListenAndServe(":8080", nil)
|
http.ListenAndServe(":8080", nil)
|
||||||
|
|
Loading…
Reference in a new issue