Skip to content

Commit

Permalink
fix: index seq
Browse files Browse the repository at this point in the history
  • Loading branch information
U-JOHNLIU\jonhl committed Feb 21, 2022
1 parent 94ba672 commit 37502f5
Show file tree
Hide file tree
Showing 3 changed files with 10 additions and 10 deletions.
2 changes: 1 addition & 1 deletion apps/dgiot_meter/src/dgiot_meter_tcp.erl
Original file line number Diff line number Diff line change
Expand Up @@ -231,7 +231,7 @@ handle_info({deliver, _Topic, Msg}, #tcp{state = #state{id = _ChannelId, protoco
io:format("~s ~p ProData ~p Protocol ~p~n", [?FILE, ?LINE, Payload, Protocol]),
case Protocol of
?DLT376 ->
Payload2 = dlt376_decoder:frame_write_param(#{<<"concentrator">> => DevAddr, <<"payload">> => Payload}),
Payload2 = dlt376_decoder:frame_write_param(#{<<"concentrator">> => DevAddr, <<"payload">> => jsx:decode(Payload)}),
?LOG(info, "Payload2:~p ~n~n", [dgiot_utils:binary_to_hex(Payload2)]),
dgiot_tcp_server:send(TCPState, Payload2);
?DLT645 ->
Expand Down
16 changes: 8 additions & 8 deletions apps/dgiot_meter/src/proctol/dlt376_decoder.erl
Original file line number Diff line number Diff line change
Expand Up @@ -72,7 +72,7 @@
},
<<"type">> => #{
order => 3,
type => string,
type => enum,
required => true,
default => #{<<"value">> => <<"byte">>, <<"label">> => <<"byte">>},
enum => [
Expand Down Expand Up @@ -500,11 +500,11 @@ pn_to_da(Pn) ->
%%<<"sessiontoken">> => <<>>}}

frame_write_param(#{<<"concentrator">> := ConAddr, <<"payload">> := Frame}) ->
SortFrame = lists:sort(maps:keys(Frame)),
io:format("~s ~p SortFrame ~p.~n", [?FILE, ?LINE, SortFrame]),
Length = length(maps:keys(Frame)),
io:format("~s ~p SortFrame ~p.~n", [?FILE, ?LINE, Length]),
{BitList, Afn, Da, Fn} =
lists:map(fun(X, {Acc, A, D, F}) ->
case maps:find(X, Frame) of
lists:map(fun(Index, {Acc, A, D, F}) ->
case maps:find(Index, Frame) of
{ok, #{<<"dataForm">> := #{<<"afn">> := AFN, <<"di">> := FN, <<"length">> := Len, <<"type">> := Type} = DataForm} = Data} ->
DA = dgiot_utils:binary_to_hex(pn_to_da(to_integer(maps:get(<<"da">>, DataForm, 0)))),
case Type of
Expand All @@ -525,7 +525,7 @@ frame_write_param(#{<<"concentrator">> := ConAddr, <<"payload">> := Frame}) ->
_ ->
{Acc, A, D, F}
end
end, {[], 0, <<>>, <<>>}, SortFrame),
end, {[], 0, <<>>, <<>>}, lists:seq(1, Length)),
io:format("~s ~p BitList ~p.~n", [?FILE, ?LINE, BitList]),
UserZone = <<<<V:BitLen>> || {V, BitLen} <- BitList>>,
io:format("~s ~p UserZone ~p.~n", [?FILE, ?LINE, UserZone]),
Expand Down Expand Up @@ -579,13 +579,13 @@ add_to_userzone(UserZone, _Afn, _Fn) ->


concentrator_to_addr(ConAddr) when byte_size(ConAddr) == 6 ->
<<A11:2/bytes, A22:2/bytes, _/bytes>> = ConAddr,
<<_:2/bytes, A11:2/bytes, A22:2/bytes>> = ConAddr,
A1 = dlt645_proctol:reverse(A11),
A2 = dlt645_proctol:reverse(A22),
A3 = <<16#02>>,
<<A1:2/bytes, A2:2/bytes, A3:1/bytes>>;
concentrator_to_addr(ConAddr) when byte_size(ConAddr) == 12 ->
<<A11:2/bytes, A22:2/bytes, _/bytes>> = dgiot_utils:hex_to_binary(ConAddr),
<<_:2/bytes, A11:2/bytes, A22:2/bytes>> = dgiot_utils:hex_to_binary(ConAddr),
A1 = dlt645_proctol:reverse(A11),
A2 = dlt645_proctol:reverse(A22),
A3 = <<16#02>>,
Expand Down
2 changes: 1 addition & 1 deletion apps/dgiot_meter/src/proctol/dlt645_decoder.erl
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,7 @@
order => 2,
type => enum,
required => true,
default => #{<<"value">> => <<"byte">>, <<"label">> => <<"byte">>},
default => <<"byte"/utf8>>,
enum => [
#{<<"value">> => <<"byte">>, <<"label">> => <<"byte">>},
#{<<"value">> => <<"little">>, <<"label">> => <<"little">>},
Expand Down

0 comments on commit 37502f5

Please sign in to comment.