javi-forge 1.1.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 (238) hide show
  1. package/ci-local/ci-local.sh +38 -10
  2. package/ci-local/hooks/pre-commit +10 -155
  3. package/ci-local/hooks/pre-push +12 -29
  4. package/dist/commands/ci.d.ts +33 -0
  5. package/dist/commands/ci.js +341 -0
  6. package/dist/commands/init.js +5 -0
  7. package/dist/index.js +39 -5
  8. package/dist/lib/docker.d.ts +43 -0
  9. package/dist/lib/docker.js +223 -0
  10. package/dist/ui/CI.d.ts +9 -0
  11. package/dist/ui/CI.js +91 -0
  12. package/package.json +9 -1
  13. package/ai-config/.skillignore +0 -15
  14. package/ai-config/AUTO_INVOKE.md +0 -300
  15. package/ai-config/agents/_TEMPLATE.md +0 -93
  16. package/ai-config/agents/business/api-designer.md +0 -1657
  17. package/ai-config/agents/business/business-analyst.md +0 -1331
  18. package/ai-config/agents/business/product-strategist.md +0 -206
  19. package/ai-config/agents/business/project-manager.md +0 -178
  20. package/ai-config/agents/business/requirements-analyst.md +0 -1277
  21. package/ai-config/agents/business/technical-writer.md +0 -1679
  22. package/ai-config/agents/creative/ux-designer.md +0 -205
  23. package/ai-config/agents/data-ai/ai-engineer.md +0 -487
  24. package/ai-config/agents/data-ai/analytics-engineer.md +0 -953
  25. package/ai-config/agents/data-ai/data-engineer.md +0 -173
  26. package/ai-config/agents/data-ai/data-scientist.md +0 -672
  27. package/ai-config/agents/data-ai/mlops-engineer.md +0 -814
  28. package/ai-config/agents/data-ai/prompt-engineer.md +0 -772
  29. package/ai-config/agents/development/angular-expert.md +0 -620
  30. package/ai-config/agents/development/backend-architect.md +0 -795
  31. package/ai-config/agents/development/database-specialist.md +0 -212
  32. package/ai-config/agents/development/frontend-specialist.md +0 -686
  33. package/ai-config/agents/development/fullstack-engineer.md +0 -668
  34. package/ai-config/agents/development/golang-pro.md +0 -338
  35. package/ai-config/agents/development/java-enterprise.md +0 -400
  36. package/ai-config/agents/development/javascript-pro.md +0 -422
  37. package/ai-config/agents/development/nextjs-pro.md +0 -474
  38. package/ai-config/agents/development/python-pro.md +0 -570
  39. package/ai-config/agents/development/react-pro.md +0 -487
  40. package/ai-config/agents/development/rust-pro.md +0 -246
  41. package/ai-config/agents/development/spring-boot-4-expert.md +0 -326
  42. package/ai-config/agents/development/typescript-pro.md +0 -336
  43. package/ai-config/agents/development/vue-specialist.md +0 -605
  44. package/ai-config/agents/infrastructure/cloud-architect.md +0 -472
  45. package/ai-config/agents/infrastructure/deployment-manager.md +0 -358
  46. package/ai-config/agents/infrastructure/devops-engineer.md +0 -455
  47. package/ai-config/agents/infrastructure/incident-responder.md +0 -519
  48. package/ai-config/agents/infrastructure/kubernetes-expert.md +0 -705
  49. package/ai-config/agents/infrastructure/monitoring-specialist.md +0 -674
  50. package/ai-config/agents/infrastructure/performance-engineer.md +0 -658
  51. package/ai-config/agents/orchestrator.md +0 -241
  52. package/ai-config/agents/quality/accessibility-auditor.md +0 -1204
  53. package/ai-config/agents/quality/code-reviewer-compact.md +0 -123
  54. package/ai-config/agents/quality/code-reviewer.md +0 -363
  55. package/ai-config/agents/quality/dependency-manager.md +0 -743
  56. package/ai-config/agents/quality/e2e-test-specialist.md +0 -1005
  57. package/ai-config/agents/quality/performance-tester.md +0 -1086
  58. package/ai-config/agents/quality/security-auditor.md +0 -133
  59. package/ai-config/agents/quality/test-engineer.md +0 -453
  60. package/ai-config/agents/specialists/api-designer.md +0 -87
  61. package/ai-config/agents/specialists/backend-architect.md +0 -73
  62. package/ai-config/agents/specialists/code-reviewer.md +0 -77
  63. package/ai-config/agents/specialists/db-optimizer.md +0 -75
  64. package/ai-config/agents/specialists/devops-engineer.md +0 -83
  65. package/ai-config/agents/specialists/documentation-writer.md +0 -78
  66. package/ai-config/agents/specialists/frontend-developer.md +0 -75
  67. package/ai-config/agents/specialists/performance-analyst.md +0 -82
  68. package/ai-config/agents/specialists/refactor-specialist.md +0 -74
  69. package/ai-config/agents/specialists/security-auditor.md +0 -74
  70. package/ai-config/agents/specialists/test-engineer.md +0 -81
  71. package/ai-config/agents/specialists/ux-consultant.md +0 -76
  72. package/ai-config/agents/specialized/agent-generator.md +0 -1190
  73. package/ai-config/agents/specialized/blockchain-developer.md +0 -149
  74. package/ai-config/agents/specialized/code-migrator.md +0 -892
  75. package/ai-config/agents/specialized/context-manager.md +0 -978
  76. package/ai-config/agents/specialized/documentation-writer.md +0 -1078
  77. package/ai-config/agents/specialized/ecommerce-expert.md +0 -1756
  78. package/ai-config/agents/specialized/embedded-engineer.md +0 -1714
  79. package/ai-config/agents/specialized/error-detective.md +0 -1034
  80. package/ai-config/agents/specialized/fintech-specialist.md +0 -1659
  81. package/ai-config/agents/specialized/freelance-project-planner-v2.md +0 -1988
  82. package/ai-config/agents/specialized/freelance-project-planner-v3.md +0 -2136
  83. package/ai-config/agents/specialized/freelance-project-planner-v4.md +0 -4503
  84. package/ai-config/agents/specialized/freelance-project-planner.md +0 -722
  85. package/ai-config/agents/specialized/game-developer.md +0 -1963
  86. package/ai-config/agents/specialized/healthcare-dev.md +0 -1620
  87. package/ai-config/agents/specialized/mobile-developer.md +0 -188
  88. package/ai-config/agents/specialized/parallel-plan-executor.md +0 -506
  89. package/ai-config/agents/specialized/plan-executor.md +0 -485
  90. package/ai-config/agents/specialized/solo-dev-planner-modular/00-INDEX.md +0 -485
  91. package/ai-config/agents/specialized/solo-dev-planner-modular/01-CORE.md +0 -3493
  92. package/ai-config/agents/specialized/solo-dev-planner-modular/02-SELF-CORRECTION.md +0 -778
  93. package/ai-config/agents/specialized/solo-dev-planner-modular/03-PROGRESSIVE-SETUP.md +0 -918
  94. package/ai-config/agents/specialized/solo-dev-planner-modular/04-DEPLOYMENT.md +0 -1537
  95. package/ai-config/agents/specialized/solo-dev-planner-modular/05-TESTING.md +0 -2633
  96. package/ai-config/agents/specialized/solo-dev-planner-modular/06-OPERATIONS.md +0 -5610
  97. package/ai-config/agents/specialized/solo-dev-planner-modular/INSTALL.md +0 -335
  98. package/ai-config/agents/specialized/solo-dev-planner-modular/QUICK-REFERENCE.txt +0 -215
  99. package/ai-config/agents/specialized/solo-dev-planner-modular/README.md +0 -260
  100. package/ai-config/agents/specialized/solo-dev-planner-modular/START-HERE.md +0 -379
  101. package/ai-config/agents/specialized/solo-dev-planner-modular/WORKFLOW-DIAGRAM.md +0 -355
  102. package/ai-config/agents/specialized/solo-dev-planner-modular/solo-dev-planner.md +0 -279
  103. package/ai-config/agents/specialized/template-writer.md +0 -347
  104. package/ai-config/agents/specialized/test-runner.md +0 -99
  105. package/ai-config/agents/specialized/vibekanban-smart-worker.md +0 -244
  106. package/ai-config/agents/specialized/wave-executor.md +0 -138
  107. package/ai-config/agents/specialized/workflow-optimizer.md +0 -1114
  108. package/ai-config/commands/git/changelog.md +0 -32
  109. package/ai-config/commands/git/ci-local.md +0 -70
  110. package/ai-config/commands/git/commit.md +0 -35
  111. package/ai-config/commands/git/fix-issue.md +0 -23
  112. package/ai-config/commands/git/pr-create.md +0 -42
  113. package/ai-config/commands/git/pr-review.md +0 -50
  114. package/ai-config/commands/git/worktree.md +0 -39
  115. package/ai-config/commands/refactoring/cleanup.md +0 -24
  116. package/ai-config/commands/refactoring/dead-code.md +0 -40
  117. package/ai-config/commands/refactoring/extract.md +0 -31
  118. package/ai-config/commands/testing/e2e.md +0 -30
  119. package/ai-config/commands/testing/tdd.md +0 -36
  120. package/ai-config/commands/testing/test-coverage.md +0 -30
  121. package/ai-config/commands/testing/test-fix.md +0 -24
  122. package/ai-config/commands/workflow/generate-agents-md.md +0 -85
  123. package/ai-config/commands/workflow/planning.md +0 -47
  124. package/ai-config/commands/workflows/compound.md +0 -89
  125. package/ai-config/commands/workflows/diagnose.md +0 -70
  126. package/ai-config/commands/workflows/discover.md +0 -86
  127. package/ai-config/commands/workflows/plan.md +0 -77
  128. package/ai-config/commands/workflows/review.md +0 -78
  129. package/ai-config/commands/workflows/work.md +0 -75
  130. package/ai-config/config.yaml +0 -18
  131. package/ai-config/hooks/_TEMPLATE.md +0 -96
  132. package/ai-config/hooks/block-dangerous-commands.md +0 -75
  133. package/ai-config/hooks/commit-guard.md +0 -90
  134. package/ai-config/hooks/context-loader.md +0 -73
  135. package/ai-config/hooks/improve-prompt.md +0 -91
  136. package/ai-config/hooks/learning-log.md +0 -72
  137. package/ai-config/hooks/model-router.md +0 -86
  138. package/ai-config/hooks/secret-scanner.md +0 -64
  139. package/ai-config/hooks/skill-validator.md +0 -102
  140. package/ai-config/hooks/task-artifact.md +0 -114
  141. package/ai-config/hooks/validate-workflow.md +0 -100
  142. package/ai-config/prompts/base.md +0 -71
  143. package/ai-config/prompts/modes/debug.md +0 -34
  144. package/ai-config/prompts/modes/deploy.md +0 -40
  145. package/ai-config/prompts/modes/research.md +0 -32
  146. package/ai-config/prompts/modes/review.md +0 -33
  147. package/ai-config/prompts/review-policy.md +0 -79
  148. package/ai-config/skills/_TEMPLATE.md +0 -157
  149. package/ai-config/skills/backend/api-gateway/SKILL.md +0 -254
  150. package/ai-config/skills/backend/bff-concepts/SKILL.md +0 -239
  151. package/ai-config/skills/backend/bff-spring/SKILL.md +0 -364
  152. package/ai-config/skills/backend/chi-router/SKILL.md +0 -396
  153. package/ai-config/skills/backend/error-handling/SKILL.md +0 -255
  154. package/ai-config/skills/backend/exceptions-spring/SKILL.md +0 -323
  155. package/ai-config/skills/backend/fastapi/SKILL.md +0 -302
  156. package/ai-config/skills/backend/gateway-spring/SKILL.md +0 -390
  157. package/ai-config/skills/backend/go-backend/SKILL.md +0 -457
  158. package/ai-config/skills/backend/gradle-multimodule/SKILL.md +0 -274
  159. package/ai-config/skills/backend/graphql-concepts/SKILL.md +0 -352
  160. package/ai-config/skills/backend/graphql-spring/SKILL.md +0 -398
  161. package/ai-config/skills/backend/grpc-concepts/SKILL.md +0 -283
  162. package/ai-config/skills/backend/grpc-spring/SKILL.md +0 -445
  163. package/ai-config/skills/backend/jwt-auth/SKILL.md +0 -412
  164. package/ai-config/skills/backend/notifications-concepts/SKILL.md +0 -259
  165. package/ai-config/skills/backend/recommendations-concepts/SKILL.md +0 -261
  166. package/ai-config/skills/backend/search-concepts/SKILL.md +0 -263
  167. package/ai-config/skills/backend/search-spring/SKILL.md +0 -375
  168. package/ai-config/skills/backend/spring-boot-4/SKILL.md +0 -172
  169. package/ai-config/skills/backend/websockets/SKILL.md +0 -532
  170. package/ai-config/skills/data-ai/ai-ml/SKILL.md +0 -423
  171. package/ai-config/skills/data-ai/analytics-concepts/SKILL.md +0 -195
  172. package/ai-config/skills/data-ai/analytics-spring/SKILL.md +0 -340
  173. package/ai-config/skills/data-ai/duckdb-analytics/SKILL.md +0 -440
  174. package/ai-config/skills/data-ai/langchain/SKILL.md +0 -238
  175. package/ai-config/skills/data-ai/mlflow/SKILL.md +0 -302
  176. package/ai-config/skills/data-ai/onnx-inference/SKILL.md +0 -290
  177. package/ai-config/skills/data-ai/powerbi/SKILL.md +0 -352
  178. package/ai-config/skills/data-ai/pytorch/SKILL.md +0 -274
  179. package/ai-config/skills/data-ai/scikit-learn/SKILL.md +0 -321
  180. package/ai-config/skills/data-ai/vector-db/SKILL.md +0 -301
  181. package/ai-config/skills/database/graph-databases/SKILL.md +0 -218
  182. package/ai-config/skills/database/graph-spring/SKILL.md +0 -361
  183. package/ai-config/skills/database/pgx-postgres/SKILL.md +0 -512
  184. package/ai-config/skills/database/redis-cache/SKILL.md +0 -343
  185. package/ai-config/skills/database/sqlite-embedded/SKILL.md +0 -388
  186. package/ai-config/skills/database/timescaledb/SKILL.md +0 -320
  187. package/ai-config/skills/docs/api-documentation/SKILL.md +0 -293
  188. package/ai-config/skills/docs/docs-spring/SKILL.md +0 -377
  189. package/ai-config/skills/docs/mustache-templates/SKILL.md +0 -190
  190. package/ai-config/skills/docs/technical-docs/SKILL.md +0 -447
  191. package/ai-config/skills/frontend/astro-ssr/SKILL.md +0 -441
  192. package/ai-config/skills/frontend/frontend-design/SKILL.md +0 -54
  193. package/ai-config/skills/frontend/frontend-web/SKILL.md +0 -368
  194. package/ai-config/skills/frontend/mantine-ui/SKILL.md +0 -396
  195. package/ai-config/skills/frontend/tanstack-query/SKILL.md +0 -439
  196. package/ai-config/skills/frontend/zod-validation/SKILL.md +0 -417
  197. package/ai-config/skills/frontend/zustand-state/SKILL.md +0 -350
  198. package/ai-config/skills/infrastructure/chaos-engineering/SKILL.md +0 -244
  199. package/ai-config/skills/infrastructure/chaos-spring/SKILL.md +0 -378
  200. package/ai-config/skills/infrastructure/devops-infra/SKILL.md +0 -435
  201. package/ai-config/skills/infrastructure/docker-containers/SKILL.md +0 -420
  202. package/ai-config/skills/infrastructure/kubernetes/SKILL.md +0 -456
  203. package/ai-config/skills/infrastructure/opentelemetry/SKILL.md +0 -546
  204. package/ai-config/skills/infrastructure/traefik-proxy/SKILL.md +0 -474
  205. package/ai-config/skills/infrastructure/woodpecker-ci/SKILL.md +0 -315
  206. package/ai-config/skills/mobile/ionic-capacitor/SKILL.md +0 -504
  207. package/ai-config/skills/mobile/mobile-ionic/SKILL.md +0 -448
  208. package/ai-config/skills/prompt-improver/SKILL.md +0 -125
  209. package/ai-config/skills/quality/ghagga-review/SKILL.md +0 -216
  210. package/ai-config/skills/references/hooks-patterns/SKILL.md +0 -238
  211. package/ai-config/skills/references/mcp-servers/SKILL.md +0 -275
  212. package/ai-config/skills/references/plugins-reference/SKILL.md +0 -110
  213. package/ai-config/skills/references/skills-reference/SKILL.md +0 -420
  214. package/ai-config/skills/references/subagent-templates/SKILL.md +0 -193
  215. package/ai-config/skills/systems-iot/modbus-protocol/SKILL.md +0 -410
  216. package/ai-config/skills/systems-iot/mqtt-rumqttc/SKILL.md +0 -408
  217. package/ai-config/skills/systems-iot/rust-systems/SKILL.md +0 -386
  218. package/ai-config/skills/systems-iot/tokio-async/SKILL.md +0 -324
  219. package/ai-config/skills/testing/playwright-e2e/SKILL.md +0 -289
  220. package/ai-config/skills/testing/testcontainers/SKILL.md +0 -299
  221. package/ai-config/skills/testing/vitest-testing/SKILL.md +0 -381
  222. package/ai-config/skills/workflow/ci-local-guide/SKILL.md +0 -118
  223. package/ai-config/skills/workflow/claude-automation-recommender/SKILL.md +0 -299
  224. package/ai-config/skills/workflow/claude-md-improver/SKILL.md +0 -158
  225. package/ai-config/skills/workflow/finishing-a-development-branch/SKILL.md +0 -117
  226. package/ai-config/skills/workflow/git-github/SKILL.md +0 -334
  227. package/ai-config/skills/workflow/git-github/references/examples.md +0 -160
  228. package/ai-config/skills/workflow/git-workflow/SKILL.md +0 -214
  229. package/ai-config/skills/workflow/ide-plugins/SKILL.md +0 -277
  230. package/ai-config/skills/workflow/ide-plugins-intellij/SKILL.md +0 -401
  231. package/ai-config/skills/workflow/obsidian-brain-workflow/SKILL.md +0 -199
  232. package/ai-config/skills/workflow/using-git-worktrees/SKILL.md +0 -100
  233. package/ai-config/skills/workflow/verification-before-completion/SKILL.md +0 -73
  234. package/ai-config/skills/workflow/wave-workflow/SKILL.md +0 -178
  235. package/schemas/agent.schema.json +0 -34
  236. package/schemas/ai-config.schema.json +0 -28
  237. package/schemas/plugin.schema.json +0 -62
  238. package/schemas/skill.schema.json +0 -44
