Skip to content

Latest commit

 

History

History
4466 lines (1975 loc) · 107 KB

README.md

File metadata and controls

4466 lines (1975 loc) · 107 KB

Firebase Realtime Database Arduino Library for ESP8266

Google's Firebase Realtime Database Arduino Library for ESP8266 v 2.9.8

Global functions

Store Firebase's authentication credentials.

param host - Your Firebase database project host e.g. Your_ProjectID.firebaseio.com.

param auth - Your database secret.

param rootCA - Root CA certificate base64 string (PEM file).

param rootCAFile - Root CA certificate DER file (binary).

param storageType - Type of storage, StorageType::SD and StorageType::FLASH.

param GMTOffset - GMT time offset in hour is required to set time in order to make BearSSL data decryption/encryption to work.

                    This parameter is only required for ESP8266 Core SDK v2.5.x or later.

Root CA certificate DER file is only supported in Core SDK v2.5.x

To use LittleFS file system for flash memory instead of SPIFFS, add the following macro in FirebaseFS.h

#define USE_LITTLEFS
void begin(const String &host, const String &auth);

void begin(const String &host, const String &auth, const char *rootCA, float GMTOffset = 0.0);
  
void begin(const String &host, const String &auth, const String &rootCAFile, uint8_t storageType, float GMTOffset = 0.0);

Reconnect WiFi if lost connection.

param reconnect - The boolean to set/unset WiFi AP reconnection.

void reconnectWiFi(bool reconnect);

Set the decimal places for float value to be stored in database.

param digits - The decimal places.

void setFloatDigits(uint8_t digits);

Set the decimal places for double value to be stored in database.

param digits - The decimal places.

void setDoubleDigits(uint8_t digits);

Set the timeouts of get function.

param dataObj - Firebase Data Object to hold data and instances.

param millisec - The milliseconds to limit the request (0 - 900,000 ms or 15 min).

void setReadTimeout(FirebaseData &dataObj, int millisec);

Set the size limit of payload data that will write to the database for each request.

param dataObj - Firebase Data Object to hold data and instances.

param size - The size identified string e.g. tiny, small, medium, large and unlimited.

Size string and its write timeout in seconds e.g. tiny (1s), small (10s), medium (30s) and large (60s).

void setwriteSizeLimit(FirebaseData &dataObj, const String &size);

Read the database rules.

param dataObj - Firebase Data Object to hold data and instances.

return - Boolean type status indicates the success of the operation.

bool getRules(FirebaseData &dataObj);

Write the database rules.

param dataObj - Firebase Data Object to hold data and instances.

param rules - Database rules in jSON String format.

return - Boolean type status indicates the success of the operation.

bool setRules(FirebaseData &dataObj, const String &rules);

Determine whether the defined database path has existed or not.

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path to be checked.

return - Boolean type result indicates whether the defined database path was existed or not.

bool pathExist(FirebaseData &dataObj, const String &path);

Determine the unique identifier (ETag) of current data at the defined database path.

return String of unique identifier.

String getETag(FirebaseData &dataObj, const String &path);

Get the shallowed data at defined node path.

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path being read the data.

return - Boolean type status indicates the success of the operation.

Return the child data with its value or JSON object (its values will be truncated to true).

Call [FirebaseData object].dataType to determine what type of data that returned from database.

Call [FirebaseData object].intData to get integer data.

Call [FirebaseData object].floatData to get float data.

Call [FirebaseData object].doubleData to get double data.

Call [FirebaseData object].boolData to get boolean data.

Call [FirebaseData object].stringData to get string data.

Call [FirebaseData object].jsonString to get JSON string data.

Call [FirebaseData object].jsonObject to get FirebaseJson object.

bool getShallowData(FirebaseData &dataObj, const String &path); 

Enable the library to use only classic HTTP GET and POST methods.

param dataObj - Firebase Data Object to hold data and instances.

param flag - Boolean value to enable.

This option used to escape the Firewall restriction (if the device is connected through Firewall) that allows only HTTP GET and POST

HTTP PATCH request was sent as PATCH which not affected by this option.

void enableClassicRequest(FirebaseData &dataObj, bool flag);

Set the virtual child node ".priority" to the defined database path.

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path which to set the priority value.

param priority - The priority value.

return - Boolean type status indicates the success of the operation.

This allows us to set priority to any node other than a priority that set through setJSON, pushJSON, updateNode and updateNodeSilent functions.

The returned priority value from server can read from function [FirebaseData object].priority().

bool setPriority(FirebaseData &dataObj, const String &path, float priority);

Read the virtual child node ".priority" value at the defined database path.

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path which to set the priority value.

return - Boolean type status indicates the success of the operation.

The priority value from server can read from function [FirebaseData object].priority().

bool getPriority(FirebaseData &dataObj, const String &path);

Append new integer value to the defined database path.

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path in which integer value will be appended.

param intValue - The appended value.

return Boolean type status indicates the success of the operation.

The new appended node's key will be stored in Firebase Data object, which its value can be accessed via function [FirebaseData object].pushName().

bool pushInt(FirebaseData &dataObj, const String &path, int intValue);

bool push(FirebaseData &dataObj, const String &path, int intValue);

Append new integer value and the virtual child ".priority" to the defined database path.

bool pushInt(FirebaseData &dataObj, const String &path, int intValue, float priority);

bool push(FirebaseData &dataObj, const String &path, int intValue, float priority);

Append new float value to the defined database path.

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path in which the float type value will be appended.

param floatValue - The appended value.

return Boolean type status indicates the success of the operation.

The new appended node's key will be stored in Firebase Data object, which its value can be accessed via function [FirebaseData object].pushName().

bool pushFloat(FirebaseData &dataObj, const String &path, float floatValue);

bool push(FirebaseData &dataObj, const String &path, float floatValue);

Append new float value and the virtual child ".priority" to the defined database path.

bool pushFloat(FirebaseData &dataObj, const String &path, float floatValue, float priority);

bool push(FirebaseData &dataObj, const String &path, float floatValue, float priority);

Append new double value (8 bytes) to the defined database path.

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path in which the float value will be appended.

param doubleValue - The appended value.

return Boolean type status indicates the success of the operation.

The new appended node's key will be stored in Firebase Data object, which its value can be accessed via function [FirebaseData object].pushName().

bool pushDouble(FirebaseData &dataObj, const String &path, double doubleValue);

bool push(FirebaseData &dataObj, const String &path, double doubleValue);

Append new double value (8 bytes) and the virtual child ".priority" to the defined database path.

bool pushDouble(FirebaseData &dataObj, const String &path, double doubleValue, float priority);

bool push(FirebaseData &dataObj, const String &path, double doubleValue, float priority);

Append new Boolean value to the defined database path.

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path which Boolean value will be appended.

param boolValue - The appended value.

return Boolean type status indicates the success of the operation.

The new appended node's key will be stored in Firebase Data object, which its value can be accessed via function [FirebaseData object].pushName().

bool pushBool(FirebaseData &dataObj, const String &path, bool boolValue);

bool push(FirebaseData &dataObj, const String &path, bool boolValue);

Append new Boolean value and the virtual child ".priority" to the defined database path.

bool pushBool(FirebaseData &dataObj, const String &path, bool boolValue, float priority);

bool push(FirebaseData &dataObj, const String &path, bool boolValue, float priority);

Append new string (text) to the defined database path.

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path which string will be appended.

param stringValue - The appended value.

return Boolean type status indicates the success of operation.

The new appended node's key stored in Firebase Data object, which can be accessed via function [FirebaseData object].pushName().

bool pushString(FirebaseData &dataObj, const String &path, const String &stringValue);

bool push(FirebaseData &dataObj, const String &path, const char *stringValue);

bool push(FirebaseData &dataObj, const String &path, const String &stringValue);

Append new string (text) and the virtual child ".priority" to the defined database path.

bool pushString(FirebaseData &dataObj, const String &path, const String &stringValue, float priority);

bool push(FirebaseData &dataObj, const String &path, const char *stringValue, float priority);

bool push(FirebaseData &dataObj, const String &path, const String &stringValue, float priority);

Append new child node' key and value (using FirebaseJson object) to the defined database path.

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path which key and value in FirebaseJson object will be appended.

param json - The appended FirebaseJson object.

return Boolean type status indicates the success of the operation.

The new appended node's key will be stored in Firebase Data object, which its value can be accessed via function [FirebaseData object].pushName().

bool pushJSON(FirebaseData &dataObj, const String &path, FirebaseJson &json);

bool push(FirebaseData &dataObj, const String &path, FirebaseJson &json);

Append new child node's key and value (using JSON data or FirebaseJson object) and the virtual child ".priority" to the defined database path.

bool pushJSON(FirebaseData &dataObj, const String &path, FirebaseJson &json, float priority);

bool push(FirebaseData &dataObj, const String &path, FirebaseJson &json, float priority);

Append child node's array (using FirebaseJsonArray object) to the defined database path.

This will replace any child nodes inside the defined path with array defined in FirebaseJsonArray object.

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path which key and value in FirebaseJsonArray object will be appended.

param arr - The appended FirebaseJsonArray object.

return Boolean type status indicates the success of the operation.

The new appended node's key will be stored in Firebase Data object, which its value can be accessed via function [FirebaseData object].pushName().

bool pushArray(FirebaseData &dataObj, const String &path, FirebaseJsonArray &arr);

bool push(FirebaseData &dataObj, const String &path, FirebaseJsonArray &arr);

