- O'Reilly Architectural Katas - Fall 2022 - HeyBlue
We are a tribe of guys who are enthusiastic about solving complex problems with technology applied vith criteria in a sustainable way.
Our name is Ingenials, becouse we work together for Ingenia, a consulting firm focused on allowing our customers to strategically and tactically leverage their business with technology.
- API: Application Program Interface.
- Charity: Organizations aimed to improve the world each day. In general, non profit organizations. e.g. Greenpeace, WWF, Operation Smile, UNICEF.
- Civilian: Member of the community that wants to connect to police officers, get points and redem them for products and services, or donate them to a charity organization or a family in needs.
- Constraint: Represents a factor that limits the realization of goals.
- Driver: Represents an external or internal condition that motivates an organization to define its goals and implement the changes necessary to achieve them
- Family in needs: Members of a community able to receive points as a donation, to after redem them for products and services.
- Goal: Represents a high-level statement of intent, direction, or desired end state for an organization and its stakeholders.
- IRS: Internal Revenue Service.
- Police Officer: Member of a community that can accept connection with a civilian, obtain points and donate them to a charity organization.
- Retail: Members of a community providing product and services that can be redem for hey blue points.
The Hey, Blue! initiative facilitates moments of meaningful connection between police officers and members of their community by offering intentional opportunities for individuals to meet and share positive experiences.
Inspired by the extraordinary acts of heroism displayed by both individual community members and first responders during 9/11, EcoSchool co-founder, John Verdi, wanted to build a platform that could bring police officers and communities together with a shared purpose. Connection-driven projects like Preschool Storytime and Selfies For Change are just the start of a larger movement designed to create an awareness of our shared humanity.
You can find additional information about HeyBlue and Verdie School in heyBlue and Verdie School Nonprofit
The figure 1 - Motivation shows the vision of HeyBlue, its functional requirements and how them relate or influence each other.
Below is a description of each one of them.
- DR01. Hey Blue is motivated for the reinforcement of a shared purpouse between community and police officers.
- DR02. Hey Blue want to create a common awareness of our shared community.
- GO01. Enforce positive relationship between police officers and civilians
- GO02. Actively support to non-profit organizations
- GO03. Reinforce a stronger community interaction
The table below describe the High level use cases, and the relationship with the goals described above.
UC ID | Description | Related Goals |
---|---|---|
UC01 | As hey blue administrator I want to get reports and analytics of the application activity | GO01, GO03 |
UC02 | As hey blue administrator I want to share aggregated tracking data with local media outlets, automatically | GO01, GO02, GO03 |
UC03 | As a local media outlet I want to subscribe to get access to aggregated data | GO03 |
UC04 | As a User I want to connect to another users | GO03 |
UC05 | As a user I want to share information about my profile in social media | GO01, GO03 |
UC06 | As HeyBlue Admin I want the app to track the location of the users | GO03 |
UC07 | As a user I want to connect to my social media profile | GO03 |
UC08 | As a user i want to opt-in and out of push notifications | GO01 |
UC09 | As a civilian I want to find retail stablishments to redeem my points | GO03 |
UC10 | As an officer I want to find charities where I can gift the points | GO02 |
UC11 | As a business/charity I want to create a storefront to encourage users to redeem or donate their points | GO01, GO02 |
UC12 | As a Business I want to manage the catalog of products and the point value assigned to them | GO03 |
UC13 | As a municipality I want to allow civilians to redeem the points to pay fines or fees | GO03 |
UC14 | As a user I want to receive positive reinforcement through intrinsec reward system based on my activity | GO01, GO03 |
UC15 | As heyblue admin I want to track how the points were used for each user | GO01, GO03 |
UC16 | As an officer or community member I want to connect with each other using QR Codes | GO03 |
UC17 | As a community member I want to see how many connections each participating officer has made | GO01, GO03 |
UC18 | As heyBlue Admin I want to know the users zip codes to share revenues with community in the user area | GO03 |
UC19 | As a civilian I want to say hi to a police officer to gain points | GO01 |
UC20 | As a HeyBlue Admin I want to ensure the employee experience, including recruiting, upskilling and lifecycle | |
UC21 | As an investor I want to get information about the financial and accounting statements of the company | |
UC22 | As HeyBlue Admin I want to control the financial performance | |
UC23 | As IT responsible of HeyBlue I want best practices and tools to ensure an efficient IT Value delivery | |
UC24 | As HeyBlue Admin I want to control and manage the risks, mainly the fraud related risks |
The figure 2 shows the Constraints detected for Hey Blue.
Below, it will describe each one of them.
- CONS.01 - The cost should be as little as possible. HeyBlue is a non-profit company. The use of resources should be wisely defined. Choose the cheapest alternative if it is possible.
- CONS.02 - Application should be mobile and web
- CONS.03 - The solution should be limited to USA cities (by Zip Codes)
- CONS.04 - The officer location feature must be implemented in a way that ensure the officer confidence on its privacy, non disclosure and safety.
- CONS.05 - There is no restriction about technology
- CONS.06 - Define a solution that evolve with a team
- CONS.07 - Compliance with GDPR
- CONS.08 - Solution should be launched on september 11, 2023
The figure 3. shows the Quality Attributes (A.K.A. Architecture Characteristics) identified for Hey Blue.
The following sections describe each architecture characteristics:
- Usability Characteristics
- Security Characteristics
- Confidence Characteristics
- Stability Characteristics
- Modifiability Characteristics
- Scalability Characteristics
- Performance Characteristics
- IRS give information through API or file sharing. that let know when an organization is a charity organization.
- A state department inform, through API or file sharing, what are the family in needs.
- A family in need can redeem their points but can't donate them.
- Due to its user characteristics, retails can only use Web channel.
- Hey Blue will hire employees or contractors to support its operation.
- If Hey Blue obtain financing from investors, they want to know the performance of the organization.
- Hey Blue will have a minimal IT team to maintain the application, supported by automated tools.
- Hey Blue need to avoid risks associated with the business operation.
- In a future, will be needed to integrate with additional social networks.
- Mentor and mentee feature will be out of scope of the first version of Hey Blue, and must be implemented in future iterations.
- There is no restriction about technology
- The solution must be defined to evolve with a team, starting with a simple but useful solution with a small team supporting it.
- Charitable organization and Family in need catalogs will be provided by external third-party services and held in another local component (user catalogs service), so it can be retrieved whenever needed to validate user creation.
- The information for user catalogs will be provided by a certified entity in the US soil (e.g. IRS) so the platform can scrape that information.
An architecture's main objective is the clear communication of the roles and responsibilities of a system, whether it is made up of software applications or other components, which will then guide decision-making to meet the requirements of an organization. The objective of the reference architecture is to define the business responsibilities that cover the needs raised by an organization or part of it, which will then serve to define the solutions (or applications) that will instantiate it. At the same time, it establishes a common language to talk about the applications that are part of solution's architecture to support the processes associated in this case with Hey Blue. The benefits of having a reference architecture are many, among which are:
- Common language.
- Standard and clear application requirements.
- Enable automation.
- Facilitate the selection of COTS (Commercial off the Shelf) solutions.
In the case of Hey Blue, we defined a reference architecture based on the work of the W3 consortium, with a few extensions of our part to cover specific requirements about product, storefront and enterprise needs.
The figure 4 shows the reference architecture for social network, which define the business responsibilities associated with the Hey Blue case.
The following sections will describe each one of the business responsibilities, with views exported from the Archimate and detail the following topics:
- How the Reference Architecture components support the Functional Requirements
- How the Reference Architecture components support the Architecture Characteristics
- How the defined Constraints influence the Reference Architecture Components
Follow each link to get more information about each Reference Architecture meta-functions:
In the sections below, we will describe the business flows identified for Hey Blue, the supporting relationship of conceptual components (defined in the seccion Application Components Collaboration Views), and how the business entities are impacted or support the business processes.
This set of views are extracted from the Archimate model and detail the:
- Main business flows of the architecture
- Main business events derived from the flow and how they connect the different business flows
- Relations between the components
- Conceptual Applications components of the architecture and how they support the business processes
- Main business entities of the architecture
- Access operations on those business entities, to show what process create, update or read them
- Charity Onboarding
- Civilian Onboarding
- Family in need Onboarding
- Municipality Onboarding
- Police Officer Onboarding
- Retail Onboarding
- Charity points redemption
- Civilian / Police Officer Interaction
- Civilian points redemption / Donation
- Family in needs points redemption
- Police Officer points transfer / donation
This view is also extracted from the Archimate model and detail the:
- Main business flows of the architecture
- Main business events derived from the flow and how they connect the different business flows
- Relations between the components
- Main business actors interacting with Hey Blue architecture
- Application coverage that supports the business processes and have direct interaction with them
It is possible to get more information about the logical components in the sections below:
- Onboarding
- User Catalogs
- Scoring
- Tracking
- Store Service
- Content Manager
- Catalog Service
- Business Rules
- Users Domain
- QR Generation
- Data Archiving
- Analytics
- Messaging Layer
- Security Concerns
This views have two different viewpoints, one extracted from draw.io and other also extracted from the Archimate model. Both detail the:
- Main application components of the architecture
- Main technology components of the architecture
- Relations between the components
For a general view, it is presented the figure below (figure 6), a simplified view of the proposed technology components.
It is possible to get more information about the technological aspects of the architecture in the sections below:
- Onboarding
- Users Domain
- Scoring
- Tracking
- Content Manager
- Business Rules
- User Catalogs
- QR Generation
- Data Archiving
- Analytics
- User Channels
Derived from the constraint CONS.01 and CONS.06, it's highly recommended the adoption of agile practices (Like SCRUM or KANBAN) to manage the development, evolution and support of the solution. It will enable Hey Blue to gain speed of delivery value, cost control and increase the quality of the product delivered.
Based on the constraint CONS.02 and the architecture characteristics AC.STA.01, AC.STA.02 and AC.MOD.01 we recommend the adoption of DevSecOps practices, in particular the application of Teams Topologies and adopt the Type 2 DevOps Topology at least at the beginning of the project, and transitate to Type 1 DevOps Topology as needed.
The incident management process is a set of activities that are performed to identify, report, and resolve incidents. The process is designed to minimize the impact of incidents on the business and to restore normal operations as quickly as possible. The process is also designed to identify the root cause of incidents and to prevent recurrence. Recommended to be integrated and automatized with the monitoring and alerting capabilities, in our case, the AWS CloudWatch, tool defined in the ADR: Observability Platform section.
Following the requirements defined by CONS.06, it's strongly recommended to addopt Team Topologies philosophy to define the responsibilities associated with Hey Blue.
In the very beginning, just one Stream Aligned team will be enough to cover the responsibilities needed to deploy the first versions of Hey Blue in an agile way. The image below (figure 7) describe this initial situation:
In this initial team deployment, it's recommended to have the following roles:
- Web Developer, responsible for the development, evolution and support of the web components.
- Mobile Developer, responsible for the development, evolution and support of the web components.
- Backend Developer, responsible for the development, evolution and support of the backend services.
- Product Owner, responsible for the definition and guidance of the business definitions and backlog priorization.
- Architect, responsible of ensure that the development activities are compliants with the architecture definition, enabling a feedback loop as needed.
- Agile Coach, who is in charge of the agile ceremonies that enable team collaboration.
- OPS, in charge of the opperation of the infrastructure, enabling of the developer platform and support for the deployment of changes.
- Quality engineer, responsible for quality assurance.
When the business and platform requirements increase in complexity, it will be possible to add a platform team to support the application lifecycle, or divide the single Strem-aligned team into several, with the following division, for example one Stream-aligned team for Civilian-oriented features, and another Stream-aligned team for non-civilian-oriented features, as shown below (figure 8).
As above figure describes, the roles are the same as in the version 1.0 (but for sure it's needed more people energizing them!). This type of organization enable a team evolve as the platform increase the complexity.
This architecture and the related decisions was based on Archimate, the Open Group Architecture Modelling Language, using the open source tool Archi.
The model was versioned in this repo (folder /model). To connect Archi with this repo and pull the model, you can use the Collaboration plugin for Archi.
Additionally, it's provided an HTML view of the model, in the folder html-model or in Github Pages.
Archimate was chosen because it is the de facto standard on architecture modelling and is very efficient to manage complex and detailed representations of the architecture. In addition, no matter how complex a model is, there is always the possibility to navigate it through the elements and relations or, given that the architecture model is not only a static diagram, it could be analyzed to generate more advanced information as, for example: what if scenarios, impact, heatmap or complexity analysis.
And lastly, the model is an architecture asset that Hey Blue as an organization could evolve over time.
- ADR Infrastructure
- ADR Cloud
- ADR Mobile Technology
- ADR Web Technology
- ADR Backend Runtime
- ADR Backend Architecture Model
- ADR Backend Technology
- ADR Messaging mechanism
- ADR IDP Platform
- ADR Notification mechanism
- ADR Observability platform
- ADR Analytics
- ADR Rule Engine
- ADR Finance and Treasury
- ADR HR
- ADR Code Repository
- ADR Document Management
- ADR Mailing
- ADR CI CD
- ADR API Gateway
- ADR EKS Dataplane Runtime
- ADR Omnichannel BFF