From 66c7630b189a9ef868804fa7ed147c89838aa74e Mon Sep 17 00:00:00 2001 From: Bogdan Marc Date: Fri, 6 Oct 2023 15:46:46 +0100 Subject: [PATCH 1/7] Added link to main LR repo --- README.md | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index 7c05f1b..d810838 100644 --- a/README.md +++ b/README.md @@ -10,7 +10,9 @@ our report generator API. This batch job will either return with the report download link, if a report with those options has already been generated and cached, or a queue position as the job moves up the batch queue. -## Running this service +Please see the other repositories in the [HM Land Registry Open +Data](https://github.com/epimorphics/hmlr-linked-data/) project for more +details. This application can be run stand-alone as a rails server in `development` mode. However, when deployed, applications will run behind a reverse proxy. From d7604d393497f70f412f80e98a7ae8cfac1bba35 Mon Sep 17 00:00:00 2001 From: Bogdan Marc Date: Fri, 6 Oct 2023 15:47:28 +0100 Subject: [PATCH 2/7] Added API running steps at the top --- README.md | 98 ------------------------------------------------------- 1 file changed, 98 deletions(-) diff --git a/README.md b/README.md index d810838..a811faf 100644 --- a/README.md +++ b/README.md @@ -14,104 +14,6 @@ Please see the other repositories in the [HM Land Registry Open Data](https://github.com/epimorphics/hmlr-linked-data/) project for more details. -This application can be run stand-alone as a rails server in `development` mode. -However, when deployed, applications will run behind a reverse proxy. - -This enables request to be routed to the appropriate application base on the -request path. In order to simplifiy the proxy configuration we retain the -original path where possible. - -For information on how to running a proxy to mimic production and run multple -services together read through the information in our -[simple-web-proxy](https://github.com/epimorphics/simple-web-proxy/edit/main/README.md) -repository. - -If running more than one application locally ensure that each is listerning on a -separate port and separate path. In the case of running local docker images, the -required configuration is captured in the `Makefile` and an image can be run by -using - -### Development and Production mode - -Applications running in `development` mode default to *not* use a sub-directory -to aid stand-alone development. - -Applications running in `production` mode *do* use a sub-directory i.e. -`/app/standard-reports`. - -In each case the is achieved by setting `config.relative_url_root` property to -this sub-directory within the file -`config/environments/(development|production).rb`. - -If need be, `config.relative_url_root` may by overridden by means of the -`RAILS_RELATIVE_URL_ROOT` environment variable, althought this could also -require rebuilding the assets or docker image. - -### Running Rails as a server - -For developing rails applications you can start the server locally using the -following command: - -```sh -rails server -``` - -and visit in your browser. - -To change to using `production` mode use the `-e` option; or to change to a -different port use the `-p` option. - -Note: In `production` mode, `SECRET_KEY_BASE` is also required. It is -insufficient to just set this as the value must be exported. e.g. - -```sh -export SECRET_KEY_BASE=$(./bin/rails secret) -``` - -#### Running Rails as a server with a sub-directory via Makefile - -```sh -API_SERVICE_URL= RAILS_ENV= RAILS_RELATIVE_URL_ROOT=/ make server -``` - -The default for `RAILS_ENV` here is `development`. - -### Building and Running the docker container - -It can be useful to run the compiled Docker image, that will mirror the -production installation, locally yourself. Assuming you have the [Standard -Reports Manager running](#running-the-standard-reports-manager-locally), then -you can run the Docker image for the app itself as follows: - -```sh -make image run -``` - -or, if the image is already built, simply - -```sh -make run -``` - -Docker images run in `production` mode. - -To test the running application visit `localhost:/`. - -## Runtime Configuration environment variables - -We use a number of environment variables to determine the runtime behaviour of -the application: - -| name | description | default value | -| -------------------------- | ----------------------------------------------------------------------- | -------------------------- | -| `API_SERVICE_URL` | The base URL from which data is accessed, including the HTTP scheme eg. | None | -| | if running a `standard-reports-manager service` locally | | -| | if running a `standard-reports-manager docker` image locally | | -| `SECRET_KEY_BASE` | See [description](https://api.rubyonrails.org/classes/Rails/Application.html#method-i-secret_key_base). | | -| | For `development` mode a acceptable value is already configured, in production mode this should be set to the output of `rails secret`. | | -| | This is handled automatically when starting a docker container, or the `server` `make` target | | -| `SENTRY_API_KEY` | The DSN for sending reports to the PPD Sentry account | None | - ### Running the Standard Reports Manager locally The application connects to the Standard Reports Manager service to submit From 2fbeb81fa609d8e826edebd57e66e0e57bc0f39a Mon Sep 17 00:00:00 2001 From: Bogdan Marc Date: Fri, 6 Oct 2023 15:48:04 +0100 Subject: [PATCH 3/7] Fixed API section headings --- README.md | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/README.md b/README.md index a811faf..a10c741 100644 --- a/README.md +++ b/README.md @@ -14,7 +14,7 @@ Please see the other repositories in the [HM Land Registry Open Data](https://github.com/epimorphics/hmlr-linked-data/) project for more details. -### Running the Standard Reports Manager locally +## Running the Standard Reports Manager locally The application connects to the Standard Reports Manager service to submit requests. @@ -25,7 +25,7 @@ manager](https://github.com/epimorphics/standard-reports-manager/) repository. or pulled from the Amazon Elastic Container Registry [ECR](https://eu-west-1.console.aws.amazon.com/ecr/repositories/private/018852084843/epimorphics/standard-reports-manager/dev?region=eu-west-1). -#### Building and running from [standard reports manager](https://github.com/epimorphics/standard-reports-manager/) repository +### Building and running from [standard reports manager](https://github.com/epimorphics/standard-reports-manager/) repository To build and a run a new docker image check out the [standard reports manager](https://github.com/epimorphics/standard-reports-manager/) repository @@ -35,7 +35,7 @@ and run make image run ``` -#### Running an existing [ECR](https://eu-west-1.console.aws.amazon.com/ecr/repositories/private/018852084843/epimorphics/standard-reports-manager/dev?region=eu-west-1) image +### Running an existing [ECR](https://eu-west-1.console.aws.amazon.com/ecr/repositories/private/018852084843/epimorphics/standard-reports-manager/dev?region=eu-west-1) image Obtaining an ECR image requires: @@ -82,7 +82,7 @@ To create the docker network run docker network create dnet ``` -### To run the Standard Reports Manager as a docker container +### Running as a docker container Take a copy of the latest Manager development configuation file From 51e2a1121baccd273dcf6af1cbe954d9cac009e3 Mon Sep 17 00:00:00 2001 From: Bogdan Marc Date: Fri, 6 Oct 2023 15:48:48 +0100 Subject: [PATCH 4/7] Removed structure section --- README.md | 3 --- 1 file changed, 3 deletions(-) diff --git a/README.md b/README.md index a10c741..f989d9a 100644 --- a/README.md +++ b/README.md @@ -110,11 +110,8 @@ port. With this set up, the api service is available on `http://localhost:8081` from the host or `http://standard-reports-manager:8080` from inside other docker containers. -## Developer notes -### Structure -This is a fairly standard Rails project, with no particular surprises. ### Coding standards From 19a1b66f4cbfe31f7214bb31261224130c6bebc5 Mon Sep 17 00:00:00 2001 From: Bogdan Marc Date: Fri, 6 Oct 2023 15:49:26 +0100 Subject: [PATCH 5/7] Running the app section is now second from the top --- README.md | 82 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 82 insertions(+) diff --git a/README.md b/README.md index f989d9a..3989240 100644 --- a/README.md +++ b/README.md @@ -110,7 +110,89 @@ port. With this set up, the api service is available on `http://localhost:8081` from the host or `http://standard-reports-manager:8080` from inside other docker containers. +## Running the app +This application can be run stand-alone as a rails server in `development` mode. +However, when deployed, applications will run behind a reverse proxy. + +This enables request to be routed to the appropriate application base on the +request path. In order to simplifiy the proxy configuration we retain the +original path where possible. + +For information on how to running a proxy to mimic production and run multple +services together read through the information in our +[simple-web-proxy](https://github.com/epimorphics/simple-web-proxy/edit/main/README.md) +repository. + +If running more than one application locally ensure that each is listerning on a +separate port and separate path. In the case of running local docker images, the +required configuration is captured in the `Makefile`. + +### Locally + +For developing rails applications you can start the server locally using the +following command: + +```sh +rails server +``` + +and visit in your browser. + +To change to using `production` mode use the `-e` option; or to change to a +different port use the `-p` option. + +Note: In `production` mode, `SECRET_KEY_BASE` is also required. It is +insufficient to just set this as the value must be exported. e.g. + +```sh +export SECRET_KEY_BASE=$(./bin/rails secret) +``` + +#### Running Rails as a server with a sub-directory via Makefile + +```sh +API_SERVICE_URL= RAILS_ENV= RAILS_RELATIVE_URL_ROOT=/ make server +``` + +The default for `RAILS_ENV` here is `development`. + +### As a docker container + +It can be useful to run the compiled Docker image, that will mirror the +production installation, locally yourself. Assuming you have the [Standard +Reports Manager running](#running-the-standard-reports-manager-locally), then +you can run the Docker image for the app itself as follows: + +```sh +make image run +``` + +or, if the image is already built, simply + +```sh +make run +``` + +Docker images run in `production` mode. + +To test the running application visit `localhost:/`. + +### Development and Production mode + +Applications running in `development` mode default to *not* use a sub-directory +to aid stand-alone development. + +Applications running in `production` mode *do* use a sub-directory i.e. +`/app/standard-reports`. + +In each case the is achieved by setting `config.relative_url_root` property to +this sub-directory within the file +`config/environments/(development|production).rb`. + +If need be, `config.relative_url_root` may by overridden by means of the +`RAILS_RELATIVE_URL_ROOT` environment variable, althought this could also +require rebuilding the assets or docker image. ### Coding standards From 385d0d89938f09957089745f3d9ad897100d6b48 Mon Sep 17 00:00:00 2001 From: Bogdan Marc Date: Fri, 6 Oct 2023 15:49:51 +0100 Subject: [PATCH 6/7] Added runtime config to additional information --- README.md | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index 3989240..5461204 100644 --- a/README.md +++ b/README.md @@ -194,6 +194,7 @@ If need be, `config.relative_url_root` may by overridden by means of the `RAILS_RELATIVE_URL_ROOT` environment variable, althought this could also require rebuilding the assets or docker image. +## Additional Information ### Coding standards @@ -215,7 +216,20 @@ Passing in the `API_SERVICE_URL` is required to ensure the tests run against the Please add issues to the [shared issues list](https://github.com/epimorphics/hmlr-linked-data/issues) -## Additional Information +### Runtime Configuration environment variables + +We use a number of environment variables to determine the runtime behaviour of +the application: + +| name | description | default value | +| -------------------------- | ----------------------------------------------------------------------- | -------------------------- | +| `API_SERVICE_URL` | The base URL from which data is accessed, including the HTTP scheme eg. | None | +| | if running a `standard-reports-manager service` locally | | +| | if running a `standard-reports-manager docker` image locally | | +| `SECRET_KEY_BASE` | See [description](https://api.rubyonrails.org/classes/Rails/Application.html#method-i-secret_key_base). | | +| | For `development` mode a acceptable value is already configured, in production mode this should be set to the output of `rails secret`. | | +| | This is handled automatically when starting a docker container, or the `server` `make` target | | +| `SENTRY_API_KEY` | The DSN for sending reports to the PPD Sentry account | None | ### Deployment From 2b8a4fc019b1e7c3f76859af4a2776fbd9cbfd31 Mon Sep 17 00:00:00 2001 From: Bogdan Marc Date: Fri, 6 Oct 2023 15:50:07 +0100 Subject: [PATCH 7/7] Fixed heading issue --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 5461204..c057e42 100644 --- a/README.md +++ b/README.md @@ -211,7 +211,7 @@ API_SERVICE_URL=http://localhost:8081 bundle exec rails test Passing in the `API_SERVICE_URL` is required to ensure the tests run against the `standard-reports-manager` service running locally. -## Issues +### Issues Please add issues to the [shared issues list](https://github.com/epimorphics/hmlr-linked-data/issues)