Archived Forum Post

Index of archived forum posts

Question:

(Androidâ„¢) Firebase Receive Server-Sent Events (text/event-stream)

Oct 19 '16 at 03:27

Gentelmen,
I have a serious intention to purchase Chilkat "Boundly-only" package to implement this example in my application, but just on simple testing I receive some logs that I dont understand at all. Can anybody take a look and advice me how to handle that ?

Thx in advance

`

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    CkGlobal glob = new CkGlobal();
    boolean success = glob.UnlockBundle("tj_gumis for 30-day trial");
    if (success != true) {
        System.out.println(glob.lastErrorText());

        return;
    }

    trigerSse();

    TextView tv = new TextView(this);

    CkCrypt2 crypt = new CkCrypt2();

    // Display the version of the CkCrypt2 class
    tv.setText(crypt.version());

    setContentView(tv);
}

private void trigerSse(){

    //  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 Firebase JWT Authentication for sample code.

    boolean success;
    String authToken = "My-previously-obtained-JWT-token";

    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("galleryingrey.com",80,true,true);
    if (success != true) {
        Log.i(TAG, rest.lastErrorText());
        return;
    }

    rest.AddQueryParam("auth",authToken);
    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) {
        Log.i(TAG, "Unexpected response code: " + String.valueOf(rest.get_ResponseStatusCode()));
        Log.i(TAG, responseBody);
        Log.i(TAG, "Failed.");
        return;
    }

    //  Get the redirect URL
    CkUrl url = rest.RedirectUrl();
    if (rest.get_LastMethodSuccess() != true) {
        Log.i(TAG, rest.lastErrorText());
        return;
    }

    Log.i(TAG, "redirect URL domain: " + url.host());
    Log.i(TAG, "redirect URL path: " + url.path());
    Log.i(TAG, "redirect URL query params: " + url.query());
    Log.i(TAG, "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) {
        Log.i(TAG, 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) {
        Log.i(TAG, 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) {
        Log.i(TAG, 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) {
        Log.i(TAG, "Response Code: " + String.valueOf(responseStatusCode));
        Log.i(TAG, "Response Status Text: " + rest2.responseStatusText());
        Log.i(TAG, "Response Header: " + rest2.responseHeader());
        responseBody = rest2.readRespBodyString();
        if (rest2.get_LastMethodSuccess() == true) {
            Log.i(TAG, "Error Response Body: " + responseBody);
        }

        Log.i(TAG, "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.

        //  Alternatively, to avoid polling,
        //  it is possible to receive the data in callbacks.
        //  Examples w/ callbacks are shown elsewhere.
        String eventStr = eventStream.readUntilMatch("\r\n\r\n");
        if (eventStream.get_LastMethodSuccess() != true) {
            Log.i(TAG, eventStream.lastErrorText());
            //  Force the loop to exit by setting the count to a high number.
            count = 99999;
        }
        else {
            Log.i(TAG, "Event: [" + eventStr + "]");

            //  We have an event. Let's update our local copy of the JSON database.
            success = sse.LoadEvent(eventStr);
            if (success != true) {
                Log.i(TAG, "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) {
                    Log.i(TAG, "Failed to apply event: " + sse.eventName() + ": " + sse.data());
                }
                else {
                    Log.i(TAG, "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);
    Log.i(TAG, "----");
    Log.i(TAG, jsonDb.emit());
}

static {
    // Important: Make sure the name passed to loadLibrary matches the shared library
    // found in your project's libs/armeabi directory.
    //  for "libchilkat.so", pass "chilkat" to loadLibrary
    //  for "libchilkatemail.so", pass "chilkatemail" to loadLibrary
    //  etc.
    //
    System.loadLibrary("chilkat");

    // Note: If the incorrect library name is passed to System.loadLibrary,
    // then you will see the following error message at application startup:
    //"The application <your-application-name> has stopped unexpectedly. Please try again."
}

}

`