Skip to content

Latest commit

 

History

History
60 lines (43 loc) · 1.66 KB

README.md

File metadata and controls

60 lines (43 loc) · 1.66 KB

proxy

Use openresty/nginx as api gateway to transform api_keys on internal services tokens and proxy requests to correct services and check and generate

Checkout how running common-group platform on with docker-compose example

How add new locations

example for projects collection

mapping new root collection sunch as '/:version/:collection/' (/v1/projects):

add new collection entry to mapped version inside conf.d/proxy.template

# conf.d/proxy.template
location ~ "^/v1/" {
  location ~ "^/v1/projects(?:\/)?.*$" {
    # you new code here
  }
}

add nested routes for collection

create a new file for collection: touch conf.d/locations/projects_location.conf and edit the proxy.template to include the file with new locations

# conf.d/proxy.template
location ~ "^/v1/" {
  location ~ "^/v1/projects(?:\/)?.*$" {
    include /etc/nginx/conf.d/locations/v1/projects_location.conf;
  }
}

mapping new locations on collection inside the new location conf:

# conf.d/locations/projects_location.conf
location ~ "^/v1/projects/([\w\d\-]+)/fund_stats$" {
	set $args "${args}${token}id=$1";
	proxy_set_header Host $host_analytics_service_api;

	proxy_pass $env_proto_schema://analytics_service_api_server/rpc/project_subscribers_info$is_args$args;
}

Testing

We provide a simple test.sh that executes a docker build on Dockerfile.test with a syntax check on nginx configuration files

Heroku cli deploying

Uses the Dockerfile.web has web in heroku dynos

heroku container:push web --recursive -a APPLICATION_NAME
heroku container:release web -a APPLICATION_NAME