Tools

This is the tech stack that we are using for the myLocal software initiative.

Backend Code

  • Go

    Go is the backbone of our backend, powering a headless API that serves both our web and mobile applications. We’re starting with a monolithic architecture to keep development agile and efficient, but as traffic scales, we’ll gradually transition to a microservices approach for better modularity and performance. Go’s concurrency model and efficiency make it the perfect choice for building a scalable, high-performance system.

  • Fiber

    Fiber is our high-performance web framework built in Go, inspired by Express.js. It provides a minimalist yet powerful API that makes developing scalable, fast web applications a breeze, ensuring that our services remain efficient and responsive as they grow.

  • GORM

    GORM powers the simple, fast REST routes in our backend, giving us clean, maintainable access to PostgreSQL. It’s lightweight and flexible—perfect for the early modular architecture—while we reserve Ent + GraphQL for more complex, structured routes.

  • Ent

    Ent is our ORM for Go, designed to provide a structured and type-safe way to interact with our database. We use Ent to power our more complex GraphQL routes, where strong schema modeling, automatic migrations, and graph-based querying help us build reliable, maintainable, and scalable data layers—while keeping performance and developer experience top of mind.

  • Llama

    Llama powers myLocal’s site monitoring and discovery engine, analyzing site usage patterns to flag abuse and identifying local businesses to list. By leveraging AI-driven insights, it helps maintain a safe, high-quality platform while expanding the local business network.

  • Kafka

    Kafka will be used in myLocal once our data volume scales to justify event-driven messaging and real-time data streaming. It will enable scalable, decoupled communication between services, ensuring smooth performance as traffic grows.

Frontend Code

  • Next.js

    Next.js is the foundation of our front-end, providing a powerful React framework that enables server-side rendering and static site generation. It allows us to build a fast, scalable, and SEO-friendly web application while keeping development efficient.

  • Relay

    Relay is our data-fetching library for managing GraphQL in the front end, ensuring highly efficient and declarative data loading. It optimizes performance with automatic caching, batching, and pagination, reducing unnecessary network requests and improving responsiveness. By using Relay with myLocal, we ensure a scalable, type-safe, and predictable way to handle complex data interactions.

  • Tailwind

    Tailwind CSS is our styling framework of choice, enabling us to build a modern, responsive UI with utility-first classes. It keeps our styles consistent, scalable, and easy to maintain while allowing for rapid development without writing custom CSS. By leveraging Tailwind’s flexibility and efficiency, we ensure that myLocal has a clean, polished design that adapts seamlessly across devices.

Mobile Code

  • React Native

    React Native, written in TypeScript, powers the mylo mobile app, enabling fast, cross-platform development for iOS and Android. Its efficient, declarative approach ensures a scalable, high-performance user experience.

  • Expo

    Expo is our mobile development platform, providing a seamless workflow for building, deploying, and testing React Native apps. It accelerates development with a rich set of tools, libraries, and services, ensuring that myLocal’s mobile app is feature-rich, performant, and user-friendly.

  • Relay

    We use Relay on mobile the same way we use it on the web, ensuring a consistent and efficient data-fetching experience across platforms.

  • NativeWind

    NativeWind is our utility-first styling library for React Native, inspired by Tailwind CSS. It allows us to build a consistent, responsive UI with minimal effort, ensuring that our mobile app looks great and performs well on all devices.

  • Zustand

    Zustand is our state management library for React, providing a simple and efficient way to manage global state in our mobile app. It enables us to share data across components, keep our app responsive, and maintain a clean, scalable codebase.

Storage

  • PostgreSQL

    PostgreSQL is our relational database of choice, providing a robust and scalable solution for storing structured data. It ensures data integrity, ACID compliance, and powerful querying capabilities, making it the perfect fit for our transactional needs.

  • PostGIS

    PostGIS extends PostgreSQL with powerful geospatial capabilities, allowing myLocal to efficiently store, query, and analyze location-based data. We use it to manage business locations, delivery areas, and geographic search features, ensuring accurate and high-performance spatial queries. By leveraging PostGIS, we provide fast, scalable, and precise geospatial data handling, enhancing location-based services within myLocal.

  • Redis

    Redis is our in-memory data store for caching and session management, enabling fast and efficient data access. It helps us reduce database load, speed up response times, and scale our services by storing frequently accessed data in memory.

  • S3

    Amazon S3 is our cloud storage solution, offering scalable, secure, and highly available object storage for myLocal. It allows us to store and retrieve data at any scale, ensuring durability and low latency for our assets. By using S3, we can efficiently manage our content, reduce operational overhead, and deliver a seamless user experience.

  • R2

    Cloudflare R2 is our cache asset storage solution, providing low-latency, cost-efficient object storage without egress fees. We use R2 to store and serve cached assets, ensuring fast delivery and reduced load on our primary infrastructure. By leveraging R2’s distributed edge network, we optimize performance, improve page load speeds, and keep operational costs minimal while maintaining a seamless user experience.

Deployment

  • GitHub

    GitHub is our version control and CI/CD platform, enabling seamless collaboration and efficient development for myLocal. We follow the GitHub Flow branching pattern, using feature branches, pull requests, and code reviews to ensure a smooth and structured development process.

  • Actions

    With GitHub Actions, we automate testing, deployments, and code quality checks, streamlining our DevOps pipeline and accelerating feature releases. By leveraging GitHub’s powerful ecosystem, we maintain a robust, secure, and efficient workflow that keeps our codebase clean, scalable, and always deployment-ready.

  • Docker

    Docker Containers power our consistent and scalable development environment, ensuring that myLocal runs smoothly across different systems. For local development, we use Docker Compose to define and manage our multi-container setup, making it easy to spin up the database, backend, and other services with a single command. This allows developers to work in a replicable, hassle-free environment, reducing setup time and ensuring consistency across teams.

  • Kubernetes

    Kubernetes powers myLocal’s scalable, resilient infrastructure, automating deployment, scaling, and management of our containerized services. With load balancing, rolling updates, and self-healing, it ensures high availability and smooth performance.

Services

  • Vision

    Google Vision powers our AI-driven image analysis, enabling myLocal to extract meaningful data from images with OCR, object detection, and label recognition. We use it to analyze product lists, customers lists, and menu images, making it easier for businesses to digitize and manage their offerings.

  • Maps

    Google Maps API is our location intelligence solution, enabling myLocal to provide accurate mapping, geolocation, and place search functionality. We use it to help users discover local businesses, navigate to storefronts, and optimize delivery routes with ease. By leveraging Google Maps' powerful geospatial data and seamless integration, we enhance the user experience while ensuring businesses are easily found by their customers.

  • SendGrid

    SendGrid is our email delivery service, ensuring reliable and scalable transactional and marketing email communication for myLocal. We use it to send order confirmations, customer notifications, and business updates with high deliverability and detailed analytics. By leveraging SendGrid’s API-driven approach and templating system, we provide a seamless, automated email experience that keeps customers and businesses connected.