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
|
-module(ssh_log_h).
-export([log/2
]).
-export([add_fun/3,
sensitive_in_opt/1,
chk_sensitive/2]).
log(LogEvent, #{?MODULE := #{function := F,
data := D}}) ->
F(LogEvent, D);
log(LogEvent, Config) ->
io:format("LogEvent = ~p~nConfig = ~p~n", [LogEvent, Config]).
%%%----------------------------------------------------------------
add_fun(Id, Fun, Data) ->
logger:add_handler(Id, ?MODULE, #{?MODULE => #{function => Fun,
data => Data}}).
%%%----------------------------------------------------------------
chk_sensitive(LogEvent, _) ->
case sensitive_in_opt(LogEvent) of
false ->
io:format("no sensitive keys are present in the log event!~n", []);
true ->
io:format("**** Sensitive keys(s) is(are) present in the log event!!~n", [])
end.
%%%----------------------------------------------------------------
sensitive_in_opt(LogEvent) ->
case locate_opts(LogEvent) of
false ->
false;
{ok, O} ->
Sensitive = [password, user_passwords,
dsa_pass_phrase, rsa_pass_phrase, ecdsa_pass_phrase,
ed25519_pass_phrase, ed448_pass_phrase],
lists:any(fun(K) -> lists:member(K, Sensitive) end,
maps:keys(O))
end.
%%%----------------------------------------------------------------
locate_opts(#{id_string := _,
tstflg := _} = Opts) ->
{ok, Opts};
locate_opts([H|T]) ->
case locate_opts(H) of
{ok, Opts} ->
{ok, Opts};
false ->
locate_opts(T)
end;
locate_opts(T) when is_tuple(T) ->
locate_opts( tuple_to_list(T) );
locate_opts(#{} = M) ->
locate_opts( maps:to_list(M) );
locate_opts(_) ->
false.
%%%----------------------------------------------------------------
|