Web Analytics

karpov-gateway

⭐ 153 stars Spanish by MiChongs

Karpov Gateway

Pasarela API integrada + consola. Backend en Go (Gin + gRPC) + frontend en Next.js (App Router + shadcn/ui), con pool de credenciales, verificación por correo, OAuth2 SSO de Linux.do, facturación por cuota, y autenticación de dos factores TOTP.

Licencia: MIT Go Next.js

✨ Características

🏗 Estructura del repositorio

karpov-gateway/
├── gateway/             # Go 后端 (Gin + gRPC)
│   ├── cmd/             # 各 service 入口 (gateway/auth/music/pool/...)
│   ├── internal/        # 业务实现 (private)
│   ├── api/             # protobuf 定义
│   ├── migrations/      # PostgreSQL schema
│   ├── go.mod           # Go 模块 (go 1.24+)
│   └── Dockerfile
├── web/                 # Next.js 16 前端控制台
│   ├── src/             # App Router pages + components
│   ├── middleware.ts    # CSRF / session / CSP nonce
│   ├── package.json     # pnpm workspace
│   └── Dockerfile
├── deploy/
│   ├── compose/         # 本地开发 (PG + Redis + pgAdmin)
│   └── compose-prod/    # 生产单机 (gateway + web + PG + Redis 全栈)
└── .github/workflows/   # GitHub Actions CI (lint / test / build / govulncheck / gosec)

🚀 Inicio Rápido

1. Requisitos Previos

| Herramienta | Versión | | ----------- | ------- | | Go | 1.24+ | | Node.js | 20.11+ | | pnpm | 9+ | | Docker | 24+ | | PostgreSQL | 14+ | | Redis | 7+ |

2. Iniciar Dependencias (Postgres + Redis + pgAdmin)

cd deploy/compose
cp .env.example .env       # 改强密码!
docker compose up -d

3. Iniciar el backend de Gateway

cd gateway
cp .env.example .env       # 与 deploy/compose/.env 的 PG/Redis 密码保持一致
go mod download
go run ./cmd/qqmusic-gateway

默认 :8080 (HTTP) + :9000 (gRPC)

首次启动会在 stderr 打印一个 superadmin 账号 + 临时密码

4. Iniciar la consola web

cd web
cp .env.example .env.local
pnpm install
pnpm dev

http://localhost:3000

🐳 Despliegue de producción (Docker Compose en máquina única)

cd deploy/compose-prod
cp .env.example .env

编辑 .env:填入真域名 / 强密码 / SMTP 凭据 / OAuth client

nano .env

生成 KEK

openssl rand -hex 32 # → 写到 POOL_KEK_HEX=

docker compose up -d --build docker compose logs -f gateway

Notas importantes:

🔐 OAuth2 (Linux.do) Integración

   OAUTH_LINUXDO_ENABLED=true
   OAUTH_LINUXDO_CLIENT_ID=...
   OAUTH_LINUXDO_CLIENT_SECRET=...
   OAUTH_LINUXDO_MIN_TRUST_LEVEL=1
   OAUTH_PUBLIC_BASE=https://your-domain
   OAUTH_FRONTEND_BASE=https://your-domain
   ``
  • Reinicie el gateway, la página de inicio de sesión / página de registro mostrará automáticamente "Linux.do inicio de sesión con un clic"

🧪 Prueba / Lint

bash

Go

cd gateway go vet ./... go test -race ./... golangci-lint run --timeout=5m

Web

cd web pnpm lint pnpm typecheck
`

📦 Dependencias clave

Backend

Frontend

📜 Licencia

MIT — ver LICENSE

🤝 Contribuciones

PR / Issues bienvenidos. Antes de enviar PR por favor:

🔒 Seguridad

Si encuentras problemas de seguridad contacta directamente al mantenedor, no abras un issue público.


Construido con ❤️ por MiChongs

--- Tranlated By Open Ai Tx | Last indexed: 2026-06-04 ---