A staff service for reviewing social visit requests to visit a prisoner in England or Wales.
Production application can be found at https://staff.prisonvisits.service.justice.gov.uk accessed via DPS.
This is a Ruby on Rails application that has two main roles. It exposes:
- A public interface for staff to manage prison visit bookings.
- An API for booking prison visits. The consumer of this API is ministryofjustice/prison-visits-public.
This is a full rewrite from the ground up, using a database instead of serialised data in URLs in emails. The CSS and JavaScript has largely been ported intact from the previous application.
The source of the predecessor can be found at ministryofjustice/prison-visits.
- ministryofjustice/prison-visits-public - this a separate Ruby on Rails application that contains the public interface for booking a prison visit.
- If on a Mac install Xcode from the App Store
- HMPPS Auth - for logging into the bookings management interface.
- Sidekiq - for background processing.
- Redis - for managing queues (required by Sidekiq)
- Postgres - for persisting data
- direnv - for managing environment variables and storing credentials.
- NOMIS API access - prison and offender data is accessed via the National Offender Management Information System. An authentication token is required to access this.
- (Optional) Transifex Client - for managing site translation. See additional documentation for setup and updating translations.
This application uses Ruby v3.2.2. Use RVM or similar to manage your ruby environment and sets of dependencies.
Note - You will need to spin up both ministryofjustice/prison-visits-2 and ministryofjustice/prison-visits-public
-
Install gems (dependencies) locally. To do this you will need to first install Bundler
-
Install packages with [yarn] https://classic.yarnpkg.com/lang/en/docs/install/#mac-stable
-
Install the
direnv
packagepvb2 $ brew install direnv
-
Enable direnv for you shell
Add the following line at the end of the
~/.bashrc
file:eval "$(direnv hook bash)"
Make sure it appears even after rvm, git-prompt and other shell extensions that manipulate the prompt.
Add the following line at the end of the
~/.zshrc
file:eval "$(direnv hook zsh)"
Add the following line at the end of the
~/.config/fish/config.fish
file:direnv hook fish | source
-
Create a .env file in the root of the folder and add any necessary environment variables. Load your environment variables into your current session ...
pvb2 $ direnv allow .
-
Install Postgres
pvb2 $ brew install postgres
-
Install Redis
pvb2 $ brew install redis
-
In separate terminal windows spin up ministryofjustice/prison-visits-2 and Sidekiq. The latter processes jobs in the background. Make sure you have the necessary environment variables declared to run Sidekiq. See additional documentation on queues.
pvb2 $ bundle exec sidekiq pvb2 $ rails server
-
In another terminal window spin up ministryofjustice/prison-visits-public on port 4000
pvb-public $ rails server -p 4000
-
Set up database and seed with prison data
pvb2 $ rake db:setup
-
Seed database with visits data
pvb2 $ rake pvb:populate:visits
pvb2 $ rails spec
More information can be found in the GitHub Wiki.