An appointment and booking api designed to support national vaccination bookings.
Slack chanel - #appointments-service
- Sponsor - James Spirit
- Product Owner - Lauren Caveney
- Development Team - Vincent Crowe, Sam Biram, Kim Crowe, Khurram Aziz, Saritha Lakkreddy, Ste Banks
- Past Development Team - Joe Farina
- Dotnet V8
- C# V12
- Azure Functions V4
- Javascript/Typescript (React V18)
- Next.js V14
- Cosmos document database
We will build an Appointments API using
- Will follow REST principles as much as possible
- Github (for code repo)
- Azure Devops (for CI pipelines)
- C# (development language)
- Azure Functions (as a platform for hosting)
We will build a web based application for appointment and site management
- We will use React/Next.js
- Github (for code repo)
- Azure Devops (pipelines)
- Azure Web Apps (to host the NextJS server)
The repo has signed commits enabled. This means that only commits that are verified can be merged into the main branch. More information about signed commits can be found here.
Your workstation will need to be set up to use signed commits. Please follow this guide for instructions.*
*At the time of writing this guide is missing a step in the Windows section. After running git config --global commit.gpgsign true
you must then run git config --global user.signingkey <key>
to actually tell git about the key you just created.
- Install Docker for Windows (use Linux Containers)
- Install .NET 8.0
- Install the Azure Functions Core Tools
- Install Node V20
- Install NPM
If you are using VS Code, you may find it beneficial to open the repo by opening the nbs-ams.code-workspace
file itself. This will open a workspace configured with several productivity boons:
- The Explorer window is split into folders for convenience and to make navigating the repo quicker/easier
- Terminals can be opened straight into any of these folders using the
ctrl-shift-'
command - Default build tasks have been configured for Dotnet and Typescript. You can run these with the
ctrl-shift-b
command - Non-build tasks have been configured for starting the docker, dotnet, and NextJS services. These are configured in
tasks.json
folders and can be ran throughTerminal
->Run Task...
Each of the following steps needs to be done in a separate terminal window
- Run containerised services
- From the root folder run
docker compose --profile local up --build -d
- (OR if using VS Code) run the
Start local development containers
task
- From the root folder run
It is also possible to run next and api services locally not using docker:
- Start mock-api, mock-oidc-server and cosmos containers:
- run
docker compose up --build -d mock-api oidc-server cosmos
- run
- Run the API
- From the folder
/src/api/Nhs.Appointments.Api
run the commandfunc start
- (OR if using VS Code) run the
Clean and Run API
task
- From the folder
- Run the Web Application
- From the folder
/src/client/
runnpm install
and then runnpm run dev
- (OR if using VS Code) run the
Run Client in Dev Mode
task
- From the folder
To run the oidc-server you will need to install a certificate. You will need to generate and trust a dev cert with the following command (in order to ensure that the certificate is placed in the correct location you should run the command from your user profile folder or amend the command accordingly).
dotnet dev-certs https -ep .aspnet/https/aspnetapp.pfx -p password -t -v
The API expects cosmos to be running at "https://localhost:8081" The API expects the mockapi to be running at "http://localhost:4011" The Web Application expects the API to be running at "http://localhost:7071"
If your configuration causes any of these to be running differently then you will need to change the application configuration files accordingly. (Or use environment variables to override local configuration)
API configuration file is found at /src/Nhs.Appointments.Api/localsettings.json
Client configuration file is found at /src/client/.env
When running locally in docker the data in the cosmos database can be viewed and modified using the cosmos emulator
explorer. To access the explorer visit https://localhost:8081/_explorer/index.html
(note you may get an unsafe page
warning unless you import the certificate from the cosmos container, this can safely be ignored for this url)
To meaningfully explore the API/frontend you'll need a minimum set of data present in the Cosmos DB. There is a .NET Console App which uploads a set of cosmos-friendly documents in /src/data/CosmosDbSeeder
.
You simply need to run this app to upload the default mock data. If using VS Code you can do this by running the Seed Cosmos
task. You can also run it manually with the dotnet run
terminal command in that folder.
The folder/file structure within the items
folder matches the desired structure in Cosmos 1:1 (that is, there will be a Cosmos container called index_data
which will contain each child .json
file as a document). If you wish to create or modify a container simply alter these files, then re-run the seeder. Remember that if you run the app manually you will need to run dotnet clean
first for the changes to be picked up (the VS Code task does this for you automatically).
Alternatively, you can upload these files one at a time yourself through the emulator's browser interface.
REST calls using an API user must be signed (via HMAC) using the key associated with the api user.
The api user is identified using the ClientId header - so the in the above example a signed request with a ClientId header of dev
would be needed to make api calls
.NET code style and formatting rules are imposed by dotnet format because it is IDE and platform agnostic, and natively included in the .NET SDK. Rule are dictated by an .editorconfig file.
The warnings and errors about violations of these rules could be surfaced at build time by enabling Enforce Code Style In Build () in each .csproj
file.
Because the .editorconfig
file is attached to the solution, both Rider and Visual Studio should automatically use its rules in place of their own defaults.
- on Visual Studio, you may need to visit
Analyze -> Code Cleanup -> Configure Code Cleanup
, then change your default profile to include only theFix all warnings and errors set in EditorConfig
step. - on Rider, you may need to visit
Settings -> Editor -> Inspection Settings
then ensureRead settings from editorconfig, project settings and rule sets
is ticked.
The easiest way is probably through an IDE, configured as per the step above. Most IDEs can format single files if you right-click it in the explorer.
Failing that, the harder way is to pass an --include <PATH>
argument to dotnet format
on the command line, providing it the files you want it to format.
You can invoke dotnet format on the command line like so:
dotnet format nbs-manage-your-appointments.sln --verify-no-changes --report dotnet-format-report.json
This will create a report named dotnet-format-report.json
in the repository root. This has been added to the .gitignore
file so should not cause a tracked change.
The --verify-no-changes
argument tells format
to make no changes. If you want it to automatically apply fixes, simply remove this argument:
dotnet format nbs-manage-your-appointments.sln
If you want to run it against one or more specific directories in the solution (or indeed exclude one or more), these can be specified through the --include <PATH>
and --exclude <PATH>
arguments.
If you want to see only errors, or include suggestions, pass a new value to the severity argument (accepted values are error
, warn
, and info
):
dotnet format nbs-manage-your-appointments.sln --severity <SEVERITY>
See the docs for more on this.
From ~/src/client
:
- Ensure you have ran
npm i
- Simply run
npm run test
If running the workspace in VS Code, the Jest tests should be automatically discovered in the test explorer window. You should be able to run and debug them via the UI.
From ~/src/client
:
- Ensure you have ran
npm i
- The very first time you run the tests you will need to run
npx playwright install
. This instructs Playwright to download and instantiate the latest version of the browsers it requires. - Ensure the Docker and .NET services are running following their respective setup commands (In the future we hope to be set these up automatically)
- Optionally run the frontend app (If you're not already running it, Playwright will start it up for you)
- Run
npm run test:e2e
. Optionally if you wish to view a step-by-step visual output of each test, runnpm run test:e2e:ui
.