Append FirebaseJsonArray object and virtual child ".priority" at the defined database path.

bool pushArray(FirebaseData &dataObj, const String &path, FirebaseJsonArray &arr, float priority);

bool push(FirebaseData &dataObj, const String &path, FirebaseJsonArray &arr, float priority);

Append new blob (binary data) to the defined database path.

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path in which binary data will be appended.

param blob - Byte array of data.

param size - Size of the byte array.

return Boolean type status indicates the success of the operation.

The new appended node's key will be stored in Firebase Data object, which its value can be accessed via function [FirebaseData object].pushName().

bool pushBlob(FirebaseData &dataObj, const String &path, uint8_t *blob, size_t size);

bool push(FirebaseData &dataObj, const String &path, uint8_t *blob, size_t size);

Append new blob (binary data) and the virtual child ".priority" to the defined database path.

bool pushBlob(FirebaseData &dataObj, const String &path, uint8_t *blob, size_t size, float priority);

bool push(FirebaseData &dataObj, const String &path, uint8_t *blob, size_t size, float priority);

Append new binary data from file stored on SD card/flash memory to the defined database path.

param dataObj - Firebase Data Object to hold data and instances.

param storageType - Type of storage to read file data, StorageType::SPIFS or StorageType::SD.

param path - Target database path in which binary data from the file will be appended.

param fileName - File name included its path in SD card/Flash memory.

return Boolean type status indicates the success of the operation.

The new appended node's key will be stored in Firebase Data object, which its value can be accessed via function [FirebaseData object].pushName().

bool pushFile(FirebaseData &dataObj, uint8_t storageType, const String &path, const String &fileName);

bool push(FirebaseData &dataObj, uint8_t storageType, const String &path, const String &fileName);

To use LittleFS file system for flash memory instead of SPIFFS, add the following macro in FirebaseFS.h

#define USE_LITTLEFS

Append new binary data from the file store on SD card/flash memory and the virtual child ".priority" to the defined database path.

bool pushFile(FirebaseData &dataObj, uint8_t storageType, const String &path, const String &fileName, float priority);

bool push(FirebaseData &dataObj, uint8_t storageType, const String &path, const String &fileName, float priority);

To use LittleFS file system for flash memory instead of SPIFFS, add the following macro in FirebaseFS.h

#define USE_LITTLEFS

Append new Firebase server's timestamp to the defined database path.

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path which timestamp will be appended.

return - Boolean type status indicates the success of the operation.

The new appended node's key will be stored in Firebase Data object, which its value can be accessed via function [FirebaseData object].pushName().

bool pushTimestamp(FirebaseData &dataObj, const String &path);

Set integer data at the defined database path.

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path in which integer data will be set.

param intValue - Integer value to set.

return Boolean type status indicates the success of the operation.

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].intData will return the integer value of the payload returned from the server.

bool setInt(FirebaseData &dataObj, const String &path, int intValue);

bool set(FirebaseData &dataObj, const String &path, int intValue);

Set integer data and virtual child ".priority" at the defined database path.

bool setInt(FirebaseData &dataObj, const String &path, int intValue, float priority);

bool set(FirebaseData &dataObj, const String &path, int intValue, float priority);

Set integer data at the defined database path if defined database path's ETag matched the ETag value.

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path in which integer data will be set.

param intValue - Integer value to set.

param ETag - Known unique identifier string (ETag) of defined database path.

return - Boolean type status indicates the success of the operation.

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

If ETag at the defined database path does not match the provided ETag parameter, the operation will fail with HTTP code 412, Precondition Failed (ETag is not matched).

If the operation failed due to ETag is not match, call [FirebaseData object].ETag() to get the current ETag value. Also call [FirebaseData object].intData to get the current integer value.

bool setInt(FirebaseData &dataObj, const String &path, int intValue, const String &ETag);

bool set(FirebaseData &dataObj, const String &path, int intValue, const String &ETag);

Set integer data and the virtual child ".priority" if defined ETag matches at the defined database path

bool setInt(FirebaseData &dataObj, const String &path, int intValue, float priority, const String &ETag);

bool set(FirebaseData &dataObj, const String &path, int intValue, float priority, const String &ETag);

Set float data at the defined database path.

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path in which float data will be set.

param floatValue - Float value to set.

return Boolean type status indicates the success of the operation.

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].floatData will return the float value of the payload returned from the server.

bool setFloat(FirebaseData &dataObj, const String &path, float floatValue);

bool set(FirebaseData &dataObj, const String &path, float floatValue);

Set float data and virtual child ".priority" at the defined database path.

bool setFloat(FirebaseData &dataObj, const String &path, float floatValue, float priority);

bool set(FirebaseData &dataObj, const String &path, float floatValue, float priority);

Set float data at the defined database path if defined database path's ETag matched the ETag value.

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path in which float data will be set.

param floatValue - Float value to set.

return Boolean type status indicates the success of the operation.

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].floatData will return the float value of the payload returned from the server.

If ETag at the defined database path does not match the provided ETag parameter, the operation will fail with HTTP code 412, Precondition Failed (ETag is not matched).

If the operation failed due to ETag is not match, call [FirebaseData object].ETag() to get the current ETag value. Also call [FirebaseData object].floatData to get the current float value.

bool setFloat(FirebaseData &dataObj, const String &path, float floatValue, const String &ETag);

bool set(FirebaseData &dataObj, const String &path, float floatValue, const String &ETag);

Set float data and the virtual child ".priority" if defined ETag matches at the defined database path

bool setFloat(FirebaseData &dataObj, const String &path, float floatValue, float priority, const String &ETag);

bool set(FirebaseData &dataObj, const String &path, float floatValue, float priority, const String &ETag);

Set double data at the defined database path.

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path in which float data will be set.

param doubleValue - Double value to set.

return Boolean type status indicates the success of the operation.

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].doubleData will return the double value of the payload returned from the server.

Due to bugs in Serial.print in Arduino, to print large double value with zero decimal place, use printf("%.9lf\n", firebaseData.doubleData()); for print the returned double value up to 9 decimal places.

bool setDouble(FirebaseData &dataObj, const String &path, double doubleValue);

bool set(FirebaseData &dataObj, const String &path, double doubleValue);

Set double data and virtual child ".priority" at the defined database path.

bool setDouble(FirebaseData &dataObj, const String &path, double doubleValue, float priority);

bool set(FirebaseData &dataObj, const String &path, double doubleValue, float priority);

Set double data at the defined database path if defined database path's ETag matched the ETag value.

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path in which float data will be set.

param doubleValue - Double value to set.

param ETag - Known unique identifier string (ETag) of defined database path.

return - Boolean type status indicates the success of the operation.

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].doubleData will return the double value of payload returned from the server.

If ETag at the defined database path does not match the provided ETag parameter, the operation will fail with HTTP code 412, Precondition Failed (ETag is not matched).

If the operation failed due to ETag is not match, call [FirebaseData object].ETag() to get the current ETag value. Also call [FirebaseData object].doubeData to get the current double value.

bool setDouble(FirebaseData &dataObj, const String &path, double doubleValue, const String &ETag);

bool set(FirebaseData &dataObj, const String &path, double doubleValue, const String &ETag);

Set double data and the virtual child ".priority" if defined ETag matches at the defined database path

bool setDouble(FirebaseData &dataObj, const String &path, double doubleValue, float priority, const String &ETag);

bool set(FirebaseData &dataObj, const String &path, double doubleValue, float priority, const String &ETag);

Set Boolean data at the defined database path.

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path in which float data will be set.

param boolValue - Boolean value to set.

return Boolean type status indicates the success of the operation.

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].boolData will return the Boolean value of the payload returned from the server.

bool setBool(FirebaseData &dataObj, const String &path, bool boolValue);

bool set(FirebaseData &dataObj, const String &path, bool boolValue);

Set boolean data and virtual child ".priority" at the defined database path.

bool setBool(FirebaseData &dataObj, const String &path, bool boolValue, float priority);

bool set(FirebaseData &dataObj, const String &path, bool boolValue, float priority);

Set Boolean data at the defined database path if defined database path's ETag matched the ETag value

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path in which float data will be set.

param boolValue - Boolean value to set.

param ETag - Known unique identifier string (ETag) of defined database path.

return Boolean type status indicates the success of the operation.

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].boolData will return the Boolean value of the payload returned from the server.

If ETag at the defined database path does not match the provided ETag parameter, the operation will fail with HTTP code 412, Precondition Failed (ETag is not matched).

If the operation failed due to ETag is not match, call [FirebaseData object].ETag() to get the current ETag value. Also call [FirebaseData object].doubeData to get the current boolean value.

bool setBool(FirebaseData &dataObj, const String &path, bool boolValue, const String &ETag);

bool set(FirebaseData &dataObj, const String &path, bool boolValue, const String &ETag);

Set boolean data and the virtual child ".priority" if defined ETag matches at the defined database path

bool setBool(FirebaseData &dataObj, const String &path, bool boolValue, float priority, const String &ETag);

bool set(FirebaseData &dataObj, const String &path, bool boolValue, float priority, const String &ETag);

Set string (text) at the defined database path

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path in which string data will be set.

param stringValue - String or text to set.

return Boolean type status indicates the success of the operation.

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].stringData will return the string value of the payload returned from the server.

bool setString(FirebaseData &dataObj, const String &path, const String &stringValue);

bool set(FirebaseData &dataObj, const String &path, const char *stringValue);

