Skip to content

Commit

Permalink
Merge pull request #582 from zmstone/fix-CI
Browse files Browse the repository at this point in the history
Fix CI
  • Loading branch information
zmstone authored Jun 15, 2024
2 parents aba0511 + 5e63808 commit adda7c3
Show file tree
Hide file tree
Showing 11 changed files with 65 additions and 47 deletions.
3 changes: 2 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -23,4 +23,5 @@ _rel/
*.log
relx
docker/
TAGS
TAGS
.vscode/
7 changes: 6 additions & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,8 +1,13 @@
# Changelog

- 3.19.1
- Made brod-cli to work on OTP 26. [PR#582](https://github.com/kafka4beam/brod/pull/582)
- `--ssl` option is now mandatory if TLS is to be used (previously it can be derived from `--cacertfile` option)
- TLS version defaults to 1.2, added `--ssl-versions` to support explictly setting TLS 1.3

- 3.19.0
- Forward unhandled messages in topic/group consumer processes to handle_info/2 callbacks
in order to support arbitrary message passing [PR#580](https://github.com/kafka4beam/brod/pull/580)
in order to support arbitrary message passing [PR#580](https://github.com/kafka4beam/brod/pull/580)

- 3.18.0
- Add transactional APIs. [PR#549](https://github.com/kafka4beam/brod/pull/549)
Expand Down
1 change: 1 addition & 0 deletions guides/examples/Authentication.md
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,7 @@ For more info see the Erlang Ecosystem Foundation's [server certificate verifica
, { depth, 3 }
, { customize_hostname_check,
[{match_fun, public_key:pkix_verify_hostname_match_fun(https)}]}
, {version, ['tlsv1.3', 'tlsv1.2']}
]}
, { sasl, {plain, "GFRW5BSQHKEH0TSG", "GrL3CNTkLhsvtBr8srGn0VilMpgDb4lPD"}}
]
Expand Down
28 changes: 3 additions & 25 deletions scripts/docker-compose.yml
Original file line number Diff line number Diff line change
@@ -1,35 +1,17 @@
version: "2"

services:
pause:
image: "gcr.io/google_containers/pause-amd64:3.0"
networks:
- pausenet
ports:
- "2181:2181"
- "9092:9092"
- "9093:9093"
- "9094:9094"
- "9095:9095"
- "9192:9192"
- "9193:9193"
- "9194:9194"
- "9195:9195"
container_name: pause
zookeeper:
depends_on:
- pause
image: "zmstone/kafka:${KAFKA_VERSION}"
container_name: zookeeper
command: run zookeeper
network_mode: service:pause
network_mode: host
kafka_1:
depends_on:
- pause
- zookeeper
image: "zmstone/kafka:${KAFKA_VERSION}"
container_name: "kafka-1"
network_mode: service:pause
network_mode: host
environment:
BROKER_ID: 0
PLAINTEXT_PORT: 9092
Expand All @@ -40,11 +22,10 @@ services:
ZOOKEEPER_CONNECT: "localhost:2181"
kafka_2:
depends_on:
- pause
- zookeeper
image: "zmstone/kafka:${KAFKA_VERSION}"
container_name: "kafka-2"
network_mode: service:pause
network_mode: host
environment:
BROKER_ID: 1
PLAINTEXT_PORT: 9192
Expand All @@ -53,6 +34,3 @@ services:
SASL_PLAINTEXT_PORT: 9195
ADVERTISED_HOSTNAME: localhost
ZOOKEEPER_CONNECT: "localhost:2181"

networks:
pausenet:
2 changes: 1 addition & 1 deletion scripts/setup-test-env.sh
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ function docker_compose {
fi
}

VERSION=${KAFKA_VERSION:-1.1}
VERSION=${KAFKA_VERSION:-2.4}
if [ -z $VERSION ]; then VERSION=$1; fi

case $VERSION in
Expand Down
43 changes: 35 additions & 8 deletions src/brod_cli.erl
Original file line number Diff line number Diff line change
Expand Up @@ -61,6 +61,8 @@ commands:
%% NOTE: bad indentation at the first line is intended
-define(COMMAND_COMMON_OPTIONS,
" --ssl Use TLS, validate server using trusted CAs
--ssl-versions=<vsns> Specify SSL versions. Comma separated versions,
e.g. 1.3,1.2
--cacertfile=<cacert> Use TLS, validate server using the given certificate
--certfile=<certfile> Client certificate in case client authentication
is enabled in brokers
Expand Down Expand Up @@ -365,6 +367,7 @@ main(Command, Doc, Args, Stop, LogLevel) ->
C1 : E1 ?BIND_STACKTRACE(Stack1) ->
?GET_STACKTRACE(Stack1),
verbose("~p:~p\n~p\n", [C1, E1, Stack1]),
io:format(user, "~p~n", [{C1, E1, Stack1}]),
?STOP(Stop)
end,
case LogLevel =:= ?LOG_LEVEL_QUIET of
Expand Down Expand Up @@ -1125,20 +1128,25 @@ parse_offset_time(T) -> int(T).

parse_connection_config(Args) ->
SslBool = parse(Args, "--ssl", fun parse_boolean/1),
SslVersions = parse(Args, "--ssl-versions", fun parse_ssl_versions/1),
CaCertFile = parse(Args, "--cacertfile", fun parse_file/1),
CertFile = parse(Args, "--certfile", fun parse_file/1),
KeyFile = parse(Args, "--keyfile", fun parse_file/1),
FilterPred = fun({_, V}) -> V =/= ?undef end,
SslOpt =
case CaCertFile of
?undef ->
SslBool;
_ ->
Files =
case SslBool of
true ->
Opts =
[{cacertfile, CaCertFile},
{certfile, CertFile},
{keyfile, KeyFile}],
lists:filter(FilterPred, Files)
{keyfile, KeyFile},
{versions, SslVersions},
%% TODO: verify_peer if cacertfile is provided
{verify, verify_none}
],
lists:filter(FilterPred, Opts);
false ->
false
end,
SaslPlain = parse(Args, "--sasl-plain", fun parse_file/1),
SaslScram256 = parse(Args, "--scram256", fun parse_file/1),
Expand All @@ -1157,12 +1165,31 @@ parse_boolean(true) -> true;
parse_boolean(false) -> false;
parse_boolean("true") -> true;
parse_boolean("false") -> false;
parse_boolean(?undef) -> ?undef.
parse_boolean(?undef) -> false.

parse_cg_ids("") -> [];
parse_cg_ids("all") -> all;
parse_cg_ids(Str) -> [bin(I) || I <- string:tokens(Str, ",")].

parse_ssl_versions(?undef) ->
parse_ssl_versions("");
parse_ssl_versions(Versions) ->
case lists:map(fun parse_ssl_version/1, string:tokens(Versions, ", ")) of
[] ->
['tlsv1.2'];
Vsns ->
Vsns
end.

parse_ssl_version("1.2") ->
'tlsv1.2';
parse_ssl_version("1.3") ->
'tlsv1.3';
parse_ssl_version("1.1") ->
'tlsv1.1';
parse_ssl_version(Other) ->
error({unsupported_tls_version, Other}).

parse_file(?undef) ->
?undef;
parse_file(Path) ->
Expand Down
16 changes: 10 additions & 6 deletions test/brod_cli_tests.erl
Original file line number Diff line number Diff line change
Expand Up @@ -37,9 +37,12 @@ meta_test() ->

ssl_test() ->
run(["meta", "-b", "localhost:9093", "-L",
"--cacertfile", "priv/ssl/ca.crt",
"--keyfile", "priv/ssl/client.key",
"--certfile", "priv/ssl/client.crt"]).
"--ssl",
"--cacertfile", "test/data/ssl/ca.pem",
"--keyfile", "test/data/ssl/client-key.pem",
"--certfile", "test/data/ssl/client-crt.pem",
"--ssl-versions", "1.2,1.1"
]).