@@ -1,398 +0,0 @@
1
- ---
2
- name: graphql-spring
3
- description: >
4
- Spring Boot GraphQL. Spring for GraphQL, resolvers, DataLoader, subscriptions.
5
- Trigger: apigen-graphql, @QueryMapping, @MutationMapping, DataLoader, GraphQL Java
6
- tools:
7
- - Read
8
- - Write
9
- - Edit
10
- - Bash
11
- - Grep
12
- metadata:
13
- author: apigen-team
14
- version: "1.0"
15
- tags: [graphql, spring-boot, resolvers, java]
16
- scope: ["apigen-graphql/**"]
17
- ---
18
-
19
- # GraphQL Spring Boot (apigen-graphql)
20
-
21
- ## Configuration
22
-
23
- ```yaml
24
- spring:
25
- graphql:
26
- graphiql:
27
- enabled: true
28
- path: /graphiql
29
- schema:
30
- locations: classpath:graphql/
31
- printer:
32
- enabled: true
33
- websocket:
34
- path: /graphql
35
-
36
- apigen:
37
- graphql:
38
- enabled: true
39
- max-depth: 10
40
- max-complexity: 200
41
- introspection-enabled: ${DEBUG:false}
42
- ```
43
-
44
- ## Schema Definition
45
-
46
- ```graphql
47
- # src/main/resources/graphql/schema.graphqls
48
-
49
- type Query {
50
- user(id: ID!): User
51
- users(page: Int = 0, size: Int = 20): UserConnection!
52
- searchUsers(query: String!): [User!]!
53
- }
54
-
55
- type Mutation {
56
- createUser(input: CreateUserInput!): User!
57
- updateUser(id: ID!, input: UpdateUserInput!): User!
58
- deleteUser(id: ID!): Boolean!
59
- }
60
-
61
- type Subscription {
62
- userCreated: User!
63
- userUpdated(id: ID!): User!
64
- }
65
-
66
- type User {
67
- id: ID!
68
- email: String!
69
- name: String
70
- posts(first: Int, after: String): PostConnection!
71
- createdAt: DateTime!
72
- }
73
-
74
- type Post {
75
- id: ID!
76
- title: String!
77
- author: User!
78
- }
79
-
80
- type UserConnection {
81
- edges: [UserEdge!]!
82
- pageInfo: PageInfo!
83
- totalCount: Int!
84
- }
85
-
86
- type UserEdge {
87
- cursor: String!
88
- node: User!
89
- }
90
-
91
- type PageInfo {
92
- hasNextPage: Boolean!
93
- hasPreviousPage: Boolean!
94
- startCursor: String
95
- endCursor: String
96
- }
97
-
98
- input CreateUserInput {
99
- email: String!
100
- name: String
101
- password: String!
102
- }
103
-
104
- input UpdateUserInput {
105
- name: String
106
- email: String
107
- }
108
-
109
- scalar DateTime
110
- ```
111
-
112
- ## Query Controller
113
-
114
- ```java
115
- @Controller
116
- public class UserGraphQLController {
117
-
118
- private final UserService userService;
119
-
120
- @QueryMapping
121
- public User user(@Argument UUID id) {
122
- return userService.findById(id)
123
- .orElse(null);
124
- }
125
-
126
- @QueryMapping
127
- public Connection<User> users(
128
- @Argument int page,
129
- @Argument int size) {
130
- Page<User> userPage = userService.findAll(PageRequest.of(page, size));
131
- return toConnection(userPage);
132
- }
133
-
134
- @QueryMapping
135
- public List<User> searchUsers(@Argument String query) {
136
- return userService.search(query);
137
- }
138
-
139
- // Nested field resolver
140
- @SchemaMapping(typeName = "User", field = "posts")
141
- public Connection<Post> posts(
142
- User user,
143
- @Argument Integer first,
144
- @Argument String after) {
145
- return postService.findByAuthorId(user.getId(), first, after);
146
- }
147
- }
148
- ```
149
-
150
- ## Mutation Controller
151
-
152
- ```java
153
- @Controller
154
- public class UserMutationController {
155
-
156
- private final UserService userService;
157
- private final ApplicationEventPublisher eventPublisher;
158
-
159
- @MutationMapping
160
- public User createUser(@Argument("input") @Valid CreateUserInput input) {
161
- User user = userService.create(input);
162
- eventPublisher.publishEvent(new UserCreatedEvent(user));
163
- return user;
164
- }
165
-
166
- @MutationMapping
167
- public User updateUser(
168
- @Argument UUID id,
169
- @Argument("input") @Valid UpdateUserInput input) {
170
- return userService.update(id, input);
171
- }
172
-
173
- @MutationMapping
174
- public boolean deleteUser(@Argument UUID id) {
175
- userService.delete(id);
176
- return true;
177
- }
178
- }
179
- ```
180
-
181
- ## Subscription Controller
182
-
183
- ```java
184
- @Controller
185
- public class UserSubscriptionController {
186
-
187
- private final Sinks.Many<User> userCreatedSink =
188
- Sinks.many().multicast().onBackpressureBuffer();
189
-
190
- @SubscriptionMapping
191
- public Flux<User> userCreated() {
192
- return userCreatedSink.asFlux();
193
- }
194
-
195
- @SubscriptionMapping
196
- public Flux<User> userUpdated(@Argument UUID id) {
197
- return userUpdatedSink.asFlux()
198
- .filter(user -> user.getId().equals(id));
199
- }
200
-
201
- @EventListener
202
- public void onUserCreated(UserCreatedEvent event) {
203
- userCreatedSink.tryEmitNext(event.getUser());
204
- }
205
- }
206
- ```
207
-
208
- ## DataLoader Configuration
209
-
210
- ```java
211
- @Configuration
212
- public class DataLoaderConfiguration {
213
-
214
- @Bean
215
- public BatchLoaderRegistry batchLoaderRegistry(
216
- UserRepository userRepository,
217
- PostRepository postRepository) {
218
-
219
- return BatchLoaderRegistry.create()
220
- .registerMappedBatchLoader(
221
- "usersById",
222
- (Set<UUID> ids, BatchLoaderEnvironment env) ->
223
- Mono.fromCallable(() ->
224
- userRepository.findAllById(ids).stream()
225
- .collect(Collectors.toMap(User::getId, Function.identity()))
226
- )
227
- )
228
- .registerMappedBatchLoader(
229
- "postsByAuthorId",
230
- (Set<UUID> authorIds, BatchLoaderEnvironment env) ->
231
- Mono.fromCallable(() ->
232
- postRepository.findByAuthorIdIn(authorIds).stream()
233
- .collect(Collectors.groupingBy(Post::getAuthorId))
234
- )
235
- );
236
- }
237
- }
238
-
239
- // Using DataLoader in resolver
240
- @Controller
241
- public class PostGraphQLController {
242
-
243
- @SchemaMapping(typeName = "Post", field = "author")
244
- public CompletableFuture<User> author(
245
- Post post,
246
- DataLoader<UUID, User> usersById) {
247
- return usersById.load(post.getAuthorId());
248
- }
249
- }
250
- ```
251
-
252
- ## Custom Scalar
253
-
254
- ```java
255
- @Configuration
256
- public class ScalarConfiguration {
257
-
258
- @Bean
259
- public RuntimeWiringConfigurer runtimeWiringConfigurer() {
260
- return wiringBuilder -> wiringBuilder
261
- .scalar(ExtendedScalars.DateTime)
262
- .scalar(ExtendedScalars.UUID)
263
- .scalar(ExtendedScalars.JSON);
264
- }
265
- }
266
- ```
267
-
268
- ## Exception Handling
269
-
270
- ```java
271
- @ControllerAdvice
272
- public class GraphQLExceptionHandler {
273
-
274
- @GraphQlExceptionHandler
275
- public GraphQLError handleNotFoundException(ResourceNotFoundException ex) {
276
- return GraphQLError.newError()
277
- .errorType(ErrorType.NOT_FOUND)
278
- .message(ex.getMessage())
279
- .build();
280
- }
281
-
282
- @GraphQlExceptionHandler
283
- public GraphQLError handleValidation(ConstraintViolationException ex) {
284
- return GraphQLError.newError()
285
- .errorType(ErrorType.BAD_REQUEST)
286
- .message("Validation failed")
287
- .extensions(Map.of(
288
- "errors", ex.getConstraintViolations().stream()
289
- .map(cv -> Map.of(
290
- "field", cv.getPropertyPath().toString(),
291
- "message", cv.getMessage()
292
- ))
293
- .toList()
294
- ))
295
- .build();
296
- }
297
- }
298
- ```
299
-
300
- ## Query Complexity
301
-
302
- ```java
303
- @Configuration
304
- public class GraphQLSecurityConfiguration {
305
-
306
- @Bean
307
- public Instrumentation maxQueryDepthInstrumentation() {
308
- return new MaxQueryDepthInstrumentation(10);
309
- }
310
-
311
- @Bean
312
- public Instrumentation maxQueryComplexityInstrumentation() {
313
- return new MaxQueryComplexityInstrumentation(200);
314
- }
315
- }
316
- ```
317
-
318
- ## Authorization
319
-
320
- ```java
321
- @Controller
322
- public class SecuredGraphQLController {
323
-
324
- @QueryMapping
325
- @PreAuthorize("hasRole('USER')")
326
- public User me(@AuthenticationPrincipal UserDetails user) {
327
- return userService.findByEmail(user.getUsername())
328
- .orElseThrow();
329
- }
330
-
331
- @MutationMapping
332
- @PreAuthorize("hasRole('ADMIN')")
333
- public boolean deleteUser(@Argument UUID id) {
334
- userService.delete(id);
335
- return true;
336
- }
337
-
338
- // Field-level authorization
339
- @SchemaMapping(typeName = "User", field = "email")
340
- @PreAuthorize("hasRole('ADMIN') or #user.id == authentication.principal.id")
341
- public String email(User user) {
342
- return user.getEmail();
343
- }
344
- }
345
- ```
346
-
347
- ## Testing
348
-
349
- ```java
350
- @GraphQlTest(UserGraphQLController.class)
351
- class UserGraphQLControllerTest {
352
-
353
- @Autowired
354
- private GraphQlTester graphQlTester;
355
-
356
- @MockBean
357
- private UserService userService;
358
-
359
- @Test
360
- void shouldGetUser() {
361
- User user = new User(UUID.randomUUID(), "test@example.com", "Test");
362
- when(userService.findById(user.getId())).thenReturn(Optional.of(user));
363
-
364
- graphQlTester.documentName("getUser")
365
- .variable("id", user.getId())
366
- .execute()
367
- .path("user.email").entity(String.class).isEqualTo("test@example.com")
368
- .path("user.name").entity(String.class).isEqualTo("Test");
369
- }
370
-
371
- @Test
372
- void shouldCreateUser() {
373
- graphQlTester.document("""
374
- mutation CreateUser($input: CreateUserInput!) {
375
- createUser(input: $input) {
376
- id
377
- email
378
- }
379
- }
380
- """)
381
- .variable("input", Map.of(
382
- "email", "new@example.com",
383
- "name", "New User",
384
- "password", "SecurePass123"
385
- ))
386
- .execute()
387
- .path("createUser.email").entity(String.class).isEqualTo("new@example.com");
388
- }
389
- }
390
- ```
391
-
392
- ## Related Skills
393
-
394
- - `graphql-concepts`: GraphQL concepts
395
- - `spring-boot-4`: Spring Boot 4.0 patterns
396
- - `apigen-architecture`: Overall system architecture
397
-
398
-
@@ -1,283 +0,0 @@
1
- ---
2
- name: grpc-concepts
3
- description: >
4
- gRPC concepts. Protocol Buffers, service definitions, streaming, error handling.
5
- Trigger: gRPC, protobuf, Protocol Buffers, RPC, streaming, service definition
6
- tools:
7
- - Read
8
- - Write
9
- - Edit
10
- - Grep
11
- metadata:
12
- author: apigen-team
13
- version: "1.0"
14
- tags: [grpc, protobuf, rpc, microservices]
15
- scope: ["**/grpc/**"]
16
- ---
17
-
18
- # gRPC Concepts
19
-
20
- ## What is gRPC?
21
-
22
- ```
23
- gRPC = Google Remote Procedure Call
24
-
25
- Features:
26
- - Binary protocol (Protocol Buffers)
27
- - HTTP/2 transport
28
- - Bi-directional streaming
29
- - Language agnostic
30
- - Strong typing
31
-
32
- Use cases:
33
- - Microservices communication
34
- - Real-time data streaming
35
- - Mobile-backend communication
36
- - IoT device communication
37
- ```
38
-
39
- ## Protocol Buffers (Protobuf)
40
-
41
- ### Message Definition
42
- ```protobuf
43
- syntax = "proto3";
44
-
45
- package com.example.user;
46
-
47
- option java_package = "com.example.user.proto";
48
- option java_multiple_files = true;
49
-
50
- message User {
51
- string id = 1;
52
- string email = 2;
53
- string name = 3;
54
- UserStatus status = 4;
55
- google.protobuf.Timestamp created_at = 5;
56
- repeated Role roles = 6;
57
- optional string phone = 7; // proto3 optional
58
- }
59
-
60
- enum UserStatus {
61
- USER_STATUS_UNSPECIFIED = 0;
62
- USER_STATUS_ACTIVE = 1;
63
- USER_STATUS_INACTIVE = 2;
64
- USER_STATUS_SUSPENDED = 3;
65
- }
66
-
67
- message Role {
68
- string id = 1;
69
- string name = 2;
70
- }
71
- ```
72
-
73
- ### Field Numbers
74
- ```
75
- Rules:
76
- - 1-15: Single byte encoding (use for frequent fields)
77
- - 16-2047: Two byte encoding
78
- - 19000-19999: Reserved by protobuf
79
- - Once assigned, never change
80
-
81
- Best practices:
82
- - Reserve removed field numbers
83
- - Document field number allocations
84
- ```
85
-
86
- ## Service Definition
87
-
88
- ```protobuf
89
- service UserService {
90
- // Unary RPC
91
- rpc GetUser(GetUserRequest) returns (User);
92
-
93
- // Server streaming
94
- rpc ListUsers(ListUsersRequest) returns (stream User);
95
-
96
- // Client streaming
97
- rpc CreateUsers(stream CreateUserRequest) returns (BatchCreateResponse);
98
-
99
- // Bi-directional streaming
100
- rpc Chat(stream ChatMessage) returns (stream ChatMessage);
101
- }
102
-
103
- message GetUserRequest {
104
- string user_id = 1;
105
- }
106
-
107
- message ListUsersRequest {
108
- int32 page_size = 1;
109
- string page_token = 2;
110
- UserFilter filter = 3;
111
- }
112
-
113
- message UserFilter {
114
- optional UserStatus status = 1;
115
- optional string email_contains = 2;
116
- }
117
- ```
118
-
119
- ## RPC Types
120
-
121
- ### Unary RPC
122
- ```
123
- Client sends single request, server returns single response
124
-
125
- Client ──request──> Server
126
- Client <──response── Server
127
-
128
- Use for: CRUD operations, simple queries
129
- ```
130
-
131
- ### Server Streaming
132
- ```
133
- Client sends single request, server returns stream of responses
134
-
135
- Client ──request──> Server
136
- Client <──response1── Server
137
- Client <──response2── Server
138
- Client <──response3── Server
139
-
140
- Use for: Large result sets, real-time updates
141
- ```
142
-
143
- ### Client Streaming
144
- ```
145
- Client sends stream of requests, server returns single response
146
-
147
- Client ──request1──> Server
148
- Client ──request2──>
149
- Client ──request3──>
150
- Client <──response── Server
151
-
152
- Use for: File uploads, batch operations
153
- ```
154
-
155
- ### Bi-directional Streaming
156
- ```
157
- Both client and server send streams
158
-
159
- Client ──request1──> Server
160
- Client <──response1──
161
- Client ──request2──>
162
- Client <──response2──
163
-
164
- Use for: Chat, real-time collaboration
165
- ```
166
-
167
- ## Error Handling
168
-
169
- ### Status Codes
170
- ```
171
- OK (0): Success
172
- CANCELLED (1): Operation cancelled
173
- UNKNOWN (2): Unknown error
174
- INVALID_ARGUMENT (3): Client error
175
- DEADLINE_EXCEEDED (4): Timeout
176
- NOT_FOUND (5): Resource not found
177
- ALREADY_EXISTS (6): Duplicate
178
- PERMISSION_DENIED (7): Authorization failed
179
- UNAUTHENTICATED (16): Authentication required
180
- RESOURCE_EXHAUSTED (8): Rate limited
181
- FAILED_PRECONDITION (9): State conflict
182
- ABORTED (10): Concurrency conflict
183
- OUT_OF_RANGE (11): Invalid range
184
- UNIMPLEMENTED (12): Not implemented
185
- INTERNAL (13): Server error
186
- UNAVAILABLE (14): Service unavailable
187
- DATA_LOSS (15): Unrecoverable data loss
188
- ```
189
-
190
- ### Rich Error Details
191
- ```protobuf
192
- import "google/rpc/error_details.proto";
193
-
194
- // Error with field violations
195
- google.rpc.BadRequest bad_request = {
196
- field_violations: [
197
- {field: "email", description: "Invalid email format"},
198
- {field: "password", description: "Too short"}
199
- ]
200
- };
201
-
202
- // Error with retry info
203
- google.rpc.RetryInfo retry_info = {
204
- retry_delay: {seconds: 30}
205
- };
206
- ```
207
-
208
- ## Metadata
209
-
210
- ```
211
- Headers sent with requests:
212
-
213
- Standard metadata:
214
- - :authority (host)
215
- - :path (method)
216
- - content-type
217
- - user-agent
218
- - grpc-timeout
219
-
220
- Custom metadata:
221
- - authorization: Bearer token
222
- - x-request-id: correlation ID
223
- - x-tenant-id: multi-tenancy
224
- ```
225
-
226
- ## Interceptors
227
-
228
- ```
229
- Client-side:
230
- 1. Add authentication token
231
- 2. Log request/response
232
- 3. Handle errors
233
- 4. Add tracing context
234
-
235
- Server-side:
236
- 1. Validate authentication
237
- 2. Rate limiting
238
- 3. Log request/response
239
- 4. Extract tracing context
240
- ```
241
-
242
- ## Best Practices
243
-
244
- ```
245
- Proto design:
246
- ✅ Use descriptive field names
247
- ✅ Reserve deprecated field numbers
248
- ✅ Use well-known types (Timestamp, Duration)
249
- ✅ Define enums with UNSPECIFIED = 0
250
- ✅ Use optional for nullable fields
251
-
252
- Performance:
253
- ✅ Reuse channels/stubs
254
- ✅ Use streaming for large data
255
- ✅ Set appropriate deadlines
256
- ✅ Enable compression
257
-
258
- Versioning:
259
- ✅ Add fields (backward compatible)
260
- ❌ Remove/rename fields
261
- ❌ Change field types
262
- ❌ Change field numbers
263
- ```
264
-
265
- ## gRPC vs REST
266
-
267
- ```
268
- | Aspect | gRPC | REST |
269
- |--------|------|------|
270
- | Protocol | HTTP/2 | HTTP/1.1 or 2 |
271
- | Format | Binary (Protobuf) | Text (JSON) |
272
- | Contract | Strong (.proto) | Weak (OpenAPI) |
273
- | Streaming | Native | Limited |
274
- | Browser | Needs grpc-web | Native |
275
- | Tools | Limited | Extensive |
276
- ```
277
-
278
- ## Related Skills
279
-
280
- - `grpc-spring`: Spring Boot gRPC implementation
281
- - `apigen-architecture`: Overall system architecture
282
-
283
-