mirror of
https://github.com/supabase/supabase.git
synced 2026-05-06 08:56:46 -04:00
134 lines
6.6 KiB
Makefile
134 lines
6.6 KiB
Makefile
REPO_DIR=$(shell pwd)
|
|
|
|
run: download transform format
|
|
|
|
|
|
###############################################################################
|
|
# Init - prepare the environment
|
|
###############################################################################
|
|
|
|
init:
|
|
cd $(REPO_DIR)/parser && npm install
|
|
|
|
|
|
###############################################################################
|
|
# Download all the specs
|
|
###############################################################################
|
|
# commment out download.auth.v1 temporarily, we're manually creating the file
|
|
# download: download.api.v1 download.auth.v1 download.storage.v1 download.tsdoc.v2
|
|
download: download.api.v1 download.storage.v1 download.tsdoc.v2
|
|
|
|
download.api.v1:
|
|
curl -sS https://api.supabase.com/api/v1-json > $(REPO_DIR)/api_v0_openapi.json
|
|
|
|
|
|
# This flow needs to be updated, so we'l comment out for the moment
|
|
# Manual flow for now:
|
|
# — get swagger.json (https://supabase.github.io/gotrue/swagger.json)
|
|
# — manually convert via swagger editor -> open api v3 spec
|
|
# dereference.tsdoc.v2 -> auth_v1_openapi_deparsed.json
|
|
|
|
# download.auth.v1:
|
|
# curl -sS https://supabase.github.io/gotrue/swagger.json > $(REPO_DIR)/auth_v1_openapi.json
|
|
|
|
download.storage.v1:
|
|
curl -sS https://supabase.github.io/storage/api.json > $(REPO_DIR)/storage_v0_openapi.json
|
|
|
|
# No longer updated
|
|
# download.tsdoc.v1:
|
|
# curl -sS https://supabase.github.io/supabase-js/v1/spec.json > $(REPO_DIR)/enrichments/tsdoc_v1/supabase.json
|
|
# curl -sS https://supabase.github.io/gotrue-js/v1/spec.json > $(REPO_DIR)/enrichments/tsdoc_v1/gotrue.json
|
|
# curl -sS https://supabase.github.io/postgrest-js/v1/spec.json > $(REPO_DIR)/enrichments/tsdoc_v1/postgrest.json
|
|
# curl -sS https://supabase.github.io/realtime-js/v1/spec.json > $(REPO_DIR)/enrichments/tsdoc_v1/realtime.json
|
|
# curl -sS https://supabase.github.io/storage-js/v1/spec.json > $(REPO_DIR)/enrichments/tsdoc_v1/storage.json
|
|
# curl -sS https://supabase.github.io/functions-js/v1/spec.json > $(REPO_DIR)/enrichments/tsdoc_v1/functions.json
|
|
|
|
download.tsdoc.v2:
|
|
curl -sS https://supabase.github.io/supabase-js/v2/spec.json > $(REPO_DIR)/enrichments/tsdoc_v2/supabase.json
|
|
curl -sS https://supabase.github.io/gotrue-js/v2/spec.json > $(REPO_DIR)/enrichments/tsdoc_v2/gotrue.json
|
|
curl -sS https://supabase.github.io/postgrest-js/v2/spec.json > $(REPO_DIR)/enrichments/tsdoc_v2/postgrest.json
|
|
curl -sS https://supabase.github.io/realtime-js/v2/spec.json > $(REPO_DIR)/enrichments/tsdoc_v2/realtime.json
|
|
curl -sS https://supabase.github.io/storage-js/v2/spec.json > $(REPO_DIR)/enrichments/tsdoc_v2/storage.json
|
|
curl -sS https://supabase.github.io/functions-js/v2/spec.json > $(REPO_DIR)/enrichments/tsdoc_v2/functions.json
|
|
|
|
download.analytics.v0:
|
|
curl -sS https://logflare.app/api/openapi > $(REPO_DIR)/analytics_v0_openapi.json
|
|
|
|
###############################################################################
|
|
# Transform docs into working files
|
|
###############################################################################
|
|
transform: dereference.api.v0 dereference.auth.v1 dereference.storage.v0 dereference.tsdoc.v2 combine.tsdoc.v2
|
|
|
|
dereference.api.v0:
|
|
npx swagger-cli bundle --dereference --outfile $(REPO_DIR)/transforms/api_v0_openapi_deparsed.json $(REPO_DIR)/api_v0_openapi.json
|
|
|
|
dereference.auth.v1:
|
|
npx swagger-cli bundle --dereference --outfile $(REPO_DIR)/transforms/auth_v1_openapi_deparsed.json $(REPO_DIR)/auth_v1_openapi.json
|
|
|
|
dereference.storage.v0:
|
|
npx swagger-cli bundle --dereference --outfile $(REPO_DIR)/transforms/storage_v0_openapi_deparsed.json $(REPO_DIR)/storage_v0_openapi.json
|
|
|
|
dereference.analytics.v0:
|
|
npx swagger-cli bundle --dereference --outfile $(REPO_DIR)/transforms/analytics_v0_openapi_deparsed.json $(REPO_DIR)/analytics_v0_openapi.json
|
|
|
|
# No longer updated
|
|
# dereference.tsdoc.v1:
|
|
# cd $(REPO_DIR)/parser && npm run tsdoc:dereference:functions:v1
|
|
# cd $(REPO_DIR)/parser && npm run tsdoc:dereference:gotrue:v1
|
|
# cd $(REPO_DIR)/parser && npm run tsdoc:dereference:postgrest:v1
|
|
# cd $(REPO_DIR)/parser && npm run tsdoc:dereference:realtime:v1
|
|
# cd $(REPO_DIR)/parser && npm run tsdoc:dereference:storage:v1
|
|
# cd $(REPO_DIR)/parser && npm run tsdoc:dereference:supabase:v1
|
|
|
|
dereference.tsdoc.v2:
|
|
cd $(REPO_DIR)/parser && npm run tsdoc:dereference:functions:v2
|
|
cd $(REPO_DIR)/parser && npm run tsdoc:dereference:gotrue:v2
|
|
cd $(REPO_DIR)/parser && npm run tsdoc:dereference:postgrest:v2
|
|
cd $(REPO_DIR)/parser && npm run tsdoc:dereference:realtime:v2
|
|
cd $(REPO_DIR)/parser && npm run tsdoc:dereference:storage:v2
|
|
cd $(REPO_DIR)/parser && npm run tsdoc:dereference:supabase:v2
|
|
|
|
# No longer updated
|
|
# combine.tsdoc.v1:
|
|
# jq -s '{ name: "Combined Specs", children: [.[0], .[1], .[2], .[3], .[4], .[5]] }' \
|
|
# $(REPO_DIR)/enrichments/tsdoc_v1/supabase_dereferenced.json \
|
|
# $(REPO_DIR)/enrichments/tsdoc_v1/gotrue_dereferenced.json \
|
|
# $(REPO_DIR)/enrichments/tsdoc_v1/postgrest_dereferenced.json \
|
|
# $(REPO_DIR)/enrichments/tsdoc_v1/realtime_dereferenced.json \
|
|
# $(REPO_DIR)/enrichments/tsdoc_v1/storage_dereferenced.json \
|
|
# $(REPO_DIR)/enrichments/tsdoc_v1/functions_dereferenced.json \
|
|
# > $(REPO_DIR)/enrichments/tsdoc_v1/combined.json
|
|
|
|
combine.tsdoc.v2:
|
|
jq -s '{ name: "Combined Specs", children: [.[0], .[1], .[2], .[3], .[4], .[5]] }' \
|
|
$(REPO_DIR)/enrichments/tsdoc_v2/supabase_dereferenced.json \
|
|
$(REPO_DIR)/enrichments/tsdoc_v2/gotrue_dereferenced.json \
|
|
$(REPO_DIR)/enrichments/tsdoc_v2/postgrest_dereferenced.json \
|
|
$(REPO_DIR)/enrichments/tsdoc_v2/realtime_dereferenced.json \
|
|
$(REPO_DIR)/enrichments/tsdoc_v2/storage_dereferenced.json \
|
|
$(REPO_DIR)/enrichments/tsdoc_v2/functions_dereferenced.json \
|
|
> $(REPO_DIR)/enrichments/tsdoc_v2/combined.json
|
|
|
|
combine-raw.tsdoc.v2:
|
|
jq -s '{ name: "Combined Specs", children: [.[0], .[1], .[2], .[3], .[4], .[5]] }' \
|
|
$(REPO_DIR)/enrichments/tsdoc_v2/supabase.json \
|
|
$(REPO_DIR)/enrichments/tsdoc_v2/gotrue.json \
|
|
$(REPO_DIR)/enrichments/tsdoc_v2/postgrest.json \
|
|
$(REPO_DIR)/enrichments/tsdoc_v2/realtime.json \
|
|
$(REPO_DIR)/enrichments/tsdoc_v2/storage.json \
|
|
$(REPO_DIR)/enrichments/tsdoc_v2/functions.json \
|
|
> $(REPO_DIR)/enrichments/tsdoc_v2/combined_raw.json
|
|
|
|
###############################################################################
|
|
# Validate OpenAPI 3.0
|
|
###############################################################################
|
|
|
|
validate.analytics.v0:
|
|
npx swagger-cli validate --no-schema $(REPO_DIR)/analytics_v0_openapi.json
|
|
|
|
###############################################################################
|
|
# Format everything - easier for git to track changes.
|
|
###############################################################################
|
|
format:
|
|
npx prettier --write .
|