This is a long-lived branch of the quote service for use in the tour application.
This branch is pulled into datawire/tour as the backend/
directory via a git subtree
.
All updates to the tour backend should be made against the tour-master branch of datawire/quote and pulled into tour by running:
git subtree pull --prefix backend https://github.com/datawire/quote tour-master --squash
docker build -t {DOCKER_USERNAME}/{IMAGE_NAME}:{VERSION} .
Ex: docker build -t datawire.io/quote:0.5.0 .
Run with Docker:
docker run -p 8080:8080 {IMAGE}
Pass environment variables with Docker:
docker run -p 8080:8080 -e ENVIRONMENT_VARIABLE='value' {IMAGE}
Name | Description | Default |
---|---|---|
PORT | What port the service should listen on | 8080 |
ENABLE_TLS | Whether to use TLS for HTTSP or use HTTP | false |
OPENAPI_PATH | What path to serve the OpenAPI document on | /.ambassador-internal/openapi-docs |
ZIPKIN_SERVER | The Zipkin service for reporting traces to | N/A |
ZIPKIN_PORT | The port for the Zipkin service | 9411 |
CONSUL_IP | The IP address of the consul server pod for registering this service with Consul | N/A |
POD_IP | The IP of this pod for registering this service with Consul | N/A |
SERVICE_NAME | The name to register this service with consul under | quote |
FILE_PATH | The path where files will be uploaded to | /images/ |
Note: The following curl commands assume that you have deployed this application by following the Ambassador Edge Stack quickstart guide.
/backend/
is the prefix for routing requests to this service, and is dropped before the request hits thequote
service. If you are running via docker, then you will not need to add/backend/
to any of your requests and can just use the endpoints directly.
-
/
GET: Gets a randomly selected quote and a string to represent the name of the quote service.
Ex:
curl -kv https://{IP_ADDR}/backend/
-
/get-quote/
GET: Gets a randomly selected quote and a string to represent the name of the quote service.
Ex:
curl -kv https://{IP_ADDR}/backend/get-quote/
-
/debug/
GET: Prints headers and information about the request.
POST: Prints headers and information about the request and sends the body of the request back as well.
Ex:
curl -kv https://{IP_ADDR}/backend/debug/
-
/debug/*
GET: Functions the same as the
/debug/
path without a POST option.Ex:
curl -kv https://{IP_ADDR}/backend/debug/{path}
-
health
GET: Returns a 200 OK when the service is functioning.
Ex:
curl -kv https://{IP_ADDR}/backend/health
-
/auth/*
GET: Alternates between sending a
500 Internal Server Error
and200 OK
response each time you make a request to this endpoint.Ex:
curl -kv https://{IP_ADDR}/backend/auth/*
-
/sleep/*
GET: Queries the URL for an ammount of time to sleep for before responding to the request. Defaults to one second when it is unable to parse a sleep parameter.
Ex:
curl -kv https://{IP_ADDR}/backend/sleep/
Ex:
curl -kv https://{IP_ADDR}/backend/sleep/\?sleep=5
Note: You need to escape the
?sleep
on the command line. On a browser you can exclude the\
-
/files/
GET: returns a list of files available to be downloaded.
POST: Uploads a file to the service to be downloaded later. Overwrites existing files if provided with the same name as an existing file. Uses the path as the name for the file.
Ex:
curl -kv https://{IP_ADDR}/backend/files/
Ex:
curl -kv --form "[email protected]" https://{IP_ADDR}/backend/files/
Note: The
FILE_PATH
environment varialbe is used to configure a custom path for storing files if using a persistent volume in Kubernetes. Otherwise it will default to storing files ephemerally inside the container.Note: For successful file uploads it expects the file to be passed in a value called
file
exactly as shown in the example.
-
/files/*
GET: returns a file of the provided name if it exists or a 404 if it cannot find the file. The container ships with a file
edgy.jepg
for testing.Ex:
curl -kv https://{IP_ADDR}/backend/files/edgy.jpeg