Parsing JSON with JsonParserGeneratorRK Library

Parsing JSON with JsonParserGeneratorRK Library

JSON Example Data

  • Consider the following JSON data is being received by the Argon
  "location": {
    "name": "Los Angeles",
    "country": "USA",
    "region": "California",
    "lat": "34.018",
    "lon": "-118.284",
  "current": {
    "observation_time": "01:56 AM",
    "temperature": 63,
    "weather_descriptions": [
      "Partly cloudy"
    "humidity": 56,

Parsing JSON with a Library: JsonParserGeneratorRK

  • JsonParserGeneratorRK is a great Argon-specific library for parsing JSON code and can be installed from Workbench
  • Use the sample code below for your event handler
  • The first part allows for responses from the webhook that come in multiple parts (you don’t need to change this)
  • The second part is where you can adapt your own code

Publishing and Subscribing

void setup() {
  // Subscribe to the integration response event
  Particle.subscribe("hook-response/JSONWeatherStack", jsonSubscriptionHandler,

void loop() {
  // Get some data
  String data = "92807";
  // Trigger the integration
  Particle.publish("JSONWeatherStack", data, PRIVATE);
  // Wait 60 seconds

Parsing with JsonParserGeneratorRK

void jsonSubscriptionHandler(const char *event, const char *data) {
  //Part 1 allows for webhook responses to be delivered in multple "chunks"; you don't need to change this
  int responseIndex = 0;
  const char *slashOffset = strrchr(event, '/');
  if (slashOffset)
    responseIndex = atoi(slashOffset + 1);
  if (responseIndex == 0)

  //Part 2 is where you can parse the actual data; you code goes in the IF
  if (jsonParser.parse()) {

  	/****** YOUR PARSING CODE GOES HERE ********/

Example: Consider the following JSON

  "place": {
    "city": "los angeles",
    "state": "california"

Configuration of JsonParserGeneratorRK

  • Import library
    #include "JsonParserGeneratorRK.h"
  • Create global JsonParser object to read JSON
    JsonParser jsonParser; 

Configuring the event handler

  • The JSON will be passed to the data parameter of event handler
    void jsonSubscriptionHandler(const char *event, const char *data) {
  • The first part of our event handler accounts for a single JSON broken up into multiple events
  • This code is complete and you don’t need to modify it
  • The part we are interested is the actual JSON parsing

Here is an example

void jsonSubscriptionHandler(const char *event, const char *data) {
  /* ... rest of function code */
  if (jsonParser.parse()) {

    String city = jsonParser.getReference()
   Serial.println("The city " + city);