javi-forge 1.2.0 → 1.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (228) hide show
  1. package/ci-local/ci-local.sh +20 -8
  2. package/package.json +1 -1
  3. package/ai-config/.skillignore +0 -15
  4. package/ai-config/AUTO_INVOKE.md +0 -300
  5. package/ai-config/agents/_TEMPLATE.md +0 -93
  6. package/ai-config/agents/business/api-designer.md +0 -1657
  7. package/ai-config/agents/business/business-analyst.md +0 -1331
  8. package/ai-config/agents/business/product-strategist.md +0 -206
  9. package/ai-config/agents/business/project-manager.md +0 -178
  10. package/ai-config/agents/business/requirements-analyst.md +0 -1277
  11. package/ai-config/agents/business/technical-writer.md +0 -1679
  12. package/ai-config/agents/creative/ux-designer.md +0 -205
  13. package/ai-config/agents/data-ai/ai-engineer.md +0 -487
  14. package/ai-config/agents/data-ai/analytics-engineer.md +0 -953
  15. package/ai-config/agents/data-ai/data-engineer.md +0 -173
  16. package/ai-config/agents/data-ai/data-scientist.md +0 -672
  17. package/ai-config/agents/data-ai/mlops-engineer.md +0 -814
  18. package/ai-config/agents/data-ai/prompt-engineer.md +0 -772
  19. package/ai-config/agents/development/angular-expert.md +0 -620
  20. package/ai-config/agents/development/backend-architect.md +0 -795
  21. package/ai-config/agents/development/database-specialist.md +0 -212
  22. package/ai-config/agents/development/frontend-specialist.md +0 -686
  23. package/ai-config/agents/development/fullstack-engineer.md +0 -668
  24. package/ai-config/agents/development/golang-pro.md +0 -338
  25. package/ai-config/agents/development/java-enterprise.md +0 -400
  26. package/ai-config/agents/development/javascript-pro.md +0 -422
  27. package/ai-config/agents/development/nextjs-pro.md +0 -474
  28. package/ai-config/agents/development/python-pro.md +0 -570
  29. package/ai-config/agents/development/react-pro.md +0 -487
  30. package/ai-config/agents/development/rust-pro.md +0 -246
  31. package/ai-config/agents/development/spring-boot-4-expert.md +0 -326
  32. package/ai-config/agents/development/typescript-pro.md +0 -336
  33. package/ai-config/agents/development/vue-specialist.md +0 -605
  34. package/ai-config/agents/infrastructure/cloud-architect.md +0 -472
  35. package/ai-config/agents/infrastructure/deployment-manager.md +0 -358
  36. package/ai-config/agents/infrastructure/devops-engineer.md +0 -455
  37. package/ai-config/agents/infrastructure/incident-responder.md +0 -519
  38. package/ai-config/agents/infrastructure/kubernetes-expert.md +0 -705
  39. package/ai-config/agents/infrastructure/monitoring-specialist.md +0 -674
  40. package/ai-config/agents/infrastructure/performance-engineer.md +0 -658
  41. package/ai-config/agents/orchestrator.md +0 -241
  42. package/ai-config/agents/quality/accessibility-auditor.md +0 -1204
  43. package/ai-config/agents/quality/code-reviewer-compact.md +0 -123
  44. package/ai-config/agents/quality/code-reviewer.md +0 -363
  45. package/ai-config/agents/quality/dependency-manager.md +0 -743
  46. package/ai-config/agents/quality/e2e-test-specialist.md +0 -1005
  47. package/ai-config/agents/quality/performance-tester.md +0 -1086
  48. package/ai-config/agents/quality/security-auditor.md +0 -133
  49. package/ai-config/agents/quality/test-engineer.md +0 -453
  50. package/ai-config/agents/specialists/api-designer.md +0 -87
  51. package/ai-config/agents/specialists/backend-architect.md +0 -73
  52. package/ai-config/agents/specialists/code-reviewer.md +0 -77
  53. package/ai-config/agents/specialists/db-optimizer.md +0 -75
  54. package/ai-config/agents/specialists/devops-engineer.md +0 -83
  55. package/ai-config/agents/specialists/documentation-writer.md +0 -78
  56. package/ai-config/agents/specialists/frontend-developer.md +0 -75
  57. package/ai-config/agents/specialists/performance-analyst.md +0 -82
  58. package/ai-config/agents/specialists/refactor-specialist.md +0 -74
  59. package/ai-config/agents/specialists/security-auditor.md +0 -74
  60. package/ai-config/agents/specialists/test-engineer.md +0 -81
  61. package/ai-config/agents/specialists/ux-consultant.md +0 -76
  62. package/ai-config/agents/specialized/agent-generator.md +0 -1190
  63. package/ai-config/agents/specialized/blockchain-developer.md +0 -149
  64. package/ai-config/agents/specialized/code-migrator.md +0 -892
  65. package/ai-config/agents/specialized/context-manager.md +0 -978
  66. package/ai-config/agents/specialized/documentation-writer.md +0 -1078
  67. package/ai-config/agents/specialized/ecommerce-expert.md +0 -1756
  68. package/ai-config/agents/specialized/embedded-engineer.md +0 -1714
  69. package/ai-config/agents/specialized/error-detective.md +0 -1034
  70. package/ai-config/agents/specialized/fintech-specialist.md +0 -1659
  71. package/ai-config/agents/specialized/freelance-project-planner-v2.md +0 -1988
  72. package/ai-config/agents/specialized/freelance-project-planner-v3.md +0 -2136
  73. package/ai-config/agents/specialized/freelance-project-planner-v4.md +0 -4503
  74. package/ai-config/agents/specialized/freelance-project-planner.md +0 -722
  75. package/ai-config/agents/specialized/game-developer.md +0 -1963
  76. package/ai-config/agents/specialized/healthcare-dev.md +0 -1620
  77. package/ai-config/agents/specialized/mobile-developer.md +0 -188
  78. package/ai-config/agents/specialized/parallel-plan-executor.md +0 -506
  79. package/ai-config/agents/specialized/plan-executor.md +0 -485
  80. package/ai-config/agents/specialized/solo-dev-planner-modular/00-INDEX.md +0 -485
  81. package/ai-config/agents/specialized/solo-dev-planner-modular/01-CORE.md +0 -3493
  82. package/ai-config/agents/specialized/solo-dev-planner-modular/02-SELF-CORRECTION.md +0 -778
  83. package/ai-config/agents/specialized/solo-dev-planner-modular/03-PROGRESSIVE-SETUP.md +0 -918
  84. package/ai-config/agents/specialized/solo-dev-planner-modular/04-DEPLOYMENT.md +0 -1537
  85. package/ai-config/agents/specialized/solo-dev-planner-modular/05-TESTING.md +0 -2633
  86. package/ai-config/agents/specialized/solo-dev-planner-modular/06-OPERATIONS.md +0 -5610
  87. package/ai-config/agents/specialized/solo-dev-planner-modular/INSTALL.md +0 -335
  88. package/ai-config/agents/specialized/solo-dev-planner-modular/QUICK-REFERENCE.txt +0 -215
  89. package/ai-config/agents/specialized/solo-dev-planner-modular/README.md +0 -260
  90. package/ai-config/agents/specialized/solo-dev-planner-modular/START-HERE.md +0 -379
  91. package/ai-config/agents/specialized/solo-dev-planner-modular/WORKFLOW-DIAGRAM.md +0 -355
  92. package/ai-config/agents/specialized/solo-dev-planner-modular/solo-dev-planner.md +0 -279
  93. package/ai-config/agents/specialized/template-writer.md +0 -347
  94. package/ai-config/agents/specialized/test-runner.md +0 -99
  95. package/ai-config/agents/specialized/vibekanban-smart-worker.md +0 -244
  96. package/ai-config/agents/specialized/wave-executor.md +0 -138
  97. package/ai-config/agents/specialized/workflow-optimizer.md +0 -1114
  98. package/ai-config/commands/git/changelog.md +0 -32
  99. package/ai-config/commands/git/ci-local.md +0 -70
  100. package/ai-config/commands/git/commit.md +0 -35
  101. package/ai-config/commands/git/fix-issue.md +0 -23
  102. package/ai-config/commands/git/pr-create.md +0 -42
  103. package/ai-config/commands/git/pr-review.md +0 -50
  104. package/ai-config/commands/git/worktree.md +0 -39
  105. package/ai-config/commands/refactoring/cleanup.md +0 -24
  106. package/ai-config/commands/refactoring/dead-code.md +0 -40
  107. package/ai-config/commands/refactoring/extract.md +0 -31
  108. package/ai-config/commands/testing/e2e.md +0 -30
  109. package/ai-config/commands/testing/tdd.md +0 -36
  110. package/ai-config/commands/testing/test-coverage.md +0 -30
  111. package/ai-config/commands/testing/test-fix.md +0 -24
  112. package/ai-config/commands/workflow/generate-agents-md.md +0 -85
  113. package/ai-config/commands/workflow/planning.md +0 -47
  114. package/ai-config/commands/workflows/compound.md +0 -89
  115. package/ai-config/commands/workflows/diagnose.md +0 -70
  116. package/ai-config/commands/workflows/discover.md +0 -86
  117. package/ai-config/commands/workflows/plan.md +0 -77
  118. package/ai-config/commands/workflows/review.md +0 -78
  119. package/ai-config/commands/workflows/work.md +0 -75
  120. package/ai-config/config.yaml +0 -18
  121. package/ai-config/hooks/_TEMPLATE.md +0 -96
  122. package/ai-config/hooks/block-dangerous-commands.md +0 -75
  123. package/ai-config/hooks/commit-guard.md +0 -90
  124. package/ai-config/hooks/context-loader.md +0 -73
  125. package/ai-config/hooks/improve-prompt.md +0 -91
  126. package/ai-config/hooks/learning-log.md +0 -72
  127. package/ai-config/hooks/model-router.md +0 -86
  128. package/ai-config/hooks/secret-scanner.md +0 -64
  129. package/ai-config/hooks/skill-validator.md +0 -102
  130. package/ai-config/hooks/task-artifact.md +0 -114
  131. package/ai-config/hooks/validate-workflow.md +0 -100
  132. package/ai-config/prompts/base.md +0 -71
  133. package/ai-config/prompts/modes/debug.md +0 -34
  134. package/ai-config/prompts/modes/deploy.md +0 -40
  135. package/ai-config/prompts/modes/research.md +0 -32
  136. package/ai-config/prompts/modes/review.md +0 -33
  137. package/ai-config/prompts/review-policy.md +0 -79
  138. package/ai-config/skills/_TEMPLATE.md +0 -157
  139. package/ai-config/skills/backend/api-gateway/SKILL.md +0 -254
  140. package/ai-config/skills/backend/bff-concepts/SKILL.md +0 -239
  141. package/ai-config/skills/backend/bff-spring/SKILL.md +0 -364
  142. package/ai-config/skills/backend/chi-router/SKILL.md +0 -396
  143. package/ai-config/skills/backend/error-handling/SKILL.md +0 -255
  144. package/ai-config/skills/backend/exceptions-spring/SKILL.md +0 -323
  145. package/ai-config/skills/backend/fastapi/SKILL.md +0 -302
  146. package/ai-config/skills/backend/gateway-spring/SKILL.md +0 -390
  147. package/ai-config/skills/backend/go-backend/SKILL.md +0 -457
  148. package/ai-config/skills/backend/gradle-multimodule/SKILL.md +0 -274
  149. package/ai-config/skills/backend/graphql-concepts/SKILL.md +0 -352
  150. package/ai-config/skills/backend/graphql-spring/SKILL.md +0 -398
  151. package/ai-config/skills/backend/grpc-concepts/SKILL.md +0 -283
  152. package/ai-config/skills/backend/grpc-spring/SKILL.md +0 -445
  153. package/ai-config/skills/backend/jwt-auth/SKILL.md +0 -412
  154. package/ai-config/skills/backend/notifications-concepts/SKILL.md +0 -259
  155. package/ai-config/skills/backend/recommendations-concepts/SKILL.md +0 -261
  156. package/ai-config/skills/backend/search-concepts/SKILL.md +0 -263
  157. package/ai-config/skills/backend/search-spring/SKILL.md +0 -375
  158. package/ai-config/skills/backend/spring-boot-4/SKILL.md +0 -172
  159. package/ai-config/skills/backend/websockets/SKILL.md +0 -532
  160. package/ai-config/skills/data-ai/ai-ml/SKILL.md +0 -423
  161. package/ai-config/skills/data-ai/analytics-concepts/SKILL.md +0 -195
  162. package/ai-config/skills/data-ai/analytics-spring/SKILL.md +0 -340
  163. package/ai-config/skills/data-ai/duckdb-analytics/SKILL.md +0 -440
  164. package/ai-config/skills/data-ai/langchain/SKILL.md +0 -238
  165. package/ai-config/skills/data-ai/mlflow/SKILL.md +0 -302
  166. package/ai-config/skills/data-ai/onnx-inference/SKILL.md +0 -290
  167. package/ai-config/skills/data-ai/powerbi/SKILL.md +0 -352
  168. package/ai-config/skills/data-ai/pytorch/SKILL.md +0 -274
  169. package/ai-config/skills/data-ai/scikit-learn/SKILL.md +0 -321
  170. package/ai-config/skills/data-ai/vector-db/SKILL.md +0 -301
  171. package/ai-config/skills/database/graph-databases/SKILL.md +0 -218
  172. package/ai-config/skills/database/graph-spring/SKILL.md +0 -361
  173. package/ai-config/skills/database/pgx-postgres/SKILL.md +0 -512
  174. package/ai-config/skills/database/redis-cache/SKILL.md +0 -343
  175. package/ai-config/skills/database/sqlite-embedded/SKILL.md +0 -388
  176. package/ai-config/skills/database/timescaledb/SKILL.md +0 -320
  177. package/ai-config/skills/docs/api-documentation/SKILL.md +0 -293
  178. package/ai-config/skills/docs/docs-spring/SKILL.md +0 -377
  179. package/ai-config/skills/docs/mustache-templates/SKILL.md +0 -190
  180. package/ai-config/skills/docs/technical-docs/SKILL.md +0 -447
  181. package/ai-config/skills/frontend/astro-ssr/SKILL.md +0 -441
  182. package/ai-config/skills/frontend/frontend-design/SKILL.md +0 -54
  183. package/ai-config/skills/frontend/frontend-web/SKILL.md +0 -368
  184. package/ai-config/skills/frontend/mantine-ui/SKILL.md +0 -396
  185. package/ai-config/skills/frontend/tanstack-query/SKILL.md +0 -439
  186. package/ai-config/skills/frontend/zod-validation/SKILL.md +0 -417
  187. package/ai-config/skills/frontend/zustand-state/SKILL.md +0 -350
  188. package/ai-config/skills/infrastructure/chaos-engineering/SKILL.md +0 -244
  189. package/ai-config/skills/infrastructure/chaos-spring/SKILL.md +0 -378
  190. package/ai-config/skills/infrastructure/devops-infra/SKILL.md +0 -435
  191. package/ai-config/skills/infrastructure/docker-containers/SKILL.md +0 -420
  192. package/ai-config/skills/infrastructure/kubernetes/SKILL.md +0 -456
  193. package/ai-config/skills/infrastructure/opentelemetry/SKILL.md +0 -546
  194. package/ai-config/skills/infrastructure/traefik-proxy/SKILL.md +0 -474
  195. package/ai-config/skills/infrastructure/woodpecker-ci/SKILL.md +0 -315
  196. package/ai-config/skills/mobile/ionic-capacitor/SKILL.md +0 -504
  197. package/ai-config/skills/mobile/mobile-ionic/SKILL.md +0 -448
  198. package/ai-config/skills/prompt-improver/SKILL.md +0 -125
  199. package/ai-config/skills/quality/ghagga-review/SKILL.md +0 -216
  200. package/ai-config/skills/references/hooks-patterns/SKILL.md +0 -238
  201. package/ai-config/skills/references/mcp-servers/SKILL.md +0 -275
  202. package/ai-config/skills/references/plugins-reference/SKILL.md +0 -110
  203. package/ai-config/skills/references/skills-reference/SKILL.md +0 -420
  204. package/ai-config/skills/references/subagent-templates/SKILL.md +0 -193
  205. package/ai-config/skills/systems-iot/modbus-protocol/SKILL.md +0 -410
  206. package/ai-config/skills/systems-iot/mqtt-rumqttc/SKILL.md +0 -408
  207. package/ai-config/skills/systems-iot/rust-systems/SKILL.md +0 -386
  208. package/ai-config/skills/systems-iot/tokio-async/SKILL.md +0 -324
  209. package/ai-config/skills/testing/playwright-e2e/SKILL.md +0 -289
  210. package/ai-config/skills/testing/testcontainers/SKILL.md +0 -299
  211. package/ai-config/skills/testing/vitest-testing/SKILL.md +0 -381
  212. package/ai-config/skills/workflow/ci-local-guide/SKILL.md +0 -118
  213. package/ai-config/skills/workflow/claude-automation-recommender/SKILL.md +0 -299
  214. package/ai-config/skills/workflow/claude-md-improver/SKILL.md +0 -158
  215. package/ai-config/skills/workflow/finishing-a-development-branch/SKILL.md +0 -117
  216. package/ai-config/skills/workflow/git-github/SKILL.md +0 -334
  217. package/ai-config/skills/workflow/git-github/references/examples.md +0 -160
  218. package/ai-config/skills/workflow/git-workflow/SKILL.md +0 -214
  219. package/ai-config/skills/workflow/ide-plugins/SKILL.md +0 -277
  220. package/ai-config/skills/workflow/ide-plugins-intellij/SKILL.md +0 -401
  221. package/ai-config/skills/workflow/obsidian-brain-workflow/SKILL.md +0 -199
  222. package/ai-config/skills/workflow/using-git-worktrees/SKILL.md +0 -100
  223. package/ai-config/skills/workflow/verification-before-completion/SKILL.md +0 -73
  224. package/ai-config/skills/workflow/wave-workflow/SKILL.md +0 -178
  225. package/schemas/agent.schema.json +0 -34
  226. package/schemas/ai-config.schema.json +0 -28
  227. package/schemas/plugin.schema.json +0 -62
  228. package/schemas/skill.schema.json +0 -44
