go-fiber

$npx mdskill add TerminalSkills/skills/go-fiber

Build high-performance APIs with Fiber, an Express-inspired Go web framework

  • Solve the need for fast, scalable web services in Go with minimal boilerplate
  • Uses Fiber and Fasthttp for routing, middleware, and high-performance networking
  • Leverages familiar Express-style syntax with Go's concurrency and performance
  • Delivers results through optimized HTTP responses and built-in middleware support

SKILL.md

.github/skills/go-fiberView on GitHub ↗
---
name: go-fiber
description: >-
  You are an expert in Fiber, the Express.js-inspired web framework for Go
  built on top of Fasthttp. You help developers build high-performance APIs
  and web services using Fiber's familiar routing, middleware system, template
  rendering, WebSocket support, and zero-allocation design — achieving
  top-tier performance while maintaining the developer experience Go
  developers love from Express/Koa in Node.js.
license: Apache-2.0
compatibility: ''
metadata:
  author: terminal-skills
  version: 1.0.0
  category: Backend Development
  tags:
    - go
    - web-framework
    - fast
    - express-inspired
    - api
    - middleware
---

# Fiber — Express-Inspired Go Web Framework

You are an expert in Fiber, the Express.js-inspired web framework for Go built on top of Fasthttp. You help developers build high-performance APIs and web services using Fiber's familiar routing, middleware system, template rendering, WebSocket support, and zero-allocation design — achieving top-tier performance while maintaining the developer experience Go developers love from Express/Koa in Node.js.

## Core Capabilities

### Application Setup

```go
// main.go — Fiber API server
package main

import (
    "log"
    "github.com/gofiber/fiber/v2"
    "github.com/gofiber/fiber/v2/middleware/cors"
    "github.com/gofiber/fiber/v2/middleware/logger"
    "github.com/gofiber/fiber/v2/middleware/recover"
    "github.com/gofiber/fiber/v2/middleware/limiter"
)

func main() {
    app := fiber.New(fiber.Config{
        ErrorHandler: customErrorHandler,
        BodyLimit:    4 * 1024 * 1024,    // 4MB
    })

    // Middleware
    app.Use(recover.New())
    app.Use(logger.New())
    app.Use(cors.New())
    app.Use(limiter.New(limiter.Config{
        Max:        100,
        Expiration: 60,                   // 100 requests per minute
    }))

    // Routes
    api := app.Group("/api/v1")
    api.Get("/users", listUsers)
    api.Get("/users/:id", getUser)
    api.Post("/users", createUser)
    api.Put("/users/:id", updateUser)
    api.Delete("/users/:id", deleteUser)

    // Health check
    app.Get("/health", func(c *fiber.Ctx) error {
        return c.JSON(fiber.Map{"status": "ok"})
    })

    log.Fatal(app.Listen(":3000"))
}
```

### Handlers

```go
type User struct {
    ID        uint   `json:"id" gorm:"primaryKey"`
    Name      string `json:"name" validate:"required,min=2"`
    Email     string `json:"email" validate:"required,email"`
    CreatedAt time.Time `json:"created_at"`
}

type CreateUserRequest struct {
    Name  string `json:"name" validate:"required,min=2,max=100"`
    Email string `json:"email" validate:"required,email"`
}

func createUser(c *fiber.Ctx) error {
    var req CreateUserRequest
    if err := c.BodyParser(&req); err != nil {
        return c.Status(400).JSON(fiber.Map{"error": "Invalid request body"})
    }

    // Validate
    if errors := validate.Struct(req); errors != nil {
        return c.Status(422).JSON(fiber.Map{"errors": formatErrors(errors)})
    }

    user := User{Name: req.Name, Email: req.Email}
    if result := db.Create(&user); result.Error != nil {
        return c.Status(500).JSON(fiber.Map{"error": "Failed to create user"})
    }

    return c.Status(201).JSON(user)
}

func getUser(c *fiber.Ctx) error {
    id := c.Params("id")                  // Path parameter
    var user User
    if result := db.First(&user, id); result.Error != nil {
        return c.Status(404).JSON(fiber.Map{"error": "User not found"})
    }
    return c.JSON(user)
}

func listUsers(c *fiber.Ctx) error {
    page := c.QueryInt("page", 1)         // Query parameter with default
    perPage := c.QueryInt("per_page", 20)
    
    var users []User
    var total int64
    db.Model(&User{}).Count(&total)
    db.Offset((page - 1) * perPage).Limit(perPage).Find(&users)
    
    return c.JSON(fiber.Map{
        "data":  users,
        "total": total,
        "page":  page,
    })
}
```

### Middleware

```go
// Custom auth middleware
func authMiddleware(c *fiber.Ctx) error {
    token := c.Get("Authorization")
    if token == "" {
        return c.Status(401).JSON(fiber.Map{"error": "Missing token"})
    }

    claims, err := validateJWT(strings.TrimPrefix(token, "Bearer "))
    if err != nil {
        return c.Status(401).JSON(fiber.Map{"error": "Invalid token"})
    }

    c.Locals("user_id", claims.UserID)    // Store in request context
    return c.Next()                        // Continue to handler
}

// Apply to group
protected := app.Group("/api/v1", authMiddleware)
protected.Get("/profile", getProfile)
protected.Put("/profile", updateProfile)
```

## Installation

```bash
go mod init myapp
go get github.com/gofiber/fiber/v2
```

## Best Practices

1. **Familiar API** — Fiber mirrors Express.js patterns; `c.Params()`, `c.Query()`, `c.JSON()`, `c.Next()`
2. **Built-in middleware** — CORS, rate limiter, logger, recover, compress, cache — all included
3. **Fasthttp engine** — Built on Fasthttp (not net/http); zero-allocation, 10x faster than standard library
4. **Group routes** — Use `app.Group()` for versioned APIs and middleware scoping
5. **Error handling** — Use custom `ErrorHandler` in config; return `fiber.NewError(status, message)` from handlers
6. **Locals for context** — Use `c.Locals()` to pass data between middleware and handlers (auth user, request ID)
7. **Prefork for production** — Enable `Prefork: true` in config to spawn worker processes per CPU core
8. **Graceful shutdown** — Use `app.ShutdownWithTimeout()` with signal handling; drains active connections

More from TerminalSkills/skills