contentparser.c 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. //
  2. // Created by janco on 25-3-16.
  3. //
  4. #include "contentparser.h"
  5. #include "ntp.h"
  6. #include "network.h"
  7. #include "jsmn.h"
  8. #include "rtc.h"
  9. #include "alarm.h"
  10. #include "displayHandler.h"
  11. int streamid;
  12. void parseAlarmJson(char* content){
  13. int r;
  14. int i = 2;
  15. jsmn_parser p;
  16. jsmntok_t token[150]; /* We expect no more than 128 tokens */
  17. jsmn_init(&p);
  18. r = jsmn_parse(&p, content, strlen(content), token, sizeof(token)/sizeof(token[0]));
  19. if (r <= 0) {
  20. printf("Failed to parse JSON: %d \n", r);
  21. return;
  22. }else{
  23. printf("Aantal tokens found: %d \n", r);
  24. }
  25. int usedAlarms[maxAlarms()];
  26. int j;
  27. struct _tm time = GetRTCTime();
  28. for(j = 0; j < maxAlarms(); j++){
  29. usedAlarms[j] = 0;
  30. }
  31. for(i; i < r; i++)
  32. {
  33. int id;
  34. u_short port;
  35. char url[24];
  36. char ip[24];
  37. char name[16];
  38. char st = -1;
  39. memset(url, 0, 24);
  40. memset(ip, 0, 24);
  41. memset(name, 0, 17);
  42. for (i; (st == -1 && i < r); i+=2) { //Zodra ST is gevonden, betekent dit de laatste token van een alarm.
  43. if (jsoneq(content, &token[i], "YYYY") == 0) {
  44. time.tm_year= getIntegerToken(content, &token[i + 1]) - 1900;
  45. }else if (jsoneq(content, &token[i], "MM") == 0) {
  46. time.tm_mon= getIntegerToken(content, &token[i + 1]) - 1;
  47. }else if (jsoneq(content, &token[i], "DD") == 0) {
  48. time.tm_mday = getIntegerToken(content, &token[i + 1]);
  49. }else if (jsoneq(content, &token[i], "hh") == 0) {
  50. time.tm_hour = getIntegerToken(content, &token[i + 1]);
  51. }else if (jsoneq(content, &token[i], "mm") == 0) {
  52. time.tm_min = getIntegerToken(content, &token[i + 1]);
  53. }else if (jsoneq(content, &token[i], "ss") == 0) {
  54. time.tm_sec = getIntegerToken(content, &token[i + 1]);
  55. }else if (jsoneq(content, &token[i], "id") == 0) {
  56. id = getIntegerToken(content, &token[i + 1]);
  57. }else if (jsoneq(content, &token[i], "port") == 0) {
  58. port = getIntegerToken(content, &token[i + 1]);
  59. }else if (jsoneq(content, &token[i], "ip") == 0) {
  60. getStringToken(content, &token[i + 1], ip, 24);
  61. }else if (jsoneq(content, &token[i], "url") == 0) {
  62. getStringToken(content, &token[i + 1], url, 24);
  63. }else if (jsoneq(content, &token[i], "name") == 0) {
  64. getStringToken(content, &token[i + 1], name, 16);
  65. }else if (jsoneq(content, &token[i], "st") == 0) {
  66. st = getIntegerToken(content, &token[i + 1]);
  67. i+=2;
  68. }
  69. }
  70. int idx = alarmExist(id);
  71. if(idx == -1){
  72. printf("New alarm found!\n");
  73. printf("Alarm time is: %02d:%02d:%02d\n", time.tm_hour, time.tm_min, time.tm_sec);
  74. printf("Alarm date is: %02d.%02d.%02d\n", time.tm_mday, (time.tm_mon + 1), (time.tm_year + 1900));
  75. printf("Alarm stream data is: %s:%d%s\n", ip, port, url);
  76. printf("Alarm id and name and st is: %d %s %d\n\n", id, name, st);
  77. //zoek naar een vrije plaats in de alarm array
  78. for(j = 0; j < maxAlarms(); j++){
  79. if(usedAlarms[j] == 0){ //Dit is een lege plaats, hier kunnen we ons nieuwe alarm plaatsen
  80. setAlarm(time, name, ip, port, url, st, id, j);
  81. usedAlarms[j] = 1;
  82. j = 10; //Uit de for loop
  83. }
  84. }
  85. }else{
  86. usedAlarms[idx] = 1; //Alarm bestaat al, dus we houden deze plaats vrij voor dat alarm
  87. }
  88. }
  89. for(j = 0; j < maxAlarms(); j++){ //Alle overige plaatsen, die wij niet gezet hebben, verwijderen.
  90. if(usedAlarms[j] == 0){
  91. deleteAlarm(j);
  92. };
  93. }
  94. }
  95. void parsetimezone(char* content)
  96. {
  97. int timezone = atoi(content); //parsing string to int (only works when everything is int)
  98. setTimeZone(timezone);
  99. }
  100. void parseTwitch(char* content) {
  101. if (!strcmp("null", content)) {
  102. printf("Nobody is streaming");
  103. return;
  104. }
  105. int r;
  106. int i;
  107. jsmn_parser p;
  108. jsmntok_t token[20]; /* We expect no more than 20 tokens */
  109. jsmn_init(&p);
  110. r = jsmn_parse(&p, content, strlen(content), token, sizeof(token) / sizeof(token[0]));
  111. if (r <= 0) {
  112. printf("Failed to parse JSON: %d \n", r);
  113. return;
  114. } else {
  115. printf("Aantal tokens found: %d \n", r);
  116. }
  117. char name[20];
  118. char title[20];
  119. char game[20];
  120. int date;
  121. memset(name, 0, 20);
  122. memset(title, 0, 20);
  123. memset(game, 0, 20);
  124. for (i = 1; i < r; i++) {
  125. if (jsoneq(content, &token[i], "Name") == 0) {
  126. getStringToken(content, &token[i + 1], name, 20);
  127. i++;
  128. }
  129. else if (jsoneq(content, &token[i], "Title") == 0) {
  130. getStringToken(content, &token[i + 1], title, 20);
  131. i++;
  132. }
  133. else if (jsoneq(content, &token[i], "Game") == 0) {
  134. getStringToken(content, &token[i + 1], game, 20);
  135. i++;
  136. }
  137. else if (jsoneq(content, &token[i], "Date") == 0) {
  138. date = getIntegerToken(content, &token[i + 1]);
  139. i++;
  140. }
  141. }
  142. if(streamid != date)
  143. {
  144. printf("%s - %s - %s", name, title, game);
  145. streamid = date;
  146. displayTwitch(name, title, game);
  147. }
  148. }
  149. void TwitterParser(char* content)
  150. {
  151. char tweet = atoi(content);
  152. printf("%d", tweet);
  153. displayTwitter(1,tweet);
  154. }