bool set(FirebaseData &dataObj, const String &path, const String &stringValue);

Set string data and virtual child ".priority" at the defined database path.

bool setString(FirebaseData &dataObj, const String &path, const String &stringValue, float priority);

bool set(FirebaseData &dataObj, const String &path, const char *stringValue, float priority);

bool set(FirebaseData &dataObj, const String &path, const String &stringValue, float priority);

Set string (text) at the defined database path if defined database path's ETag matched the ETag value

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path in which string data will be set.

param stringValue - String or text to set.

param ETag - Known unique identifier string (ETag) of defined database path.

return Boolean type status indicates the success of the operation.

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].stringData will return the string value of the payload returned from the server.

If ETag at the defined database path does not match the provided ETag parameter, the operation will fail with HTTP code 412, Precondition Failed (ETag is not matched).

If the operation failed due to ETag is not match, call [FirebaseData object].ETag() to get the current ETag value. Also, call [FirebaseData object].stringData to get the current string value.

bool setString(FirebaseData &dataObj, const String &path, const String &stringValue, const String &ETag);

bool set(FirebaseData &dataObj, const String &path, const char *stringValue, const String &ETag);

bool set(FirebaseData &dataObj, const String &path, const String &stringValue, const String &ETag);

Set string data and the virtual child ".priority" if defined ETag matches at the defined database path

bool setString(FirebaseData &dataObj, const String &path, const String &stringValue, float priority, const String &ETag);

bool set(FirebaseData &dataObj, const String &path, const char *stringValue, float priority, const String &ETag);

bool set(FirebaseData &dataObj, const String &path, const String &stringValue, float priority, const String &ETag);

Set child node's key and value (using FirebaseJson object) to the defined database path

This will replace any child nodes inside the defined path with node' s key and value defined in FirebaseJson object.

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path which key and value in FirebaseJson object will be replaced or set.

param json - The FirebaseJson object.

return Boolean type status indicates the success of the operation.

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].jsonData will return the JSON string value of the payload returned from the server.

Call [FirebaseData object].jsonObject will return the FirebaseJson object of payload returned from server.

bool setJSON(FirebaseData &dataObj, const String &path, FirebaseJson &json);

bool set(FirebaseData &dataObj, const String &path, FirebaseJson &json);

Set JSON data or FirebaseJson object and virtual child ".priority" at the defined database path.

bool setJSON(FirebaseData &dataObj, const String &path, FirebaseJson &json, float priority);

bool set(FirebaseData &dataObj, const String &path, FirebaseJson &json, float priority);

Set child node's key and value (using JSON data or FirebaseJson object) to the defined database path if defined database path's ETag matched the ETag value

This will replace any child nodes inside the defined path with node' s key and value defined in JSON data or FirebaseJson object.

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path which key and value in JSON data or FirebaseJson object will be replaced or set.

param jsonString - The JSON string to set (should be valid JSON data).

param json - The FirebaseJson object.

param ETag - Known unique identifier string (ETag) of defined database path.

return Boolean type status indicates the success of the operation.

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].jsonData will return the JSON string value of the payload returned from the server.

Call [FirebaseData object].jsonObject will return the FirebaseJson object of payload returned from server.

If ETag at the defined database path does not match the provided ETag parameter, the operation will fail with HTTP code 412, Precondition Failed (ETag is not matched).

If the operation failed due to ETag is not match, call [FirebaseData object].ETag() to get the current ETag value. Also call [FirebaseData object].jsonData to get the current JSON string value [FirebaseData object].jsonObject to get the FirebaseJson object.

bool setJSON(FirebaseData &dataObj, const String &path, FirebaseJson &json, const String &ETag);

bool set(FirebaseData &dataObj, const String &path, FirebaseJson &json, const String &ETag);

Set JSON data or FirebaseJson object and the virtual child ".priority" if defined ETag matches at the defined database path

bool setJSON(FirebaseData &dataObj, const String &path, FirebaseJson &json, float priority, const String &ETag);

bool set(FirebaseData &dataObj, const String &path, FirebaseJson &json, float priority, const String &ETag);

Set child nodes's array (using FirebaseJsonArray object) to the defined database path.

This will replace any child nodes inside the defined path with array defined in FirebaseJsonArray object.

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path which key and value in FirebaseJsonArray object will be replaced or set.

param arr - The FirebaseJsonArray object.

return - Boolean type status indicates the success of the operation.

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].jsonArray will return pointer to FirebaseJsonArray object contains array payload returned from server, get the array payload using FirebaseJsonArray *arr = firebaseData.jsonArray();

bool setArray(FirebaseData &dataObj, const String &path, FirebaseJsonArray &arr);

bool set(FirebaseData &dataObj, const String &path, FirebaseJsonArray &arr);

Set FirebaseJsonArray object and virtual child ".priority" at the defined database path.

bool setArray(FirebaseData &dataObj, const String &path, FirebaseJsonArray &arr, float priority);

bool set(FirebaseData &dataObj, const String &path, FirebaseJsonArray &arr, float priority);

Set array (using JSON data or FirebaseJson object) to the defined database path if defined database path's ETag matched the ETag value.

This will replace any child nodes inside the defined path with array defined in FirebaseJsonArray object.

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path which key and value in JSON data will be replaced or set.

param arr - The FirebaseJsonArray object.

param ETag - Known unique identifier string (ETag) of defined database path.

return - Boolean type status indicates the success of the operation.

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].jsonArray will return pointer to FirebaseJsonArray object contains array payload returned from server, get the array payload using FirebaseJsonArray *arr = firebaseData.jsonArray();

If ETag at the defined database path does not match the provided ETag parameter, the operation will fail with HTTP code 412, Precondition Failed (ETag is not matched).

If the operation failed due to ETag is not match, call [FirebaseData object].ETag() to get the current ETag value.

Also call [FirebaseData object].jsonArray to get the pointer to FirebaseJsonArray object of current array value.

bool setArray(FirebaseData &dataObj, const String &path, FirebaseJsonArray &arr, const String &ETag);

bool set(FirebaseData &dataObj, const String &path, FirebaseJsonArray &arr, const String &ETag);
Set FirebaseJsonArray object and the virtual child ".priority" if defined ETag matches at the defined database path 
bool setArray(FirebaseData &dataObj, const String &path, FirebaseJsonArray &arr, float priority, const String &ETag);

bool set(FirebaseData &dataObj, const String &path, FirebaseJsonArray &arr, float priority, const String &ETag);

Set blob (binary data) at the defined database path

This will replace any child nodes inside the defined path with a blob or binary data.

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path in which binary data will be set.

param blob - Byte array of data.

param size - Size of the byte array.

return Boolean type status indicates the success of the operation.

No payload returned from the server.

bool setBlob(FirebaseData &dataObj, const String &path, uint8_t *blob, size_t size);

bool set(FirebaseData &dataObj, const String &path, uint8_t *blob, size_t size);

Set blob data and virtual child ".priority" at the defined database path.

bool setBlob(FirebaseData &dataObj, const String &path, uint8_t *blob, size_t size, float priority);

bool set(FirebaseData &dataObj, const String &path, uint8_t *blob, size_t size, float priority);

Set blob (binary data) at the defined database path if defined database path's ETag matched the ETag value

This will replace any child nodes inside the defined path with a blob or binary data.

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path in which binary data will be set.

param blob - Byte array of data.

param size - Size of the byte array.

param ETag - Known unique identifier string (ETag) of defined database path.

return Boolean type status indicates the success of the operation.

No payload returned from the server.

If ETag at the defined database path does not match the provided ETag parameter, the operation will fail with HTTP code 412, Precondition Failed (ETag is not matched).

bool setBlob(FirebaseData &dataObj, const String &path, uint8_t *blob, size_t size, const String &ETag);

bool set(FirebaseData &dataObj, const String &path, uint8_t *blob, size_t size, const String &ETag);

Set blob data and the virtual child ".priority" if defined ETag matches at the defined database path

bool setBlob(FirebaseData &dataObj, const String &path, uint8_t *blob, size_t size, float priority, const String &ETag);

bool set(FirebaseData &dataObj, const String &path, uint8_t *blob, size_t size, float priority, const String &ETag);

Set binary data from a file stored on SD card/flash memory to the defined database path.

param dataObj - Firebase Data Object to hold data and instances.

param storageType - Type of storage to read file data, StorageType::SPIFS or StorageType::SD.

param path - Target database path in which binary data from the file will be set.

param fileName - File name included its path in SD card/Flash memory.

return Boolean type status indicates the success of the operation.

No payload returned from the server.

bool setFile(FirebaseData &dataObj, uint8_t storageType, const String &path, const String &fileName);

bool set(FirebaseData &dataObj, uint8_t storageType, const String &path, const String &fileName);

To use LittleFS file system for flash memory instead of SPIFFS, add the following macro in FirebaseFS.h

#define USE_LITTLEFS

Set binary data from the file and virtual child ".priority" at the defined database path.

bool setFile(FirebaseData &dataObj, uint8_t storageType, const String &path, const String &fileName, float priority);

bool set(FirebaseData &dataObj, uint8_t storageType, const String &path, const String &fileName, float priority);

Set binary data from a file stored on SD card/flash memory to the defined database path if defined database path's ETag matched the ETag value

param dataObj - Firebase Data Object to hold data and instances.

param storageType - Type of storage to read file data, StorageType::SPIFS or StorageType::SD.

param path - Target database path in which binary data from the file will be set.

param fileName - File name included its path in SD card/Flash memory.

