Extract EtcdHelper interface
This commit is contained in:
@@ -17,9 +17,12 @@ limitations under the License.
|
||||
package tools
|
||||
|
||||
import (
|
||||
"github.com/GoogleCloudPlatform/kubernetes/pkg/runtime"
|
||||
"github.com/coreos/go-etcd/etcd"
|
||||
"time"
|
||||
|
||||
"github.com/GoogleCloudPlatform/kubernetes/pkg/runtime"
|
||||
"github.com/GoogleCloudPlatform/kubernetes/pkg/watch"
|
||||
|
||||
"github.com/coreos/go-etcd/etcd"
|
||||
)
|
||||
|
||||
const (
|
||||
@@ -64,3 +67,108 @@ type EtcdVersioner interface {
|
||||
// Should return an error if the specified object does not have a persistable version.
|
||||
ObjectResourceVersion(obj runtime.Object) (uint64, error)
|
||||
}
|
||||
|
||||
// ResponseMeta contains information about the etcd metadata that is associated with
|
||||
// an object. It abstracts the actual underlying objects to prevent coupling with etcd
|
||||
// and to improve testability.
|
||||
type ResponseMeta struct {
|
||||
// TTL is the time to live of the node that contained the returned object. It may be
|
||||
// zero or negative in some cases (objects may be expired after the requested
|
||||
// expiration time due to server lag).
|
||||
TTL int64
|
||||
// Expiration is the time at which the node that contained the returned object will expire and be deleted.
|
||||
// This can be nil if there is no expiration time set for the node.
|
||||
Expiration *time.Time
|
||||
// The resource version of the node that contained the returned object.
|
||||
ResourceVersion uint64
|
||||
}
|
||||
|
||||
// Pass an StorageUpdateFunc to StorageInterface.GuaranteedUpdate to make an update
|
||||
// that is guaranteed to succeed.
|
||||
// See the comment for GuaranteedUpdate for more details.
|
||||
type StorageUpdateFunc func(input runtime.Object, res ResponseMeta) (output runtime.Object, ttl *uint64, err error)
|
||||
|
||||
// StorageInterface offers a common interface for object marshaling/unmarshling operations and
|
||||
// hids all the storage-related operations behind it.
|
||||
type StorageInterface interface {
|
||||
// CreateObj adds a new object at a key unless it already exists. 'ttl' is time-to-live
|
||||
// in seconds (0 means forever). If no error is returned and out is not nil, out will be
|
||||
// set to the read value from etcd.
|
||||
//
|
||||
// TODO(wojtekt): Rename to Create().
|
||||
CreateObj(key string, obj, out runtime.Object, ttl uint64) error
|
||||
|
||||
// SetObj marshals obj via json and stores in etcd under key. Will do an atomic update
|
||||
// if obj's ResourceVersion field is set. 'ttl' is time-to-live in seconds (0 means forever).
|
||||
// If no error is returned and out is not nil, out will be set to the read value from etcd.
|
||||
//
|
||||
// TODO(wojtekt): Rename to Set() (or Update?).
|
||||
SetObj(key string, obj, out runtime.Object, ttl uint64) error
|
||||
|
||||
// DeleteObj removes the specified key and returns the value that existed at that spot.
|
||||
//
|
||||
// TODO(wojtekt): Rename to Delete().
|
||||
DeleteObj(key string, out runtime.Object) error
|
||||
|
||||
// Delete removes the specified key.
|
||||
//
|
||||
// TODO(wojtekt): Unify it with DeleteObj().
|
||||
Delete(key string, recursive bool) error
|
||||
|
||||
// Watch begins watching the specified key. Events are decoded into API objects,
|
||||
// and any items passing 'filter' are sent down to returned watch.Interface.
|
||||
// resourceVersion may be used to specify what version to begin watching
|
||||
// (e.g. reconnecting without missing any updates).
|
||||
Watch(key string, resourceVersion uint64, filter FilterFunc) (watch.Interface, error)
|
||||
|
||||
// WatchList begins watching the specified key's items. Items are decoded into API
|
||||
// objects and any item passing 'filter' are sent down to returned watch.Interface.
|
||||
// resourceVersion may be used to specify what version to begin watching
|
||||
// (e.g. reconnecting without missing any updates).
|
||||
WatchList(key string, resourceVersion uint64, filter FilterFunc) (watch.Interface, error)
|
||||
|
||||
// ExtractObj unmarshals json found at key into objPtr. On a not found error, will either
|
||||
// return a zero object of the requested type, or an error, depending on ignoreNotFound.
|
||||
// Treats empty responses and nil response nodes exactly like a not found error.
|
||||
//
|
||||
// TODO(wojtekt): Rename to Get().
|
||||
ExtractObj(key string, objPtr runtime.Object, ignoreNotFound bool) error
|
||||
|
||||
// ExtractObjToList unmarshals json found at key and opaque it into *List api object
|
||||
// (an object that satisfies the runtime.IsList definition).
|
||||
//
|
||||
// TODO(wojtekt): Rename to GetToList().
|
||||
ExtractObjToList(key string, listObj runtime.Object) error
|
||||
|
||||
// ExtractToList unmarshalls jsons found at directory defined by key and opaque them
|
||||
// into *List api object (an object that satisfies runtime.IsList definition).
|
||||
//
|
||||
// TODO(wojtekt): Rename to List().
|
||||
ExtractToList(key string, listObj runtime.Object) error
|
||||
|
||||
// GuaranteedUpdate keeps calling 'tryUpdate()' to update key 'key' (of type 'ptrToType')
|
||||
// retrying the update until success if there is etcd index conflict.
|
||||
// Note that object passed to tryUpdate may change acress incovations of tryUpdate() if
|
||||
// other writers are simultanously updateing it, to tryUpdate() needs to take into account
|
||||
// the current contents of the object when deciding how the update object should look.
|
||||
//
|
||||
// Exmaple:
|
||||
//
|
||||
// s := /* implementation of StorageInterface */
|
||||
// err := s.GuaranteedUpdate(
|
||||
// "myKey", &MyType{}, true,
|
||||
// func(input runtime.Object, res ResponseMeta) (runtime.Object, *uint64, error) {
|
||||
// // Before each incovation of the user defined function, "input" is reset to
|
||||
// // etcd's current contents for "myKey".
|
||||
// curr := input.(*MyType) // Guaranteed to succeed.
|
||||
//
|
||||
// // Make the modification
|
||||
// curr.Counter++
|
||||
//
|
||||
// // Return the modified object - return an error to stop iterating. Return
|
||||
// // a uint64 to alter the TTL on the object, or nil to keep it the same value.
|
||||
// return cur, nil, nil
|
||||
// }
|
||||
// })
|
||||
GuaranteedUpdate(key string, ptrToType runtime.Object, ignoreNotFound bool, tryUpdate StorageUpdateFunc) error
|
||||
}
|
||||
|
Reference in New Issue
Block a user