api: rename input validation functions
This commit is contained in:
parent
606efd7c79
commit
a1d81946f3
1 changed files with 17 additions and 16 deletions
|
@ -21,11 +21,11 @@ allowed_methods(ReqData, State) ->
|
||||||
{['GET'], ReqData, State}.
|
{['GET'], ReqData, State}.
|
||||||
|
|
||||||
malformed_request(ReqData, _State) ->
|
malformed_request(ReqData, _State) ->
|
||||||
{RrdSensor, ValidSensor} = rrd_sensor(wrq:path_info(sensor, ReqData)),
|
{RrdSensor, ValidSensor} = check_sensor(wrq:path_info(sensor, ReqData)),
|
||||||
{RrdTime, ValidInterval} = rrd_time(wrq:get_qs_value("interval", ReqData)),
|
{RrdTime, ValidInterval} = check_time(wrq:get_qs_value("interval", ReqData)),
|
||||||
{RrdFactor, ValidUnit} = rrd_factor(wrq:get_qs_value("unit", ReqData)),
|
{RrdFactor, ValidUnit} = check_factor(wrq:get_qs_value("unit", ReqData)),
|
||||||
{Token, ValidToken} = token(wrq:get_req_header("X-Token", ReqData), wrq:get_qs_value("token", ReqData)),
|
{Token, ValidToken} = check_token(wrq:get_req_header("X-Token", ReqData), wrq:get_qs_value("token", ReqData)),
|
||||||
{JsonpCallback, ValidJsonpCallback} = jsonp_callback(wrq:get_qs_value("jsonp_callback", ReqData)),
|
{JsonpCallback, ValidJsonpCallback} = check_jsonp_callback(wrq:get_qs_value("jsonp_callback", ReqData)),
|
||||||
|
|
||||||
State = #state{rrdSensor = RrdSensor, rrdTime = RrdTime, rrdFactor = RrdFactor, token = Token, jsonpCallback = JsonpCallback},
|
State = #state{rrdSensor = RrdSensor, rrdTime = RrdTime, rrdFactor = RrdFactor, token = Token, jsonpCallback = JsonpCallback},
|
||||||
|
|
||||||
|
@ -69,13 +69,14 @@ to_json(ReqData, #state{rrdSensor = RrdSensor, rrdTime = RrdTime, rrdFactor = Rr
|
||||||
{{halt, 404}, ReqData, State}
|
{{halt, 404}, ReqData, State}
|
||||||
end.
|
end.
|
||||||
|
|
||||||
rrd_sensor(Sensor) ->
|
%% internal functions
|
||||||
|
check_sensor(Sensor) ->
|
||||||
case re:run(Sensor, "[0-9a-f]+", []) of
|
case re:run(Sensor, "[0-9a-f]+", []) of
|
||||||
{match, [{0,32}]} -> {Sensor, true};
|
{match, [{0,32}]} -> {Sensor, true};
|
||||||
_ -> {false, false}
|
_ -> {false, false}
|
||||||
end.
|
end.
|
||||||
|
|
||||||
rrd_time(Interval) ->
|
check_time(Interval) ->
|
||||||
Intervals = [{"hour", "end-1h"},
|
Intervals = [{"hour", "end-1h"},
|
||||||
{"day", "end-1d"},
|
{"day", "end-1d"},
|
||||||
{"month", "end-30d"},
|
{"month", "end-30d"},
|
||||||
|
@ -87,7 +88,7 @@ rrd_time(Interval) ->
|
||||||
{_Interval, RrdTime} -> {RrdTime, true}
|
{_Interval, RrdTime} -> {RrdTime, true}
|
||||||
end.
|
end.
|
||||||
|
|
||||||
rrd_factor(Unit) ->
|
check_factor(Unit) ->
|
||||||
Units = [{"watt", 3600},
|
Units = [{"watt", 3600},
|
||||||
{"kwhperyear", 31536},
|
{"kwhperyear", 31536},
|
||||||
{"eurperyear", 5676},
|
{"eurperyear", 5676},
|
||||||
|
@ -98,18 +99,18 @@ rrd_factor(Unit) ->
|
||||||
{_Unit, RrdFactor} -> {RrdFactor, true}
|
{_Unit, RrdFactor} -> {RrdFactor, true}
|
||||||
end.
|
end.
|
||||||
|
|
||||||
token(undefined, undefined) ->
|
check_token(undefined, undefined) ->
|
||||||
{false, false};
|
{false, false};
|
||||||
token(Token, undefined) ->
|
check_token(Token, undefined) ->
|
||||||
rrd_sensor(Token);
|
check_sensor(Token);
|
||||||
token(undefined, Token) ->
|
check_token(undefined, Token) ->
|
||||||
rrd_sensor(Token);
|
check_sensor(Token);
|
||||||
token(_, _) ->
|
check_token(_, _) ->
|
||||||
{false, false}.
|
{false, false}.
|
||||||
|
|
||||||
jsonp_callback(undefined) ->
|
check_jsonp_callback(undefined) ->
|
||||||
{undefined, true};
|
{undefined, true};
|
||||||
jsonp_callback(JsonpCallback) ->
|
check_jsonp_callback(JsonpCallback) ->
|
||||||
Length = string:len(JsonpCallback),
|
Length = string:len(JsonpCallback),
|
||||||
|
|
||||||
case re:run(JsonpCallback, "[0-9a-zA-Z_]+", []) of
|
case re:run(JsonpCallback, "[0-9a-zA-Z_]+", []) of
|
||||||
|
|
Loading…
Reference in a new issue