diff options
| author | David Lamparter <equinox@diac24.net> | 2013-06-29 03:02:19 +0200 | 
|---|---|---|
| committer | David Lamparter <equinox@diac24.net> | 2013-06-29 03:02:19 +0200 | 
| commit | 1bfcd1954976d42783efb581cf70026417e935eb (patch) | |
| tree | a4f74154a4dcfd4ef09c9ae20e94c5ada97bdcc1 /cethcan | |
| parent | d7f15e86a711019ea49c4f24206e38ff4f203982 (diff) | |
cethcan: add ESPnet RPC
Diffstat (limited to 'cethcan')
| -rw-r--r-- | cethcan/rpc.c | 79 | 
1 files changed, 62 insertions, 17 deletions
| diff --git a/cethcan/rpc.c b/cethcan/rpc.c index f9a47fc..ef0414f 100644 --- a/cethcan/rpc.c +++ b/cethcan/rpc.c @@ -12,42 +12,87 @@ static int rpc_ping(void *apparg, json_t *json_params, json_t **result)  static int rpc_light_set(void *apparg, json_t *json_params, json_t **result)  {  	struct light *l; +	struct espnet_device *esp;  	const char *name = json_string_value(json_array_get(json_params, 0)); -	unsigned val = json_integer_value(json_array_get(json_params, 1)); -	 +	const char *emsg; +  	l = light_find(name); -	if (!l) { -		*result = jsonrpc_error_object(JSONRPC_INVALID_PARAMS, -			json_string("cann't find specified light")); -		return JSONRPC_INVALID_PARAMS; +	if (l) { +		unsigned val; + +		if (!json_is_integer(json_array_get(json_params, 1))) { +			emsg = "expected integer value"; +			goto out_err; +		} + +		val = json_integer_value(json_array_get(json_params, 1)); +		*result = json_boolean(!light_set(l, val)); +		return 0;  	} -	*result = json_boolean(!light_set(l, val)); -	return 0; + +	esp = espnet_find(name); +	if (esp) { +		unsigned r, g, b; +		json_t *val = json_array_get(json_params, 1); + +		if (json_is_integer(val)) +			r = g = b = json_integer_value(val); +		else if (json_is_array(val)) { +			if (json_unpack(val, "[iii]", &r, &g, &b)) { +				emsg = "failed to parse value array"; +				goto out_err; +			} +		} else { +			emsg = "expected integer or [int,int,int] value"; +			goto out_err; +		} + +		*result = json_boolean(!espnet_set(esp, r, g, b)); +		return 0; +	} + +	emsg = "cann't find specified light"; +out_err: +	*result = jsonrpc_error_object(JSONRPC_INVALID_PARAMS, +			json_string(emsg)); +	return JSONRPC_INVALID_PARAMS;  }  static int rpc_light_get(void *apparg, json_t *json_params, json_t **result)  {  	struct light *l; +	struct espnet_device *esp;  	const char *name = json_string_value(json_array_get(json_params, 0));  	unsigned set, actual;  	l = light_find(name); -	if (!l) { -		*result = jsonrpc_error_object(JSONRPC_INVALID_PARAMS, -			json_string("cannot find specified light")); -		return JSONRPC_INVALID_PARAMS; +	if (l) { +		set = light_getset(l); +		actual = light_getact(l); + +		*result = json_pack("{s:i,s:i}", +				"set", set, "actual", actual); +		return 0;  	} -	set = light_getset(l); -	actual = light_getact(l); +	esp = espnet_find(name); +	if (esp) { +		unsigned r, g, b; +		espnet_get(esp, &r, &g, &b); -	*result = json_pack("{s:i,s:i}", "set", set, "actual", actual); -	return 0; +		*result = json_pack("{s:i,s:i,s:i}", +				"r", r, "g", g, "b", b); +		return 0; +	} + +	*result = jsonrpc_error_object(JSONRPC_INVALID_PARAMS, +		json_string("cannot find specified light")); +	return JSONRPC_INVALID_PARAMS;  }  struct jsonrpc_method_entry_t method_table[] = {  	{ "ping", rpc_ping, "" }, -	{ "light_set", rpc_light_set, "[si]" }, +	{ "light_set", rpc_light_set, "[so]" },  	{ "light_get", rpc_light_get, "[s]" },  	{ NULL, NULL, NULL },  }; | 
