Rust based library for interacting with the Firebase REST API.
API Docs can be found at here
This is a fork of the original project firebase by "David White david.white@spry-soft.com" and "Michael Eden themichaeleden@gmail.com
The APIs in this README do not document all of the APIs available! Go to the official docs for the most up to date version of the API.
Don't forget to include the library in your project:
Rust
extern crate firebase_db_access;
use firebase::Firebase;
You can currently create a simple reference to your firebase server:
Rust
let firebase = Firebase::new("https://<your-firebase>.firebaseio.com");
Or you can create an authenticated connection by supplying your auth token:
Rust
let firebase = Firebase::authed("https://<your-firebase>.firebaseio.com", "<token>");
NOTE: You must send your requests through HTTPS or Firebase will reject it. Not specifying HTTPS will also result in an error: ParseError::UrlIsNotHTTPS
Reference nested objects in your server like so:
Rust
let show = firebase.at("/shows/futurama"); // points to /shows/futurama
let episode = show.at("s10/meanwhile"); // points to /shows/futurama/s10/meanwhile
Slashes and .json extensions will be handled accordingly:
Rust
// All of the following are equivalent:
let show = firebase.at("/shows/futurama.json");
let show = firebase.at("shows/futurama/");
let show = firebase.at("/shows/futurama/");
Reading data can be done with a simple call to .get()
Rust
let response = show.get();
Rust
let description = episode.at("description");
let response = description.set("the last episode");
Rust
let episodes = firebase.at("/shows/futurama/episodes");
let response = episodes.push("The Lost Episode!");
Rust
let description = episode.at("description");
let response = description.update("the penultimate episode");
Rust
let episode = firebase.at("/shows/futurama/s10/meanwhile");
let response = episode.remove();
Rust
let episodes = firebase.at("/shows/futurama/episodes");
let top5 = episodes.order_by("\"imdb\"").limit_to_first(5).get();
The full list of supported parameters are listed here:
order_by
limit_to_first
limit_to_last
start_at
end_at
equal_to
shallow
For now JSON is sent and received as a string literal, an easier method is likely to be implemented in future versions
```Rust let json = "{ \"name\": \"David Smith\" }"
let people = firebase.at("/earth/us/indiana"); let response = episodes.push(json); ```