]> git.sur5r.net Git - bacula/bacula/blob - bacula/src/lib/bsock.h
ebl add Error status in update volume=xxx status=yyyy
[bacula/bacula] / bacula / src / lib / bsock.h
1 /*
2  * Bacula Sock Structure definition
3  *
4  * Kern Sibbald, May MM
5  *
6  * Zero msglen from other end indicates soft eof (usually
7  *   end of some binary data stream, but not end of conversation).
8  *
9  * Negative msglen, is special "signal" (no data follows).
10  *   See below for SIGNAL codes.
11  *
12  *   Version $Id$
13  */
14 /*
15    Bacula® - The Network Backup Solution
16
17    Copyright (C) 2000-2006 Free Software Foundation Europe e.V.
18
19    The main author of Bacula is Kern Sibbald, with contributions from
20    many others, a complete list can be found in the file AUTHORS.
21    This program is Free Software; you can redistribute it and/or
22    modify it under the terms of version two of the GNU General Public
23    License as published by the Free Software Foundation plus additions
24    that are listed in the file LICENSE.
25
26    This program is distributed in the hope that it will be useful, but
27    WITHOUT ANY WARRANTY; without even the implied warranty of
28    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
29    General Public License for more details.
30
31    You should have received a copy of the GNU General Public License
32    along with this program; if not, write to the Free Software
33    Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
34    02110-1301, USA.
35
36    Bacula® is a registered trademark of John Walker.
37    The licensor of Bacula is the Free Software Foundation Europe
38    (FSFE), Fiduciary Program, Sumatrastrasse 25, 8006 Zürich,
39    Switzerland, email:ftf@fsfeurope.org.
40 */
41
42 struct BSOCK {
43    uint64_t read_seqno;               /* read sequence number */
44    uint32_t in_msg_no;                /* input message number */
45    uint32_t out_msg_no;               /* output message number */
46    int fd;                            /* socket file descriptor */
47    TLS_CONNECTION *tls;               /* associated tls connection */
48    int32_t msglen;                    /* message length */
49    int b_errno;                       /* bsock errno */
50    int port;                          /* desired port */
51    int blocking;                      /* blocking state (0 = nonblocking, 1 = blocking) */
52    volatile int errors;               /* incremented for each error on socket */
53    volatile bool suppress_error_msgs: 1; /* set to suppress error messages */
54    volatile bool timed_out: 1;        /* timed out in read/write */
55    volatile bool terminated: 1;       /* set when BNET_TERMINATE arrives */
56    bool duped: 1;                     /* set if duped BSOCK */
57    bool spool: 1;                     /* set for spooling */
58    volatile time_t timer_start;       /* time started read/write */
59    volatile time_t timeout;           /* timeout BSOCK after this interval */
60    POOLMEM *msg;                      /* message pool buffer */
61    char *who;                         /* Name of daemon to which we are talking */
62    char *host;                        /* Host name/IP */
63    POOLMEM *errmsg;                   /* edited error message */
64    RES *res;                          /* Resource to which we are connected */
65    BSOCK *next;                       /* next BSOCK if duped */
66    FILE *spool_fd;                    /* spooling file */
67    JCR *jcr;                          /* jcr or NULL for error msgs */
68    struct sockaddr client_addr;    /* client's IP address */
69    struct sockaddr_in peer_addr;    /* peer's IP address */
70 };
71
72 /* Signal definitions for use in bnet_sig() */
73 enum {
74    BNET_EOD            = -1,          /* End of data stream, new data may follow */
75    BNET_EOD_POLL       = -2,          /* End of data and poll all in one */
76    BNET_STATUS         = -3,          /* Send full status */
77    BNET_TERMINATE      = -4,          /* Conversation terminated, doing close() */
78    BNET_POLL           = -5,          /* Poll request, I'm hanging on a read */
79    BNET_HEARTBEAT      = -6,          /* Heartbeat Response requested */
80    BNET_HB_RESPONSE    = -7,          /* Only response permited to HB */
81    BNET_PROMPT         = -8,          /* Prompt for UA */
82    BNET_BTIME          = -9,          /* Send UTC btime */
83    BNET_BREAK          = -10,         /* Stop current command -- ctl-c */
84    BNET_START_SELECT   = -11,         /* Start of a selection list */
85    BNET_END_SELECT     = -12          /* End of a select list */
86 };
87
88 #define BNET_SETBUF_READ  1           /* Arg for bnet_set_buffer_size */
89 #define BNET_SETBUF_WRITE 2           /* Arg for bnet_set_buffer_size */
90
91 /* Return status from bnet_recv() */
92 #define BNET_SIGNAL  -1
93 #define BNET_HARDEOF -2
94 #define BNET_ERROR   -3
95
96 /*
97  * TLS enabling values. Value is important for comparison, ie:
98  * if (tls_remote_need < BNET_TLS_REQUIRED) { ... }
99  */
100 #define BNET_TLS_NONE     0           /* cannot do TLS */
101 #define BNET_TLS_OK       1           /* can do, but not required on my end */
102 #define BNET_TLS_REQUIRED 2           /* TLS is required */