Blob Blame History Raw
/*
   Copyright (c) 2013 Red Hat, Inc. <http://www.redhat.com>
   This file is part of GlusterFS.

   This file is licensed to you under your choice of the GNU Lesser
   General Public License, version 3 or any later version (LGPLv3 or
   later), or the GNU General Public License, version 2 (GPLv2), in all
   cases as published by the Free Software Foundation.
*/

#ifndef _GF_CHANGELOG_H
#define _GF_CHANGELOG_H

struct gf_brick_spec;

/**
 * Max bit shiter for event selection
 */
#define CHANGELOG_EV_SELECTION_RANGE 5

#define CHANGELOG_OP_TYPE_JOURNAL (1 << 0)
#define CHANGELOG_OP_TYPE_OPEN (1 << 1)
#define CHANGELOG_OP_TYPE_CREATE (1 << 2)
#define CHANGELOG_OP_TYPE_RELEASE (1 << 3)
#define CHANGELOG_OP_TYPE_BR_RELEASE                                           \
    (1 << 4) /* logical release (last close()),                                \
                sent by bitrot stub */
#define CHANGELOG_OP_TYPE_MAX (1 << CHANGELOG_EV_SELECTION_RANGE)

struct ev_open {
    unsigned char gfid[16];
    int32_t flags;
};

struct ev_creat {
    unsigned char gfid[16];
    int32_t flags;
};

struct ev_release {
    unsigned char gfid[16];
};

struct ev_release_br {
    unsigned long version;
    unsigned char gfid[16];
    int32_t sign_info;
};

struct ev_changelog {
    char path[PATH_MAX];
};

typedef struct changelog_event {
    unsigned int ev_type;

    union {
        struct ev_open open;
        struct ev_creat create;
        struct ev_release release;
        struct ev_changelog journal;
        struct ev_release_br releasebr;
    } u;
} changelog_event_t;

#define CHANGELOG_EV_SIZE (sizeof(changelog_event_t))

/**
 * event callback, connected & disconnection defs
 */
typedef void(CALLBACK)(void *, char *, void *, changelog_event_t *);
typedef void *(INIT)(void *, struct gf_brick_spec *);
typedef void(FINI)(void *, char *, void *);
typedef void(CONNECT)(void *, char *, void *);
typedef void(DISCONNECT)(void *, char *, void *);

struct gf_brick_spec {
    char *brick_path;
    unsigned int filter;

    INIT *init;
    FINI *fini;
    CALLBACK *callback;
    CONNECT *connected;
    DISCONNECT *disconnected;

    void *ptr;
};

/* API set */

int
gf_changelog_register(char *brick_path, char *scratch_dir, char *log_file,
                      int log_levl, int max_reconnects);
ssize_t
gf_changelog_scan();

int
gf_changelog_start_fresh();

ssize_t
gf_changelog_next_change(char *bufptr, size_t maxlen);

int
gf_changelog_done(char *file);

/* newer flexible API */
int
gf_changelog_init(void *xl);

int
gf_changelog_register_generic(struct gf_brick_spec *bricks, int count,
                              int ordered, char *logfile, int lvl, void *xl);

#endif