param ETag - Known unique identifier string (ETag) of defined database path.

return Boolean type status indicates the success of the operation.

No payload returned from the server.

If ETag at the defined database path does not match the provided ETag parameter, the operation will fail with HTTP code 412, Precondition Failed (ETag is not matched).

bool setFile(FirebaseData &dataObj, uint8_t storageType, const String &path, const String &fileName, const String &ETag);

bool set(FirebaseData &dataObj, uint8_t storageType, const String &path, const String &fileName, const String &ETag);

To use LittleFS file system for flash memory instead of SPIFFS, add the following macro in FirebaseFS.h

#define USE_LITTLEFS

Set binary data from the file and the virtual child ".priority" if defined ETag matches at the defined database path

bool setFile(FirebaseData &dataObj, uint8_t storageType, const String &path, const String &fileName, float priority, const String &ETag);

bool set(FirebaseData &dataObj, uint8_t storageType, const String &path, const String &fileName, float priority, const String &ETag);

Set Firebase server's timestamp to the defined database path

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path which timestamp will be set.

return - Boolean type status indicates the success of the operation.

Call [FirebaseData object].intData will return the integer value of timestamp in seconds or [FirebaseData object].doubleData to get millisecond timestamp.

Due to bugs in Serial.print in Arduino, to print large double value with zero decimal place, use printf("%.0lf\n", firebaseData.doubleData());.

bool setTimestamp(FirebaseData &dataObj, const String &path);

Update child node's key or existing key's value (using FirebaseJson object) under the defined database path

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path which key and value in FirebaseJson object will be updated.

param json - The FirebaseJson object used for update.

return Boolean type status indicates the success of the operation.

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].jsonData will return the json string value of payload returned from server.

Call [FirebaseData object].jsonObject will return the FirebaseJson object of payload returned from server.

To reduce network data usage, use updateNodeSilent instead.

bool updateNode(FirebaseData &dataObj, const String &path, FirebaseJson &json);

Update child node's key or existing key's value and virtual child ".priority" (using JSON data or FirebaseJson object) under the defined database path.

bool updateNode(FirebaseData &dataObj, const String &path, FirebaseJson &json, float priority);

Update child node's key or existing key's value (using FirebaseJson object) under the defined database path

param dataObj - Firebase Data Object to hold data and instances.

param path - Target database path which key and value in FirebaseJson object will be updated.

param json - The FirebaseJson object used for update.

return Boolean type status indicates the success of the operation.

Owing to the objective of this function to reduce network data usage, no payload will be returned from the server.

bool updateNodeSilent(FirebaseData &dataObj, const String &path, FirebaseJson &json);

Update child node's key and virtual child ".priority" (using JSON data or FirebaseJson object) under the defined database path.

bool updateNodeSilent(FirebaseData &dataObj, const String &path, FirebaseJson &json, float priority);

Read any type of value at the defined database path.

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path in which the float value is being read.

return - Boolean type status indicates the success of the operation.

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].intData, [FirebaseData object].floatData, [FirebaseData object].doubleData, [FirebaseData object].boolData, [FirebaseData object].stringData, [FirebaseData object].jsonObject (pointer), [FirebaseData object].jsonArray (pointer) and [FirebaseData object].blobData corresponded to its type from [FirebaseData object].dataType.

bool get(FirebaseData &dataObj, const String &path);

Read the integer value at the defined database path

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path in which the integer value is being read.

return Boolean type status indicates the success of the operation.

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].intData will return the integer value of the payload returned from the server.

If the payload returned from server is not integer or float type, the function [FirebaseData object].intData will return zero (0).

If the payload returned from server is float type, the function [FirebaseData object].intData will return rounded integer value.

bool getInt(FirebaseData &dataObj, const String &path);

Read the integer value at the defined database path

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path in which the integer value is being read.

param target - The integer type variable to store value.

return Boolean type status indicates the success of the operation.

If the type of payload returned from the server is not an integer, float and double, the target variable's value will be zero (0).

bool getInt(FirebaseData &dataObj, const String &path, int &target);

Read the float value at the defined database path

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path in which the float value is being read.

return Boolean type status indicates the success of the operation.

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].floatData will return the float value of the payload returned from the server.

If the payload returned from server is not integer or float type, the function [FirebaseData object].intData will return zero (0).

bool getFloat(FirebaseData &dataObj, const String &path);

Read the float value at the defined database path

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path in which the float value is being read.

param target - The float type variable to store value.

return Boolean type status indicates the success of the operation.

If the type of payload returned from the server is not an integer, float and double, the target variable's value will be zero (0).

bool getFloat(FirebaseData &dataObj, const String &path, float &target);

Read the double value at the defined database path

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path in which the float value is being rea.

return Boolean type status indicates the success of the operation.

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].doubleData will return the double value of the payload returned from the server.

If the payload returned from server is not integer, float and double, the function [FirebaseData object].doubleData will return zero (0).

Due to bugs in Serial.print in Arduino, to print large double value with zero decimal place, use printf("%.9lf\n", firebaseData.doubleData()); for print the returned double value up to 9 decimal places.

bool getDouble(FirebaseData &dataObj, const String &path);

Read the float value at the defined database path

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path in which the float value is being read.

param target - The double type variable to store value.

return Boolean type status indicates the success of the operation.

If the type of payload returned from the server is not an integer, float and double, the target variable's value will be zero (0).

bool getDouble(FirebaseData &dataObj, const String &path, double &target);

Read the Boolean value at the defined database path

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path in which the Boolean value is being read.

return Boolean type status indicates the success of the operation.

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].boolData will return the Boolean value of the payload returned from the server.

If the payload returned from server is not boolean type, the function [FirebaseData object].boolData will return false.

bool getBool(FirebaseData &dataObj, const String &path);

Read the Boolean value at the defined database path

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path in which the Boolean value is being read.

param target - The boolean type variable to store value.

return Boolean type status indicates the success of the operation.

If the type of payload returned from the server is not Boolean, the target variable's value will be false.

bool getBool(FirebaseData &dataObj, const String &path, bool &target);

Read the string or text at the defined database path

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path in which the string value is being read.

return Boolean type status indicates the success of the operation.

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].stringData will return the string value of the payload returned from the server.

If the payload returned from the server is not string type, the function [FirebaseData object].stringData will return empty string (String object).

bool getString(FirebaseData &dataObj, const String &path);

Read the string or text at the defined database path

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path in which the string value is being read.

param target - The String object to store value.

return Boolean type status indicates the success of the operation.

If the type of payload returned from the server is not a string, the target String object's value will be empty.

bool getString(FirebaseData &dataObj, const String &path, String &target);

Read the JSON string at the defined database path

The returned payload JSON string represents the child nodes and their value.

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path in which the JSON string value is being read.

return Boolean type status indicates the success of the operation.

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].jsonData will return the JSON string value of the payload returned from the server.

Call [FirebaseData object].jsonObject will return the FirebaseJson object of payload returned from server.

If the type of payload returned from server is not json, the function [FirebaseData object].jsonObject will contain empty object.

bool getJSON(FirebaseData &dataObj, const String &path);

Read the JSON string at the defined database path

The returned payload JSON string represents the child nodes and their value.

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path in which the JSON string value is being read.

param target - The FirebaseJson object pointer to get json data

return Boolean type status indicates the success of the operation.

If the type of payload returned from the server is not JSON, the target FirebaseJson object will contain an empty object.

bool getJSON(FirebaseData &dataObj, const String &path, FirebaseJson *target);

Read the JSON string with data filtering at the defined database path

The returned payload JSON string represents the child nodes and their value.

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path in which the JSON string value is being read.

param query - QueryFilter class to set query parameters to filter data.

return Boolean type status indicates the success of the operation.

Available query parameters for filtering the data are the following.

QueryFilter.orderBy - Required parameter to specify which data used for data filtering included child key, key, and value.

Use "$key" for filtering data by keys of all nodes at the defined database path.

Use "$value" for filtering data by value of all nodes at the defined database path.

Use "$priority" for filtering data by "virtual child" named .priority of all nodes.

Use any child key to filter by that key.

QueryFilter.limitToFirst - The total children (number) to filter from the first child.

QueryFilter.limitToLast - The total last children (number) to filter.

QueryFilter.startAt - Starting value of range (number or string) of query upon orderBy param.

QueryFilter.endAt - Ending value of range (number or string) of query upon orderBy param.

QueryFilter.equalTo - Value (number or string) matches the orderBy param

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].jsonData will return the JSON string value of the payload returned from the server.

Call [FirebaseData object].jsonObject will return the FirebaseJson object of payload returned from server.

If the type of payload returned from server is not json, the function [FirebaseData object].jsonObject will contain empty object.

bool getJSON(FirebaseData &dataObj, const String &path, QueryFilter &quer);

Read the JSON string at the defined database path as above

The returned payload JSON string represents the child nodes and their value.

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path in which the JSON string value is being read.

param target - The FirebaseJson object pointer to get json data.

return Boolean type status indicates the success of the operation.

If the type of payload returned from the server is not JSON, the target FirebaseJson object will contain an empty object.

bool getJSON(FirebaseData &dataObj, const String &path, QueryFilter &query, FirebaseJson *target);

Read the array data at the defined database path.

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path in which the array is being read.

return - Boolean type status indicates the success of the operation.

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].jsonArray will return the pointer to FirebaseJsonArray object contains array value of the payload returned from the the server.

