1 /* 2 * Generic Settings storage 3 * 4 * Copyright (C) 2020 Andy Green <andy@warmcat.com> 5 * 6 * Permission is hereby granted, free of charge, to any person obtaining a copy 7 * of this software and associated documentation files (the "Software"), to 8 * deal in the Software without restriction, including without limitation the 9 * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or 10 * sell copies of the Software, and to permit persons to whom the Software is 11 * furnished to do so, subject to the following conditions: 12 * 13 * The above copyright notice and this permission notice shall be included in 14 * all copies or substantial portions of the Software. 15 * 16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 19 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING 21 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS 22 * IN THE SOFTWARE. 23 * 24 * 25 * This is like an abstract class for non-volatile storage, whether in a file- 26 * system or flash-backed blocks, etc. Named blobs of variable size are stored 27 * in nonvolatile media of some sort. Typically, these are JSON objects under 28 * a naming scheme like, eg, "network". 29 * 30 * There's a platform-specific storage identifier opaque_plat provided when the 31 * storage object is instantiated, this describes eg the storage device or 32 * partition in instantiation-specific terms. 33 * 34 * Blobs have a further "filename" associated with them. 35 */ 36 37 #define LSOOPEN_FLAG_WRITEABLE (1 << 0) 38 39 struct lws_settings_ops; 40 41 typedef struct { 42 void *handle_plat; 43 const struct lws_settings_ops *so; 44 uint8_t refcount; 45 void *opaque_plat; 46 } lws_settings_instance_t; 47 48 typedef struct lws_settings_ops { 49 int (*get)(lws_settings_instance_t *si, const char *name, 50 uint8_t *dest, size_t *max_actual); 51 /**< if dest is NULL, max_actual is set to the actual length without 52 * copying anything out */ 53 int (*set)(lws_settings_instance_t *si, const char *name, 54 const uint8_t *src, size_t len); 55 } lws_settings_ops_t; 56 57 /** 58 * lws_settings_plat_get() - read a named blob from a settings instance 59 * 60 * \param si: the settings instance 61 * \param name: the name of the setting blob in the instance 62 * \param dest: NULL, or the buffer to copy the setting blob info 63 * \param max_actual: point to size of dest, or zero; actual blob size on exit 64 * 65 * If the named blob doesn't exist in the si, or can't read, returns nonzero. 66 * Otherwise, returns 0 and sets *max_actual to the true blob size. If dest is 67 * non-NULL, as much of the blob as will fit in the amount specified by 68 * *max_actual on entry is copied to dest. 69 */ 70 LWS_VISIBLE LWS_EXTERN int 71 lws_settings_plat_get(lws_settings_instance_t *si, const char *name, 72 uint8_t *dest, size_t *max_actual); 73 74 /** 75 * lws_settings_plat_get() - read a named blob from a settings instance 76 * 77 * \param si: the settings instance 78 * \param name: the name of the setting blob in the instance 79 * \param src: blob to copy to settings instance 80 * \param len: length of blob to copy 81 * 82 * Creates or replaces a settings blob of the given name made up of the \p len 83 * bytes of data from \p src. 84 */ 85 LWS_VISIBLE LWS_EXTERN int 86 lws_settings_plat_set(lws_settings_instance_t *si, const char *name, 87 const uint8_t *src, size_t len); 88 89 /** 90 * lws_settings_plat_printf() - read a named blob from a settings instance 91 * 92 * \param si: the settings instance 93 * \param name: the name of the setting blob in the instance 94 * \param format: printf-style format string 95 * 96 * Creates or replaces a settings blob of the given name from the printf-style 97 * format string and arguments provided. There's no specific limit to the size, 98 * the size is computed and then a temp heap buffer used. 99 */ 100 LWS_VISIBLE LWS_EXTERN int 101 lws_settings_plat_printf(lws_settings_instance_t *si, const char *name, 102 const char *format, ...) LWS_FORMAT(3); 103 104 #define lws_settings_ops_plat \ 105 .get = lws_settings_plat_get, \ 106 .set = lws_settings_plat_set, 107 108 LWS_VISIBLE LWS_EXTERN lws_settings_instance_t * 109 lws_settings_init(const lws_settings_ops_t *so, void *opaque_plat); 110 111 LWS_VISIBLE LWS_EXTERN void 112 lws_settings_deinit(lws_settings_instance_t **si); 113