summaryrefslogtreecommitdiffstats
path: root/low-can/doors.c
blob: ce0b0c9b1f7a7cc00258ec542de8db3349038d27 (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) 2016 "IoT.bzh"
 * Author Romain Forlot <romain.forlot@iot.bzh>
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *   http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *
*/

#define _GNU_SOURCE  // needed for vasprintf

#define AFB_BINDING_VERSION 2
#include <afb/afb-binding.h>
#include <systemd/sd-event.h>
#include <json-c/json_object.h>
#include <stdbool.h>
#include <string.h>

#include "ctl-plugin.h"
#include "wrap-json.h"

CTLP_REGISTER("low-can");

typedef struct {
	bool door;
	bool window;
} doorT;

typedef struct {
	doorT* front_left;
	doorT* front_right;
	doorT* rear_left;
	doorT* rear_right;
} allDoorsCtxT;

// Call at initialisation time
CTLP_ONLOAD(plugin, api) {
	allDoorsCtxT *allDoorCtx = (allDoorsCtxT*)calloc (1, sizeof(allDoorsCtxT));
	memset(allDoorCtx, 0, sizeof(allDoorsCtxT));

	AFB_NOTICE ("Low-can door plugin: label='%s' version='%s' info='%s'", plugin->label, plugin->version, plugin->info);
	return (void*)allDoorCtx;
}

CTLP_CAPI (isOpen, source, argsJ, eventJ, context) {

	const char* eventName;
	json_object *eventStatus = NULL;
	long long int *timestamp = NULL;
	allDoorsCtxT *ctx=(allDoorsCtxT*)context;

	AFB_DEBUG("Here is the situation: source:%s, args:%s, event:%s,\n fld: %s, flw: %s, frd: %s, frw: %s, rld: %s, rlw: %s, rrd: %s, rrw: %s",
		source->label,
		json_object_to_json_string(argsJ),
		json_object_to_json_string(eventJ),
		ctx->front_left->door ? "true":"false",
		ctx->front_left->window ? "true":"false",
		ctx->front_right->door ? "true":"false",
		ctx->front_right->window ? "true":"false",
		ctx->rear_left->door ? "true":"false",
		ctx->rear_left->window ? "true":"false",
		ctx->rear_right->door ? "true":"false",
		ctx->rear_right->window ? "true":"false"
	);

	int err = wrap_json_unpack(eventJ, "{ss,sb,s?F}",
		"event", &eventName,
		"value", &eventStatus,
		"timestamp", &timestamp);
	if(err)
	{
		AFB_ERROR("Error parsing event %s", json_object_to_json_string(eventJ));
		return -1;
	}

	if(strcasestr(eventName, "front_left"))
	{
		if(strcasestr(eventName, "door")) {ctx->front_left->door = eventStatus;}
		else if(strcasestr(eventName, "window")) {ctx->front_left->window = eventStatus;}
		else {AFB_WARNING("Unexpected behavior, this '%s' is not a door ! ", json_object_to_json_string(eventJ));}
	}
	else if(strcasestr(eventName, "front_right"))
	{
		if(strcasestr(eventName, "door")) {ctx->front_right->door = eventStatus;}
		else if(strcasestr(eventName, "window")) {ctx->front_right->window = eventStatus;}
		else {AFB_WARNING("Unexpected behavior, this '%s' is not a door ! ", json_object_to_json_string(eventJ));}
	}
	else if(strcasestr(eventName, "rear_left"))
	{
		if(strcasestr(eventName, "door")) {ctx->rear_left->door = eventStatus;}
		else if(strcasestr(eventName, "window")) {ctx->rear_left->window = eventStatus;}
		else {AFB_WARNING("Unexpected behavior, this '%s' is not a door ! ", json_object_to_json_string(eventJ));}
	}
	else if(strcasestr(eventName, "rear_right"))
	{
		if(strcasestr(eventName, "door")) {ctx->rear_right->door = eventStatus;}
		else if(strcasestr(eventName, "window")) {ctx->rear_right->window = eventStatus;}
		else {AFB_WARNING("Unexpected behavior, this '%s' is not a door ! ", json_object_to_json_string(eventJ));}
	}
	else {AFB_WARNING("Unexpected behavior, this '%s' is not a door ! ", json_object_to_json_string(eventJ));}

	return 0;
}