The GDS Way
The GDS Way guides teams to build and operate brilliant, cost-effective digital services.
It documents the specific technology, tools and processes that Government Digital Service (GDS) teams use.
It’s not intended as guidance for anyone working outside GDS (though some other Cabinet Office teams use it too) - you’ll find that in the Service Manual.
About The GDS Way
The GDS Way shares agreed ways of working so service teams benefit from:
- using similar tools
- central procurement
- costs savings as new teams will be cheaper to spin up
The GDS Way makes it easier for projects to get started while still giving teams flexibility to do something different if their project needs it.
The GDS Way includes consistent:
- terminology
- ways of working
- technology and tools
- measures
All decisions are made in alignment with Service Manual, which covers service design more broadly, and the Technology Code of Practice.
Products at GDS in discovery or alpha development phases must follow agile delivery principles and also have the option to follow the standards in this repository.
Products in beta and live phases must follow both the instructions set out in the Service Manual and the standards in this repository. They must be secure by design.
How to add new guidance
Contribute to this repository by making a pull request in GitHub for discussion at the GDS Way Forum.
You can also read the service manual to find out about learning about and writing user needs.
Thank you for your contributions as we develop this repository.
Submission template
When you create a new Markdown file follow this pattern and then make a pull request:
---
title: Thing you're writing a standard about
last_reviewed_on: yyyy-mm-dd
review_in: 6 months
---
# <%= current_page.data.title %>
Introduction of a couple of paragraphs to explain why the thing you're
writing a standard about is important.
## User needs
Why do we do this thing? Who is it helping?
## Principles
What broad approaches do we follow when we do this thing?
## Tools
What specific bits of software (commercial or open source) do
we use to help us do this thing?
The GDS Way Forum
This site documents some of the decisions agreed at the GDS Way Forum about the products we operate.
The GDS Forum meets once a month. The Forum is lead developers and technical architects representing GDS programmes who are responsible for communicating and implementing the GDS Way.
The Forum reviews:
- all GDS Way open and closed PRs
- expired guidance and if it should be continued
- possible subject areas and ownership of new content
Contact The GDS Way Forum
Contact the GDS Way Forum using the #gds-way Slack channel or by email at the-gds-way@digital.cabinet-office.gov.uk.
Software development
- How to name software products
- Choosing a programming language
- Style guides
- How to manage third party software dependencies
- Building accessible services
- Pair programming
- Test-driven Development (TDD)
- Breaking down work
- Supporting different browsers
- How to optimise frontend performance
- Documenting architecture decisions
- Diagrams as code
- Anticipate security issues using threat modelling
Version control and deployments
- How to store source code
- Using Pull Requests
- Writing READMEs
- Writing release notes
- Licensing
- Use continuous delivery
Hosting and infrastructure
- How to host a service
- How to manage DNS records for your service
- Use configuration management
- Operating systems for virtual machines
- Use a web application firewall (WAF)
- Security overview for websites
- Tagging AWS resources
- Working with AWS accounts
Logging, monitoring and alerting
- Store and query logs
- How to monitor your service
- How to manage alerts
- Make data-driven decisions with Service Level Objectives (SLOs)
- Run a Service Level Indicator (SLI) workshop
Operating a service
- Understand the risks to your service
- How to track technical debt
- How to manage access to your third-party service accounts
- How to store credentials
- How to do penetration testing
- Performance testing
- How to send email notifications
- How GDS provides user support
- Incident management
- Disaster Recovery
- Principle of least privilege
- Tracking access control
- Secret auditing
- Vulnerability disclosure and security.txt