nRF Connect SDK API 0.1.0
Loading...
Searching...
No Matches
nrf_cloud_codec.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2023 Nordic Semiconductor ASA
3 *
4 * SPDX-License-Identifier: LicenseRef-Nordic-5-Clause
5 */
6
7#ifndef NRF_CLOUD_CODEC_H__
8#define NRF_CLOUD_CODEC_H__
9
10#include <net/nrf_cloud.h>
11#if defined(CONFIG_NRF_CLOUD_PGPS)
12#include <net/nrf_cloud_pgps.h>
13#endif
14#if defined(CONFIG_NRF_MODEM)
15#include <nrf_modem_gnss.h>
16#endif /* CONFIG_NRF_MODEM */
18#include <modem/lte_lc.h>
19
20#include <cJSON.h>
21#include <modem/lte_lc.h>
24
25#ifdef __cplusplus
26extern "C" {
27#endif
28
36
42
44};
45
54};
55
67};
68
71 char *app_id;
74 union {
75 char *str_val;
77 double double_val;
79 };
80 int64_t ts;
81};
82
85
87 union {
88 cJSON *json;
90 };
91
96};
97
100 /* A shadow delta, when there is a mismatch between "desired" and "reported" sections. */
102 /* The accepted shadow data. nRF Cloud provides a trimmed report to reduce overhead. */
105
109 int ver;
111 int64_t ts;
114};
115
126};
127
132 union {
137 };
138};
139
146#define NRF_CLOUD_OBJ_JSON_DEFINE(_name) \
147 struct nrf_cloud_obj _name = { .type = NRF_CLOUD_OBJ_TYPE_JSON, .json = NULL, \
148 .enc_src = NRF_CLOUD_ENC_SRC_NONE, \
149 .encoded_data = { .ptr = NULL, .len = 0 } }
150
151#define NRF_CLOUD_OBJ_COAP_CBOR_DEFINE(_name) \
152 struct nrf_cloud_obj _name = { .type = NRF_CLOUD_OBJ_TYPE_COAP_CBOR, \
153 .coap_cbor = NULL, \
154 .enc_src = NRF_CLOUD_ENC_SRC_NONE, \
155 .encoded_data = { .ptr = NULL, .len = 0 } }
156
162#define NRF_CLOUD_OBJ_DEFINE(_name, _type) \
163 struct nrf_cloud_obj _name = { 0 }; \
164 _name.type = _type; \
165 _name.enc_src = NRF_CLOUD_ENC_SRC_NONE;
166
176#define NRF_CLOUD_OBJ_PRE_ENC_DEFINE(_name, _data, _len) \
177 struct nrf_cloud_obj _name = { .type = NRF_CLOUD_OBJ_TYPE__UNDEFINED, \
178 .enc_src = NRF_CLOUD_ENC_SRC_PRE_ENCODED, \
179 .encoded_data = { .ptr = _data, .len = _len } }
180
188#define NRF_CLOUD_OBJ_TYPE_VALID(_obj_ptr) \
189 (bool)((_obj_ptr != NULL) && \
190 (_obj_ptr->type > NRF_CLOUD_OBJ_TYPE__UNDEFINED) && \
191 (_obj_ptr->type < NRF_CLOUD_OBJ_TYPE__LAST))
192
211 const struct nrf_cloud_data *const input);
212
226int nrf_cloud_obj_msg_check(const struct nrf_cloud_obj *const obj, const char *const app_id,
227 const char *const msg_type);
228
243int nrf_cloud_obj_num_get(const struct nrf_cloud_obj *const obj, const char *const key,
244 double *num);
245
260int nrf_cloud_obj_str_get(const struct nrf_cloud_obj *const obj, const char *const key,
261 char **str);
262
277int nrf_cloud_obj_bool_get(const struct nrf_cloud_obj *const obj, const char *const key,
278 bool *val);
279
297int nrf_cloud_obj_object_detach(struct nrf_cloud_obj *const obj, const char *const key,
298 struct nrf_cloud_obj *const obj_out);
299
316int nrf_cloud_obj_msg_init(struct nrf_cloud_obj *const obj, const char *const app_id,
317 const char *const msg_type);
318
319
335
350int nrf_cloud_obj_init(struct nrf_cloud_obj *const obj);
351
361int nrf_cloud_obj_reset(struct nrf_cloud_obj *const obj);
362
376int nrf_cloud_obj_free(struct nrf_cloud_obj *const obj);
377
386
402int nrf_cloud_obj_bulk_add(struct nrf_cloud_obj *const bulk, struct nrf_cloud_obj *const obj);
403
416int nrf_cloud_obj_ts_add(struct nrf_cloud_obj *const obj, const int64_t time_ms);
417
433int nrf_cloud_obj_num_add(struct nrf_cloud_obj *const obj, const char *const key,
434 const double val, const bool data_child);
435
451int nrf_cloud_obj_str_add(struct nrf_cloud_obj *const obj, const char *const key,
452 const char *const val, const bool data_child);
453
469int nrf_cloud_obj_bool_add(struct nrf_cloud_obj *const obj, const char *const key,
470 const bool val, const bool data_child);
471
486int nrf_cloud_obj_null_add(struct nrf_cloud_obj *const obj, const char *const key,
487 const bool data_child);
488
507int nrf_cloud_obj_object_add(struct nrf_cloud_obj *const obj, const char *const key,
508 struct nrf_cloud_obj *const obj_to_add, const bool data_child);
509
526int nrf_cloud_obj_int_array_add(struct nrf_cloud_obj *const obj, const char *const key,
527 const uint32_t ints[], const uint32_t ints_cnt,
528 const bool data_child);
529
546int nrf_cloud_obj_str_array_add(struct nrf_cloud_obj *const obj, const char *const key,
547 const char *const strs[], const uint32_t strs_cnt,
548 const bool data_child);
549
565
579
599 const struct nrf_cloud_gnss_data * const gnss);
600
620 const struct lte_lc_cells_info *const cells_inf,
621 const struct wifi_scan_info *const wifi_inf,
622 const struct nrf_cloud_location_config *const config);
623
638 const struct nrf_cloud_gnss_pvt * const pvt);
639
640#if defined(CONFIG_NRF_MODEM)
656 const struct nrf_modem_gnss_pvt_data_frame * const mdm_pvt);
657#endif /* CONFIG_NRF_MODEM */
658
659#if defined(CONFIG_NRF_CLOUD_PGPS)
677 const struct gps_pgps_request * const request);
678#endif
679
690 cJSON * const gnss_msg_obj);
691
702 cJSON * const svc_inf_obj);
703
716 cJSON * const mod_inf_obj);
717
735int nrf_cloud_error_msg_decode(const char * const buf,
736 const char * const app_id,
737 const char * const msg_type,
738 enum nrf_cloud_error * const err);
739
772 bool accept);
773
776#ifdef __cplusplus
777}
778#endif
779
780#endif /* NRF_CLOUD_CODEC_H__ */
int nrf_cloud_obj_msg_init(struct nrf_cloud_obj *const obj, const char *const app_id, const char *const msg_type)
Initialize an object as an nRF Cloud device message.
int nrf_cloud_obj_gnss_msg_create(struct nrf_cloud_obj *const obj, const struct nrf_cloud_gnss_data *const gnss)
Create an nRF Cloud GNSS message object.
int nrf_cloud_obj_bulk_init(struct nrf_cloud_obj *const bulk)
Initialize an object as an nRF Cloud bulk message.
int nrf_cloud_obj_str_get(const struct nrf_cloud_obj *const obj, const char *const key, char **str)
Get the string value associated with the provided key.
int nrf_cloud_obj_str_add(struct nrf_cloud_obj *const obj, const char *const key, const char *const val, const bool data_child)
Add a key string and string value to the provided object.
int nrf_cloud_obj_bool_get(const struct nrf_cloud_obj *const obj, const char *const key, bool *val)
Get the boolean value associated with the provided key.
int nrf_cloud_obj_null_add(struct nrf_cloud_obj *const obj, const char *const key, const bool data_child)
Add a key string and null value to the provided object.
int nrf_cloud_obj_cloud_encode(struct nrf_cloud_obj *const obj)
Encode the object's data for transport to nRF Cloud.
int nrf_cloud_obj_msg_check(const struct nrf_cloud_obj *const obj, const char *const app_id, const char *const msg_type)
Check if the object contains the specified app ID and message type.
int nrf_cloud_obj_num_get(const struct nrf_cloud_obj *const obj, const char *const key, double *num)
Get the number value associated with the provided key.
int nrf_cloud_obj_shadow_delta_response_encode(struct nrf_cloud_obj *const delta_state_obj, bool accept)
Encode the response to the shadow delta update.
int nrf_cloud_obj_bool_add(struct nrf_cloud_obj *const obj, const char *const key, const bool val, const bool data_child)
Add a key string and boolean value to the provided object.
int nrf_cloud_service_info_json_encode(const struct nrf_cloud_svc_info *const svc_inf, cJSON *const svc_inf_obj)
Add service info into the provided cJSON object.
int nrf_cloud_obj_str_array_add(struct nrf_cloud_obj *const obj, const char *const key, const char *const strs[], const uint32_t strs_cnt, const bool data_child)
Add a key string and string array value to the provided object.
int nrf_cloud_obj_init(struct nrf_cloud_obj *const obj)
Initialize an empty object.
int nrf_cloud_obj_pvt_add(struct nrf_cloud_obj *const obj, const struct nrf_cloud_gnss_pvt *const pvt)
Add PVT data to the provided object.
nrf_cloud_obj_shadow_type
Types of shadow updates.
Definition: nrf_cloud_codec.h:99
@ NRF_CLOUD_OBJ_SHADOW_TYPE_ACCEPTED
Definition: nrf_cloud_codec.h:103
@ NRF_CLOUD_OBJ_SHADOW_TYPE_DELTA
Definition: nrf_cloud_codec.h:101
int nrf_cloud_obj_bulk_add(struct nrf_cloud_obj *const bulk, struct nrf_cloud_obj *const obj)
Add an object to a bulk message object.
int nrf_cloud_obj_location_request_create(struct nrf_cloud_obj *const obj, const struct lte_lc_cells_info *const cells_inf, const struct wifi_scan_info *const wifi_inf, const struct nrf_cloud_location_config *const config)
Create an nRF Cloud Location request message object.
int nrf_cloud_obj_int_array_add(struct nrf_cloud_obj *const obj, const char *const key, const uint32_t ints[], const uint32_t ints_cnt, const bool data_child)
Add a key string and integer array value to the provided object.
int nrf_cloud_modem_info_json_encode(const struct nrf_cloud_modem_info *const mod_inf, cJSON *const mod_inf_obj)
Add modem info into the provided cJSON object.
int nrf_cloud_error_msg_decode(const char *const buf, const char *const app_id, const char *const msg_type, enum nrf_cloud_error *const err)
Check for a JSON error message in the data received from nRF Cloud over MQTT.
int nrf_cloud_obj_object_add(struct nrf_cloud_obj *const obj, const char *const key, struct nrf_cloud_obj *const obj_to_add, const bool data_child)
Add a key string and object to the provided object.
bool nrf_cloud_obj_bulk_check(struct nrf_cloud_obj *const obj)
Check if an object is a JSON array eligible for bulk transfer.
int nrf_cloud_obj_input_decode(struct nrf_cloud_obj *const obj, const struct nrf_cloud_data *const input)
Decode data received from nRF Cloud.
int nrf_cloud_obj_object_detach(struct nrf_cloud_obj *const obj, const char *const key, struct nrf_cloud_obj *const obj_out)
Get and detach the object associated with the provided key.
int nrf_cloud_obj_reset(struct nrf_cloud_obj *const obj)
Reset the state of an object; does not free memory.
nrf_cloud_obj_type
Object types for encoding and decoding.
Definition: nrf_cloud_codec.h:34
@ NRF_CLOUD_OBJ_TYPE__LAST
Definition: nrf_cloud_codec.h:43
@ NRF_CLOUD_OBJ_TYPE_JSON
Definition: nrf_cloud_codec.h:37
@ NRF_CLOUD_OBJ_TYPE__UNDEFINED
Definition: nrf_cloud_codec.h:35
@ NRF_CLOUD_OBJ_TYPE_COAP_CBOR
Definition: nrf_cloud_codec.h:41
int nrf_cloud_obj_free(struct nrf_cloud_obj *const obj)
Free the memory of an initialized object.
int nrf_cloud_obj_ts_add(struct nrf_cloud_obj *const obj, const int64_t time_ms)
Add a timestamp to an object.
nrf_cloud_enc_src
Encoded data sources.
Definition: nrf_cloud_codec.h:47
@ NRF_CLOUD_ENC_SRC_CLOUD_ENCODED
Definition: nrf_cloud_codec.h:51
@ NRF_CLOUD_ENC_SRC_PRE_ENCODED
Definition: nrf_cloud_codec.h:53
@ NRF_CLOUD_ENC_SRC_NONE
Definition: nrf_cloud_codec.h:49
int nrf_cloud_obj_num_add(struct nrf_cloud_obj *const obj, const char *const key, const double val, const bool data_child)
Add a key string and number value to the provided object.
int nrf_cloud_obj_modem_pvt_add(struct nrf_cloud_obj *const obj, const struct nrf_modem_gnss_pvt_data_frame *const mdm_pvt)
Add modem PVT data to the provided object.
int nrf_cloud_obj_cloud_encoded_free(struct nrf_cloud_obj *const obj)
Free the memory of the encoded data in the object.
int nrf_cloud_gnss_msg_json_encode(const struct nrf_cloud_gnss_data *const gnss, cJSON *const gnss_msg_obj)
Create an nRF Cloud GNSS device message using the provided GNSS data.
nrf_cloud_data_type
Data types for nrf_cloud_sensor_data.
Definition: nrf_cloud_codec.h:57
@ NRF_CLOUD_DATA_TYPE_STR
Definition: nrf_cloud_codec.h:62
@ NRF_CLOUD_DATA_TYPE_INT
Definition: nrf_cloud_codec.h:66
@ NRF_CLOUD_DATA_TYPE_NONE
Definition: nrf_cloud_codec.h:58
@ NRF_CLOUD_DATA_TYPE_DOUBLE
Definition: nrf_cloud_codec.h:64
@ NRF_CLOUD_DATA_TYPE_PVT
Definition: nrf_cloud_codec.h:60
int nrf_cloud_obj_pgps_request_create(struct nrf_cloud_obj *const obj, const struct gps_pgps_request *const request)
Create an nRF Cloud P-GPS request device message object.
nrf_cloud_error
nRF Cloud error codes. See the Error Codes section of nRF Cloud API documentation for more informatio...
Definition: nrf_cloud.h:210
Module to provide nRF Cloud location support to nRF9160 SiP.
Module to provide nRF Cloud Predicted GPS (P-GPS) support to nRF9160 SiP.
P-GPS request type.
Definition: nrf_cloud_pgps.h:83
Definition: lte_lc.h:513
Generic encapsulation for any data that is sent to the cloud.
Definition: nrf_cloud.h:371
GNSS data to be sent to nRF Cloud as a device message.
Definition: nrf_cloud.h:593
PVT data.
Definition: nrf_cloud.h:545
Location request config.
Definition: nrf_cloud_location.h:97
Modem info data and which sections should be encoded.
Definition: nrf_cloud.h:493
enum nrf_cloud_data_type type
Definition: nrf_cloud_codec.h:73
int int_val
Definition: nrf_cloud_codec.h:78
double double_val
Definition: nrf_cloud_codec.h:77
char * app_id
Definition: nrf_cloud_codec.h:71
struct nrf_cloud_gnss_pvt * pvt
Definition: nrf_cloud_codec.h:76
int64_t ts
Definition: nrf_cloud_codec.h:80
char * str_val
Definition: nrf_cloud_codec.h:75
Object to support nRF Cloud CoAP CBOR messages.
Definition: nrf_cloud_codec.h:70
struct nrf_cloud_obj desired
Definition: nrf_cloud_codec.h:119
struct nrf_cloud_obj config
Definition: nrf_cloud_codec.h:125
struct nrf_cloud_obj reported
Definition: nrf_cloud_codec.h:121
Object containing the accepted shadow data.
Definition: nrf_cloud_codec.h:117
struct nrf_cloud_obj_shadow_accepted * accepted
Definition: nrf_cloud_codec.h:134
struct nrf_cloud_obj_shadow_delta * delta
Definition: nrf_cloud_codec.h:136
enum nrf_cloud_obj_shadow_type type
Definition: nrf_cloud_codec.h:131
Object containing shadow update data.
Definition: nrf_cloud_codec.h:129
int ver
Definition: nrf_cloud_codec.h:109
int64_t ts
Definition: nrf_cloud_codec.h:111
struct nrf_cloud_obj state
Definition: nrf_cloud_codec.h:113
Object containing shadow delta data.
Definition: nrf_cloud_codec.h:107
cJSON * json
Definition: nrf_cloud_codec.h:88
enum nrf_cloud_enc_src enc_src
Definition: nrf_cloud_codec.h:93
enum nrf_cloud_obj_type type
Definition: nrf_cloud_codec.h:86
struct nrf_cloud_obj_coap_cbor * coap_cbor
Definition: nrf_cloud_codec.h:89
struct nrf_cloud_data encoded_data
Definition: nrf_cloud_codec.h:95
Object used for building nRF Cloud messages.
Definition: nrf_cloud_codec.h:84
Structure to specify which components are added to the encoded service info object.
Definition: nrf_cloud.h:512
Access points found during a Wi-Fi scan.
Definition: wifi_location_common.h:29