offset_test() ->
Args = ["offset", "-b", "localhost", "-t", "test-topic", "-p", "0"],
Expand Down Expand Up @@ -74,9 +77,10 @@ test_sasl() ->
Output =
cmd(["send", "--brokers", "localhost:9194,localhost:9094",
"-t", "test-topic", "-p", "0",
"--cacertfile", "priv/ssl/ca.crt",
"--keyfile", "priv/ssl/client.key",
"--certfile", "priv/ssl/client.crt",
"--ssl",
"--cacertfile", "test/data/ssl/ca.pem",
"--keyfile", "test/data/ssl/client-key.pem",
"--certfile", "test/data/ssl/client-crt.pem",
"--sasl-plain", "sasl.testdata",
"-k", K, "-v", V]),
?assertEqual(<<"">>, Output),
Expand Down
12 changes: 7 additions & 5 deletions test/brod_client_SUITE.erl
Original file line number Diff line number Diff line change
Expand Up @@ -385,11 +385,13 @@ t_magic_version(Config) when is_list(Config) ->
auth(_Host, _Sock, _Mod, _ClientId, _Timeout, _Opts) -> ok.

ssl_options() ->
PrivDir = code:priv_dir(brod),
Fname = fun(Name) -> filename:join([PrivDir, ssl, Name]) end,
[ {cacertfile, Fname("ca.crt")}
, {keyfile, Fname("client.key")}
, {certfile, Fname("client.crt")}
LibDir = code:lib_dir(brod),
Fname = fun(Name) -> filename:join([LibDir, test, data, ssl, Name]) end,
[ {cacertfile, Fname("ca.pem")}
, {keyfile, Fname("client-key.pem")}
, {certfile, Fname("client-crt.pem")}
, {versions, ['tlsv1.2']}
, {verify, verify_none}
].

produce_and_consume_message(Host, Client, ClientConfig) ->
Expand Down
File renamed without changes.
File renamed without changes.
File renamed without changes.

0 comments on commit adda7c3

Please sign in to comment.