If the type of payload returned from the server is not an array, the array element in [FirebaseData object].jsonArray will be empty.

bool getArray(FirebaseData &dataObj, const String &path);

Read the array data at the defined database path and assign data to the target.

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path in which the array is being read.

param **`target - The FirebaseJsonArray object pointer to get array value.

return - Boolean type status indicates the success of the operation.

If the type of payload returned from the server is not an array, the target FirebaseJsonArray object will contain an empty array.

bool getArray(FirebaseData &dataObj, const String &path, FirebaseJsonArray *target);

Read the array data at the defined database path.

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path in which the array is being read.

param query - QueryFilter class to set query parameters to filter data.

return - Boolean type status indicates the success of the operation.

Available query parameters for filtering the data are the following.

QueryFilter.orderBy - Required parameter to specify which data used for data filtering included child key, key, and value. Use "$key" for filtering data by keys of all nodes at the defined database path. Use "$value" for filtering data by value of all nodes at the defined database path. Use "$priority" for filtering data by "virtual child" named .priority of all nodes. Use any child key to filter by that key.

QueryFilter.limitToFirst - The total children (number) to filter from the first child.

QueryFilter.limitToLast - The total last children (number) to filter.

QueryFilter.startAt - Starting value of range (number or string) of query upon orderBy param.

QueryFilter.endAt - Ending value of range (number or string) of query upon orderBy param.

QueryFilter.equalTo - Value (number or string) matches the orderBy param

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].jsonArray will return the pointer to FirebaseJsonArray object contains array of the payload returned from the server.

If the type of payload returned from the server is not an array, the function [FirebaseData object].jsonArray will contain empty array.

bool getArray(FirebaseData &dataObj, const String &path, QueryFilter &query);

Read the array data at the defined database path as above

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path in which the array is being read.

param target - The FirebaseJsonArray object to get array value.

return - Boolean type status indicates the success of the operation.

If the type of payload returned from the server is not an array, the target FirebaseJsonArray object will contain an empty array.

bool getArray(FirebaseData &dataObj, const String &path, QueryFilter &query, FirebaseJsonArray *target);

Read the blob (binary data) at the defined database path

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path in which the binary data is being read.

return Boolean type status indicates the success of the operation.

Call [FirebaseData object].dataType to determine what type of data successfully stores in the database.

Call [FirebaseData object].blobData will return the dynamic array of unsigned 8-bit data (i.e. std::vector<uint8_t>) of payload returned from server.

If the payload returned from the server is not blob type, the function [FirebaseData object].blobData will return empty array.

bool getBlob(FirebaseData &dataObj, const String &path);

Read the blob (binary data) at the defined database path

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path in which the binary data is being read.

param target - Dynamic array of unsigned 8-bit data (i.e. std::vector<uint8_t>) to store value.

return Boolean type status indicates the success of the operation.

If the type of payload returned from the server is not a blob, the target variable value will be an empty array.

bool getBlob(FirebaseData &dataObj, const String &path, std::vector<uint8_t> &target);

Download file data in a database at the defined database path and save to SD card/flash memory.

The downloaded data will be decoded to binary and save to SD card/Flash memory, then

please make sure that data at the defined database path is the file type.

param dataObj - Firebase Data Object to hold data and instances.

param storageType - Type of storage to write file data, StorageType::SPIFS or StorageType::SD.

param nodePath - Database path that file data will be downloaded.

param fileName - File name included its path in SD card/Flash memory.

return Boolean type status indicates the success of the operation.

bool getFile(FirebaseData &dataObj, uint8_t storageType, const String &nodePath, const String &fileName);

To use LittleFS file system for flash memory instead of SPIFFS, add the following macro in FirebaseFS.h

#define USE_LITTLEFS

Delete all child nodes at the defined database path

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path to be deleted.

return Boolean type status indicates the success of the operation.*

bool deleteNode(FirebaseData &dataObj, const String &path);

Delete all child nodes at the defined database path if defined database path's ETag matched the ETag value

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path to be deleted.

param ETag - Known unique identifier string (ETag) of defined database path.

return Boolean type status indicates the success of the operation.*

If ETag at the defined database path does not match the provided ETag parameter, the operation will fail with HTTP code 412, Precondition Failed (ETag is not matched).

bool deleteNode(FirebaseData &dataObj, const String &path, const String &ETag);

Start monitoring the value changes at the defined path and its children

param dataObj - Firebase Data Object to hold data and instances.

param path - Database path to subscribe.

return Boolean type status indicates the success of the operation.*

bool beginStream(FirebaseData &dataObj, const String &path);

Start subscribe to the value changes at the defined parent node path with multiple nodes paths parsing.

param dataObj - Firebase Data Object to hold data and instances.

param parentPath - Database parent node path to subscribe.

param childPath - The string array of child nodes paths for parsing.

param size - The size of string array of child nodes paths for parsing.

return Boolean type status indicates the success of the operation.*

bool beginMultiPathStream(FirebaseData &dataObj, const String &parentPath, const String *childPath, size_t size);

Read the stream event data at the defined database path

Once beginStream was called e.g. in setup(), the readStream function should call inside the loop function.

param dataObj - Firebase Data Object to hold data and instances.

return Boolean type status indicates the success of the operation.

Using the same Firebase Data object for stream read/monitoring associated with reading, store, update, delete will break or quit the current stream connection.

The stream will be resumed or reconnected automatically when calling readStream.

bool readStream(FirebaseData &dataObj);

End the stream connection at the defined path

It can be restart again by calling beginStream.

param dataObj - Firebase Data Object to hold data and instances.

return Boolean type status indicates the success of the operation.

bool endStream(FirebaseData &dataObj);

Backup (download) database at defined database path to SD card/flash memory

param dataObj - Firebase Data Object to hold data and instances.

param storageType - Type of storage to save file, StorageType::SPIFS or StorageType::SD.

param nodePath - Database path to be backup.

param fileName - File name to save.

Only 8.3 DOS format (max. 8 bytes file name and 3 bytes file extension) can be saved to the SD card.

return Boolean type status indicates the success of the operation.

bool backup(FirebaseData &dataObj, uint8_t storageType, const String &nodePath, const String &fileName);

To use LittleFS file system for flash memory instead of SPIFFS, add the following macro in FirebaseFS.h

#define USE_LITTLEFS

Restore database at a defined path using backup file saved on SD card/flash memory

param dataObj - Firebase Data Object to hold data and instances.

param storageType - Type of storage to read file, StorageType::SPIFS or StorageType::SD.

param nodePath - Database path to be restored.

param fileName - File name to read.

return Boolean type status indicates the success of the operation.

bool restore(FirebaseData &dataObj, uint8_t storageType const String &nodePath, const String &fileName);

To use LittleFS file system for flash memory instead of SPIFFS, add the following macro in FirebaseFS.h

#define USE_LITTLEFS

Set the stream callback functions

setStreamCallback should be called before Firebase.beginStream.

param dataObj - Firebase Data Object to hold data and instances.

param dataAvailablecallback - Callback function that accepts streamData parameter.

param timeoutCallback - Callback function will be called when stream connection was timeout (optional).

dataAvailablecallback will be called When data in the defined path changed or the stream path changed or stream connection was resumed from reading, store, update and delete the node.

The payload returned from the server will be one of these integer, float, string, JSON and blob types.

Call [streamData object].dataType to determine what type of data that successfully store in the database.

Call [streamData object].xxxData will return the appropriate data type of the payload returned from the server.

void setStreamCallback(FirebaseData &dataObj, StreamEventCallback dataAvailablecallback, StreamTimeoutCallback timeoutCallback = NULL);

Set the multiple paths stream callback functions.

setMultiPathStreamCallback should be called before Firebase.beginMultiPathStream.

param dataObj - Firebase Data Object to hold data and instances.

param multiPathDataCallback - a Callback function that accepts MultiPathStreamData parameter.

param timeoutCallback - a Callback function will be called when stream connection was timeout (optional).

multiPathDataCallback will be called When data in the defined path changed or the stream path changed or stream connection was resumed from getXXX, setXXX, pushXXX, updateNode, deleteNode.

The payload returned from the server will be one of these integer, float, string and JSON.

Call [MultiPathStreamData object].get to get the child node value, type and data path.

The properties [MultiPathStreamData object].value, [MultiPathStreamData object].dataPath, and [MultiPathStreamData object].type will return the value, path of data, and type of data respectively.

These properties will store the result from calling the function [MultiPathStreamData object].get.

void setMultiPathStreamCallback(FirebaseData &dataObj, MultiPathStreamEventCallback multiPathDataCallback, StreamTimeoutCallback timeoutCallback = NULL);

Remove stream callback functions

param dataObj - Firebase Data Object to hold data and instances.

void removeStreamCallback(FirebaseData &dataObj);

Remove multiple paths stream callback functions.

param dataObj - Firebase Data Object to hold data and instances.

void removeMultiPathStreamCallback(FirebaseData &dataObj);

Set maximum Firebase read/store retry operation (0 - 255) in case of network problems and buffer overflow

param dataObj - Firebase Data Object to hold data and instances.

param num - The maximum retry.

void setMaxRetry(FirebaseData &dataObj, uint8_t num);

Start the Firbase Error Queues Auto Run Process

param dataObj - Firebase Data Object to hold data and instances.

param callback - Callback function that accepts QueueInfo Object as parameter, optional.

The following functions are available from QueueInfo Object accepted by callback.

queueInfo.totalQueues(), get the total Error Queues in Error Queue Collection.

queueInfo.currentQueueID(), get current Error Queue ID that being process.

queueInfo.isQueueFull(), determine whether Error Queue Collection is full or not.

queueInfo.dataType(), get a string of the Firebase call data type that being process of current Error Queue.

queueInfo.method(), get a string of the Firebase call method that being process of current Error Queue.

queueInfo.path(), get a string of the Firebase call path that being process of current Error Queue.

void beginAutoRunErrorQueue(FirebaseData &dataObj, QueueInfoCallback callback = NULL);

Stop the Firebase Error Queues Auto Run Process

param dataObj - Firebase Data Object to hold data and instances.

void endAutoRunErrorQueue(FirebaseData &dataObj);

Set the maximum Firebase Error Queues in collection (0 - 255)

Firebase read/store operation causes by network problems and buffer overflow will be added to Firebase Error Queues collection.

param dataObj - Firebase Data Object to hold data and instances.

param num - The maximum Firebase Error Queues.

void setMaxErrorQueue(FirebaseData &dataObj, uint8_t num);

Save Firebase Error Queues as SPIFFS file (save only database store queues)

Firebase read (get) operation will not be saved.

param dataObj - Firebase Data Object to hold data and instances.

param filename - File name to be saved.

param storageType - Type of storage to save file, StorageType::SPIFS or StorageType::SD.

bool saveErrorQueue(FirebaseData &dataObj, const String &filename, uint8_t storageType);

Delete file in flash memory (SPIFFS and LittleFS file systems) or SD card

param filename - File name to delete.

param storageType - Type of storage to save file, StorageType::SPIFS or StorageType::SD.

bool deleteStorageFile(const String &filename, uint8_t storageType);

To use LittleFS file system for flash memory instead of SPIFFS, add the following macro in FirebaseFS.h

#define USE_LITTLEFS

Restore Firebase Error Queues from SPIFFS file

param dataObj - Firebase Data Object to hold data and instances.

param filename - Filename to be read and restore queues.

param storageType - Type of storage to read file, StorageType::SPIFS or StorageType::SD.

bool restoreErrorQueue(FirebaseData &dataObj, const String &filename, uint8_t storageType);

Determine the number of Firebase Error Queues stored in defined SPIFFS file

param dataObj - Firebase Data Object to hold data and instances.

param filename - Filename to be read and count for queues.

param storageType - Type of storage to read file, StorageType::SPIFS or StorageType::SD.

return Number (0-255) of queues store in defined SPIFFS file.

uint8_t errorQueueCount(FirebaseData &dataObj, const String &filename, uint8_t storageType);

Determine number of queues in Firebase Data object Firebase Error Queues collection

param dataObj - Firebase Data Object to hold data and instances.

return Number (0-255) of queues in Firebase Data object queue collection.

uint8_t errorQueueCount(FirebaseData &dataObj);

Determine whether the Firebase Error Queues collection was full or not

param dataObj - Firebase Data Object to hold data and instances.

return Boolean type status indicates whether the Firebase Error Queues collection was full or not.

bool isErrorQueueFull(FirebaseData &dataObj);

Process all failed Firebase operation queue items when network is available

param dataObj - Firebase Data Object to hold data and instances.

param callback - Callback function that accepts QueueInfo parameter.

void processErrorQueue(FirebaseData &dataObj, QueueInfoCallback callback = NULL);

Return Firebase Error Queue ID of last Firebase Error

Return 0 if there is no Firebase Error from last operation.

param dataObj - Firebase Data Object to hold data and instances.

return Number of Queue ID.

uint32_t getErrorQueueID(FirebaseData &dataObj);

Determine whether Firebase Error Queue has currently existed in Error Queue collection or not

param dataObj - Firebase Data Object to hold data and instances.

param errorQueueID - The Firebase Error Queue ID get from getErrorQueueID.

return - Boolean type status indicates the queue existence.

bool isErrorQueueExisted(FirebaseData &dataObj, uint32_t errorQueueID);

Clear all Firbase Error Queues in Error Queue collection

param dataObj - Firebase Data Object to hold data and instances.

void clearErrorQueue(FirebaseData &dataObj);

Send Firebase Cloud Messaging to device with first registeration token which added by firebaseData.fcm.addDeviceToken

param dataObj - Firebase Data Object to hold data and instances.

param index - The index (starts from 0) of recipient device token which added by firebaseData.fcm.addDeviceToken

return - Boolean type status indicates the success of the operation.

bool sendMessage(FirebaseData &dataObj, uint16_t index);

Send Firebase Cloud Messaging to all devices (multicast) which added by firebaseData.fcm.addDeviceToken

param dataObj - Firebase Data Object to hold data and instances.

return - Boolean type status indicates the success of the operation.

bool broadcastMessage(FirebaseData &dataObj);

Send Firebase Cloud Messaging to devices that subscribed to the topic

param dataObj - Firebase Data Object to hold data and instances.

return - Boolean type status indicates the success of the operation.

bool sendTopic(FirebaseData &dataObj);

Firebase Data Object Functions

Set the receive and transmit buffer memory size for secured mode BearSSL WiFi client.

param rx - The number of bytes for receive buffer memory for secured mode BearSSL (512 is minimum, 16384 is maximum).

param tx - The number of bytes for transmit buffer memory for secured mode BearSSL (512 is minimum, 16384 is maximum).

Set this option to false to support get large Blob and File operations.

void void setBSSLBufferSize(uint16_t rx, uint16_t tx);

Set the http response size limit.

param len - The server response buffer size limit.

void setResponseSize(uint16_t len);

Get WiFi client instance

return WiFi client instance.

WiFiClientSecure *getWiFiClient();

Pause/Unpause WiFiClient from all Firebase operations

param pause True for pause and False for unpause.

return Boolean type status indicates the success of the operation.

bool pauseFirebase(bool pause);

Determine the data type of payload returned from the server

return The one of these data type e.g. integer, float, string, JSON and blob.

String dataType();

Determine the event type of stream

return The one of these event type String e.g. put, patch, cancel, and auth_revoked.

The event type "put" indicated that data at the event path relative to the stream path was completely changed. The event path can be determined by dataPath().

The event type "patch" indicated that data at the event path relative to stream path was updated. The event path can be determined by dataPath().

The event type "cancel" indicated something wrong and cancel by the server.

The event type "auth_revoked" indicated the provided Firebase Authentication Data (Database secret) is no longer valid.

String eventType();

Determine the unique identifier (ETag) of current data

return String. of unique identifier.

String ETag();

Determine the current stream path

return The database streaming path.

String streamPath();

Determine the current data path

return The database path which belongs to server' s returned payload.

The database path returned from this function in case of stream, also changed upon the child or parent's stream value changes.

String dataPath();

Determine the error reason String from the process

return The error description string (String object).

String errorReason();

Return the integer data of server returned payload

return Integer value.

int intData();

Return the float data of server returned payload

return Float value.

float floatData();

Return the double data of server returned payload

return Double value.

float doubleData();

Return the Boolean data of server returned payload

return Boolean value.

float boolData();

Return the String data of server returned payload

return String (String object).

String stringData();

Return the JSON String data of server returned payload

return String (String object).

String jsonString();

Return the Firebase JSON object of server returned payload.

return FirebaseJson object.

FirebaseJson &jsonObject();

Return the Firebase JSON object pointer of server returned payload.

return **FirebaseJson object **pointer.

FirebaseJson *jsonObjectPtr();

Return the Firebase JSON Array object of server returned payload.

return FirebaseJsonArray object.

FirebaseJsonArray &jsonArray();

Return the Firebase JSON Array object pointer of server returned payload.

return FirebaseJsonArray object pointer.

FirebaseJsonArray *jsonArrayPtr();

the Firebase JSON Data object that keeps the get(parse) result.

return FirebaseJsonData object .

FirebaseJsonData &jsonData();

the Firebase JSON Data object pointer that keeps the get(parse) result.

return **FirebaseJsonData object **pointer.

FirebaseJsonData *jsonData();

Return the blob data (uint8_t) array of server returned payload

return Dynamic array of 8-bit unsigned integer i.e. std::vector<uint8_t>.

std::vector<uint8_t> blobData();

Return the new appended node's name or key of server returned payload when calling pushXXX function

return String (String object).

String pushName();

Determine the stream connection status

return Boolean type status indicates whether the Firebase Data object is working with the stream or not.

bool isStream();

Determine the server connection status

return Boolean type status indicates whether the Firebase Data object is connected to the server or not.

bool httpConnected();

Determine the timeout event of server's stream (30 sec is the default)

Nothing to do when stream connection timeout, the stream connection will be automatically resumed.

return Boolean type status indicates whether the stream was time out or not.

bool streamTimeout();

Determine the availability of data or payload returned from the server

return Boolean type status indicates whether the server returns the new payload or not.

bool dataAvailable();

Determine the availability of stream event-data payload returned from the server

return Boolean type status indicates whether the server returns the stream event-data payload or not.

bool streamAvailable();

Determine the matching between data type that intend to get from/store to database and the server's return payload data type

return Boolean type status indicates whether the type of data being get from/store to database and the server's returned payload is matched or not.

bool mismatchDataType();

Determine the HTTP status code return from the server

return Integer number of HTTP status.

int httpCode();

Check overflow of the returned payload data buffer

return Boolean of the overflow status.

Total default HTTP response buffer size is 400 bytes which can be set through Firebase.setResponseSize.

bool bufferOverflow();

Determine the name (full path) of backup file in SD card/flash memory

return String (String object) of a file name that stores on SD card/flash memory after backup operation.

String getBackupFilename();

To use LittleFS file system for flash memory instead of SPIFFS, add the following macro in FirebaseFS.h

#define USE_LITTLEFS

Determine the size of the backup file

return Number of byte of backup file in byte after backup operation.

size_t getBackupFileSize();

Clear or empty data in Firebase Data object

void clear();

Determine the error description for file transferring (pushFile, setFile, backup and restore)

return Error description string* (String object).

String fileTransferError();

Return the server's payload data

return Payload string* (String object).

String payload();

Firebase Cloud Messaging Object Functions

Store Firebase Cloud Messaging's authentication credentials

param serverKey - Server key found on Console: Project settings > Cloud Messaging

void begin(const String &serverKey);

Add recipient's device registration token or instant ID token

param deviceToken - Recipient's device registration token to add that message will be sent to.

void addDeviceToken(const String &deviceToken);

Remove recipient's device registration token or instant ID token

param index - Index (start from zero) of recipient's device registration token that added to FCM Data Object of Firebase Data object.

void removeDeviceToken(uint16_t index);

Clear all recipient's device registration tokens

void clearDeviceToken();

Set the notify message type information

param title - The title text of notification message.

param body - The body text of notification message.

void setNotifyMessage(const String &title, const String &body);

Set the notify message type information

param title - The title text of notification message.

param body - The body text of notification message.

param icon - The name and/or included URI/URL of the icon to show on notifying the message.

void setNotifyMessage(const String &title, const String &body, const String &icon);

Set the notify message type information

param title - The title text of notification message.

param body - The body text of notification message.

param icon - The name and/or included URI/URL of the icon to show on notifying the message.

param click_action - The URL or intent to accept click event on the notification message.

void setNotifyMessage(const String &title, const String &body, const String &icon, const String &click_action);

Clear all notify message information

void clearNotifyMessage();

Set the custom data message type information

param jsonString - The JSON structured data string.

void setDataMessage(const String &jsonString);

Set the custom data message type information

param json - The FirebaseJson object.

void setDataMessage(FirebaseJson &json);

Clear custom data message type information

void clearDataMessage();

Set the priority of the message (notification and custom data)

param priority - The priority string i.e. normal and high.

void setPriority(const String &priority);

Set the collapse key of the message (notification and custom data)

param key - String of collapse key.

void setCollapseKey(const String &key);

Set the Time To Live of the message (notification and custom data)

param seconds - Number of seconds from 0 to 2,419,200 (4 weeks).

void setTimeToLive(uint32_t seconds);

Set topic of the message will be sent to

param **`topic - Topic string.

