Skip to content
This repository has been archived by the owner on May 17, 2022. It is now read-only.

K.2 Init Firestore

Hadi Tavakoli edited this page Dec 16, 2017 · 1 revision

Initialize Firebase Firestore

You can initialize Firestore by calling Firestore.init(); As soon as you initialized the firebaseFirestore.ane in your project, you will be ready to read and write data to your the Firestore.

NOTE: Make sure you have already initialized the Firebase core before trying any other Firebase child ANEs.

Add data

Cloud Firestore stores data in Documents, which are stored in Collections. Cloud Firestore creates collections and documents implicitly the first time you add data to the document. You do not need to explicitly create collections or documents.

Create a new collection and a document using the following example code.

// Create a new user with a first and last name
var user:Object = {
	first: "Ada",
	last: "Lovelace",
	born: 1815
};

// Add a new document with a generated ID
var collection:CollectionReference = Firestore.collection("users");
collection.addEventListener(FirestoreEvents.COLLECTION_ADD_SUCCESS, onCollectionAddSuccess);
collection.addEventListener(FirestoreEvents.COLLECTION_ADD_FAILURE, onCollectionAddFailure);
collection.add(user);

function onCollectionAddSuccess(e:FirestoreEvents):void
{
	var c:CollectionReference = e.target as CollectionReference;
	c.removeEventListener(FirestoreEvents.COLLECTION_ADD_SUCCESS, onCollectionAddSuccess);
	c.removeEventListener(FirestoreEvents.COLLECTION_ADD_FAILURE, onCollectionAddFailure);
	
	trace("DocumentSnapshot added with ID: " + e.documentReference.documentId);
}

function onCollectionAddFailure(e:FirestoreEvents):void
{
	var c:CollectionReference = e.target as CollectionReference;
	c.removeEventListener(FirestoreEvents.COLLECTION_ADD_SUCCESS, onCollectionAddSuccess);
	c.removeEventListener(FirestoreEvents.COLLECTION_ADD_FAILURE, onCollectionAddFailure);
	
	trace("Error adding document: " + e.msg);
}

Now add another document to the users collection. Notice that this document includes a key-value pair (middle name) that does not appear in the first document. Documents in a collection can contain different sets of information.

// Create a new user with a first, middle, and last name
var user:Object = {
	first: "Alan",
	middle: "Mathison",
	last: "Turring",
	born: 1912
};

// Add a new document with a generated ID
var collection:CollectionReference = Firestore.collection("users");
collection.addEventListener(FirestoreEvents.COLLECTION_ADD_SUCCESS, onCollectionAddSuccess);
collection.addEventListener(FirestoreEvents.COLLECTION_ADD_FAILURE, onCollectionAddFailure);
collection.add(user);

Read Data

To quickly verify that you've added data to Cloud Firestore, use the data viewer in the Firebase console.

You can also use the "read" method to retrieve the entire collection.

var collection:CollectionReference = Firestore.collection("users");
collection.addEventListener(FirestoreEvents.QUERY_GET_SUCCESS, onCollectionReadSuccess);
collection.addEventListener(FirestoreEvents.QUERY_GET_FAILURE, onCollectionReadFailure);
collection.read();

function onCollectionReadSuccess(e:FirestoreEvents):void
{
	var c:CollectionReference = e.target as CollectionReference;
	c.removeEventListener(FirestoreEvents.QUERY_GET_SUCCESS, onCollectionReadSuccess);
	c.removeEventListener(FirestoreEvents.QUERY_GET_FAILURE, onCollectionReadFailure);
	
	for(var i:int=0; i < e.querySnapshot.documents.length; i++)
	{
		var doc:DocumentSnapshot = e.querySnapshot.documents[i];
		trace(doc.snapshotId + " => " + JSON.stringify(doc.data));
	}
}

function onCollectionReadFailure(e:FirestoreEvents):void
{
	var c:CollectionReference = e.target as CollectionReference;
	c.removeEventListener(FirestoreEvents.QUERY_GET_SUCCESS, onCollectionReadSuccess);
	c.removeEventListener(FirestoreEvents.QUERY_GET_FAILURE, onCollectionReadFailure);
	
	trace("Error getting documents: " + e.msg);
}

Secure your data

Introduction to Firebase ANEs collection for Adobe Air apps


Get Started with Firebase Core in AIR

  1. Prerequisites
  2. Add Firebase to your app
  3. Add the Firebase SDK
  4. Init Firebase Core
  5. Available ANEs
  6. Managing Firebase iid

Get Started with Analytics

  1. Add Analytics ANE
  2. Init Analytics ANE
  3. Log Events
  4. Set User Properties

Get Started with Crashlytics

  1. Add Crashlytics ANE
  2. Test Your Implementation
  3. Customize Crash Reports
  4. Upload .dSYM for iOS apps

Get Started with DynamicLinks

  1. Add DynamicLinks ANE
  2. Init DynamicLinks ANE
  3. Create DynamicLinks
  4. Receive DynamicLinks
  5. View Analytics

Get Started with Authentication

  1. Add Authentication
  2. Init Authentication
  3. Manage Users
  4. Phone Number
  5. Custom Auth
  6. Anonymous Auth
  7. State in Email Actions
  8. Email Link Authentication

Get Started with FCM + OneSignal

  1. Add FCM ANE
  2. Init FCM ANE
  3. Send Your 1st Message
  4. Send Msg to Topics
  5. Understanding FCM Messages
  6. init OneSignal

Get Started with Firestore

  1. Add Firestore
  2. Init Firestore
  3. Add Data
  4. Transactions & Batches
  5. Delete Data
  6. Manage the Console
  7. Get Data
  8. Get Realtime Updates
  9. Simple and Compound
  10. Order and Limit Data
  11. Paginate Data
  12. Manage Indexes
  13. Secure Data
  14. Offline Data
  15. Where to Go From Here

Get Started with Realtime Database

  1. Add Realtime Database
  2. Init Realtime Database
  3. Structure Your Database
  4. Save Data
  5. Retrieve Data
  6. Enable Offline Capabilities

Get Started with Remote Config

  1. Parameters and Conditions
  2. Add Remote Config
  3. Init Remote Config

Get Started with Performance

  1. Add Performance ANE
  2. Init & Start Monitoring

Get Started with Storage

  1. Add Storage ANE
  2. Init Storage ANE
  3. Upload Files to Storage
  4. Download Files to Air
  5. Use File Metadata
  6. Delete Files

Get Started with Functions

  1. Write & Deploy Functions
  2. Add Functions ANE
  3. Init Functions
Clone this wiki locally