@@ -1,457 +0,0 @@
1
- ---
2
- name: go-backend
3
- description: >
4
- Go backend development patterns with Chi router, PostgreSQL/pgx, JWT auth, and clean architecture.
5
- Trigger: Go API, Chi router, pgx, PostgreSQL, Go backend, REST API Go, Go service
6
- tools:
7
- - Read
8
- - Write
9
- - Bash
10
- - Grep
11
- metadata:
12
- author: plataforma-industrial
13
- version: "2.0"
14
- tags: [go, backend, chi, postgresql, jwt, api, clean-architecture]
15
- updated: "2026-02"
16
- ---
17
-
18
- # Go Backend Development
19
-
20
- Patterns for building production Go backends with Chi, PostgreSQL, and clean architecture.
21
-
22
- ## Stack
23
-
24
- ```yaml
25
- Go: 1.22+
26
- Chi: 5.0.12
27
- pgx: v5.5.5
28
- JWT: golang-jwt/jwt/v5
29
- Validator: go-playground/validator/v10
30
- ```
31
-
32
- ## Project Structure
33
-
34
- ```
35
- apps/api/
36
- ├── cmd/
37
- │ └── server/
38
- │ └── main.go
39
- ├── internal/
40
- │ ├── config/
41
- │ │ └── config.go
42
- │ ├── server/
43
- │ │ ├── server.go
44
- │ │ └── routes.go
45
- │ ├── middleware/
46
- │ │ ├── auth.go
47
- │ │ ├── logging.go
48
- │ │ └── recovery.go
49
- │ ├── domain/
50
- │ │ └── model.go
51
- │ ├── repository/
52
- │ │ └── postgres.go
53
- │ ├── service/
54
- │ │ └── service.go
55
- │ └── handler/
56
- │ └── handler.go
57
- ├── pkg/
58
- │ ├── logger/
59
- │ └── response/
60
- ├── go.mod
61
- └── Dockerfile
62
- ```
63
-
64
- ## Model Pattern
65
-
66
- ```go
67
- package domain
68
-
69
- import (
70
- "time"
71
- "github.com/google/uuid"
72
- )
73
-
74
- type Status string
75
-
76
- const (
77
- StatusActive Status = "active"
78
- StatusInactive Status = "inactive"
79
- )
80
-
81
- type Entity struct {
82
- ID uuid.UUID `json:"id" db:"id"`
83
- Name string `json:"name" db:"name" validate:"required,min=3,max=100"`
84
- Status Status `json:"status" db:"status" validate:"required,oneof=active inactive"`
85
- CreatedAt time.Time `json:"created_at" db:"created_at"`
86
- UpdatedAt time.Time `json:"updated_at" db:"updated_at"`
87
- }
88
-
89
- type CreateRequest struct {
90
- Name string `json:"name" validate:"required,min=3,max=100"`
91
- Status Status `json:"status" validate:"required,oneof=active inactive"`
92
- }
93
-
94
- type UpdateRequest struct {
95
- Name *string `json:"name,omitempty" validate:"omitempty,min=3,max=100"`
96
- Status *Status `json:"status,omitempty" validate:"omitempty,oneof=active inactive"`
97
- }
98
- ```
99
-
100
- ## Repository Pattern
101
-
102
- ```go
103
- package repository
104
-
105
- import (
106
- "context"
107
- "errors"
108
- "fmt"
109
-
110
- "github.com/google/uuid"
111
- "github.com/jackc/pgx/v5"
112
- "github.com/jackc/pgx/v5/pgxpool"
113
- )
114
-
115
- var (
116
- ErrNotFound = errors.New("entity not found")
117
- ErrDuplicateName = errors.New("name already exists")
118
- )
119
-
120
- type Repository interface {
121
- Create(ctx context.Context, entity *Entity) error
122
- GetByID(ctx context.Context, id uuid.UUID) (*Entity, error)
123
- GetAll(ctx context.Context) ([]Entity, error)
124
- Update(ctx context.Context, entity *Entity) error
125
- Delete(ctx context.Context, id uuid.UUID) error
126
- }
127
-
128
- type PostgresRepository struct {
129
- db *pgxpool.Pool
130
- }
131
-
132
- func NewPostgresRepository(db *pgxpool.Pool) *PostgresRepository {
133
- return &PostgresRepository{db: db}
134
- }
135
-
136
- func (r *PostgresRepository) GetByID(ctx context.Context, id uuid.UUID) (*Entity, error) {
137
- query := `SELECT id, name, status, created_at, updated_at FROM entities WHERE id = $1`
138
-
139
- var entity Entity
140
- err := r.db.QueryRow(ctx, query, id).Scan(
141
- &entity.ID, &entity.Name, &entity.Status,
142
- &entity.CreatedAt, &entity.UpdatedAt,
143
- )
144
-
145
- if errors.Is(err, pgx.ErrNoRows) {
146
- return nil, ErrNotFound
147
- }
148
- if err != nil {
149
- return nil, fmt.Errorf("get entity: %w", err)
150
- }
151
-
152
- return &entity, nil
153
- }
154
- ```
155
-
156
- ## Service Pattern
157
-
158
- ```go
159
- package service
160
-
161
- import (
162
- "context"
163
- "log/slog"
164
- "time"
165
-
166
- "github.com/google/uuid"
167
- )
168
-
169
- type Service struct {
170
- repo Repository
171
- logger *slog.Logger
172
- }
173
-
174
- func NewService(repo Repository, logger *slog.Logger) *Service {
175
- return &Service{repo: repo, logger: logger}
176
- }
177
-
178
- func (s *Service) Create(ctx context.Context, req CreateRequest) (*Entity, error) {
179
- entity := &Entity{
180
- ID: uuid.New(),
181
- Name: req.Name,
182
- Status: req.Status,
183
- CreatedAt: time.Now().UTC(),
184
- UpdatedAt: time.Now().UTC(),
185
- }
186
-
187
- if err := s.repo.Create(ctx, entity); err != nil {
188
- s.logger.Error("failed to create entity", "error", err)
189
- return nil, err
190
- }
191
-
192
- s.logger.Info("entity created", "id", entity.ID)
193
- return entity, nil
194
- }
195
- ```
196
-
197
- ## Handler Pattern
198
-
199
- ```go
200
- package handler
201
-
202
- import (
203
- "encoding/json"
204
- "errors"
205
- "net/http"
206
-
207
- "github.com/go-chi/chi/v5"
208
- "github.com/go-playground/validator/v10"
209
- "github.com/google/uuid"
210
- )
211
-
212
- type Handler struct {
213
- service *Service
214
- validator *validator.Validate
215
- }
216
-
217
- func NewHandler(service *Service) *Handler {
218
- return &Handler{
219
- service: service,
220
- validator: validator.New(),
221
- }
222
- }
223
-
224
- func (h *Handler) RegisterRoutes(r chi.Router) {
225
- r.Route("/entities", func(r chi.Router) {
226
- r.Get("/", h.GetAll)
227
- r.Post("/", h.Create)
228
- r.Route("/{id}", func(r chi.Router) {
229
- r.Get("/", h.GetByID)
230
- r.Put("/", h.Update)
231
- r.Delete("/", h.Delete)
232
- })
233
- })
234
- }
235
-
236
- func (h *Handler) GetByID(w http.ResponseWriter, r *http.Request) {
237
- id, err := uuid.Parse(chi.URLParam(r, "id"))
238
- if err != nil {
239
- respondError(w, http.StatusBadRequest, "invalid id")
240
- return
241
- }
242
-
243
- entity, err := h.service.GetByID(r.Context(), id)
244
- if errors.Is(err, ErrNotFound) {
245
- respondError(w, http.StatusNotFound, "entity not found")
246
- return
247
- }
248
- if err != nil {
249
- respondError(w, http.StatusInternalServerError, "internal error")
250
- return
251
- }
252
-
253
- respondJSON(w, http.StatusOK, entity)
254
- }
255
- ```
256
-
257
- ## PostgreSQL Connection
258
-
259
- ```go
260
- package database
261
-
262
- import (
263
- "context"
264
- "fmt"
265
- "time"
266
-
267
- "github.com/jackc/pgx/v5/pgxpool"
268
- )
269
-
270
- type Config struct {
271
- Host string
272
- Port int
273
- User string
274
- Password string
275
- DBName string
276
- SSLMode string
277
- MaxConns int32
278
- }
279
-
280
- func NewPool(ctx context.Context, cfg Config) (*pgxpool.Pool, error) {
281
- dsn := fmt.Sprintf(
282
- "postgres://%s:%s@%s:%d/%s?sslmode=%s",
283
- cfg.User, cfg.Password, cfg.Host, cfg.Port, cfg.DBName, cfg.SSLMode,
284
- )
285
-
286
- poolConfig, err := pgxpool.ParseConfig(dsn)
287
- if err != nil {
288
- return nil, fmt.Errorf("parse config: %w", err)
289
- }
290
-
291
- poolConfig.MaxConns = cfg.MaxConns
292
- poolConfig.MaxConnLifetime = 1 * time.Hour
293
- poolConfig.MaxConnIdleTime = 30 * time.Minute
294
-
295
- pool, err := pgxpool.NewWithConfig(ctx, poolConfig)
296
- if err != nil {
297
- return nil, fmt.Errorf("create pool: %w", err)
298
- }
299
-
300
- if err := pool.Ping(ctx); err != nil {
301
- pool.Close()
302
- return nil, fmt.Errorf("ping: %w", err)
303
- }
304
-
305
- return pool, nil
306
- }
307
- ```
308
-
309
- ## JWT Authentication
310
-
311
- ```go
312
- package auth
313
-
314
- import (
315
- "errors"
316
- "time"
317
-
318
- "github.com/golang-jwt/jwt/v5"
319
- "github.com/google/uuid"
320
- )
321
-
322
- var (
323
- ErrInvalidToken = errors.New("invalid token")
324
- ErrExpiredToken = errors.New("token expired")
325
- )
326
-
327
- type Claims struct {
328
- UserID uuid.UUID `json:"sub"`
329
- Email string `json:"email"`
330
- Role string `json:"role"`
331
- jwt.RegisteredClaims
332
- }
333
-
334
- type JWTService struct {
335
- secretKey []byte
336
- accessExpiry time.Duration
337
- }
338
-
339
- func NewJWTService(secret string, expiry time.Duration) *JWTService {
340
- return &JWTService{
341
- secretKey: []byte(secret),
342
- accessExpiry: expiry,
343
- }
344
- }
345
-
346
- func (s *JWTService) GenerateToken(userID uuid.UUID, email, role string) (string, error) {
347
- claims := Claims{
348
- UserID: userID,
349
- Email: email,
350
- Role: role,
351
- RegisteredClaims: jwt.RegisteredClaims{
352
- ExpiresAt: jwt.NewNumericDate(time.Now().Add(s.accessExpiry)),
353
- IssuedAt: jwt.NewNumericDate(time.Now()),
354
- },
355
- }
356
-
357
- token := jwt.NewWithClaims(jwt.SigningMethodHS256, claims)
358
- return token.SignedString(s.secretKey)
359
- }
360
-
361
- func (s *JWTService) ValidateToken(tokenString string) (*Claims, error) {
362
- token, err := jwt.ParseWithClaims(tokenString, &Claims{}, func(token *jwt.Token) (interface{}, error) {
363
- if _, ok := token.Method.(*jwt.SigningMethodHMAC); !ok {
364
- return nil, ErrInvalidToken
365
- }
366
- return s.secretKey, nil
367
- })
368
-
369
- if err != nil {
370
- if errors.Is(err, jwt.ErrTokenExpired) {
371
- return nil, ErrExpiredToken
372
- }
373
- return nil, ErrInvalidToken
374
- }
375
-
376
- claims, ok := token.Claims.(*Claims)
377
- if !ok || !token.Valid {
378
- return nil, ErrInvalidToken
379
- }
380
-
381
- return claims, nil
382
- }
383
- ```
384
-
385
- ## Response Helpers
386
-
387
- ```go
388
- package response
389
-
390
- import (
391
- "encoding/json"
392
- "net/http"
393
- )
394
-
395
- type ErrorResponse struct {
396
- Error string `json:"error"`
397
- Details map[string]string `json:"details,omitempty"`
398
- }
399
-
400
- func JSON(w http.ResponseWriter, status int, data any) {
401
- w.Header().Set("Content-Type", "application/json")
402
- w.WriteHeader(status)
403
- if data != nil && status != http.StatusNoContent {
404
- json.NewEncoder(w).Encode(data)
405
- }
406
- }
407
-
408
- func Error(w http.ResponseWriter, status int, message string) {
409
- JSON(w, status, ErrorResponse{Error: message})
410
- }
411
- ```
412
-
413
- ## Testing
414
-
415
- ```go
416
- package service_test
417
-
418
- import (
419
- "context"
420
- "testing"
421
-
422
- "github.com/stretchr/testify/assert"
423
- "github.com/stretchr/testify/require"
424
- )
425
-
426
- func TestService_Create(t *testing.T) {
427
- repo := NewMockRepository()
428
- svc := NewService(repo, slog.Default())
429
-
430
- req := CreateRequest{
431
- Name: "Test Entity",
432
- Status: StatusActive,
433
- }
434
-
435
- entity, err := svc.Create(context.Background(), req)
436
-
437
- require.NoError(t, err)
438
- assert.Equal(t, "Test Entity", entity.Name)
439
- assert.NotEmpty(t, entity.ID)
440
- }
441
- ```
442
-
443
- ## Conventions
444
-
445
- - **Packages:** lowercase, singular (`user`, not `users`)
446
- - **Files:** snake_case (`user_repository.go`)
447
- - **Error handling:** Always wrap with context `fmt.Errorf("operation: %w", err)`
448
- - **Context:** Always first parameter
449
- - **Validation:** Use `go-playground/validator` tags
450
-
451
- ## Related Skills
452
-
453
- - `chi-router`: Chi HTTP routing patterns
454
- - `pgx-postgres`: PostgreSQL with pgx driver
455
- - `jwt-auth`: Authentication middleware
456
- - `redis-cache`: Caching strategies
457
- - `docker-containers`: Containerization
@@ -1,274 +0,0 @@
1
- ---
2
- name: gradle-multimodule
3
- description: >
4
- Gradle 9.x multi-module configuration for APiGen. Build, dependencies, publishing.
5
- Trigger: gradle, build.gradle, multi-module, dependencies, publishing
6
- tools:
7
- - Read
8
- - Write
9
- - Edit
10
- - Bash
11
- - Grep
12
- metadata:
13
- author: apigen-team
14
- version: "1.0"
15
- tags: [gradle, build, multimodule]
16
- scope: ["*.gradle", "*.gradle.kts", "settings.gradle"]
17
- ---
18
-
19
- # Gradle Multi-Module (APiGen)
20
-
21
- ## Estructura
22
-
23
- ```
24
- apigen/
25
- ├── build.gradle # Root: plugins, common config
26
- ├── settings.gradle # Module includes
27
- ├── gradle.properties # Versions, properties
28
- ├── apigen-bom/build.gradle # BOM module
29
- ├── apigen-core/build.gradle # Library module
30
- ├── apigen-security/ # Library module
31
- ├── apigen-codegen/ # Utility module
32
- ├── apigen-server/ # Application module
33
- └── ...
34
- ```
35
-
36
- ## Root build.gradle
37
-
38
- ```groovy
39
- plugins {
40
- id 'java'
41
- id 'com.diffplug.spotless' version '7.1.0'
42
- id 'org.sonarqube' version '6.1.0.5360'
43
- id 'io.spring.dependency-management' version '1.1.7' apply false
44
- id 'org.springframework.boot' version '4.0.0' apply false
45
- }
46
-
47
- // Common config for all subprojects
48
- subprojects {
49
- if (name != 'apigen-bom') {
50
- apply plugin: 'java'
51
- apply plugin: 'io.spring.dependency-management'
52
-
53
- java {
54
- toolchain {
55
- languageVersion = JavaLanguageVersion.of(25)
56
- }
57
- }
58
-
59
- repositories {
60
- mavenCentral()
61
- }
62
-
63
- dependencyManagement {
64
- imports {
65
- mavenBom "org.springframework.boot:spring-boot-dependencies:4.0.0"
66
- }
67
- }
68
-
69
- // Spotless
70
- spotless {
71
- java {
72
- target 'src/**/*.java'
73
- googleJavaFormat('1.33.0').aosp().reflowLongStrings()
74
- }
75
- }
76
- }
77
- }
78
- ```
79
-
80
- ## Module: apigen-bom
81
-
82
- ```groovy
83
- plugins {
84
- id 'java-platform'
85
- id 'maven-publish'
86
- }
87
-
88
- javaPlatform {
89
- allowDependencies()
90
- }
91
-
92
- dependencies {
93
- api platform("org.springframework.boot:spring-boot-dependencies:4.0.0")
94
-
95
- constraints {
96
- api "com.jnzader:apigen-core:${version}"
97
- api "com.jnzader:apigen-security:${version}"
98
- api "com.jnzader:apigen-graphql:${version}"
99
- api "com.jnzader:apigen-grpc:${version}"
100
- api "com.jnzader:apigen-gateway:${version}"
101
-
102
- // Third-party
103
- api "io.jsonwebtoken:jjwt-api:0.13.0"
104
- api "com.bucket4j:bucket4j-core:8.16.0"
105
- }
106
- }
107
- ```
108
-
109
- ## Module: Library (apigen-core)
110
-
111
- ```groovy
112
- plugins {
113
- id 'java-library'
114
- id 'maven-publish'
115
- }
116
-
117
- dependencies {
118
- // API dependencies (transitivas)
119
- api 'org.springframework.boot:spring-boot-starter-data-jpa'
120
- api 'org.springframework.boot:spring-boot-starter-validation'
121
- api 'org.springframework.boot:spring-boot-starter-hateoas'
122
-
123
- // Implementation (no transitivas)
124
- implementation 'com.github.ben-manes.caffeine:caffeine'
125
- implementation 'org.mapstruct:mapstruct:1.6.3'
126
-
127
- // Annotation processors
128
- annotationProcessor 'org.mapstruct:mapstruct-processor:1.6.3'
129
- annotationProcessor 'org.projectlombok:lombok'
130
-
131
- // Test
132
- testImplementation 'org.springframework.boot:spring-boot-starter-test'
133
- testImplementation 'org.testcontainers:postgresql'
134
- }
135
- ```
136
-
137
- ## Module: Application (apigen-server)
138
-
139
- ```groovy
140
- plugins {
141
- id 'org.springframework.boot'
142
- }
143
-
144
- dependencies {
145
- implementation project(':apigen-core')
146
- implementation project(':apigen-security')
147
- implementation project(':apigen-codegen')
148
-
149
- implementation 'org.springframework.boot:spring-boot-starter-web'
150
-
151
- // Runtime only
152
- runtimeOnly 'org.postgresql:postgresql'
153
-
154
- // Test
155
- testImplementation 'org.springframework.boot:spring-boot-starter-test'
156
- }
157
-
158
- bootJar {
159
- archiveFileName = "apigen-server.jar"
160
- }
161
- ```
162
-
163
- ## Comandos Comunes
164
-
165
- ```bash
166
- # Formatear código
167
- ./gradlew spotlessApply
168
-
169
- # Build específico
170
- ./gradlew :apigen-core:build
171
-
172
- # Test específico
173
- ./gradlew :apigen-core:test
174
-
175
- # Build todo
176
- ./gradlew buildAll
177
-
178
- # Test todo
179
- ./gradlew testAll
180
-
181
- # Publish local
182
- ./gradlew publishToMavenLocal
183
-
184
- # Dependencias de un módulo
185
- ./gradlew :apigen-core:dependencies
186
-
187
- # Ejecutar servidor
188
- ./gradlew :apigen-server:bootRun
189
- ```
190
-
191
- ## Custom Tasks (root build.gradle)
192
-
193
- ```groovy
194
- tasks.register('buildAll') {
195
- group = 'build'
196
- description = 'Build all modules'
197
- dependsOn subprojects.collect { "${it.path}:build" }
198
- }
199
-
200
- tasks.register('testAll') {
201
- group = 'verification'
202
- description = 'Test all modules'
203
- dependsOn subprojects.collect { "${it.path}:test" }
204
- }
205
-
206
- tasks.register('publishAll') {
207
- group = 'publishing'
208
- description = 'Publish all modules to Maven Local'
209
- dependsOn subprojects.findAll { it.plugins.hasPlugin('maven-publish') }
210
- .collect { "${it.path}:publishToMavenLocal" }
211
- }
212
- ```
213
-
214
- ## Testing Configuration
215
-
216
- ```groovy
217
- // En root o cada módulo
218
- test {
219
- useJUnitPlatform()
220
-
221
- testLogging {
222
- events "passed", "skipped", "failed"
223
- }
224
-
225
- // Paralelismo
226
- maxParallelForks = Runtime.runtime.availableProcessors().intdiv(2) ?: 1
227
- }
228
-
229
- // Separar IT tests
230
- tasks.register('integrationTest', Test) {
231
- description = 'Run integration tests'
232
- group = 'verification'
233
-
234
- testClassesDirs = sourceSets.test.output.classesDirs
235
- classpath = sourceSets.test.runtimeClasspath
236
-
237
- useJUnitPlatform {
238
- includeTags 'integration'
239
- }
240
- }
241
- ```
242
-
243
- ## JaCoCo Coverage
244
-
245
- ```groovy
246
- plugins {
247
- id 'jacoco'
248
- }
249
-
250
- jacoco {
251
- toolVersion = "0.8.12"
252
- }
253
-
254
- jacocoTestReport {
255
- reports {
256
- xml.required = true
257
- html.required = true
258
- }
259
- }
260
-
261
- jacocoTestCoverageVerification {
262
- violationRules {
263
- rule {
264
- limit {
265
- minimum = 0.70
266
- }
267
- }
268
- }
269
- }
270
- ```
271
-
272
- ## Related Skills
273
-
274
- - `spring-boot-4`: Dependencias Spring