void setTopic(const String &topic);

Get the send result

return String of payload returned from the server.

String getSendResult();

FirebaseJSON object Functions

Clear internal buffer of FirebaseJson object.

return instance of an object.

FirebaseJson &clear();

Set JSON data (JSON object string) to FirebaseJson object.

param data - The JSON object string.

return instance of an object.

FirebaseJson &setJsonData(const String &data);

Add null to FirebaseJson object.

param key - The new key string that null to be added.

return instance of an object.

FirebaseJson &add(const String &key);

Add string to FirebaseJson object.

param key - The new key string that string value to be added.

param value - The String value for the new specified key.

return instance of an object.

FirebaseJson &add(const String &key, const String &value);

Add string (chars array) to FirebaseJson object.

param key - The new key string that string (chars array) value to be added.

param value - The char array for the new specified key.

return instance of an object.

FirebaseJson &add(const String &key, const char *value);

Add integer/unsigned short to FirebaseJson object.

param key - The new key string that the value to be added.

param value - The integer/unsigned short value for new specified key.

return instance of an object.

FirebaseJson &add(const String &key, int value);
FirebaseJson &add(const String &key, unsigned short value);

Add float to FirebaseJson object.

param key - The new key string that float value to be added.

param value - The float value for the new specified key.

return instance of an object.

