Etcd watcher for Casbin

Clone this repo:
  1. d70f304 feat: fix panic on empty Events array in etcd watch response (#36) by Yang Luo · 8 weeks ago master v2.5.0
  2. 2f2c69e feat: fix CI, replace deprecated go get with go install for goveralls (#35) by Yang Luo · 8 weeks ago v2.4.0
  3. c7a6985 feat: fix CI bug in "quay.io/coreos/etcd:latest" by Yang Luo · 8 weeks ago
  4. 74f390d feat: improve CI and README badges (#33) by Yang Luo · 8 weeks ago
  5. f24b286 feat: remove Travis CI script by Yang Luo · 8 weeks ago

Etcd Watcher

Go Report Card Go Coverage Status Go Reference Release Discord Sourcegraph

Etcd Watcher is the Etcd watcher for Casbin. With this library, Casbin can synchronize the policy with the database in multiple enforcer instances.

Installation

go get github.com/casbin/etcd-watcher/v2

Simple Example

package main

import (
    "log"

    casbin "github.com/casbin/casbin/v2"
    etcdwatcher "github.com/casbin/etcd-watcher/v2"
)

func updateCallback(rev string) {
    log.Println("New revision detected:", rev)
}

func main() {
    // Initialize the watcher.
    // Use the endpoint of etcd cluster as parameter.
    w, _ := etcdwatcher.NewWatcher([]string{"http://127.0.0.1:2379"}, "keyname")
    
    // Initialize the enforcer.
    e, _ := casbin.NewEnforcer("examples/rbac_model.conf", "examples/rbac_policy.csv")
    
    // Set the watcher for the enforcer.
    e.SetWatcher(w)
    
    // By default, the watcher's callback is automatically set to the
    // enforcer's LoadPolicy() in the SetWatcher() call.
    // We can change it by explicitly setting a callback.
    w.SetUpdateCallback(updateCallback)
    
    // Update the policy to test the effect.
    // You should see "[New revision detected: X]" in the log.
    e.SavePolicy()
}

Simple Example(Configuration Mode)

package main

import (
    "log"

    casbin "github.com/casbin/casbin/v2"
    etcdwatcher "github.com/casbin/etcd-watcher/v2"
)

func updateCallback(rev string) {
    log.Println("New revision detected:", rev)
}

func main() {
    // Initialize the watcher.
    // Use the configuration file as the parameter
	w, _ := etcdwatcher.NewWatcherWithConfig(etcdwatcher.WatcherConfig{
		Hosts: []string{"http://127.0.0.1:2379"},
		Key:   "/casbin",
		User:  "root",
		Pass:  "123",
	})
    
    // Initialize the enforcer.
    e, _ := casbin.NewEnforcer("examples/rbac_model.conf", "examples/rbac_policy.csv")
    
    // Set the watcher for the enforcer.
    e.SetWatcher(w)
    
    // By default, the watcher's callback is automatically set to the
    // enforcer's LoadPolicy() in the SetWatcher() call.
    // We can change it by explicitly setting a callback.
    w.SetUpdateCallback(updateCallback)
    
    // Update the policy to test the effect.
    // You should see "[New revision detected: X]" in the log.
    e.SavePolicy()
}

Getting Help

License

This project is under Apache 2.0 License. See the LICENSE file for the full license text.