This go package aims to provide reflection for the Augeas library.
This allows to turn Augeas lenses into Go structs for easy parsing and modification of configuration files.
import (
"log"
"honnef.co/go/augeas"
"github.com/raphink/narcissus"
)
func main() {
aug, err := augeas.New("/", "", augeas.None)
if err != nil {
log.Fatal("Failed to create Augeas handler")
}
n := narcissus.New(&aug)
user := n.NewPasswdUser("raphink")
if err != nil {
log.Fatalf("Failed to retrieve user: %v" err)
}
log.Printf("UID=%v", user.UID)
// Modify UID
user.UID = 42
err = n.Write(user)
if err != nil {
log.Fatalf("Failed to save user: %v", err)
}
}
Fstab
maps a whole/etc/fstab
fileFstabEntry
maps a single/etc/fstab
entry
Passwd
maps a whole/etc/passwd
filePasswdUser
maps a single/etc/passwd
entry
import (
"log"
"honnef.co/go/augeas"
"github.com/raphink/narcissus"
)
type group struct {
augeasPath string
Name string `narcissus:".,value-from-label"`
Password string `narcissus:"password"`
GID int `narcissus:"gid"`
Users []string `narcissus:"user"`
}
func main() {
aug, err := augeas.New("/", "", augeas.None)
if err != nil {
log.Fatal("Failed to create Augeas handler")
}
n := narcissus.New(&aug)
group := &group{
augeasPath: "/files/etc/group/docker",
}
err = n.Parse(group)
if err != nil {
log.Fatalf("Failed to retrieve group: %v", err)
}
log.Printf("GID=%v", group.GID)
log.Printf("Users=%v", strings.Join(group.Users, ","))
}
The narcissus
tag accepts multiple comma separated values. The first value in
the list is the relative path where the field is mapped in the Augeas tree.
Other possible (optional) values are:
value-from-label
: get field value from the node label instead of its value;seq
(slice field only): will treat field as a seq entry in the Augeas tree;key-from-value
(map field only): get the key from the node label instead of its value;purge
(map field only): purge all unknown keys in the map.
Described structures have special fields to specify parameters for Augeas.
augeasPath
(mandatory): the path to the structure in the Augeas tree;augeasFile
(optional): let Augeas load only this file. IfaugeasLens
is not specified, Augeas will use the default lens for the file if available;augeasLens
(optional): ifaugeasFile
is set (ignored otherwise), specifies which lens to use to parse the file. This is required when parsing a file at a non-standard location.
Each of these fields can be specified in one of two ways:
- by using the
default
tag with a default value for the field, e.g.
type group struct {
augeasPath string `default:"/files/etc/group/root"`
}
- by specifying a value for the instance in the structure field, e.g.
myGroup := group {
augeasPath: "/files/etc/group/docker",
}