FirebaseJson &add(const String &key, float value);

Add double to FirebaseJson object.

param key - The new key string that double value to be added.

param value - The double value for the new specified key.

return instance of an object.

FirebaseJson &add(const String &key, double value);

Add boolean to FirebaseJson object.

param key - The new key string that bool value to be added.

param value - The boolean value for new specified key.

return instance of an object.

FirebaseJson &add(const String &key, bool value);

Add nested FirebaseJson object into FirebaseJson object.

param key - The new key string that FirebaseJson object to be added.

param json - The FirebaseJson object for the new specified key.

return instance of an object.

FirebaseJson &add(const String &key, FirebaseJson &json);

Add nested FirebaseJsonArray object into FirebaseJson object.

param key - The new key string that FirebaseJsonArray object to be added.

param arr - The FirebaseJsonArray for the new specified key.

return instance of an object.

FirebaseJson &add(const String &key, FirebaseJsonArray &arr);

Get the FirebaseJson object serialized string.

param buf - The returning String object.

param prettify - Boolean flag for return the pretty format string i.e. with text indentation and newline.

void toString(String &buf, bool prettify = false);

Get the value from the specified node path in FirebaseJson object.

param jsonData - The returning FirebaseJsonData that hold the returned data.

param path - Relative path to the specific node in FirebaseJson object.

param prettify - The bool flag for the prettifying string in FirebaseJsonData's stringValue.

return boolean status of the operation.

The FirebaseJsonData object holds the returned data which can be read from the following properties.

jsonData.stringValue - contains the returned string.

jsonData.intValue - contains the returned integer value.

jsonData.floatValue - contains the returned float value.

jsonData.doubleValue - contains the returned double value.

jsonData.boolValue - contains the returned boolean value.

jsonData.success - used to determine the result of the get operation.

jsonData.type - used to determine the type of returned value in string represent 
the types of value e.g. string, int, double, boolean, array, object, null and undefined.

jsonData.typeNum used to determine the type of returned value is an integer as represented by the following value.

FirebaseJson::UNDEFINED = 0
FirebaseJson::OBJECT = 1
FirebaseJson::ARRAY = 2
FirebaseJson::STRING = 3
FirebaseJson::INT = 4
FirebaseJson::FLOAT = 5
FirebaseJson::DOUBLE = 6
FirebaseJson::BOOL = 7 and
FirebaseJson::NULL = 8
bool get(FirebaseJsonData &jsonData, const String &path, bool prettify = false);

Parse and collect all node/array elements in FirebaseJson object.

param data - The JSON data string to parse (optional for replacing the internal buffer with new data).

return number of child/array elements in FirebaseJson object.

size_t iteratorBegin(const char* data = NULL);

Get child/array elements from FirebaseJson objects at specified index.

param index - The element index to get.

param type - The integer which holds the type of data i.e. FirebaseJson::OBJECT and FirebaseJson::ARR

param key - The string which holds the key/name of the object, can return empty String if the data type is an array.

param value - The string which holds the value for the element key or array.

void iteratorGet(size_t index, int &type, String &key, String &value);

Clear all iterator buffer (should be called since iteratorBegin was called).

void iteratorEnd();

Set null to FirebaseJson object at the specified node path.

param path - The relative path that null to be set.

The relative path can be mixed with array index (number placed inside square brackets) and node names e.g. /myRoot/[2]/Sensor1/myData/[3].

void set(const String &path);

Set String value to FirebaseJson object at the specified node path.

param path - The relative path that string value to be set.

param value - The string value to set.

The relative path can be mixed with array index (number placed inside square brackets) and node names e.g. /myRoot/[2]/Sensor1/myData/[3].

void set(const String &path, const String &value);

Set string (chars array) value to FirebaseJson object at the specified node path.

param path - The relative path that string (chars array) to be set.

param value - The char array to set.

The relative path can be mixed with array index (number placed inside square brackets) and node names e.g. /myRoot/[2]/Sensor1/myData/[3].

void set(const String &path, const char *value);

Set integer/unsigned short value to FirebaseJson object at specified node path.

param path - The relative path that int value to be set.

param value - The integer/unsigned short value to set.

The relative path can be mixed with array index (number placed inside square brackets) and node names e.g. /myRoot/[2]/Sensor1/myData/[3].

void set(const String &path, int value);
void set(const String &path, unsigned short value);

Set the float value to FirebaseJson object at the specified node path.

param path - The relative path that float value to be set.

param value - The float value to set.

The relative path can be mixed with array index (number placed inside square brackets) and node names e.g. /myRoot/[2]/Sensor1/myData/[3].

void set(const String &path, float value);

Set the double value to FirebaseJson object at the specified node path.

param path - The relative path that double value to be set.

param value - The double value to set.

The relative path can be mixed with array index (number placed inside square brackets) and node names e.g. /myRoot/[2]/Sensor1/myData/[3].

void set(const String &path, double value);

Set the boolean value to FirebaseJson object at the specified node path.

param path - The relative path that bool value to be set.

param value - The boolean value to set.

The relative path can be mixed with array index (number placed inside square brackets) and node names e.g. /myRoot/[2]/Sensor1/myData/[3].

void set(const String &path, bool value);

Set nested FirebaseJson object to FirebaseJson object at the specified node path.

param path - The relative path that nested FirebaseJson object to be set.

param json - The FirebaseJson object to set.

The relative path can be mixed with array index (number placed inside square brackets) and node names e.g. /myRoot/[2]/Sensor1/myData/[3].

void set(const String &path, FirebaseJson &json);

