summaryrefslogtreecommitdiffstats
path: root/xlators/mgmt/glusterd/src/glusterd-svc-mgmt.h
blob: 5daee99383348bd57bb915f2ce48316f22e94f4e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
/*
   Copyright (c) 2014 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 _GLUSTERD_SVC_MGMT_H_
#define _GLUSTERD_SVC_MGMT_H_

#include "glusterd-proc-mgmt.h"
#include "glusterd-conn-mgmt.h"
#include "glusterd-rcu.h"

struct glusterd_svc_;

typedef struct glusterd_svc_ glusterd_svc_t;
typedef struct glusterd_svc_proc_ glusterd_svc_proc_t;

typedef void (*glusterd_svc_build_t)(glusterd_svc_t *svc);

typedef int (*glusterd_svc_manager_t)(glusterd_svc_t *svc, void *data,
                                      int flags);
typedef int (*glusterd_svc_start_t)(glusterd_svc_t *svc, int flags);
typedef int (*glusterd_svc_stop_t)(glusterd_svc_t *svc, int sig);
typedef int (*glusterd_svc_reconfigure_t)(void *data);

typedef int (*glusterd_muxsvc_conn_notify_t)(glusterd_svc_proc_t *mux_proc,
                                             rpc_clnt_event_t event);

typedef enum gf_svc_status {
    GF_SVC_STARTING,
    GF_SVC_STARTED,
    GF_SVC_STOPPING,
    GF_SVC_DISCONNECTED,
    GF_SVC_DIED,
} gf_svc_status_t;

struct glusterd_svc_proc_ {
    struct cds_list_head svc_proc_list;
    struct cds_list_head svcs;
    glusterd_muxsvc_conn_notify_t notify;
    rpc_clnt_t *rpc;
    void *data;
    gf_svc_status_t status;
};

struct glusterd_svc_ {
    glusterd_conn_t conn;
    glusterd_svc_manager_t manager;
    glusterd_svc_start_t start;
    glusterd_svc_stop_t stop;
    glusterd_svc_reconfigure_t reconfigure;
    glusterd_svc_proc_t *svc_proc;
    struct cds_list_head mux_svc;
    glusterd_proc_t proc;
    char name[NAME_MAX];
    gf_boolean_t online;
    gf_boolean_t inited;
};

int
glusterd_svc_create_rundir(char *rundir);

int
glusterd_svc_init(glusterd_svc_t *svc, char *svc_name);

int
glusterd_svc_start(glusterd_svc_t *svc, int flags, dict_t *cmdline);

int
glusterd_svc_stop(glusterd_svc_t *svc, int sig);

void
glusterd_svc_build_pidfile_path(char *server, char *workdir, char *path,
                                size_t len);

void
glusterd_svc_build_volfile_path(char *server, char *workdir, char *volfile,
                                size_t len);

void
glusterd_svc_build_logfile_path(char *server, char *logdir, char *logfile,
                                size_t len);

void
glusterd_svc_build_svcdir(char *server, char *workdir, char *path, size_t len);

void
glusterd_svc_build_rundir(char *server, char *workdir, char *path, size_t len);

int
glusterd_svc_reconfigure(int (*create_volfile)());

int
glusterd_svc_common_rpc_notify(glusterd_conn_t *conn, rpc_clnt_event_t event);

int
glusterd_muxsvc_common_rpc_notify(glusterd_svc_proc_t *conn,
                                  rpc_clnt_event_t event);

int
glusterd_proc_get_pid(glusterd_proc_t *proc);

int
glusterd_muxsvc_conn_init(glusterd_conn_t *conn, glusterd_svc_proc_t *mux_proc,
                          char *sockpath, int frame_timeout,
                          glusterd_muxsvc_conn_notify_t notify);
#endif