api: rename input validation functions

This commit is contained in:
Bart Van Der Meerssche 2010-04-27 23:23:27 +02:00
parent 606efd7c79
commit a1d81946f3

View file

@ -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