Skip to content

pmsl/parse-go

 
 

Repository files navigation

parse-go

Parse.com API Client Library

This package provides a client for Parse's REST API. So far, it supports most of the query operations provided by Parse's Javascript library, with a few exceptions (listed below under TODO).

###Installation

go get github.com/ihoukai/parse-go ###Documentation Full documentation is provided by godoc.org

###Usage:

package main

import ( "fmt" "time"

parse "github.com/ihoukai/parse-go"

)

func main() { parse.Initialize("APP_ID", "REST_KEY", "MASTER_KEY") // master key is optional

user := parse.User{}
q, err := parse.NewQuery(&user)
if err != nil {
	panic(err)
}
q.EqualTo("email", "[email protected]")
q.GreaterThan("numFollowers", 10).OrderBy("-createdAt") // API is chainable
err := q.First()
if err != nil {
    if pe, ok := err.(parse.ParseError); ok {
        fmt.Printf("Error querying parse: %d - %s\n", pe.Code(), pe.Message())
    }
}

fmt.Printf("Retrieved user with id: %s\n", u.Id)

q2, _ := parse.NewQuery(&parse.User{})
q2.GreaterThan("createdAt", time.Date(2014, 01, 01, 0, 0, 0, 0, time.UTC))

rc := make(chan *parse.User)

// .Each will retrieve all results for a query and send them to the provided channel
// The iterator returned allows for early cancelation of the iteration process, and
// stores any error that triggers early termination
iterator, err := q2.Each(rc)
for u := range rc{
	fmt.Printf("received user: %v\n", u)
	// Do something
	if err := process(u); err != nil {
		// Cancel if there was an error
		iterator.Cancel()
	}
}

// An error occurred - not all rows were processed
if it.Error() != nil {
	panic(it.Error())
}

} ###TODO

Missing query operations Related to Missing CRUD operations: Update Field ops (__op): AddRelation RemoveRelation Roles Background Jobs Analytics File upload/retrieval Batch operations

About

Parse.com API Client Library

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Go 100.0%