Set nested FirebaseJsonAtrray object to FirebaseJson object at specified node path.

param path - The relative path that nested FirebaseJsonAtrray object to be set.

param arr - The FirebaseJsonAtrray object to set.

The relative path can be mixed with array index (number placed inside square brackets) and node names e.g. /myRoot/[2]/Sensor1/myData/[3].

void set(const String &path, FirebaseJsonArray &arr);

Remove the specified node and its content.

param path - The relative path to remove its contents/children.

return bool value represents the successful operation.

bool remove(const String &path);

FirebaseJsonArray object functions

Add null to FirebaseJsonArray object.

return instance of an object.

FirebaseJsonArray &add();

Add string to FirebaseJsonArray object.

param value - The String value to add.

return instance of an object.

FirebaseJsonArray &add(const String &value);

Add string (chars arrar) to FirebaseJsonArray object.

param value - The chars array to add.

return instance of an object.

FirebaseJsonArray &add(const char *value);

Add integer/unsigned short to FirebaseJsonArray object.

param value - The integer/unsigned short value to add.

return instance of an object.

FirebaseJsonArray &add(int value);
FirebaseJsonArray &add(unsigned short value);

Add float to FirebaseJsonArray object.

param value - The float value to add.

return instance of an object.

FirebaseJsonArray &add(float value);

Add double to FirebaseJsonArray object.

param value - The double value to add.

return instance of an object.

FirebaseJsonArray &add(double value);

Add boolean to FirebaseJsonArray object.

param value - The boolean value to add.

return instance of an object.

FirebaseJsonArray &add(bool value);

Add nested FirebaseJson object to FirebaseJsonArray object.

param json - The FirebaseJson object to add.

return instance of an object.

FirebaseJsonArray &add(FirebaseJson &json);

Add nested FirebaseJsonArray object to FirebaseJsonArray object.

param arr - The FirebaseJsonArray object to add.

return instance of an object.

FirebaseJsonArray &add(FirebaseJsonArray &arr);

Get the array value at specified index from FirebaseJsonArray object.

param jsonObj - The returning FirebaseJsonData object that holds data at the specified index.

param index - Index of data in FirebaseJsonArray object.

return boolean status of the operation.

bool get(FirebaseJsonData &jsonObj, int index);
bool get(FirebaseJsonData *jsonData, int index);

Get the array value at the specified path from FirebaseJsonArray object.

param jsonObj - The returning FirebaseJsonData object that holds data at the specified path.

param path - Relative path to data in FirebaseJsonArray object.

return boolean status of the operation.

The relative path must begin with array index (number placed inside square brackets) followed by other array indexes or node names e.g. /[2]/myData would get the data from myData key inside the array indexes 2.

bool get(FirebaseJsonData &jsonData, const String &path);

Get the length of array in FirebaseJsonArray object.

return length of the array.

size_t size();

Get the FirebaseJsonArray object serialized string.

param buf - The returning String object.

param prettify - Boolean flag for return the pretty format string i.e. with text indentation and newline.

void toString(String &buf, bool prettify = false);

Clear all array in FirebaseJsonArray object.

return instance of an object.

FirebaseJsonArray &clear();

Set null to FirebaseJsonArray object at specified index.

param index - The array index to set null.

void set(int index);

Set String to FirebaseJsonArray object at specified index.

param index -The array index that String value to be set.

param value - The String to set.

void set(int index, const String &value);

Set string (chars array) to FirebaseJsonArray object at specified index.

param index - The array index that string (chars array) to be set.

param value - The char array to set.

void set(int index, const char *value);

Set integer/unsigned short value to FirebaseJsonArray object at specified index.

param index - The array index that int/unsigned short to be set.

param value - The integer/unsigned short value to set.

void set(int index, int value);
void set(int index, unsigned short value);

Set float value to FirebaseJsonArray object at specified index.

param index - The array index that float value to be set.

param value - The float value to set.

void set(int index, float value);

Set double value to FirebaseJsonArray object at specified index.

param index - The array index that double value to be set.

param value - The double value to set.

void set(int index, double value);

Set boolean value to FirebaseJsonArray object at specified index.

param index - The array index that bool value to be set.

param value - The boolean value to set.

void set(int index, bool value);

Set nested FirebaseJson object to FirebaseJsonArray object at specified index.

param index - The array index that nested FirebaseJson object to be set.

param value - The FirebaseJson object to set.

void set(int index, FirebaseJson &json);

Set nested FirebaseJsonArray object to FirebaseJsonArray object at specified index.

param index - The array index that nested FirebaseJsonArray object to be set.

param value - The FirebaseJsonArray object to set.

void set(int index, FirebaseJsonArray &arr);

Set null to FirebaseJson object at the specified path.

param path - The relative path that null to be set.

The relative path must begin with array index (number placed inside square brackets) followed by other array indexes or node names e.g. /[2]/myData would get the data from myData key inside the array indexes 2.

void set(const String &path);

Set String to FirebaseJsonArray object at specified path.

param path - The relative path that string value to be set.

param value - The String to set.

The relative path must begin with array index (number placed inside square brackets) followed by other array indexes or node names e.g. /[2]/myData would get the data from myData key inside the array indexes 2.

void set(const String &path, const String &value);

Set string (chars array) to FirebaseJsonArray object at specified path.

param path - The relative path that string (chars array) value to be set.

param value - The char array to set.

The relative path must begin with array index (number placed inside square brackets) followed by other array indexes or node names e.g. /[2]/myData would get the data from myData key inside the array indexes 2.

void set(const String &path, const char *value);

Set integer/unsigned short value to FirebaseJsonArray object at specified path.

param path - The relative path that integer/unsigned short value to be set.

param value - The integer value to set.

The relative path must begin with array index (number placed inside square brackets) followed by other array indexes or node names e.g. /[2]/myData would get the data from myData key inside the array indexes 2.

void set(const String &path, int value);
void set(const String &path, unsigned short value);

Set float value to FirebaseJsonArray object at specified path.

param path - The relative path that float value to be set.

param value - The float to set.

The relative path must begin with array index (number placed inside square brackets) followed by other array indexes or node names e.g. /[2]/myData would get the data from myData key inside the array indexes 2.

void set(const String &path, float value);

Set double value to FirebaseJsonArray object at specified path.

param path - The relative path that double value to be set.

param value - The double to set.

The relative path must begin with array index (number placed inside square brackets) followed by other array indexes or node names e.g. /[2]/myData would get the data from myData key inside the array indexes 2.

void set(const String &path, double value);

Set boolean value to FirebaseJsonArray object at specified path.

param path - The relative path that bool value to be set.

param value - The boolean value to set.

The relative path must begin with array index (number placed inside square brackets) followed by other array indexes or node names e.g. /[2]/myData would get the data from myData key inside the array indexes 2.

void set(const String &path, bool value);

Set the nested FirebaseJson object to FirebaseJsonArray object at the specified path.

param path - The relative path that nested FirebaseJson object to be set.

param value - The FirebaseJson object to set.

The relative path must begin with array index (number placed inside square brackets) followed by other array indexes or node names e.g. /[2]/myData would get the data from myData key inside the array indexes 2.

void set(const String &path, FirebaseJson &json);

Set the nested FirebaseJsonArray object to FirebaseJsonArray object at specified path.

param path - The relative path that nested FirebaseJsonArray object to be set.

param value - The FirebaseJsonArray object to set.

The relative path must begin with array index (number placed inside square brackets) followed by other array indexes or node names e.g. /[2]/myData would get the data from myData key inside the array indexes 2.

void set(const String &path, FirebaseJsonArray &arr);

Remove the array value at specified index from FirebaseJsonArray object.

param index - The array index to be removed.

return bool value represents the successful operation.

bool remove(int index);

Remove the array value at the specified path from FirebaseJsonArray object.

param path - The relative path to array in FirebaseJsonArray object to be removed.

return bool value represents the successful operation.

The relative path must begin with array index (number placed inside square brackets) followed by other array indexes or node names e.g. /[2]/myData would get the data from myData key inside the array indexes 2.

bool remove(const String &path);

FirebaseJsonData object functions

Get array data as FirebaseJsonArray object from FirebaseJsonData object.

param jsonArray -The returning FirebaseJsonArray object.

return bool status for successful operation.

This should call after pares or get functions.

bool getArray(FirebaseJsonArray &jsonArray);

Get array data as FirebaseJson object from FirebaseJsonData object.

param jsonArray - The returning FirebaseJson object.

return bool status for successful operation.

This should call after pares or get functions.

bool getJSON(FirebaseJson &json);

FirebaseJsonData object properties

stringValue The String value of parses data.

intValue The int value of parses data.

floatValue The double value of parses data.

doubleValue The double value of parses data.

boolValue The bool value of parses data.

success used to determine the result of the get operation.

type The type String of parses data e.g. string, int, double, boolean, array, object, null and undefined.

typeNum The type (number) of parses data in form of the following jsonDataType value.

FirebaseJson::UNDEFINED = 0

FirebaseJson::OBJECT = 1

FirebaseJson::ARRAY = 2

FirebaseJson::STRING = 3

FirebaseJson::INT = 4

FirebaseJson::FLOAT = 5

FirebaseJson::DOUBLE = 6

FirebaseJson::BOOL = 7 and

FirebaseJson::NULL = 8

success The success flag of parsing data.

License

The MIT License (MIT)

Copyright (c) 2019 K. Suwatchai (Mobizt)

Permission is hereby granted, free of charge, to any person returning a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.