laconicd/scripts/protoc-swagger-gen.sh

31 lines
1.1 KiB
Bash
Raw Normal View History

#!/usr/bin/env bash
set -eo pipefail
mkdir -p ./tmp-swagger-gen
2021-04-19 07:10:57 +00:00
proto_dirs=$(find ./proto ./third_party/proto -path -prune -o -name '*.proto' -print0 | xargs -0 -n1 dirname | sort | uniq)
for dir in $proto_dirs; do
2021-04-19 07:10:57 +00:00
# generate swagger files (filter query files)
query_file=$(find "${dir}" -maxdepth 1 \( -name 'query.proto' -o -name 'service.proto' \))
2021-04-19 07:10:57 +00:00
if [[ ! -z "$query_file" ]]; then
protoc \
-I "proto" \
-I "third_party/proto" \
"$query_file" \
--swagger_out ./tmp-swagger-gen \
--swagger_opt logtostderr=true --swagger_opt fqn_for_swagger_name=true --swagger_opt simple_operation_ids=true
fi
done
# combine swagger files
# uses nodejs package `swagger-combine`.
# all the individual swagger files need to be configured in `config.json` for merging
swagger-combine ./client/docs/config.json -o ./client/docs/swagger-ui/swagger.yaml -f yaml --continueOnConflictingPaths true --includeDefinitions true
# clean swagger files
rm -rf ./tmp-swagger-gen
2021-04-19 07:10:57 +00:00
# generate binary for static server
statik -src=./client/docs/swagger-ui -dest=./client/docs