diff --git a/.nojekyll b/.nojekyll index bc25002..0239075 100644 --- a/.nojekyll +++ b/.nojekyll @@ -1 +1 @@ -166460bf \ No newline at end of file +11886b27 \ No newline at end of file diff --git a/book/developer_notes.html b/book/developer_notes.html index 31f06f9..3f6cce3 100644 --- a/book/developer_notes.html +++ b/book/developer_notes.html @@ -337,16 +337,17 @@

The calculation of indicators for custom scenarios in the web app relies on an API. Right now, the web app uses an API which is hosted as an Azure Function.

In particular, the function must accept a POST body that looks like this. Only output areas which are changed relative to the baseline need to be included in the inner JSON object:

{
-  "scenario_json": {
-    output_area_name: {
-      "signature_type": int | null,
-      "job": float | null,
-      "use": float | null,
-      "greenspace": float | null
-    },
-    ...
-  }
-}
+ "model_identifier": string, + "scenario_json": { + output_area_name: { + "signature_type": int | null, + "job": float | null, + "use": float | null, + "greenspace": float | null + }, + ... + } +}

Upon success, this must return a JSON response with the following format (all output areas must be included):

{
   output_area_name: {
@@ -376,11 +377,11 @@ 

To test the function locally, run:

func start

You should then be able to access the API at http://localhost:7071/api/scenario. For example, you can test it using the following command, which asks it to calculate the baseline indicators (an empty scenario means no changes relative to the baseline):

-
curl http://localhost:7071/api/scenario -X POST -d "{\"scenario_json\": {}}" -v
+
curl http://localhost:7071/api/scenario -X POST -d "{\"scenario_json\": {}, \"model_identifier\": \"tyne_and_wear\"}" -v
  • To deploy it to Azure, run the following, which will take a few minutes:

    -
    func azure functionapp publish demolandapi --python
    +
    func azure functionapp publish demolandapi

    Test it with:

    -
    curl https://demolandapi.azurewebsites.net/api/scenario -X POST -d "{\"scenario_json\": {}}" -v
  • +
    curl https://demolandapi.azurewebsites.net/api/scenario -X POST -d "{\"scenario_json\": {}, \"model_identifier\": \"tyne_and_wear\"}" -v
    diff --git a/search.json b/search.json index de369a0..433b49a 100644 --- a/search.json +++ b/search.json @@ -165,14 +165,14 @@ "href": "book/developer_notes.html#api-specification", "title": "5  Developer notes", "section": "5.1 API specification", - "text": "5.1 API specification\nThe calculation of indicators for custom scenarios in the web app relies on an API. Right now, the web app uses an API which is hosted as an Azure Function.\nIn particular, the function must accept a POST body that looks like this. Only output areas which are changed relative to the baseline need to be included in the inner JSON object:\n{\n \"scenario_json\": {\n output_area_name: {\n \"signature_type\": int | null,\n \"job\": float | null,\n \"use\": float | null,\n \"greenspace\": float | null\n },\n ...\n }\n}\nUpon success, this must return a JSON response with the following format (all output areas must be included):\n{\n output_area_name: {\n \"air_quality\": float,\n \"house_price\": float,\n \"job_accessibility\": float,\n \"greenspace_accessibility\": float,\n \"signature_type\": int\n },\n ...\n}" + "text": "5.1 API specification\nThe calculation of indicators for custom scenarios in the web app relies on an API. Right now, the web app uses an API which is hosted as an Azure Function.\nIn particular, the function must accept a POST body that looks like this. Only output areas which are changed relative to the baseline need to be included in the inner JSON object:\n{\n \"model_identifier\": string,\n \"scenario_json\": {\n output_area_name: {\n \"signature_type\": int | null,\n \"job\": float | null,\n \"use\": float | null,\n \"greenspace\": float | null\n },\n ...\n }\n}\nUpon success, this must return a JSON response with the following format (all output areas must be included):\n{\n output_area_name: {\n \"air_quality\": float,\n \"house_price\": float,\n \"job_accessibility\": float,\n \"greenspace_accessibility\": float,\n \"signature_type\": int\n },\n ...\n}" }, { "objectID": "book/developer_notes.html#azure-functions", "href": "book/developer_notes.html#azure-functions", "title": "5  Developer notes", "section": "5.2 Azure Functions", - "text": "5.2 Azure Functions\nThe code required to deploy this can be found on the azure-functions branch of the engine repository, specifically the function_app.py file.\nTo deploy a new version of the Azure function, make sure you are a member of the “Land Use Indicator” Azure subscription (the subscription ID is 86307bb0-6d16-4077-b1f7-939370d5289a). If you are not, get Dani to add you.\nThen, follow these instructions:\n\nLog in to Azure. This will open a browser window where you can log in with your Microsoft account.\n az login\nSet your active subscription to the one above:\naz account set -s 86307bb0-6d16-4077-b1f7-939370d5289a\nInstall the Azure Functions Core Tools. The following Homebrew command works on macOS; for other operating systems, refer to the Azure docs\nbrew tap azure/functions\nbrew install azure-functions-core-tools@4\nClone the demoland-engine repository (if you don’t already have it), and cd to the top level of the demoland-engine repository.\nTo test the function locally, run:\nfunc start\nYou should then be able to access the API at http://localhost:7071/api/scenario. For example, you can test it using the following command, which asks it to calculate the baseline indicators (an empty scenario means no changes relative to the baseline):\ncurl http://localhost:7071/api/scenario -X POST -d \"{\\\"scenario_json\\\": {}}\" -v\nTo deploy it to Azure, run the following, which will take a few minutes:\nfunc azure functionapp publish demolandapi --python\nTest it with:\ncurl https://demolandapi.azurewebsites.net/api/scenario -X POST -d \"{\\\"scenario_json\\\": {}}\" -v" + "text": "5.2 Azure Functions\nThe code required to deploy this can be found on the azure-functions branch of the engine repository, specifically the function_app.py file.\nTo deploy a new version of the Azure function, make sure you are a member of the “Land Use Indicator” Azure subscription (the subscription ID is 86307bb0-6d16-4077-b1f7-939370d5289a). If you are not, get Dani to add you.\nThen, follow these instructions:\n\nLog in to Azure. This will open a browser window where you can log in with your Microsoft account.\n az login\nSet your active subscription to the one above:\naz account set -s 86307bb0-6d16-4077-b1f7-939370d5289a\nInstall the Azure Functions Core Tools. The following Homebrew command works on macOS; for other operating systems, refer to the Azure docs\nbrew tap azure/functions\nbrew install azure-functions-core-tools@4\nClone the demoland-engine repository (if you don’t already have it), and cd to the top level of the demoland-engine repository.\nTo test the function locally, run:\nfunc start\nYou should then be able to access the API at http://localhost:7071/api/scenario. For example, you can test it using the following command, which asks it to calculate the baseline indicators (an empty scenario means no changes relative to the baseline):\ncurl http://localhost:7071/api/scenario -X POST -d \"{\\\"scenario_json\\\": {}, \\\"model_identifier\\\": \\\"tyne_and_wear\\\"}\" -v\nTo deploy it to Azure, run the following, which will take a few minutes:\nfunc azure functionapp publish demolandapi\nTest it with:\ncurl https://demolandapi.azurewebsites.net/api/scenario -X POST -d \"{\\\"scenario_json\\\": {}, \\\"model_identifier\\\": \\\"tyne_and_wear\\\"}\" -v" }, { "objectID": "code/01_baseline/01_accessibility.html#variables-definition-and-data-import",