2021-01-07 21:45:32 +00:00
|
|
|
#!/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)
|
2021-01-07 21:45:32 +00:00
|
|
|
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')
|
|
|
|
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
|
2021-01-07 21:45:32 +00:00
|
|
|
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
|