c-ipfs/include/ipfs/repo/config/datastore.h

63 lines
2 KiB
C
Raw Normal View History

2016-10-27 01:14:07 +00:00
#ifndef __DATASTORE_H__
#define __DATASTORE_H__
#include <stdint.h>
#include "ipfs/blocks/block.h"
2016-10-27 01:14:07 +00:00
2016-10-27 03:32:23 +00:00
//const char* datastore_default_directory = "datastore";
2016-10-27 01:14:07 +00:00
2017-03-24 19:29:00 +00:00
enum DatastoreCursorOp { CURSOR_FIRST, CURSOR_NEXT };
2016-10-27 18:11:34 +00:00
struct Datastore {
2016-10-27 01:14:07 +00:00
char* type;
char* path;
char* storage_max;
int storage_gc_watermark;
2016-10-27 01:14:07 +00:00
char* gc_period;
char* params;
int no_sync;
int hash_on_read;
int bloom_filter_size;
// function pointers for datastore operations
int (*datastore_open)(int argc, char** argv, struct Datastore* datastore);
2016-12-01 18:08:30 +00:00
int (*datastore_close)(struct Datastore* datastore);
int (*datastore_put)(const unsigned char* key, size_t key_size, unsigned char* data, size_t data_length, const struct Datastore* datastore);
2017-03-24 19:29:00 +00:00
int (*datastore_get)(const char* key, size_t key_size,
unsigned char* data, size_t max_data_length, size_t* data_length,
const struct Datastore* datastore);
int (*datastore_cursor_open)(struct Datastore* datastore);
int (*datastore_cursor_close)(struct Datastore* datastore);
int (*datastore_cursor_get)(unsigned char** key, int* key_length, unsigned char** value, int* value_length, enum DatastoreCursorOp op, struct Datastore* datastore);
// generic connection and status variables for the datastore
void* handle; // a handle to the database
void* cursor; // a current cursor
2016-10-27 01:14:07 +00:00
};
/***
* Initialize the structure of the datastore to default settings. Used for
* creating a new datastore on the disk.
* @param datastore the struct to initialize
* @param config_root the path to the root of IPFS
* @returns true(1) on success
*/
int ipfs_repo_config_datastore_init(struct Datastore* datastore, const char* config_root);
/***
* initialize the structure of the datastore
* @param datastore the struct to initialize
* @returns true(1) on success
*/
int ipfs_repo_config_datastore_new(struct Datastore** datastore);
/***
* deallocate the memory and clear resources from a datastore_init
* @param datastore the struct to deallocate
* @returns true(1)
*/
int ipfs_repo_config_datastore_free(struct Datastore* datastore);
2016-10-27 01:14:07 +00:00
#endif