ctdb-common: Return script_list for zero scripts
[vlendec/samba-autobuild/.git] / ctdb / common / common.h
1 /*
2    ctdb database library
3
4    Copyright (C) Amitay Isaacs  2015
5
6    This program is free software; you can redistribute it and/or modify
7    it under the terms of the GNU General Public License as published by
8    the Free Software Foundation; either version 3 of the License, or
9    (at your option) any later version.
10
11    This program is distributed in the hope that it will be useful,
12    but WITHOUT ANY WARRANTY; without even the implied warranty of
13    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14    GNU General Public License for more details.
15
16    You should have received a copy of the GNU General Public License
17    along with this program; if not, see <http://www.gnu.org/licenses/>.
18 */
19
20 #ifndef __CTDB_COMMON_H__
21 #define __CTDB_COMMON_H__
22
23 /* From common/ctdb_io.c */
24
25 typedef void (*ctdb_queue_cb_fn_t)(uint8_t *data, size_t length,
26                                    void *private_data);
27
28 int ctdb_queue_length(struct ctdb_queue *queue);
29
30 int ctdb_queue_send(struct ctdb_queue *queue, uint8_t *data, uint32_t length);
31
32 int ctdb_queue_set_fd(struct ctdb_queue *queue, int fd);
33
34 struct ctdb_queue *ctdb_queue_setup(struct ctdb_context *ctdb,
35                                     TALLOC_CTX *mem_ctx, int fd, int alignment,
36                                     ctdb_queue_cb_fn_t callback,
37                                     void *private_data, const char *fmt, ...)
38                                     PRINTF_ATTRIBUTE(7,8);
39
40 /* From common/ctdb_ltdb.c */
41
42 int ctdb_db_tdb_flags(uint8_t db_flags, bool with_valgrind, bool with_mutex);
43
44 struct ctdb_db_context *ctdb_db_handle(struct ctdb_context *ctdb,
45                                        const char *name);
46
47 bool ctdb_db_persistent(struct ctdb_db_context *ctdb_db);
48 bool ctdb_db_replicated(struct ctdb_db_context *ctdb_db);
49 bool ctdb_db_volatile(struct ctdb_db_context *ctdb_db);
50
51 bool ctdb_db_readonly(struct ctdb_db_context *ctdb_db);
52 void ctdb_db_set_readonly(struct ctdb_db_context *ctdb_db);
53 void ctdb_db_reset_readonly(struct ctdb_db_context *ctdb_db);
54
55 bool ctdb_db_sticky(struct ctdb_db_context *ctdb_db);
56 void ctdb_db_set_sticky(struct ctdb_db_context *ctdb_db);
57
58 uint32_t ctdb_lmaster(struct ctdb_context *ctdb, const TDB_DATA *key);
59
60 int ctdb_ltdb_fetch(struct ctdb_db_context *ctdb_db,
61                     TDB_DATA key, struct ctdb_ltdb_header *header,
62                     TALLOC_CTX *mem_ctx, TDB_DATA *data);
63
64 int ctdb_ltdb_fetch_with_header(struct ctdb_db_context *ctdb_db,
65                                 TDB_DATA key, struct ctdb_ltdb_header *header,
66                                 TALLOC_CTX *mem_ctx, TDB_DATA *data);
67
68 int ctdb_ltdb_store(struct ctdb_db_context *ctdb_db, TDB_DATA key,
69                     struct ctdb_ltdb_header *header, TDB_DATA data);
70
71 int ctdb_ltdb_lock(struct ctdb_db_context *ctdb_db, TDB_DATA key);
72
73 int ctdb_ltdb_unlock(struct ctdb_db_context *ctdb_db, TDB_DATA key);
74
75 int ctdb_ltdb_delete(struct ctdb_db_context *ctdb_db, TDB_DATA key);
76
77 int ctdb_trackingdb_add_pnn(struct ctdb_context *ctdb, TDB_DATA *data, uint32_t pnn);
78
79 typedef void (*ctdb_trackingdb_cb)(struct ctdb_context *ctdb, uint32_t pnn,
80                                    void *private_data);
81
82 void ctdb_trackingdb_traverse(struct ctdb_context *ctdb, TDB_DATA data,
83                               ctdb_trackingdb_cb cb, void *private_data);
84
85 int ctdb_null_func(struct ctdb_call_info *call);
86
87 int ctdb_fetch_func(struct ctdb_call_info *call);
88
89 int ctdb_fetch_with_header_func(struct ctdb_call_info *call);
90
91 /* from common/ctdb_util.c */
92
93 const char *ctdb_errstr(struct ctdb_context *ctdb);
94
95 void ctdb_set_error(struct ctdb_context *ctdb, const char *fmt, ...)
96                     PRINTF_ATTRIBUTE(2,3);
97
98 void ctdb_fatal(struct ctdb_context *ctdb, const char *msg);
99
100 void ctdb_die(struct ctdb_context *ctdb, const char *msg);
101
102 bool ctdb_set_helper(const char *type, char *helper, size_t size,
103                      const char *envvar,
104                      const char *dir, const char *file);
105
106 int ctdb_parse_address(TALLOC_CTX *mem_ctx, const char *str,
107                        ctdb_sock_addr *address);
108
109 bool ctdb_same_address(ctdb_sock_addr *a1, ctdb_sock_addr *a2);
110
111 uint32_t ctdb_hash(const TDB_DATA *key);
112
113 struct ctdb_rec_data_old *ctdb_marshall_record(TALLOC_CTX *mem_ctx,
114                                                uint32_t reqid,
115                                                TDB_DATA key,
116                                                struct ctdb_ltdb_header *header,
117                                                TDB_DATA data);
118
119 struct ctdb_marshall_buffer *ctdb_marshall_add(TALLOC_CTX *mem_ctx,
120                                                struct ctdb_marshall_buffer *m,
121                                                uint32_t db_id,
122                                                uint32_t reqid,
123                                                TDB_DATA key,
124                                                struct ctdb_ltdb_header *header,
125                                                TDB_DATA data);
126
127 TDB_DATA ctdb_marshall_finish(struct ctdb_marshall_buffer *m);
128
129 struct ctdb_rec_data_old *ctdb_marshall_loop_next(
130                                         struct ctdb_marshall_buffer *m,
131                                         struct ctdb_rec_data_old *r,
132                                         uint32_t *reqid,
133                                         struct ctdb_ltdb_header *header,
134                                         TDB_DATA *key, TDB_DATA *data);
135
136 void ctdb_canonicalize_ip(const ctdb_sock_addr *ip, ctdb_sock_addr *cip);
137
138 bool ctdb_same_ip(const ctdb_sock_addr *tip1, const ctdb_sock_addr *tip2);
139
140 bool ctdb_same_sockaddr(const ctdb_sock_addr *ip1, const ctdb_sock_addr *ip2);
141
142 char *ctdb_addr_to_str(ctdb_sock_addr *addr);
143
144 unsigned ctdb_addr_to_port(ctdb_sock_addr *addr);
145
146 struct ctdb_node_map_old *ctdb_read_nodes_file(TALLOC_CTX *mem_ctx,
147                                                const char *nlist);
148
149 struct ctdb_node_map_old *ctdb_node_list_to_map(struct ctdb_node **nodes,
150                                                 uint32_t num_nodes,
151                                                 TALLOC_CTX *mem_ctx);
152
153 const char *runstate_to_string(enum ctdb_runstate runstate);
154
155 enum ctdb_runstate runstate_from_string(const char *label);
156
157 void ctdb_set_runstate(struct ctdb_context *ctdb, enum ctdb_runstate runstate);
158
159 uint32_t *ctdb_key_to_idkey(TALLOC_CTX *mem_ctx, TDB_DATA key);
160
161 #endif /* __CTDB_COMMON_H__ */