Fuego is a Go client library for Google Firestore. It can be used in App Engine, Cloud Run, Google Cloud Functions and more.
It does not do anything crazy or magic – the purpose is to reduce the amount of boilerplate by hiding the ceremony that comes with interacting with Firestore.
While working on a project running on multiple services and serverless functions, I quickly realised that the amount of repetitive and boilerplate code related to Firestore increased exponentially.
I decided to extract this code in a thin layer on top of the Firestore admin client. That's how fuego came to life.
- CRUD operations
- Retrieving/Updating specific fields only
- Simple Exists check
- Write Batches
- Batch processing (update field for all, delete all, etc.)
- Better flexibility with Arrays and Maps (append/merge or override data)
go get github.com/remychantenay/fuego
import "github.com/remychantenay/fuego"
func main() {
fuegoClient := fuego.New(firestoreClient) // firestoreClient needs to be created beforehand.
/// Your code here...
}
Bear in mind that the examples below are not including how to initialize Firebase and nor create the Firestore client. Check Firebase's documentation for more info.
type User struct {
FirstName string `firestore:"FirstName"`
LastName string `firestore:"LastName"`
EmailAddress string `firestore:"EmailAddress"`
Address string `firestore:"Address"`
Tokens map[string]string `firestore:"Tokens"`
}
func main() {
user := User{
FirstName: "John",
LastName: "Smith",
EmailAddress: "jsmith@email.com",
Address: []string{"123 Street", "2nd Building"},
Tokens: map[string]string{
"Android": "cHzDGYfl5G8vnNCd9xQsbZ:APA...",
},
}
err := fuegoClient.Document("users", "jsmith").Create(ctx, user)
if err != nil {
panic(err)
}
}
user := User{}
err := fuegoClient.Document("users", "jsmith").Retrieve(ctx, &user)
if err != nil {
panic(err)
}
fmt.Println("LastName: ", user.LastName) // prints: Smith
You also may want to only check if a given document exists without providing a struct:
// Note: false will be returned if an error occurs as well
value := fuegoClient.Document("users", "jsmith").Exists(ctx)
fmt.Println("Exists: ", value)
Please read the doc to see all the documents related operations.
Below the list of operations available for collections (read the doc for more details):
Operation | Description | Additional Information |
---|---|---|
Retrieve | Retrieve all documents from a collection. | |
RetrieveWith | Retrieve documents from a collection (if they meet the criteras). | Uses firestore.Query. |
SetForAll | Set a field value for all documents in the collection | Uses Write Batches. |
DeleteAll | Removes all documents from a collection. | Uses Write Batches. |
Please read the doc to see all the collections related operations.
Write Batches allow to group writes together to avoid multiple round trips. They are NOT transactions. More info here.
IMPORTANT: not all operations are compatible with Write Batches.
fuegoClient.StartBatch()
// All **supported** operations executed between here and commit will be batched.
fuegoClient.Document("users", "jsmith").Number("Age").Update(33)
fuegoClient.Document("users", "enorton").String("FirstName").Update("Eddy")
fuegoClient.Document("users", "jdoe").Boolean("Premium").Update(true)
wr, err := fuegoClient.CommitBatch(ctx)
if err != nil {
panic(err)
}
- Start the Firestore emulator:
firebase emulators:start --only firestore
- Run the tests
go test . -v
- Firebase:
firebase.google.com/go
- Firestore:
cloud.google.com/go/firestore
More info here
Apache License Version 2.0