Skip to content

Latest commit

 

History

History
41 lines (27 loc) · 1.79 KB

README.md

File metadata and controls

41 lines (27 loc) · 1.79 KB

Running

  1. Build the service
  2. docker build -t <some-name> .
  3. docker run --rm -d -p <some-port>:80 -p <some-other-port>:22 <some-name>

You should now have an nginx server running at <some-port>.

The haskell service should be running at localhost:<some-port>/api/*, and you can also see a php info file at localhost:<some-port>/info.php.

You can also run the image environemnt interactively with docker run --rm --entrypoint /bin/bash -it <some-name>. However, this will not start the nginx/php-fpm/mysql/etc services automatically, because they are usually started as the ENTRYPOINT for the docker image.

You can also use ssh to access the container while it's running via password asdf:

ssh -p <some-other-port> root@localhost

Building

  1. Have docker
  2. ./stack.sh install --local-bin-path=.
  3. wait a long time the first time around

You should now have an executable called service-exe inside the service folder.

Note that you can also build (and e.g. also use ghci) without using stack.sh (which runs a build inside a docker image). You'll need libpcre3-dev + libmariadbclient-dev (this is what they're called on debian).

This build is in place so that you can easily run a "dev" server afterwards, refer to Running. Building it on your machine might cause a libc mismatch between what is in the "deploy" image.

Modifications to js query functions

Since servant doesn't return json-encoded values for errors (it's plaintext) the js functions need to be modified not to attempt to parse the error body as json.

xhr.withCredentials = true; should be set for the XMLHttpRequests so that cookies are sent. The cookieHeader argument should be deleted, since xhr.withCredentials = true means that they will be sent automatically.