tscParseLine.h 3.2 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
/*
 * Copyright (c) 2021 TAOS Data, Inc. <jhtao@taosdata.com>
 *
 * This program is free software: you can use, redistribute, and/or modify
 * it under the terms of the GNU Affero General Public License, version 3
 * or later ("AGPL"), as published by the Free Software Foundation.
 *
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with this program. If not, see <http://www.gnu.org/licenses/>.
 */

#ifndef TDENGINE_TSCPARSELINE_H
#define TDENGINE_TSCPARSELINE_H

#ifdef __cplusplus
extern "C" {
#endif

23 24 25
#define SML_TIMESTAMP_SECOND_DIGITS 10
#define SML_TIMESTAMP_MILLI_SECOND_DIGITS 13

G
Ganlin Zhao 已提交
26
typedef TSDB_SML_PROTOCOL_TYPE SMLProtocolType;
G
Ganlin Zhao 已提交
27

28 29 30 31 32
typedef struct {
  char* key;
  uint8_t type;
  int16_t length;
  char* value;
33
  uint32_t fieldSchemaIdx;
34 35 36 37 38 39 40 41 42 43 44 45
} TAOS_SML_KV;

typedef struct {
  char* stableName;

  char* childTableName;
  TAOS_SML_KV* tags;
  int32_t tagNum;

  // first kv must be timestamp
  TAOS_SML_KV* fields;
  int32_t fieldNum;
46 47

  uint32_t schemaIdx;
48 49 50
} TAOS_SML_DATA_POINT;

typedef enum {
G
Ganlin Zhao 已提交
51
  SML_TIME_STAMP_NOT_CONFIGURED,
52 53
  SML_TIME_STAMP_HOURS,
  SML_TIME_STAMP_MINUTES,
54 55 56
  SML_TIME_STAMP_SECONDS,
  SML_TIME_STAMP_MILLI_SECONDS,
  SML_TIME_STAMP_MICRO_SECONDS,
57
  SML_TIME_STAMP_NANO_SECONDS,
G
Ganlin Zhao 已提交
58
  SML_TIME_STAMP_NOW
59 60
} SMLTimeStampType;

S
shenglian zhou 已提交
61 62 63 64 65 66 67
typedef struct SSmlSqlInsertBatch {
  uint64_t id;
  int32_t index;

  char* sql;
  int32_t code;
  int32_t tryTimes;
S
shenglian zhou 已提交
68
  tsem_t sem;
S
shenglian zhou 已提交
69 70 71 72 73 74 75 76
  int32_t affectedRows;
  bool tryAgain;
  bool resetQueryCache;
  bool sleep;
} SSmlSqlInsertBatch;

#define MAX_SML_SQL_INSERT_BATCHES 512

77 78
typedef struct {
  uint64_t id;
79 80
  SMLProtocolType protocol;
  SMLTimeStampType tsType;
81
  SHashObj* smlDataToSchema;
82

G
Ganlin Zhao 已提交
83
  int32_t affectedRows;
S
shenglian zhou 已提交
84 85 86 87 88

  pthread_mutex_t batchMutex;
  pthread_cond_t batchCond;
  int32_t numBatches;
  SSmlSqlInsertBatch batches[MAX_SML_SQL_INSERT_BATCHES];
89
} SSmlLinesInfo;
S
shenglian zhou 已提交
90

91
char* addEscapeCharToString(char *str, int32_t len);
92
int tscSmlInsert(TAOS* taos, TAOS_SML_DATA_POINT* points, int numPoint, SSmlLinesInfo* info);
93
bool checkDuplicateKey(char *key, SHashObj *pHash, SSmlLinesInfo* info);
94 95 96
bool isValidInteger(char *str);
bool isValidFloat(char *str);

97
int32_t isValidChildTableName(const char *pTbName, int16_t len, SSmlLinesInfo* info);
98

99
bool convertSmlValueType(TAOS_SML_KV *pVal, char *value,
100
                         uint16_t len, SSmlLinesInfo* info, bool isTag);
101 102 103
int32_t convertSmlTimeStamp(TAOS_SML_KV *pVal, char *value,
                            uint16_t len, SSmlLinesInfo* info);

104 105
void destroySmlDataPoint(TAOS_SML_DATA_POINT* point);

106 107
int taos_insert_lines(TAOS* taos, char* lines[], int numLines, SMLProtocolType protocol,
                      SMLTimeStampType tsType, int* affectedRows);
108 109 110 111
int taos_insert_telnet_lines(TAOS* taos, char* lines[], int numLines, SMLProtocolType protocol,
                             SMLTimeStampType tsType, int* affectedRows);
int taos_insert_json_payload(TAOS* taos, char* payload, SMLProtocolType protocol,
                             SMLTimeStampType tsType, int* affectedRows);
112 113


114 115 116 117 118
#ifdef __cplusplus
}
#endif

#endif  // TDENGINE_TSCPARSELINE_H