Java
Java
Firebase Receive Server-Sent Events (text/event-stream)
See more Firebase Examples
Demonstrates how to start receiving server-sent events and update your JSON database with each event.Chilkat Java Downloads
import com.chilkatsoft.*;
public class ChilkatExample {
static {
try {
System.loadLibrary("chilkat");
} catch (UnsatisfiedLinkError e) {
System.err.println("Native code library failed to load.\n" + e);
System.exit(1);
}
}
public static void main(String argv[])
{
boolean success = false;
// Demonstrates how to begin receiving server-sent events, and to update
// your JSON database for each event.
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
// This example assumes a JWT authentication token, if required, has been previously obtained.
// See Get Firebase Access Token from JSON Service Account Private Key for sample code.
// Load the previously obtained Firebase access token into a string.
CkFileAccess fac = new CkFileAccess();
String accessToken = fac.readEntireTextFile("qa_data/tokens/firebaseToken.txt","utf-8");
if (fac.get_LastMethodSuccess() == false) {
System.out.println(fac.lastErrorText());
return;
}
CkRest rest = new CkRest();
// Make the initial connection (without sending a request yet).
// Once connected, any number of requests may be sent. It is not necessary to explicitly
// call Connect before each request.
success = rest.Connect("chilkat.firebaseio.com",443,true,true);
if (success == false) {
System.out.println(rest.lastErrorText());
return;
}
CkAuthGoogle authGoogle = new CkAuthGoogle();
authGoogle.put_AccessToken(accessToken);
rest.SetAuthGoogle(authGoogle);
rest.AddHeader("Accept","text/event-stream");
rest.AddHeader("Cache-Control","no-cache");
String responseBody = rest.fullRequestNoBody("GET","/.json");
// A 307 redirect response is expected.
if (rest.get_ResponseStatusCode() != 307) {
System.out.println("Unexpected response code: " + rest.get_ResponseStatusCode());
System.out.println(responseBody);
System.out.println("Failed.");
return;
}
// Get the redirect URL
String urlStr = rest.lastRedirectUrl();
CkUrl url = new CkUrl();
url.ParseUrl(urlStr);
System.out.println("redirect URL domain: " + url.host());
System.out.println("redirect URL path: " + url.path());
System.out.println("redirect URL query params: " + url.query());
System.out.println("redirect URL path with query params: " + url.pathWithQueryParams());
// Our text/event-stream will be obtained from the redirect URL...
CkRest rest2 = new CkRest();
success = rest2.Connect(url.host(),443,true,true);
if (success != true) {
System.out.println(rest2.lastErrorText());
return;
}
rest2.AddHeader("Accept","text/event-stream");
rest2.AddHeader("Cache-Control","no-cache");
// Add the redirect query params to the request
rest2.AddQueryParams(url.query());
// In our case, we don't actually need the auth query param,
// so remove it.
rest2.RemoveQueryParam("auth");
// Send the request. (We are only sending the request here.
// We are not yet getting the response because the response
// will be a text/event-stream.)
success = rest2.SendReqNoBody("GET",url.path());
if (success != true) {
System.out.println(rest2.lastErrorText());
return;
}
// Read the response header.
// We want to first get the response header to see if it's a successful
// response status code. If not, then the response will not be a text/event-stream
// and we should read the response body normally.
int responseStatusCode = rest2.ReadResponseHeader();
if (responseStatusCode < 0) {
System.out.println(rest2.lastErrorText());
return;
}
// If successful, a 200 response code is expected.
// If the reponse code is not 200, then read the response body and fail..
if (responseStatusCode != 200) {
System.out.println("Response Code: " + responseStatusCode);
System.out.println("Response Status Text: " + rest2.responseStatusText());
System.out.println("Response Header: " + rest2.responseHeader());
responseBody = rest2.readRespBodyString();
if (rest2.get_LastMethodSuccess() == true) {
System.out.println("Error Response Body: " + responseBody);
}
System.out.println("Failed.");
return;
}
// For this example, our JSON database will be empty at the beginning.
// The incoming events (put and patch) will be applied to this database.
CkJsonObject jsonDb = new CkJsonObject();
// Make sure to set the JSON path delimiter to "/". The default is "." and this
// is not compatible with Firebase paths.
jsonDb.put_DelimiterChar("/");
// At this point, we've received the response header. Now it's time to begin
// receiving the event stream. We'll start a background thread to read the
// stream. (Our main application (foreground) thread can cancel it at any time.)
// While receiving in the background thread, our foreground thread can read the stream
// as it desires..
CkStream eventStream = new CkStream();
// This sse object will be used as a helper to parse the server-sent event stream.
CkServerSentEvent sse = new CkServerSentEvent();
CkTask task = rest2.ReadRespBodyStreamAsync(eventStream,true);
task.Run();
// For this example, we'll just read a few events, and then cancel the
// async task.
int count = 0;
while ((count < 3) && (task.get_Finished() == false)) {
// Get the next event, which is a series of text lines ending with
// a blank line.
// Note: This method blocks the calling thread until a message arrives.
// a program might instead periodically check the availability of
// data via the stream's DataAvailable property, and then do the read.
// An alternative to writing a while loop to read the event stream
// would be to setup some sort of timer event in your program (using whatever timer functionality
// is provided in a programming language/environment), to periodically check the eventStream's
// DataAvailable property and consume the incoming event.
String eventStr = eventStream.readUntilMatch("\r\n\r\n");
if (eventStream.get_LastMethodSuccess() != true) {
System.out.println(eventStream.lastErrorText());
// Force the loop to exit by setting the count to a high number.
count = 99999;
}
else {
System.out.println("Event: [" + eventStr + "]");
// We have an event. Let's update our local copy of the JSON database.
success = sse.LoadEvent(eventStr);
if (success != true) {
System.out.println("Failed to load sse event: " + eventStr);
}
else {
// Now we can easily access the event name and data, and apply it to our JSON database:
success = jsonDb.FirebaseApplyEvent(sse.eventName(),sse.data());
if (success != true) {
System.out.println("Failed to apply event: " + sse.eventName() + ": " + sse.data());
}
else {
System.out.println("Successfully applied event: " + sse.eventName() + ": " + sse.data());
}
}
}
count = count+1;
}
// Make sure the background task is cancelled if still running.
task.Cancel();
// Examine the JSON database after applying events..
jsonDb.put_EmitCompact(false);
System.out.println("----");
System.out.println(jsonDb.emit());
}
}