authExample.go 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. package main
  2. import (
  3. "fmt"
  4. "net/http"
  5. dbConn "github.com/porter-dev/porter/internal/adapter"
  6. sessionstore "github.com/porter-dev/porter/internal/auth"
  7. )
  8. var db, dbErr = dbConn.New()
  9. var (
  10. key = []byte("secret") // change to os.Getenv("SESSION_KEY")
  11. store, _ = sessionstore.NewStore(db, key)
  12. )
  13. func secret(w http.ResponseWriter, r *http.Request) {
  14. session, _ := store.Get(r, "cookie-name")
  15. fmt.Println(session.Values["authenticated"])
  16. // Check if user is authenticated
  17. if auth, ok := session.Values["authenticated"].(bool); !ok || !auth {
  18. http.Error(w, "Forbidden", http.StatusForbidden)
  19. return
  20. }
  21. // Print secret message
  22. fmt.Fprintln(w, "The cake is a lie!")
  23. }
  24. func login(w http.ResponseWriter, r *http.Request) {
  25. session, _ := store.Get(r, "cookie-name")
  26. // Authentication goes here
  27. // ...
  28. // Set user as authenticated
  29. session.Values["authenticated"] = true
  30. session.Save(r, w)
  31. }
  32. func logout(w http.ResponseWriter, r *http.Request) {
  33. session, _ := store.Get(r, "cookie-name")
  34. // Revoke users authentication
  35. session.Values["authenticated"] = false
  36. session.Save(r, w)
  37. }
  38. func main() {
  39. http.HandleFunc("/secret", secret)
  40. http.HandleFunc("/login", login)
  41. http.HandleFunc("/logout", logout)
  42. http.ListenAndServe(":8080", nil)
  43. }