taos.h 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362
  1. /*
  2. * Copyright (c) 2019 TAOS Data, Inc. <jhtao@taosdata.com>
  3. *
  4. * This program is free software: you can use, redistribute, and/or modify
  5. * it under the terms of the GNU Affero General Public License, version 3
  6. * or later ("AGPL"), as published by the Free Software Foundation.
  7. *
  8. * This program is distributed in the hope that it will be useful, but WITHOUT
  9. * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  10. * FITNESS FOR A PARTICULAR PURPOSE.
  11. *
  12. * You should have received a copy of the GNU Affero General Public License
  13. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  14. */
  15. #ifndef TDENGINE_TAOS_H
  16. #define TDENGINE_TAOS_H
  17. #include <stdbool.h>
  18. #include <stdint.h>
  19. #ifdef __cplusplus
  20. extern "C" {
  21. #endif
  22. typedef void TAOS;
  23. typedef void TAOS_STMT;
  24. typedef void TAOS_RES;
  25. typedef void **TAOS_ROW;
  26. typedef void TAOS_SUB;
  27. // Data type definition
  28. #define TSDB_DATA_TYPE_NULL 0 // 1 bytes
  29. #define TSDB_DATA_TYPE_BOOL 1 // 1 bytes
  30. #define TSDB_DATA_TYPE_TINYINT 2 // 1 byte
  31. #define TSDB_DATA_TYPE_SMALLINT 3 // 2 bytes
  32. #define TSDB_DATA_TYPE_INT 4 // 4 bytes
  33. #define TSDB_DATA_TYPE_BIGINT 5 // 8 bytes
  34. #define TSDB_DATA_TYPE_FLOAT 6 // 4 bytes
  35. #define TSDB_DATA_TYPE_DOUBLE 7 // 8 bytes
  36. #define TSDB_DATA_TYPE_VARCHAR 8 // string, alias for varchar
  37. #define TSDB_DATA_TYPE_TIMESTAMP 9 // 8 bytes
  38. #define TSDB_DATA_TYPE_NCHAR 10 // unicode string
  39. #define TSDB_DATA_TYPE_UTINYINT 11 // 1 byte
  40. #define TSDB_DATA_TYPE_USMALLINT 12 // 2 bytes
  41. #define TSDB_DATA_TYPE_UINT 13 // 4 bytes
  42. #define TSDB_DATA_TYPE_UBIGINT 14 // 8 bytes
  43. #define TSDB_DATA_TYPE_JSON 15 // json string
  44. #define TSDB_DATA_TYPE_VARBINARY 16 // binary
  45. #define TSDB_DATA_TYPE_DECIMAL 17 // decimal
  46. #define TSDB_DATA_TYPE_BLOB 18 // binary
  47. #define TSDB_DATA_TYPE_MEDIUMBLOB 19
  48. #define TSDB_DATA_TYPE_BINARY TSDB_DATA_TYPE_VARCHAR // string
  49. #define TSDB_DATA_TYPE_GEOMETRY 20 // geometry
  50. #define TSDB_DATA_TYPE_MAX 21
  51. typedef enum {
  52. TSDB_OPTION_LOCALE,
  53. TSDB_OPTION_CHARSET,
  54. TSDB_OPTION_TIMEZONE,
  55. TSDB_OPTION_CONFIGDIR,
  56. TSDB_OPTION_SHELL_ACTIVITY_TIMER,
  57. TSDB_OPTION_USE_ADAPTER,
  58. TSDB_MAX_OPTIONS
  59. } TSDB_OPTION;
  60. typedef enum {
  61. TSDB_SML_UNKNOWN_PROTOCOL = 0,
  62. TSDB_SML_LINE_PROTOCOL = 1,
  63. TSDB_SML_TELNET_PROTOCOL = 2,
  64. TSDB_SML_JSON_PROTOCOL = 3,
  65. } TSDB_SML_PROTOCOL_TYPE;
  66. typedef enum {
  67. TSDB_SML_TIMESTAMP_NOT_CONFIGURED = 0,
  68. TSDB_SML_TIMESTAMP_HOURS,
  69. TSDB_SML_TIMESTAMP_MINUTES,
  70. TSDB_SML_TIMESTAMP_SECONDS,
  71. TSDB_SML_TIMESTAMP_MILLI_SECONDS,
  72. TSDB_SML_TIMESTAMP_MICRO_SECONDS,
  73. TSDB_SML_TIMESTAMP_NANO_SECONDS,
  74. } TSDB_SML_TIMESTAMP_TYPE;
  75. typedef struct taosField {
  76. char name[65];
  77. int8_t type;
  78. int32_t bytes;
  79. } TAOS_FIELD;
  80. typedef struct TAOS_FIELD_E {
  81. char name[65];
  82. int8_t type;
  83. uint8_t precision;
  84. uint8_t scale;
  85. int32_t bytes;
  86. } TAOS_FIELD_E;
  87. #ifdef WINDOWS
  88. #define DLL_EXPORT __declspec(dllexport)
  89. #else
  90. #define DLL_EXPORT
  91. #endif
  92. typedef void (*__taos_async_fn_t)(void *param, TAOS_RES *res, int code);
  93. typedef void (*__taos_notify_fn_t)(void *param, void *ext, int type);
  94. typedef struct TAOS_MULTI_BIND {
  95. int buffer_type;
  96. void *buffer;
  97. uintptr_t buffer_length;
  98. int32_t *length;
  99. char *is_null;
  100. int num;
  101. } TAOS_MULTI_BIND;
  102. typedef enum {
  103. SET_CONF_RET_SUCC = 0,
  104. SET_CONF_RET_ERR_PART = -1,
  105. SET_CONF_RET_ERR_INNER = -2,
  106. SET_CONF_RET_ERR_JSON_INVALID = -3,
  107. SET_CONF_RET_ERR_JSON_PARSE = -4,
  108. SET_CONF_RET_ERR_ONLY_ONCE = -5,
  109. SET_CONF_RET_ERR_TOO_LONG = -6
  110. } SET_CONF_RET_CODE;
  111. typedef enum {
  112. TAOS_NOTIFY_PASSVER = 0,
  113. } TAOS_NOTIFY_TYPE;
  114. #define RET_MSG_LENGTH 1024
  115. typedef struct setConfRet {
  116. SET_CONF_RET_CODE retCode;
  117. char retMsg[RET_MSG_LENGTH];
  118. } setConfRet;
  119. typedef struct TAOS_VGROUP_HASH_INFO {
  120. int32_t vgId;
  121. uint32_t hashBegin;
  122. uint32_t hashEnd;
  123. } TAOS_VGROUP_HASH_INFO;
  124. typedef struct TAOS_DB_ROUTE_INFO {
  125. int32_t routeVersion;
  126. int16_t hashPrefix;
  127. int16_t hashSuffix;
  128. int8_t hashMethod;
  129. int32_t vgNum;
  130. TAOS_VGROUP_HASH_INFO *vgHash;
  131. } TAOS_DB_ROUTE_INFO;
  132. DLL_EXPORT void taos_cleanup(void);
  133. DLL_EXPORT int taos_options(TSDB_OPTION option, const void *arg, ...);
  134. DLL_EXPORT setConfRet taos_set_config(const char *config);
  135. DLL_EXPORT int taos_init(void);
  136. DLL_EXPORT TAOS *taos_connect(const char *ip, const char *user, const char *pass, const char *db, uint16_t port);
  137. DLL_EXPORT TAOS *taos_connect_auth(const char *ip, const char *user, const char *auth, const char *db, uint16_t port);
  138. DLL_EXPORT void taos_close(TAOS *taos);
  139. DLL_EXPORT const char *taos_data_type(int type);
  140. DLL_EXPORT TAOS_STMT *taos_stmt_init(TAOS *taos);
  141. DLL_EXPORT TAOS_STMT *taos_stmt_init_with_reqid(TAOS *taos, int64_t reqid);
  142. DLL_EXPORT int taos_stmt_prepare(TAOS_STMT *stmt, const char *sql, unsigned long length);
  143. DLL_EXPORT int taos_stmt_set_tbname_tags(TAOS_STMT *stmt, const char *name, TAOS_MULTI_BIND *tags);
  144. DLL_EXPORT int taos_stmt_set_tbname(TAOS_STMT *stmt, const char *name);
  145. DLL_EXPORT int taos_stmt_set_tags(TAOS_STMT *stmt, TAOS_MULTI_BIND *tags);
  146. DLL_EXPORT int taos_stmt_set_sub_tbname(TAOS_STMT *stmt, const char *name);
  147. DLL_EXPORT int taos_stmt_get_tag_fields(TAOS_STMT *stmt, int *fieldNum, TAOS_FIELD_E **fields);
  148. DLL_EXPORT int taos_stmt_get_col_fields(TAOS_STMT *stmt, int *fieldNum, TAOS_FIELD_E **fields);
  149. // let stmt to reclaim TAOS_FIELD_E that was allocated by `taos_stmt_get_tag_fields`/`taos_stmt_get_col_fields`
  150. DLL_EXPORT void taos_stmt_reclaim_fields(TAOS_STMT *stmt, TAOS_FIELD_E *fields);
  151. DLL_EXPORT int taos_stmt_is_insert(TAOS_STMT *stmt, int *insert);
  152. DLL_EXPORT int taos_stmt_num_params(TAOS_STMT *stmt, int *nums);
  153. DLL_EXPORT int taos_stmt_get_param(TAOS_STMT *stmt, int idx, int *type, int *bytes);
  154. DLL_EXPORT int taos_stmt_bind_param(TAOS_STMT *stmt, TAOS_MULTI_BIND *bind);
  155. DLL_EXPORT int taos_stmt_bind_param_batch(TAOS_STMT *stmt, TAOS_MULTI_BIND *bind);
  156. DLL_EXPORT int taos_stmt_bind_single_param_batch(TAOS_STMT *stmt, TAOS_MULTI_BIND *bind, int colIdx);
  157. DLL_EXPORT int taos_stmt_add_batch(TAOS_STMT *stmt);
  158. DLL_EXPORT int taos_stmt_execute(TAOS_STMT *stmt);
  159. DLL_EXPORT TAOS_RES *taos_stmt_use_result(TAOS_STMT *stmt);
  160. DLL_EXPORT int taos_stmt_close(TAOS_STMT *stmt);
  161. DLL_EXPORT char *taos_stmt_errstr(TAOS_STMT *stmt);
  162. DLL_EXPORT int taos_stmt_affected_rows(TAOS_STMT *stmt);
  163. DLL_EXPORT int taos_stmt_affected_rows_once(TAOS_STMT *stmt);
  164. DLL_EXPORT TAOS_RES *taos_query(TAOS *taos, const char *sql);
  165. DLL_EXPORT TAOS_RES *taos_query_with_reqid(TAOS *taos, const char *sql, int64_t reqId);
  166. DLL_EXPORT TAOS_ROW taos_fetch_row(TAOS_RES *res);
  167. DLL_EXPORT int taos_result_precision(TAOS_RES *res); // get the time precision of result
  168. DLL_EXPORT void taos_free_result(TAOS_RES *res);
  169. DLL_EXPORT void taos_kill_query(TAOS *taos);
  170. DLL_EXPORT int taos_field_count(TAOS_RES *res);
  171. DLL_EXPORT int taos_num_fields(TAOS_RES *res);
  172. DLL_EXPORT int taos_affected_rows(TAOS_RES *res);
  173. DLL_EXPORT int64_t taos_affected_rows64(TAOS_RES *res);
  174. DLL_EXPORT TAOS_FIELD *taos_fetch_fields(TAOS_RES *res);
  175. DLL_EXPORT int taos_select_db(TAOS *taos, const char *db);
  176. DLL_EXPORT int taos_print_row(char *str, TAOS_ROW row, TAOS_FIELD *fields, int num_fields);
  177. DLL_EXPORT void taos_stop_query(TAOS_RES *res);
  178. DLL_EXPORT bool taos_is_null(TAOS_RES *res, int32_t row, int32_t col);
  179. DLL_EXPORT bool taos_is_update_query(TAOS_RES *res);
  180. DLL_EXPORT int taos_fetch_block(TAOS_RES *res, TAOS_ROW *rows);
  181. DLL_EXPORT int taos_fetch_block_s(TAOS_RES *res, int *numOfRows, TAOS_ROW *rows);
  182. DLL_EXPORT int taos_fetch_raw_block(TAOS_RES *res, int *numOfRows, void **pData);
  183. DLL_EXPORT int *taos_get_column_data_offset(TAOS_RES *res, int columnIndex);
  184. DLL_EXPORT int taos_validate_sql(TAOS *taos, const char *sql);
  185. DLL_EXPORT void taos_reset_current_db(TAOS *taos);
  186. DLL_EXPORT int *taos_fetch_lengths(TAOS_RES *res);
  187. DLL_EXPORT TAOS_ROW *taos_result_block(TAOS_RES *res);
  188. DLL_EXPORT const char *taos_get_server_info(TAOS *taos);
  189. DLL_EXPORT const char *taos_get_client_info();
  190. DLL_EXPORT int taos_get_current_db(TAOS *taos, char *database, int len, int *required);
  191. DLL_EXPORT const char *taos_errstr(TAOS_RES *res);
  192. DLL_EXPORT int taos_errno(TAOS_RES *res);
  193. DLL_EXPORT void taos_query_a(TAOS *taos, const char *sql, __taos_async_fn_t fp, void *param);
  194. DLL_EXPORT void taos_query_a_with_reqid(TAOS *taos, const char *sql, __taos_async_fn_t fp, void *param, int64_t reqid);
  195. DLL_EXPORT void taos_fetch_rows_a(TAOS_RES *res, __taos_async_fn_t fp, void *param);
  196. DLL_EXPORT void taos_fetch_raw_block_a(TAOS_RES *res, __taos_async_fn_t fp, void *param);
  197. DLL_EXPORT const void *taos_get_raw_block(TAOS_RES *res);
  198. DLL_EXPORT int taos_get_db_route_info(TAOS *taos, const char *db, TAOS_DB_ROUTE_INFO *dbInfo);
  199. DLL_EXPORT int taos_get_table_vgId(TAOS *taos, const char *db, const char *table, int *vgId);
  200. DLL_EXPORT int taos_get_tables_vgId(TAOS *taos, const char *db, const char *table[], int tableNum, int *vgId);
  201. DLL_EXPORT int taos_load_table_info(TAOS *taos, const char *tableNameList);
  202. // set heart beat thread quit mode , if quicByKill 1 then kill thread else quit from inner
  203. DLL_EXPORT void taos_set_hb_quit(int8_t quitByKill);
  204. DLL_EXPORT int taos_set_notify_cb(TAOS *taos, __taos_notify_fn_t fp, void *param, int type);
  205. /* --------------------------schemaless INTERFACE------------------------------- */
  206. DLL_EXPORT TAOS_RES *taos_schemaless_insert(TAOS *taos, char *lines[], int numLines, int protocol, int precision);
  207. DLL_EXPORT TAOS_RES *taos_schemaless_insert_with_reqid(TAOS *taos, char *lines[], int numLines, int protocol,
  208. int precision, int64_t reqid);
  209. DLL_EXPORT TAOS_RES *taos_schemaless_insert_raw(TAOS *taos, char *lines, int len, int32_t *totalRows, int protocol,
  210. int precision);
  211. DLL_EXPORT TAOS_RES *taos_schemaless_insert_raw_with_reqid(TAOS *taos, char *lines, int len, int32_t *totalRows,
  212. int protocol, int precision, int64_t reqid);
  213. DLL_EXPORT TAOS_RES *taos_schemaless_insert_ttl(TAOS *taos, char *lines[], int numLines, int protocol, int precision,
  214. int32_t ttl);
  215. DLL_EXPORT TAOS_RES *taos_schemaless_insert_ttl_with_reqid(TAOS *taos, char *lines[], int numLines, int protocol,
  216. int precision, int32_t ttl, int64_t reqid);
  217. DLL_EXPORT TAOS_RES *taos_schemaless_insert_raw_ttl(TAOS *taos, char *lines, int len, int32_t *totalRows, int protocol,
  218. int precision, int32_t ttl);
  219. DLL_EXPORT TAOS_RES *taos_schemaless_insert_raw_ttl_with_reqid(TAOS *taos, char *lines, int len, int32_t *totalRows,
  220. int protocol, int precision, int32_t ttl, int64_t reqid);
  221. /* --------------------------TMQ INTERFACE------------------------------- */
  222. typedef struct tmq_t tmq_t;
  223. typedef struct tmq_conf_t tmq_conf_t;
  224. typedef struct tmq_list_t tmq_list_t;
  225. typedef void(tmq_commit_cb(tmq_t *, int32_t code, void *param));
  226. DLL_EXPORT tmq_list_t *tmq_list_new();
  227. DLL_EXPORT int32_t tmq_list_append(tmq_list_t *, const char *);
  228. DLL_EXPORT void tmq_list_destroy(tmq_list_t *);
  229. DLL_EXPORT int32_t tmq_list_get_size(const tmq_list_t *);
  230. DLL_EXPORT char **tmq_list_to_c_array(const tmq_list_t *);
  231. DLL_EXPORT tmq_t *tmq_consumer_new(tmq_conf_t *conf, char *errstr, int32_t errstrLen);
  232. DLL_EXPORT const char *tmq_err2str(int32_t code);
  233. /* ------------------------TMQ CONSUMER INTERFACE------------------------ */
  234. typedef struct tmq_topic_assignment {
  235. int32_t vgId;
  236. int64_t currentOffset;
  237. int64_t begin;
  238. int64_t end;
  239. } tmq_topic_assignment;
  240. DLL_EXPORT int32_t tmq_subscribe(tmq_t *tmq, const tmq_list_t *topic_list);
  241. DLL_EXPORT int32_t tmq_unsubscribe(tmq_t *tmq);
  242. DLL_EXPORT int32_t tmq_subscription(tmq_t *tmq, tmq_list_t **topics);
  243. DLL_EXPORT TAOS_RES *tmq_consumer_poll(tmq_t *tmq, int64_t timeout);
  244. DLL_EXPORT int32_t tmq_consumer_close(tmq_t *tmq);
  245. DLL_EXPORT int32_t tmq_commit_sync(tmq_t *tmq, const TAOS_RES *msg);
  246. DLL_EXPORT void tmq_commit_async(tmq_t *tmq, const TAOS_RES *msg, tmq_commit_cb *cb, void *param);
  247. DLL_EXPORT int32_t tmq_get_topic_assignment(tmq_t *tmq, const char *pTopicName, tmq_topic_assignment **assignment,
  248. int32_t *numOfAssignment);
  249. DLL_EXPORT void tmq_free_assignment(tmq_topic_assignment* pAssignment);
  250. DLL_EXPORT int32_t tmq_offset_seek(tmq_t *tmq, const char *pTopicName, int32_t vgId, int64_t offset);
  251. /* ----------------------TMQ CONFIGURATION INTERFACE---------------------- */
  252. enum tmq_conf_res_t {
  253. TMQ_CONF_UNKNOWN = -2,
  254. TMQ_CONF_INVALID = -1,
  255. TMQ_CONF_OK = 0,
  256. };
  257. typedef enum tmq_conf_res_t tmq_conf_res_t;
  258. DLL_EXPORT tmq_conf_t *tmq_conf_new();
  259. DLL_EXPORT tmq_conf_res_t tmq_conf_set(tmq_conf_t *conf, const char *key, const char *value);
  260. DLL_EXPORT void tmq_conf_destroy(tmq_conf_t *conf);
  261. DLL_EXPORT void tmq_conf_set_auto_commit_cb(tmq_conf_t *conf, tmq_commit_cb *cb, void *param);
  262. /* -------------------------TMQ MSG HANDLE INTERFACE---------------------- */
  263. DLL_EXPORT const char *tmq_get_topic_name(TAOS_RES *res);
  264. DLL_EXPORT const char *tmq_get_db_name(TAOS_RES *res);
  265. DLL_EXPORT int32_t tmq_get_vgroup_id(TAOS_RES *res);
  266. DLL_EXPORT int64_t tmq_get_vgroup_offset(TAOS_RES* res);
  267. /* ------------------------------ TAOSX -----------------------------------*/
  268. // note: following apis are unstable
  269. enum tmq_res_t {
  270. TMQ_RES_INVALID = -1,
  271. TMQ_RES_DATA = 1,
  272. TMQ_RES_TABLE_META = 2,
  273. TMQ_RES_METADATA = 3,
  274. };
  275. typedef struct tmq_raw_data {
  276. void *raw;
  277. uint32_t raw_len;
  278. uint16_t raw_type;
  279. } tmq_raw_data;
  280. typedef enum tmq_res_t tmq_res_t;
  281. DLL_EXPORT const char *tmq_get_table_name(TAOS_RES *res);
  282. DLL_EXPORT tmq_res_t tmq_get_res_type(TAOS_RES *res);
  283. DLL_EXPORT int32_t tmq_get_raw(TAOS_RES *res, tmq_raw_data *raw);
  284. DLL_EXPORT int32_t tmq_write_raw(TAOS *taos, tmq_raw_data raw);
  285. DLL_EXPORT int taos_write_raw_block(TAOS *taos, int numOfRows, char *pData, const char *tbname);
  286. DLL_EXPORT int taos_write_raw_block_with_fields(TAOS *taos, int rows, char *pData, const char *tbname,
  287. TAOS_FIELD *fields, int numFields);
  288. DLL_EXPORT void tmq_free_raw(tmq_raw_data raw);
  289. // Returning null means error. Returned result need to be freed by tmq_free_json_meta
  290. DLL_EXPORT char *tmq_get_json_meta(TAOS_RES *res);
  291. DLL_EXPORT void tmq_free_json_meta(char *jsonMeta);
  292. /* ---------------------------- TAOSX END -------------------------------- */
  293. typedef enum {
  294. TSDB_SRV_STATUS_UNAVAILABLE = 0,
  295. TSDB_SRV_STATUS_NETWORK_OK = 1,
  296. TSDB_SRV_STATUS_SERVICE_OK = 2,
  297. TSDB_SRV_STATUS_SERVICE_DEGRADED = 3,
  298. TSDB_SRV_STATUS_EXTING = 4,
  299. } TSDB_SERVER_STATUS;
  300. DLL_EXPORT TSDB_SERVER_STATUS taos_check_server_status(const char *fqdn, int port, char *details, int maxlen);
  301. #ifdef __cplusplus
  302. }
  303. #endif
  304. #endif