"If a worker wants to do his job well, he must first sharpen his tools." - Confucius, "The Analects of Confucius. Lu Linggong"
Front page > Programming > Laravel to Go: My Journey and the Creation of a Fiber API Boilerplate

Laravel to Go: My Journey and the Creation of a Fiber API Boilerplate

Posted on 2025-03-12
Browse:246

Laravel to Go: My Journey and the Creation of a Fiber API Boilerplate

After spending more than four years immersed in Laravel, I’ve become very familiar with the MVC (Model-View-Controller) architecture. Its simplicity and structure make it a joy to work with, and Laravel’s thoughtfully organized folders help developers stay on track. You always know where to place your code, and the extensive built-in tools—database connections, Redis, queues, migrations, ORM, and more—make setup seamless. With just a few tweaks to your environment, your app is ready to go.

For me, Laravel’s MVC approach remains one of the most robust. The Model defines your data, the View determines what users see, and the Controller manages your business logic. It’s simple yet structured, and Laravel delivers this setup by default, making it an excellent framework for development.

But as my career advanced and I worked across industries and businesses, I realized that Laravel’s MVC approach wasn’t always enough, especially for complex applications.


Extending Laravel’s MVC for Complexity

MVC shines for simple applications but can fall short when logic becomes more intricate. For instance, when using Laravel for APIs, the View layer often goes unused. Meanwhile, putting all the logic in controllers can quickly lead to bloated files that are hard to maintain.

To address this, I extended Laravel’s MVC structure by introducing Service and Repository layers, creating a flow like this:

Controller → Service → Repository → Model

  • Controller: Handles validation and directs the application flow.
  • Service: Manages business logic, broken into reusable functions.
  • Repository: Manages database interactions.
  • Model: Defines the data structure.

This layered approach makes the code more maintainable and scalable. Over time, I became so accustomed to this structure that it felt natural to adopt it in other projects.


Enter Go: A Whole New Challenge

When I started working with Go (Golang), it felt like stepping into uncharted territory. Go is quite different from PHP and lacks an inherent folder structure. It’s also not an object-oriented language, so I couldn’t simply replicate what I knew from Laravel.

After some trial and error, I decided to stick with what I was familiar with: the CSRM concept (Controller, Service, Repository, Model). I adapted this structure to Go, even though it required some creative thinking. Additionally, I explored frameworks that could simplify development. I tried Gin and Fiber, ultimately choosing Fiber for its speed, modern features, and active community.


The Birth of My Fiber API Boilerplate

After more than two years of working with Go and Fiber, I decided to create a boilerplate to streamline API development. This wasn’t just for me—I wanted to help others quickly set up their projects too.

The result: Fiber API Boilerplate.

This boilerplate is specifically for APIs, so it doesn’t include features like view rendering or template engines. The folder structure takes inspiration from:

  • Golang Project Layout Standards
  • Ayoub Zulfiqar’s Project Layout Gist

I also borrowed many ideas from Laravel, such as ORM, database connections, Redis, queues, and authentication. While it’s not as comprehensive as Laravel, it’s more than sufficient for building general APIs.


Features of the Boilerplate

Here’s what the boilerplate currently offers:

  1. Authentication: Simplified user management out of the box.
  2. Error Reporting: Integrated with Sentry.
  3. Application Monitoring: Uses New Relic for real-time insights.
  4. Hot Reload: Includes Air for faster development.
  5. Static Code Checks: Uses GolangCI-Lint.
  6. API Documentation: Built-in Swagger support via Swag.
  7. Dependency Injection: Powered by Google Wire.
  8. Deployment: Comes with Docker and Supervisor for seamless deployment.

The repository also includes example code and a detailed README to guide you through each folder and feature.


Building for the Future

While the boilerplate is already functional, I have plans to expand it further by adding tools like migrations, event listeners, and commands. It’s an evolving project designed to grow with its users.

You’re welcome to explore and use the boilerplate. Feel free to customize it—add tools you like or remove ones you don’t need. If you have suggestions or feature requests, create an issue or submit a pull request.


Get Started

Check out the Fiber API Boilerplate and take it for a spin. I hope it helps simplify your Go API development journey as much as it has for me. Let’s build something amazing together!

Release Statement This article is reproduced at: https://dev.to/granitebps/laravel-to-go-my-journey-and-the-creation-of-a-fiber-api-boilerplate-2pll?1 If there is any infringement, please contact [email protected] to delete it.
Latest tutorial More>

Disclaimer: All resources provided are partly from the Internet. If there is any infringement of your copyright or other rights and interests, please explain the detailed reasons and provide proof of copyright or rights and interests and then send it to the email: [email protected] We will handle it for you as soon as possible.

Copyright© 2022 湘ICP备2022001581号-3