Documentation ¶
Overview ¶
Package aetools helps writting, testing and analysing Google App Engine applications.
The aetools package implements a simple API to export the entity data from Datastore as a JSON stream, as well as load a JSON stream back into the Datastore. This can be used as a simple way to express state into a unit test, to backup a development environment state that can be shared with team members, or to make quick batch changes to data offline, like setting up configuration entities via Remote API.
The goal is to provide both an API and a set of executable tools that uses that API, allowing for maximum flexibility.
Load and Dump Data Format ¶
The functions Load, LoadJSON, Dump and DumpJSON operate using JSON data that represents datastore entities. Each entity is mapped to a JSON Object, where each entity property name is an Object atribute, and each property value is the corresponding Object atribute value.
The property value is encoded using a JSON primitive, when possible. When the primitives are not sufficient to represent the property value, a JSON Object with the attributes "type" and "value" is used. The "type" attribute is a Datastore type, and value is a json-primitive serialization of that value. For instance, Blobs are encoded as a base64 JSON string, and time.Time values are encoded using the time.RFC3339 layout, also as strings.
Datastore Keys are aways encoded as a JSON Array that represents the Key Path, including ancestors, but without the application ID. This is done to allow the entity key to be more readable and to be application independent. Currently, they don't support namespaces.
Multiple properties are represented as a JSON Array of values described above. Unindexed properties are aways JSON objects with the "indexed" attribute set to false.
This format is intended to make use of the JSON types as much as possible, so an entity can be easily represented as a text file, suitable for read or SCM checkin.
The exported data format can also be used as an alternative way to export from Datastore, and then load the results right into other service, such as Google BigQuery or MongoDB.
The Web Bundle ¶
The package aetools/bundle contains a sample webapp to help you manage and stream datastore entities into BigQuery. The bundle uses the aetools/bigquerysync functions to infer an usefull schema from datastore statistics, and sync your entity data into BigQuery.
The Remote API CLI ¶
The command aetools/remote_api is a Remote API client that exposes the Load and Dump functions to make backup and restore of development environment state quick and easy. This tool can also help setting up Q.A. or Production apps, but should be used with care.
Index ¶
- Constants
- Variables
- func Dump(c appengine.Context, w io.Writer, o *Options) error
- func DumpJSON(c appengine.Context, o *Options) (string, error)
- func EncodeEntities(entities []Entity, w io.Writer) error
- func KeyPath(k *datastore.Key) string
- func Load(c appengine.Context, r io.Reader, o *Options) error
- func LoadJSON(c appengine.Context, s string, o *Options) error
- type DumpOptions
- type Entity
- func (e *Entity) Add(p datastore.Property)
- func (e *Entity) Get(name string) interface{}
- func (e *Entity) GetBool(name string) bool
- func (e *Entity) GetFloat(name string) float64
- func (e *Entity) GetInt(name string) int64
- func (e *Entity) GetString(name string) string
- func (e *Entity) Load(c <-chan datastore.Property) error
- func (e *Entity) Map() (map[string]interface{}, error)
- func (e *Entity) MarshalJSON() ([]byte, error)
- func (e *Entity) Save(c chan<- datastore.Property) error
- type Options
Constants ¶
const ( // DateTimeFormat is used to store and load time.Time objects DateTimeFormat = time.RFC3339 )
Variables ¶
var ( // ErrInvalidRootElement is returned when the root element is not a valid JSON Array. ErrInvalidRootElement = errors.New("aetools: root object is not an array") // ErrInvalidElementType is retunred when the element is not a JSON Object. ErrInvalidElementType = errors.New("aetools: element is not a JSON object") // ErrInvalidPropertiesElement is returned when the field to be decoded is not valid. ErrInvalidPropertiesElement = errors.New("aetools: element's properties field is invalid") // ErrNoKeyElement is returned for an entity with missing key information. ErrNoKeyElement = errors.New("aetools: element's key field is not present") // ErrInvalidKeyElement is returned when the key is not properly encoded. ErrInvalidKeyElement = errors.New("aetools: element's key field is invalid") )
var ( // LoadSync is an aetools.Options that enforces data to sync // after it get loaded into the datastore. // This Options will cause a datastore.Get to happen // for each entity loaded. LoadSync = &Options{ GetAfterPut: true, } )
Functions ¶
func Dump ¶
Dump exports entities from the context c using the specified Options o and writing the generated JSON representations to the io.Writer w. You can configure how the dump will run by using the Options parameter. If there is an error generating the output, or writting to the writer, it is returned. This method may return an error after writting bytes to w: the output is not buffered.
func DumpJSON ¶
DumpJSON is a convenient wrapper that captures the generated JSON from Dump in memory, and return it as a string. If Dump returns an error, an empty string and the error are returned.
func EncodeEntities ¶
EncodeEntities serializes the parameter into a JSON string.
func KeyPath ¶
KeyPath returns a representation of a Key as a string with each value in the key path separated by a coma. The key representation has all ancestors, but has no information about namespaces or ancestors.
func Load ¶
Load reads the JSON representation of entities from the io.Reader "r", and stores them in the Datastore using the given appengine.Context. The Options parameter allows you to configure how the dump will work. If there is any parsing erros, improper format, or datastore failures during the process, that error is returned and processing stops. The error may be returned after some entities were loaded: there is no parsing cache.
Types ¶
type DumpOptions ¶
type DumpOptions struct {
Options
}
DumpOptions is deprecated. Use Options instead.
type Entity ¶
type Entity struct { Key *datastore.Key Properties datastore.PropertyList }
Entity is a small wrapper around datastore.PropertyList to also hold a *datastore.Key.
func DecodeEntities ¶
DecodeEntities deserielizes the parameter from a JSON string
func (*Entity) Get ¶
Get returns the property value of the given name. If no property with that name exists, returns nil. It also returns nil if the property Value attribute is nil.
func (*Entity) GetBool ¶
GetBool returns the string value of the named property, and returns the zero value (false) if the property is not found, if its value is nil, or if its type is not bool.
func (*Entity) GetFloat ¶
GetFloat returns the string value of the named property, and returns the zero value (0.0) if the property is not found, if its value is nil or if its type is not float32 or float64.
func (*Entity) GetInt ¶
GetInt returns the int value of the named property, and returns the zero value (0) if the property is not found, if its value is nil or if its type is not int, int32 or int64.
func (*Entity) GetString ¶
GetString returns the string value of the named property, and returns the zero value ("") if the property is not found, if its value is nil or if its type is not string.
func (*Entity) Load ¶
Load decodes all properties into Entity.Propertioes object, implementing the datastore.PropertyLoadSaver interface.
func (*Entity) Map ¶
Map converts the entity data into a JSON compatible map. Usefull to manually encode the entity using different marshallers than the JSON built-in.
func (*Entity) MarshalJSON ¶
MarshalJSON implements the json.Marshaller interface by dumping the entity key and properties.
type Options ¶
type Options struct { // GetAfterPut indicates if we must force the Datastore to load // entities to be visible for non-ancestor queries, by issuing a // Get by key. // Not used when loading. GetAfterPut bool // The size for batch operations when loading/dumping BatchSize int // Kind is used to specify the kind when dumping. // Not used when loading. Kind string // PrettyPrint is used to specify if the dump should beaultify the output. // Not used when loading. PrettyPrint bool }
Options allows callees to specify parameters to the Load function.
Directories ¶
Path | Synopsis |
---|---|
Command aeremote is a simple Remote API client to download and upload data to your app.
|
Command aeremote is a simple Remote API client to download and upload data to your app. |
Package aestubs provides a set of App Engine service stubs and a configurable appengine.Context implementation.
|
Package aestubs provides a set of App Engine service stubs and a configurable appengine.Context implementation. |
Package bigquerysync allow the AppEngine Datastore to be synced with Google BigQuery.
|
Package bigquerysync allow the AppEngine Datastore to be synced with Google BigQuery. |
Package bundle is a self-contained appengine module with aetools.
|
Package bundle is a self-contained appengine module with aetools. |
The serviceaccount package provides support for making OAuth2-authorized HTTP requests from App Engine using service accounts.
|
The serviceaccount package provides support for making OAuth2-authorized HTTP requests from App Engine using service accounts. |