* functions to create a database
* if the database already exists this function is a NOP
*/
-typedef void (*ctdb_createdb_cb)(int32_t status, void *private_data);
+typedef void (*ctdb_createdb_cb)(int32_t status, uint32_t db_id, void *private_data);
ctdb_handle *
ctdb_createdb_send(struct ctdb_context *ctdb, uint32_t destnode,
ctdb_createdb_cb callback,
void *private_data);
int ctdb_createdb_recv(struct ctdb_context *ctdb,
- ctdb_handle *handle);
+ ctdb_handle *handle, uint32_t *db_id);
int ctdb_createdb(struct ctdb_context *ctdb, uint32_t destnode,
- const char *name, int persistent);
+ const char *name, int persistent, uint32_t *db_id);
struct ctdb_control_cb_data {
void *callback;
void *private_data;
+ uint32_t db_id;
};
{
struct ctdb_control_cb_data *cb_data = state->async.private_data;
ctdb_createdb_cb callback = (ctdb_createdb_cb)cb_data->callback;
+ uint32_t db_id;
- callback(state->status, cb_data->private_data);
+ if (state->state == CTDB_CONTROL_DONE && state->status == 0) {
+ if (state->outdata.dsize != sizeof(uint32_t)) {
+ DEBUG(DEBUG_ERR, (" Wrond size of data returned for CREATEDB control. Got %zd bytes but expected %zd\n", state->outdata.dsize, sizeof(uint32_t)));
+
+ callback(CTDB_CONTROL_ERROR, 0, cb_data->private_data);
+ return;
+ }
+
+ db_id = *(uint32_t *)state->outdata.dptr;
+ }
+
+ callback(state->status, db_id, cb_data->private_data);
}
}
-int ctdb_createdb_recv(struct ctdb_context *ctdb, ctdb_handle *handle)
+int ctdb_createdb_recv(struct ctdb_context *ctdb, ctdb_handle *handle, uint32_t *db_id)
{
struct ctdb_client_control_state *state = talloc_get_type(handle, struct ctdb_client_control_state);
int ret;
int32_t res;
+ TALLOC_CTX *tmp_ctx = talloc_new(NULL);
+ TDB_DATA data;
- ret = ctdb_control_recv(ctdb, state, state, NULL, &res, NULL);
+ ret = ctdb_control_recv(ctdb, state, tmp_ctx, &data, &res, NULL);
if (ret != 0 || res != 0) {
DEBUG(DEBUG_ERR,(__location__ " ctdb_createdb_recv failed\n"));
+ talloc_free(tmp_ctx);
return -1;
}
+ if (data.dsize != sizeof(uint32_t)) {
+ DEBUG(DEBUG_ERR, (__location__ " Wrong size of returned data. Got %zd bytes but expected %zd\n", data.dsize, sizeof(uint32_t)));
+ talloc_free(tmp_ctx);
+ return -1;
+ }
+
+ if (db_id != NULL) {
+ *db_id = *(uint32_t *)data.dptr;
+ }
+
+ talloc_free(tmp_ctx);
return state->status;
}
-int ctdb_createdb(struct ctdb_context *ctdb, uint32_t destnode, const char *name, int persistent)
+int ctdb_createdb(struct ctdb_context *ctdb, uint32_t destnode, const char *name, int persistent, uint32_t *db_id)
{
struct ctdb_client_control_state *state;
return -1;
}
- return ctdb_createdb_recv(ctdb, state);
+ return ctdb_createdb_recv(ctdb, state, db_id);
}