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,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
-