public
Created

Example session with tagging support in the Wallaby client library

  • Download Gist
gistfile1.py
Python
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35
import wallaby
 
# the "tagging" module patches the Wallaby client library with
# support for tag operations
import tagging
 
# We'll start by setting up a Wallaby client library session against
# the broker on localhost
from qmf.console import Session
console = Session()
console.addBroker()
raw_store, = console.getObjects(_class="Store")
store = wallaby.Store(raw_store, console)
 
# call this method after the store client is initialized so that
# the tagging library knows how to create missing groups
tagging.setup(store)
 
# Clear out all of the memberships on a fake node
store.getNode("fake-node.example.com").modifyMemberships("REPLACE", [], {})
 
# After clearing a node's membership list, it will have no tags
store.getNode("fake-node.example.com").getTags()
 
# You can also access the tags of a given node via its "tags" attribute
store.getNode("fake-node.example.com").tags
 
# by convention, we're preceding tags with "@" here
store.getNode("fake-node.example.com").modifyTags("ADD", ["@Foo", "@Blitz"], create_missing_tags=True)
 
# This should return ["@Foo", "@Blitz"]
store.getNode("fake-node.example.com").tags
 
# This should return ["===TAGS_BELOW===", "@Foo", "@Blitz"]
store.getNode("fake-node.example.com").memberships

Please sign in to comment on this gist.

Something went wrong with that request. Please try again.