Sample code for 30+ languages & platforms
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

Java
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());
  }
}