This repository contains the project overview, technical documentation and architecture diagrams of MyHearty. The documentation serves as a permanent record for the project implementaton.
MyHearty is a one-stop, centralized charity website for people to fundraise, donate, volunteer and apply for aids. The motivation behind this project stems from the idea of integrating fundraising, donation, volunteering and aiding functions into a single platform with API access. This project aims to connect various parties that are involved in charity via a centralized platform and provide open charity data via an API.
Term | Description |
---|---|
Charitable Aid | Refers to any charitable giving that are given to people in need. For example, food aid, educational kits for needy students, scholarships and financial assistance. |
API | Application Programming Interface |
CSR | Client-Side Rendering |
FPX | Financial Process Exchange, a Malaysia-based payment method that allows customers to complete transactions online using their bank credentials. |
KYC | Know Your Customer, a set of standards used within the financial services industry to verify customers, their risk profiles, and financial profile. |
SSR | Server-Side Rendering |
VPS | Virtual Private Server |
Figure 1 shows a big picture overview of MyHearty. The proposed solution consists of 3 parts: MyHearty website, MyHearty dashboard and MyHearty API server. There are 6 types of users involved, which are charities, organizations, donors, volunteers, receivers and third-party developers.
Figure 1: Big picture overview of MyHearty |
Via MyHearty dashboard, both charities and organizations can create volunteer event and aid pages. However, only charities can create fundraising campaigns pages to accept donations from the public. For MyHearty website, donors can donate for a fundraising campaign, volunteers can register for volunteer events and receivers can apply for available charitable aids. Both the dashboard and the website are powered by MyHearty API that serves JSON responses to the frontend API clients. The API server also allows third-party developers to access charity data, thus opening up chances for developers to build custom integrations into their platforms. Besides, Stripe will be used as the payment processor for donations made on MyHearty website.
Figure 2 shows the high-level architecture diagram of MyHearty. The high-level architecture diagram consists of 3 parts: the frontend app, the backend services and the payment processor. The frontend apps are deployed as Next.js apps on Vercel to leverage the framework’s CSR and SSR features and also Vercel’s global edge network.
Figure 2: High-level architecture diagram |
For the backend, all services are deployed as multi-container Docker applications via Docker Compose on the Exabytes VPS. There are 4 backend components: NGINX web server, Rails API server, PostgreSQL database and Typesense search engine. The NGINX web server acts as a reverse proxy server that directs client requests to the appropriate backend services based on the API URL paths, which, in this case, refer to the Rails API server and the Typesense search engine. The Rails API server is responsible for hosting MyHearty API that handles requests from the Next.js apps. It communicates with the PostgreSQL database for access and retrieval of the app data. The Typesense search engine is used to offer typo-tolerant instant search for resources hosted on MyHearty, which include fundraising campaigns, volunteer events and charitable aids. The API server will index the resources into Typesense collections every time a new resource is published or updated on MyHearty.
Stripe is used as the payment processor for donations made on MyHearty. There are 2 services involved: Stripe Connect and Stripe Checkout. Stripe Connect is used to onboard organizations that want to publish fundraising campaigns on MyHearty by collecting their business information, which include business name, location and bank account information. This avoids the need for MyHearty to store sensitive data that often require strict data compliance process. Besides, Stripe Checkout provides a hosted payment page that can be customized to securely accept online payments from donors. It supports credit card, debit card, FPX and some digital wallet payments.
Figure 3 shows the detailed breakdown of the high-level architecture diagram. In the detailed-level architecture diagram, each dedicated component is decomposed into a set of subcomponents.
Figure 3: Detailed-level architecture diagram |
For the frontend, there are 2 Next.js apps: MyHearty website and MyHearty dashboard. MyHearty web app will be used by donors, volunteers and receivers that would like to search for fundraising campaigns, volunteer events or charitable aids. On the other hand, MyHearty dashboard will be used by charities and organizations to create fundraising campaigns, volunteer events or charitable aid pages.
For the Rails API server, there are 9 main components: Personal Account, Donation, Volunteering, Aid Receival, Charity and Organization Account, Fundraising Management, Volunteer Event Management, Aid Management, and API Access.
- Personal Account component: users can sign up and log into their accounts on MyHearty website.
- Donation component: users can perform online donation payments and view their donation records.
- Volunteering component: users can submit registrations for volunteer events and view their volunteering records after participating in the volunteer events.
- Aid receival component: users can submit applications for available charitable aids and view their aid receival records.
- Charity and Organization Account component: charities and organizations can sign up and log into their accounts on MyHearty dashboard. They also can create member accounts to allow other members to manage the published pages.
- Fundraising Management component: charities can publish their fundraising campaign pages and view the fundraising data.
- Volunteer Event Management component: organizations can publish their volunteer event pages and manage the volunteer applications.
- Aid Management component: organizations can publish their charitable aid pages and manage the charitable aid applications.
- API Access component: developers can create their developer accounts and API keys to access MyHearty API for obtaining data related to fundraising campaigns, volunteer events or charitable aids.
The PostgreSQL database is responsible for storing and retrieving MyHearty app data. For Stripe payment processor, Stripe Checkout is used to host payment pages and provide webhooks to notify MyHearty whether the payment has been successfully processed, whereas Stripe Connect is used to perform KYC onboarding for charities and organizations and is responsible for distributing donation payouts to their bank accounts on a weekly basis. There are 2 components under the Typesense search engine: indexing component, which is responsible for indexing MyHearty resources into Typesense, and searching component, which offers different types of search experiences, such as instant search, geosearch and similarity search, to MyHearty website users.
Figure 4 shows the database diagram of MyHearty. There are 10 main tables in MyHearty. Each table is colour-coded according to its corresponding functionality: blue refers to the user, organization and member account-related classes, red refers to the fundraising campaign-related classes, yellow refers to the volunteer event-related classes, and green refers to the charitable aid-related classes.
Figure 4: Database diagram |
- The organization class has a one-to-many relationship with the member, fundraising campaign, volunteer event and charitable aid classes.
- The fundraising campaign class has a one-to-many connection with the donation and payment classes.
- The volunteer event class has a one-to-many connection with the volunteer application class.
- The charitable aid class has a one-to-many connection with the charitable aid application class.
- Correspondingly, the user class has a one-to-many connection with the donation, payment, volunteer application and charitable aid application classes.
Refer to the MyHearty database schema for the full database implementation.