aboutsummaryrefslogtreecommitdiff
path: root/sbin/hastd/event.c
diff options
context:
space:
mode:
authorPawel Jakub Dawidek <pjd@FreeBSD.org>2010-08-31 09:38:43 +0000
committerPawel Jakub Dawidek <pjd@FreeBSD.org>2010-08-31 09:38:43 +0000
commit71c895eb1fb680a5d9783e99da84dd0bcbeb830c (patch)
treeadd13bb144cb9cb3e5fb5588fb1406cee791a56c /sbin/hastd/event.c
parent34759932a8c5b0de7a43f59aeb02de70ecb8aeea (diff)
downloadsrc-71c895eb1fb680a5d9783e99da84dd0bcbeb830c.tar.gz
src-71c895eb1fb680a5d9783e99da84dd0bcbeb830c.zip
Forgot to add event.c and event.h in r212038.
Pointed out by: pluknet <pluknet@gmail.com> MFC after: 2 weeks Obtained from: Wheel Systems Sp. z o.o. http://www.wheelsystems.com
Notes
Notes: svn path=/head/; revision=212049
Diffstat (limited to 'sbin/hastd/event.c')
-rw-r--r--sbin/hastd/event.c162
1 files changed, 162 insertions, 0 deletions
diff --git a/sbin/hastd/event.c b/sbin/hastd/event.c
new file mode 100644
index 000000000000..d772f692ba2e
--- /dev/null
+++ b/sbin/hastd/event.c
@@ -0,0 +1,162 @@
+/*-
+ * Copyright (c) 2010 Pawel Jakub Dawidek <pjd@FreeBSD.org>
+ * All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#include <sys/cdefs.h>
+__FBSDID("$FreeBSD$");
+
+#include <assert.h>
+#include <errno.h>
+
+#include "hast.h"
+#include "hast_proto.h"
+#include "hooks.h"
+#include "nv.h"
+#include "pjdlog.h"
+#include "proto.h"
+#include "subr.h"
+
+#include "event.h"
+
+void
+event_send(const struct hast_resource *res, int event)
+{
+ struct nv *nvin, *nvout;
+ int error;
+
+ assert(res != NULL);
+ assert(event >= EVENT_MIN && event <= EVENT_MAX);
+
+ nvin = nvout = NULL;
+
+ /*
+ * Prepare and send event to parent process.
+ */
+ nvout = nv_alloc();
+ nv_add_uint8(nvout, (uint8_t)event, "event");
+ error = nv_error(nvout);
+ if (error != 0) {
+ pjdlog_common(LOG_ERR, 0, error,
+ "Unable to prepare event header");
+ goto done;
+ }
+ if (hast_proto_send(res, res->hr_event, nvout, NULL, 0) < 0) {
+ pjdlog_errno(LOG_ERR, "Unable to send event header");
+ goto done;
+ }
+ if (hast_proto_recv_hdr(res->hr_event, &nvin) < 0) {
+ pjdlog_errno(LOG_ERR, "Unable to receive event header");
+ goto done;
+ }
+ /*
+ * Do nothing with the answer. We only wait for it to be sure not
+ * to exit too quickly after sending an event and exiting immediately.
+ */
+done:
+ if (nvin != NULL)
+ nv_free(nvin);
+ if (nvout != NULL)
+ nv_free(nvout);
+}
+
+int
+event_recv(const struct hast_resource *res)
+{
+ struct nv *nvin, *nvout;
+ const char *evstr;
+ uint8_t event;
+ int error;
+
+ assert(res != NULL);
+
+ nvin = nvout = NULL;
+
+ if (hast_proto_recv_hdr(res->hr_event, &nvin) < 0) {
+ /*
+ * First error log as debug. This is because worker process
+ * most likely exited.
+ */
+ pjdlog_common(LOG_DEBUG, 1, errno,
+ "Unable to receive event header");
+ goto fail;
+ }
+
+ event = nv_get_uint8(nvin, "event");
+ if (event == EVENT_NONE) {
+ pjdlog_error("Event header is missing 'event' field.");
+ goto fail;
+ }
+
+ switch (event) {
+ case EVENT_CONNECT:
+ evstr = "connect";
+ break;
+ case EVENT_DISCONNECT:
+ evstr = "disconnect";
+ break;
+ case EVENT_SYNCSTART:
+ evstr = "syncstart";
+ break;
+ case EVENT_SYNCDONE:
+ evstr = "syncdone";
+ break;
+ case EVENT_SYNCINTR:
+ evstr = "syncintr";
+ break;
+ case EVENT_SPLITBRAIN:
+ evstr = "split-brain";
+ break;
+ default:
+ pjdlog_error("Event header contain invalid event number (%hhu).",
+ event);
+ goto fail;
+ }
+
+ pjdlog_prefix_set("[%s] (%s) ", res->hr_name, role2str(res->hr_role));
+ hook_exec(res->hr_exec, evstr, res->hr_name, NULL);
+ pjdlog_prefix_set("%s", "");
+
+ nvout = nv_alloc();
+ nv_add_int16(nvout, 0, "error");
+ error = nv_error(nvout);
+ if (error != 0) {
+ pjdlog_common(LOG_ERR, 0, error,
+ "Unable to prepare event header");
+ goto fail;
+ }
+ if (hast_proto_send(res, res->hr_event, nvout, NULL, 0) < 0) {
+ pjdlog_errno(LOG_ERR, "Unable to send event header");
+ goto fail;
+ }
+ nv_free(nvin);
+ nv_free(nvout);
+ return (0);
+fail:
+ if (nvin != NULL)
+ nv_free(nvin);
+ if (nvout != NULL)
+ nv_free(nvout);
+ return (-1);
+}