pacemaker  2.1.9-49aab99839
Scalable High-Availability cluster resource manager
remote_internal.h
Go to the documentation of this file.
1 /*
2  * Copyright 2008-2024 the Pacemaker project contributors
3  *
4  * The version control history for this file may have further details.
5  *
6  * This source code is licensed under the GNU Lesser General Public License
7  * version 2.1 or later (LGPLv2.1+) WITHOUT ANY WARRANTY.
8  */
9 
10 #ifndef PCMK__CRM_COMMON_REMOTE_INTERNAL__H
11 #define PCMK__CRM_COMMON_REMOTE_INTERNAL__H
12 
13 #include <stdbool.h> // bool
14 
15 #include <crm/common/nodes.h> // pcmk_node_variant_remote
16 #include <crm/common/scheduler_types.h> // pcmk_node_t
17 
18 // internal functions from remote.c
19 
21 
22 int pcmk__remote_send_xml(pcmk__remote_t *remote, const xmlNode *msg);
23 int pcmk__remote_ready(const pcmk__remote_t *remote, int timeout_ms);
25 int pcmk__read_remote_message(pcmk__remote_t *remote, int timeout_ms);
27 int pcmk__connect_remote(const char *host, int port, int timeout_ms,
28  int *timer_id, int *sock_fd, void *userdata,
29  void (*callback) (void *userdata, int rc, int sock));
30 int pcmk__accept_remote_connection(int ssock, int *csock);
31 void pcmk__sockaddr2str(const void *sa, char *s);
32 
41 static inline bool
42 pcmk__is_pacemaker_remote_node(const pcmk_node_t *node)
43 {
44  return (node != NULL) && (node->details->type == pcmk_node_variant_remote);
45 }
46 
55 static inline bool
56 pcmk__is_remote_node(const pcmk_node_t *node)
57 {
58  return pcmk__is_pacemaker_remote_node(node)
59  && ((node->details->remote_rsc == NULL)
60  || (node->details->remote_rsc->container == NULL));
61 }
62 
71 static inline bool
72 pcmk__is_guest_or_bundle_node(const pcmk_node_t *node)
73 {
74  return pcmk__is_pacemaker_remote_node(node)
75  && (node->details->remote_rsc != NULL)
76  && (node->details->remote_rsc->container != NULL);
77 }
78 
79 #ifdef HAVE_GNUTLS_GNUTLS_H
80 #include <gnutls/gnutls.h>
81 
82 gnutls_session_t *pcmk__new_tls_session(int csock, unsigned int conn_type,
83  gnutls_credentials_type_t cred_type,
84  void *credentials);
85 int pcmk__init_tls_dh(gnutls_dh_params_t *dh_params);
86 int pcmk__read_handshake_data(const pcmk__client_t *client);
87 
99 int pcmk__tls_client_try_handshake(pcmk__remote_t *remote, int *gnutls_rc);
100 
113 int pcmk__tls_client_handshake(pcmk__remote_t *remote, int timeout_sec,
114  int *gnutls_rc);
115 
116 #endif // HAVE_GNUTLS_GNUTLS_H
117 #endif // PCMK__CRM_COMMON_REMOTE_INTERNAL__H
pcmk__cpg_host_t host
Definition: cpg.c:52
Type aliases needed to define scheduler objects.
int pcmk__accept_remote_connection(int ssock, int *csock)
Definition: remote.c:1231
pcmk_resource_t * container
Definition: resources.h:476
int pcmk__read_available_remote_data(pcmk__remote_t *remote)
Definition: remote.c:718
int pcmk__remote_ready(const pcmk__remote_t *remote, int timeout_ms)
Definition: remote.c:666
int pcmk__connect_remote(const char *host, int port, int timeout_ms, int *timer_id, int *sock_fd, void *userdata, void(*callback)(void *userdata, int rc, int sock))
Definition: remote.c:1096
struct pe_node_shared_s * details
Definition: nodes.h:168
void pcmk__sockaddr2str(const void *sa, char *s)
Definition: remote.c:1202
int pcmk__remote_send_xml(pcmk__remote_t *remote, const xmlNode *msg)
Definition: remote.c:517
Scheduler API for nodes.
int pcmk__read_remote_message(pcmk__remote_t *remote, int timeout_ms)
Definition: remote.c:824
enum node_type type
Definition: nodes.h:75
xmlNode * pcmk__remote_message_xml(pcmk__remote_t *remote)
Definition: remote.c:570
pcmk_resource_t * remote_rsc
Definition: nodes.h:136