Sobes.tech
Назад к вопросам
Junior — Middle
78

Можете описать свой опыт применения паттерна Chain of Responsibility в реальных проектах?

Компании, где спрашивали
Zonatelecom

Ответ от нейросети

sobes.tech AI

В одном из проектов на Go я использовал паттерн Chain of Responsibility для обработки HTTP-запросов с разными уровнями валидации и авторизации. Каждый обработчик в цепочке проверял определённое условие — например, валидность токена, права доступа, формат данных — и либо обрабатывал запрос, либо передавал дальше по цепочке. Это позволило гибко добавлять новые проверки без изменения существующего кода и улучшило читаемость.

Пример упрощённой реализации:

package main
import "fmt"

type Handler interface {
    SetNext(handler Handler)
    Handle(request string)
}

type BaseHandler struct {
    next Handler
}

func (b *BaseHandler) SetNext(handler Handler) {
    b.next = handler
}

func (b *BaseHandler) Handle(request string) {
    if b.next != nil {
        b.next.Handle(request)
    }
}

type AuthHandler struct { BaseHandler }

func (h *AuthHandler) Handle(request string) {
    if request == "valid_token" {
        fmt.Println("Auth passed")
        h.BaseHandler.Handle(request)
    } else {
        fmt.Println("Auth failed")
    }
}

func main() {
    auth := &AuthHandler{}
    auth.SetNext(&BaseHandler{})

    auth.Handle("valid_token")  // Auth passed
    auth.Handle("invalid")      // Auth failed
}

Такой подход помогает разделить ответственность и упростить поддержку.