@graphql-hive/federation-gateway-audit 0.0.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 (293) hide show
  1. package/.changeset/@graphql-hive_federation-gateway-audit-293-dependencies.md +5 -0
  2. package/.changeset/README.md +9 -0
  3. package/.changeset/config.json +18 -0
  4. package/.changeset/funky-times-cry.md +5 -0
  5. package/.github/CONTRIBUTING.md +9 -0
  6. package/.github/workflows/ci.yaml +97 -0
  7. package/.github/workflows/release.yml +58 -0
  8. package/LICENSE +21 -0
  9. package/README.md +113 -0
  10. package/REPORT.md +812 -0
  11. package/dist/cli.js +547 -0
  12. package/dist/env-Dj2M4ll3.cjs +15 -0
  13. package/dist/env-j1f_SZtG.js +13 -0
  14. package/dist/env-j1f_SZtG.mjs +13 -0
  15. package/dist/index--3rcSZqA.js +227 -0
  16. package/dist/index-0MDIXUzP.cjs +589 -0
  17. package/dist/index-19eD5lFk.mjs +163 -0
  18. package/dist/index-1ZtG04bN.js +222 -0
  19. package/dist/index-1nZTfbJn.cjs +168 -0
  20. package/dist/index-1smMXABT.mjs +227 -0
  21. package/dist/index-2oy7cA9A.js +225 -0
  22. package/dist/index-3BM15w2Y.mjs +234 -0
  23. package/dist/index-3CyAnc7j.js +234 -0
  24. package/dist/index-4Vj-ND7j.mjs +213 -0
  25. package/dist/index-4swHVe9x.cjs +507 -0
  26. package/dist/index-6itLA31k.js +382 -0
  27. package/dist/index-6qNpP2wc.mjs +238 -0
  28. package/dist/index-81CiuWlP.mjs +333 -0
  29. package/dist/index-8FxjbyOU.cjs +236 -0
  30. package/dist/index-A2YbwKzc.mjs +288 -0
  31. package/dist/index-B-YHHt9g.js +333 -0
  32. package/dist/index-B0coRevy.mjs +337 -0
  33. package/dist/index-B1NAc0TI.cjs +215 -0
  34. package/dist/index-B1WvIzTg.js +371 -0
  35. package/dist/index-B38OpRtf.js +166 -0
  36. package/dist/index-B3aDw4Tt.js +359 -0
  37. package/dist/index-B55AdoQy.js +273 -0
  38. package/dist/index-B7cr8XE-.js +194 -0
  39. package/dist/index-B7zN3YzE.cjs +683 -0
  40. package/dist/index-B8X923W3.mjs +262 -0
  41. package/dist/index-B958BFYC.cjs +224 -0
  42. package/dist/index-B9T896rB.mjs +163 -0
  43. package/dist/index-BA3ERnyq.mjs +234 -0
  44. package/dist/index-BDMi6sOm.cjs +252 -0
  45. package/dist/index-BDNWXFb_.mjs +304 -0
  46. package/dist/index-BEMScD_X.cjs +173 -0
  47. package/dist/index-BF0H5kP0.cjs +384 -0
  48. package/dist/index-BGC0_vWj.cjs +335 -0
  49. package/dist/index-BGNmWPAk.js +381 -0
  50. package/dist/index-BGUm947D.cjs +229 -0
  51. package/dist/index-BJB0tRA1.js +550 -0
  52. package/dist/index-BKcwbRZx.cjs +339 -0
  53. package/dist/index-BKpVb_h9.cjs +236 -0
  54. package/dist/index-BPFol6Ww.mjs +129 -0
  55. package/dist/index-BPza8i2Q.mjs +213 -0
  56. package/dist/index-BQQgQaGz.cjs +552 -0
  57. package/dist/index-BReFIfq_.cjs +361 -0
  58. package/dist/index-BS7JyQSU.js +250 -0
  59. package/dist/index-BSWSgZCO.cjs +252 -0
  60. package/dist/index-BStXx4OK.js +705 -0
  61. package/dist/index-BSwOAvti.js +288 -0
  62. package/dist/index-BWO8QbMB.mjs +587 -0
  63. package/dist/index-BYEdADrG.cjs +227 -0
  64. package/dist/index-B_eGT6oX.js +225 -0
  65. package/dist/index-B_u5Boud.js +333 -0
  66. package/dist/index-BaH3FI9i.cjs +361 -0
  67. package/dist/index-BaluTf1I.cjs +707 -0
  68. package/dist/index-BblYlZ3A.cjs +131 -0
  69. package/dist/index-BcZC0OIN.js +234 -0
  70. package/dist/index-Bcjyyjhh.mjs +259 -0
  71. package/dist/index-BcoW0aPo.cjs +165 -0
  72. package/dist/index-BdNZKlDU.js +284 -0
  73. package/dist/index-Bf81cAA1.mjs +444 -0
  74. package/dist/index-Bg3H3fgZ.js +259 -0
  75. package/dist/index-Bgl_1Y6Q.mjs +681 -0
  76. package/dist/index-BgmItHIB.mjs +129 -0
  77. package/dist/index-BgryMCqm.mjs +213 -0
  78. package/dist/index-Bh6a3eXK.mjs +227 -0
  79. package/dist/index-BhPDIfmU.js +304 -0
  80. package/dist/index-BiTzMTFn.js +304 -0
  81. package/dist/index-BjbmOyBP.cjs +215 -0
  82. package/dist/index-BjwZX2iS.mjs +273 -0
  83. package/dist/index-Bm8hqSRd.cjs +168 -0
  84. package/dist/index-BmOn6xYL.js +228 -0
  85. package/dist/index-BmQrhPXB.cjs +131 -0
  86. package/dist/index-Bnb8TpOO.js +280 -0
  87. package/dist/index-BndUB2KV.mjs +381 -0
  88. package/dist/index-Bo74nI4n.js +129 -0
  89. package/dist/index-BoGmP6Cy.cjs +230 -0
  90. package/dist/index-BodMjESw.mjs +250 -0
  91. package/dist/index-BpJZCoVH.mjs +250 -0
  92. package/dist/index-Br-Y1qC_.cjs +446 -0
  93. package/dist/index-BrFtcRgi.mjs +194 -0
  94. package/dist/index-BsPxDJAB.mjs +238 -0
  95. package/dist/index-Bu7pZnPO.cjs +170 -0
  96. package/dist/index-Bu8SXnTf.mjs +227 -0
  97. package/dist/index-BuNNRp3W.mjs +117 -0
  98. package/dist/index-Bwh8HVkw.cjs +384 -0
  99. package/dist/index-BxK3Y72_.js +227 -0
  100. package/dist/index-BxPUzymh.cjs +208 -0
  101. package/dist/index-ByUUB7Zn.js +250 -0
  102. package/dist/index-ByUr80PD.cjs +306 -0
  103. package/dist/index-ByZa9qm8.mjs +273 -0
  104. package/dist/index-BzPCjhuQ.cjs +264 -0
  105. package/dist/index-Bz_LTy1A.mjs +222 -0
  106. package/dist/index-C05_HMLC.js +225 -0
  107. package/dist/index-C15P-_1j.cjs +229 -0
  108. package/dist/index-C1GgHOiD.js +228 -0
  109. package/dist/index-C4Pk-zTm.mjs +227 -0
  110. package/dist/index-C4dnTlBf.js +262 -0
  111. package/dist/index-C6LW00iX.mjs +505 -0
  112. package/dist/index-C6nkQ480.js +225 -0
  113. package/dist/index-C8Mu4K9Q.cjs +383 -0
  114. package/dist/index-C8mB7yWC.mjs +288 -0
  115. package/dist/index-C9Eh7qBC.js +273 -0
  116. package/dist/index-CAJ9YPxc.js +681 -0
  117. package/dist/index-CD03pVUt.cjs +373 -0
  118. package/dist/index-CD8GiuIg.js +227 -0
  119. package/dist/index-CHB_0VqK.mjs +333 -0
  120. package/dist/index-CKEgb_R7.cjs +215 -0
  121. package/dist/index-CLsasg69.js +228 -0
  122. package/dist/index-CMdC_Cah.js +213 -0
  123. package/dist/index-CNOcqGKC.cjs +227 -0
  124. package/dist/index-CNvZCDZa.js +166 -0
  125. package/dist/index-CO0GiXGE.js +168 -0
  126. package/dist/index-COGhiFjk.mjs +284 -0
  127. package/dist/index-COIlelpZ.mjs +262 -0
  128. package/dist/index-CPph-RFN.mjs +168 -0
  129. package/dist/index-CPu_XkjY.mjs +304 -0
  130. package/dist/index-CQ5t4ZXm.js +117 -0
  131. package/dist/index-CQeQ1nto.js +681 -0
  132. package/dist/index-CSc_T8Lu.js +218 -0
  133. package/dist/index-CUFKuE64.js +550 -0
  134. package/dist/index-CW8h3l6M.js +262 -0
  135. package/dist/index-CWrng7Hd.mjs +550 -0
  136. package/dist/index-CWuObqnS.mjs +587 -0
  137. package/dist/index-CX7-wc6X.cjs +1837 -0
  138. package/dist/index-CXviN8qZ.cjs +224 -0
  139. package/dist/index-CY9mowWW.mjs +705 -0
  140. package/dist/index-C_pTgB_1.js +194 -0
  141. package/dist/index-C_qaNb-X.mjs +225 -0
  142. package/dist/index-Ca0FeU7u.js +505 -0
  143. package/dist/index-Cb3ImEjd.cjs +165 -0
  144. package/dist/index-Cbhvi8yk.cjs +229 -0
  145. package/dist/index-Cc3vrs6_.mjs +228 -0
  146. package/dist/index-CcIXvx40.mjs +171 -0
  147. package/dist/index-CdaeeF3f.cjs +306 -0
  148. package/dist/index-CddVoIp2.js +213 -0
  149. package/dist/index-CeiRxGcN.mjs +218 -0
  150. package/dist/index-ChefKWWr.mjs +381 -0
  151. package/dist/index-Cj2ocjXI.cjs +227 -0
  152. package/dist/index-CkWEXzTN.js +129 -0
  153. package/dist/index-Ckhb9QAu.cjs +264 -0
  154. package/dist/index-CklJfQlf.cjs +220 -0
  155. package/dist/index-Cmh7PJUd.mjs +372 -0
  156. package/dist/index-Cn0ZJkAv.mjs +280 -0
  157. package/dist/index-CqTzarV1.mjs +198 -0
  158. package/dist/index-CrUbbFxE.js +284 -0
  159. package/dist/index-CsKaFB2K.mjs +228 -0
  160. package/dist/index-Cu8Ii5r7.cjs +335 -0
  161. package/dist/index-Cuw9ylL-.mjs +371 -0
  162. package/dist/index-CwOULUAt.mjs +382 -0
  163. package/dist/index-CyVnRqjE.cjs +196 -0
  164. package/dist/index-D-1dDKiZ.mjs +227 -0
  165. package/dist/index-D00bnaJy.cjs +220 -0
  166. package/dist/index-D07xiOJ6.cjs +446 -0
  167. package/dist/index-D1Ip6ro6.js +458 -0
  168. package/dist/index-D1Ymvd2b.cjs +286 -0
  169. package/dist/index-D5jOBT3f.cjs +240 -0
  170. package/dist/index-D5tEp8IU.js +337 -0
  171. package/dist/index-D7WuGKYY.cjs +227 -0
  172. package/dist/index-D8Dp6TnQ.cjs +1837 -0
  173. package/dist/index-D9OKpqgG.js +381 -0
  174. package/dist/index-DBMI2EcB.cjs +170 -0
  175. package/dist/index-DBRUKV0U.mjs +225 -0
  176. package/dist/index-DEvExC5x.cjs +119 -0
  177. package/dist/index-DEzxU_gQ.cjs +507 -0
  178. package/dist/index-DFypMD6R.cjs +261 -0
  179. package/dist/index-DHRqE92a.cjs +290 -0
  180. package/dist/index-DISym5OL.js +198 -0
  181. package/dist/index-DJ3ndv3i.mjs +705 -0
  182. package/dist/index-DJXP-Gmp.js +218 -0
  183. package/dist/index-DJlXDQOY.cjs +200 -0
  184. package/dist/index-DLW4GEJl.cjs +229 -0
  185. package/dist/index-DLu9E2Vq.js +238 -0
  186. package/dist/index-DM4ddIL6.js +382 -0
  187. package/dist/index-DMgHLbwU.cjs +339 -0
  188. package/dist/index-DN-ScBql.mjs +458 -0
  189. package/dist/index-DOkkIHER.js +163 -0
  190. package/dist/index-DRY8sDun.cjs +165 -0
  191. package/dist/index-DS3cjugP.mjs +171 -0
  192. package/dist/index-DS86eFsI.mjs +1835 -0
  193. package/dist/index-DUlT8CJ2.js +458 -0
  194. package/dist/index-DV1F4nxP.js +372 -0
  195. package/dist/index-DXsAcJ-o.mjs +359 -0
  196. package/dist/index-DZws2w4w.cjs +229 -0
  197. package/dist/index-D_HiVe2_.cjs +200 -0
  198. package/dist/index-Da6L5V_Z.mjs +681 -0
  199. package/dist/index-Dbb-jnWf.js +206 -0
  200. package/dist/index-DdXy_-T9.js +444 -0
  201. package/dist/index-DddNFRG3.js +337 -0
  202. package/dist/index-DejhKwvw.cjs +173 -0
  203. package/dist/index-DfBdD-5Z.cjs +383 -0
  204. package/dist/index-Df_KCbC4.mjs +213 -0
  205. package/dist/index-DiDq1sL6.cjs +240 -0
  206. package/dist/index-DiuJQ9Mq.js +198 -0
  207. package/dist/index-Djqj3DWJ.js +171 -0
  208. package/dist/index-Dk0q-ENv.mjs +166 -0
  209. package/dist/index-DlFElztE.mjs +163 -0
  210. package/dist/index-DlkxQ-B5.mjs +359 -0
  211. package/dist/index-Dm5kpK9t.js +227 -0
  212. package/dist/index-Dp8mobro.js +444 -0
  213. package/dist/index-DpBWZa1x.cjs +683 -0
  214. package/dist/index-DrkXuLUZ.js +227 -0
  215. package/dist/index-Dsq1FK90.cjs +275 -0
  216. package/dist/index-DtmhGgM8.cjs +282 -0
  217. package/dist/index-Du5MxO_2.mjs +505 -0
  218. package/dist/index-DveYQLCZ.cjs +460 -0
  219. package/dist/index-DxHMqS-W.js +117 -0
  220. package/dist/index-DyTApTHI.cjs +282 -0
  221. package/dist/index-DyTSkAm4.cjs +208 -0
  222. package/dist/index-DygJOEne.mjs +550 -0
  223. package/dist/index-DzAewrkw.js +238 -0
  224. package/dist/index-ESWdD7ek.cjs +215 -0
  225. package/dist/index-EuKHpnHv.mjs +117 -0
  226. package/dist/index-F1A7LMlw.mjs +228 -0
  227. package/dist/index-FP6hvgSw.cjs +552 -0
  228. package/dist/index-GDSrKnPp.mjs +198 -0
  229. package/dist/index-GMCZo-KH.js +222 -0
  230. package/dist/index-IQJLr7nR.js +288 -0
  231. package/dist/index-IawHHRZX.mjs +206 -0
  232. package/dist/index-Jk7MG7tE.cjs +286 -0
  233. package/dist/index-JtGxTXPr.mjs +337 -0
  234. package/dist/index-KAC20a9r.js +359 -0
  235. package/dist/index-LVWQqV-v.js +163 -0
  236. package/dist/index-Ls2fI7y4.js +163 -0
  237. package/dist/index-NB1VDvjW.cjs +374 -0
  238. package/dist/index-NIEZaRYg.cjs +261 -0
  239. package/dist/index-PQXUx1ZR.mjs +1835 -0
  240. package/dist/index-PyaLRKuk.mjs +168 -0
  241. package/dist/index-QQGo-BV1.mjs +444 -0
  242. package/dist/index-QXYDkAsQ.cjs +119 -0
  243. package/dist/index-SmEIf5jz.mjs +259 -0
  244. package/dist/index-UJhFwnD_.mjs +284 -0
  245. package/dist/index-UVyXzNlG.js +705 -0
  246. package/dist/index-UgyHGpUU.mjs +163 -0
  247. package/dist/index-UhQiJabs.cjs +707 -0
  248. package/dist/index-VvuhRvnC.mjs +218 -0
  249. package/dist/index-WPXuueaq.mjs +194 -0
  250. package/dist/index-X4u6bs58.js +259 -0
  251. package/dist/index-XZiO6uje.cjs +275 -0
  252. package/dist/index-YOlsBREZ.cjs +230 -0
  253. package/dist/index-Ytb942t9.js +587 -0
  254. package/dist/index-_2dg_MWu.cjs +460 -0
  255. package/dist/index-eFEW10em.js +213 -0
  256. package/dist/index-eq8bbEej.mjs +225 -0
  257. package/dist/index-f7FiDQMk.js +171 -0
  258. package/dist/index-fBzI1kbw.mjs +225 -0
  259. package/dist/index-fdDnq3vQ.js +163 -0
  260. package/dist/index-fqmAgjhG.js +206 -0
  261. package/dist/index-ikGyewP-.cjs +165 -0
  262. package/dist/index-jft-1bQ6.cjs +230 -0
  263. package/dist/index-l8e8ip4U.js +168 -0
  264. package/dist/index-lkBiml03.js +1835 -0
  265. package/dist/index-mm-YMeoi.js +505 -0
  266. package/dist/index-o7g3iua7.cjs +290 -0
  267. package/dist/index-ojnncNWd.js +587 -0
  268. package/dist/index-q9SCjCJM.mjs +280 -0
  269. package/dist/index-rn-_7-wp.cjs +196 -0
  270. package/dist/index-s27DHpTG.js +1835 -0
  271. package/dist/index-s2HuXM4d.mjs +206 -0
  272. package/dist/index-sbc7nDv3.js +213 -0
  273. package/dist/index-tx0X6vuE.mjs +222 -0
  274. package/dist/index-uCwv2hr-.mjs +166 -0
  275. package/dist/index-vHngHSlz.js +280 -0
  276. package/dist/index-xOtG5E4u.cjs +589 -0
  277. package/dist/index-zJk-Nm6b.mjs +458 -0
  278. package/dist/index-zqxgDrLR.mjs +382 -0
  279. package/dist/index.cjs +233 -0
  280. package/dist/index.d.cts +9 -0
  281. package/dist/index.d.cts.map +1 -0
  282. package/dist/index.d.ts +9 -0
  283. package/dist/index.d.ts.map +1 -0
  284. package/dist/index.js +230 -0
  285. package/dist/index.mjs +230 -0
  286. package/dist/testkit-BtZjdl4n.js +269 -0
  287. package/dist/testkit-BtZjdl4n.mjs +269 -0
  288. package/dist/testkit-C920qivh.js +281 -0
  289. package/dist/testkit-C920qivh.mjs +281 -0
  290. package/dist/testkit-CAf-AsDy.cjs +273 -0
  291. package/dist/testkit-D0rTQ6MD.cjs +286 -0
  292. package/makefile +47 -0
  293. package/package.json +89 -0
@@ -0,0 +1,705 @@
1
+ import { c as createSubgraph, a as createTest, s as serve } from './testkit-C920qivh.mjs';
2
+ import '@apollo/composition';
3
+ import 'graphql';
4
+ import 'fets';
5
+ import '@apollo/subgraph';
6
+ import 'graphql-yoga';
7
+
8
+ const users = [
9
+ {
10
+ id: "u1",
11
+ name: "u1-name",
12
+ username: "u1-username",
13
+ age: 11
14
+ },
15
+ {
16
+ id: "u2",
17
+ name: "u2-name",
18
+ username: "u2-username",
19
+ age: 22
20
+ }
21
+ ];
22
+ const accounts = [
23
+ {
24
+ __typename: "Admin",
25
+ id: "u1",
26
+ name: "Alice",
27
+ isMain: false,
28
+ isActive: true
29
+ },
30
+ {
31
+ __typename: "Admin",
32
+ id: "u2",
33
+ name: "Bob",
34
+ isMain: true,
35
+ isActive: true
36
+ },
37
+ {
38
+ __typename: "Regular",
39
+ id: "u3",
40
+ name: "Charlie",
41
+ isMain: false,
42
+ isActive: true
43
+ }
44
+ ];
45
+
46
+ var a = createSubgraph("a", {
47
+ typeDefs: (
48
+ /* GraphQL */
49
+ `
50
+ extend schema
51
+ @link(
52
+ url: "https://specs.apollo.dev/federation/v2.3"
53
+ import: ["@key", "@shareable"]
54
+ )
55
+
56
+ type Query {
57
+ users: [NodeWithName!]!
58
+ }
59
+
60
+ interface NodeWithName @key(fields: "id") {
61
+ id: ID!
62
+ name: String
63
+ }
64
+
65
+ type User implements NodeWithName @key(fields: "id") {
66
+ id: ID!
67
+ name: String
68
+ age: Int
69
+ }
70
+
71
+ interface Account @key(fields: "id") {
72
+ id: ID!
73
+ }
74
+
75
+ type Admin implements Account @key(fields: "id") {
76
+ id: ID!
77
+ isMain: Boolean!
78
+ isActive: Boolean! @shareable
79
+ }
80
+
81
+ type Regular implements Account @key(fields: "id") {
82
+ id: ID!
83
+ isMain: Boolean!
84
+ }
85
+ `
86
+ ),
87
+ resolvers: {
88
+ NodeWithName: {
89
+ __resolveReference(key) {
90
+ const node = users.find((u) => u.id === key.id);
91
+ if (!node) {
92
+ return null;
93
+ }
94
+ return {
95
+ __typename: "User",
96
+ id: node.id,
97
+ name: node.name,
98
+ age: node.age
99
+ };
100
+ }
101
+ },
102
+ User: {
103
+ __resolveReference(key) {
104
+ const user = users.find((u) => u.id === key.id);
105
+ if (!user) {
106
+ return null;
107
+ }
108
+ return {
109
+ __typename: "User",
110
+ id: user.id,
111
+ name: user.name,
112
+ age: user.age
113
+ };
114
+ }
115
+ },
116
+ Account: {
117
+ __resolveReference(key) {
118
+ const account = accounts.find((account2) => account2.id === key.id);
119
+ if (!account) {
120
+ return null;
121
+ }
122
+ return {
123
+ __typename: account.__typename,
124
+ id: account.id,
125
+ isActive: account.isActive
126
+ };
127
+ }
128
+ },
129
+ Admin: {
130
+ __resolveReference(key) {
131
+ const admin = accounts.find((account) => account.id === key.id);
132
+ if (!admin) {
133
+ return null;
134
+ }
135
+ if (admin.__typename !== "Admin") {
136
+ return null;
137
+ }
138
+ return {
139
+ __typename: admin.__typename,
140
+ id: admin.id,
141
+ isMain: admin.isMain,
142
+ isActive: admin.isActive
143
+ };
144
+ },
145
+ isMain(admin) {
146
+ if (typeof admin.isMain === "boolean") {
147
+ return admin.isMain;
148
+ }
149
+ const account = accounts.find((a) => a.id === admin.id);
150
+ if (!account) {
151
+ return null;
152
+ }
153
+ return account.isMain;
154
+ }
155
+ },
156
+ Regular: {
157
+ __resolveReference(key) {
158
+ const admin = accounts.find((account) => account.id === key.id);
159
+ if (!admin) {
160
+ return null;
161
+ }
162
+ return {
163
+ __typename: admin.__typename,
164
+ id: admin.id,
165
+ isMain: admin.isMain,
166
+ isActive: admin.isActive
167
+ };
168
+ },
169
+ isMain(admin) {
170
+ if (typeof admin.isMain === "boolean") {
171
+ return admin.isMain;
172
+ }
173
+ const account = accounts.find((a) => a.id === admin.id);
174
+ if (!account) {
175
+ return null;
176
+ }
177
+ return account.isMain;
178
+ }
179
+ },
180
+ Query: {
181
+ users() {
182
+ return users.map((u) => ({
183
+ __typename: "User",
184
+ id: u.id,
185
+ name: u.name,
186
+ age: u.age
187
+ }));
188
+ }
189
+ }
190
+ }
191
+ });
192
+
193
+ var b = createSubgraph("b", {
194
+ typeDefs: (
195
+ /* GraphQL */
196
+ `
197
+ extend schema
198
+ @link(
199
+ url: "https://specs.apollo.dev/federation/v2.3"
200
+ import: ["@key", "@interfaceObject", "@shareable"]
201
+ )
202
+
203
+ type Query {
204
+ anotherUsers: [NodeWithName]
205
+ accounts: [Account] @shareable
206
+ }
207
+
208
+ type Account @key(fields: "id") @interfaceObject {
209
+ id: ID!
210
+ name: String!
211
+ }
212
+
213
+ type NodeWithName @key(fields: "id") @interfaceObject {
214
+ id: ID!
215
+ username: String
216
+ }
217
+ `
218
+ ),
219
+ resolvers: {
220
+ NodeWithName: {
221
+ __resolveReference(key) {
222
+ const node = users.find((u) => u.id === key.id);
223
+ if (!node) {
224
+ return null;
225
+ }
226
+ return {
227
+ __typename: "User",
228
+ id: node.id,
229
+ username: node.username
230
+ };
231
+ },
232
+ username(node) {
233
+ const user = users.find((u) => u.id === node.id);
234
+ if (!user) {
235
+ return null;
236
+ }
237
+ return user.username;
238
+ }
239
+ },
240
+ Account: {
241
+ __resolveReference(key) {
242
+ const account = accounts.find((account2) => account2.id === key.id);
243
+ if (!account) {
244
+ return null;
245
+ }
246
+ return {
247
+ // I deliberately return a wrong __typename here to make sure it's not used by the gateway
248
+ __typename: "Never",
249
+ id: account.id
250
+ };
251
+ },
252
+ name(account) {
253
+ return accounts.find((u) => u.id === account.id)?.name;
254
+ }
255
+ },
256
+ Query: {
257
+ anotherUsers() {
258
+ return users.map((u) => ({
259
+ __typename: "User",
260
+ id: u.id,
261
+ username: u.username
262
+ }));
263
+ },
264
+ accounts() {
265
+ return accounts.map((user) => {
266
+ return {
267
+ // I deliberately return a wrong __typename here to make sure it's not used by the gateway
268
+ __typename: "Never",
269
+ id: user.id
270
+ };
271
+ });
272
+ }
273
+ }
274
+ }
275
+ });
276
+
277
+ var c = createSubgraph("c", {
278
+ typeDefs: (
279
+ /* GraphQL */
280
+ `
281
+ extend schema
282
+ @link(
283
+ url: "https://specs.apollo.dev/federation/v2.3"
284
+ import: ["@key", "@interfaceObject", "@shareable"]
285
+ )
286
+
287
+ type Account @key(fields: "id") @interfaceObject {
288
+ id: ID!
289
+ isActive: Boolean! @shareable
290
+ }
291
+ `
292
+ ),
293
+ resolvers: {
294
+ Account: {
295
+ __resolveReference(key) {
296
+ const account = accounts.find((account2) => account2.id === key.id);
297
+ if (!account) {
298
+ return null;
299
+ }
300
+ return {
301
+ // I deliberately return a wrong __typename here to make sure it's not used by the gateway
302
+ __typename: "Never",
303
+ id: account.id
304
+ };
305
+ },
306
+ isActive(account) {
307
+ return false;
308
+ }
309
+ },
310
+ Query: {
311
+ accounts() {
312
+ return accounts.map((user) => {
313
+ return {
314
+ // I deliberately return a wrong __typename here to make sure it's not used by the gateway
315
+ __typename: "Never",
316
+ id: user.id
317
+ };
318
+ });
319
+ }
320
+ }
321
+ }
322
+ });
323
+
324
+ var test = [
325
+ createTest(
326
+ /* GraphQL */
327
+ `
328
+ query {
329
+ anotherUsers {
330
+ id
331
+ name
332
+ username
333
+ }
334
+ }
335
+ `,
336
+ {
337
+ data: {
338
+ anotherUsers: [
339
+ {
340
+ id: "u1",
341
+ name: "u1-name",
342
+ username: "u1-username"
343
+ },
344
+ {
345
+ id: "u2",
346
+ name: "u2-name",
347
+ username: "u2-username"
348
+ }
349
+ ]
350
+ }
351
+ }
352
+ ),
353
+ createTest(
354
+ /* GraphQL */
355
+ `
356
+ query {
357
+ users {
358
+ id
359
+ name
360
+ username
361
+ }
362
+ }
363
+ `,
364
+ {
365
+ data: {
366
+ users: [
367
+ {
368
+ id: "u1",
369
+ name: "u1-name",
370
+ username: "u1-username"
371
+ },
372
+ {
373
+ id: "u2",
374
+ name: "u2-name",
375
+ username: "u2-username"
376
+ }
377
+ ]
378
+ }
379
+ }
380
+ ),
381
+ createTest(
382
+ /* GraphQL */
383
+ `
384
+ query {
385
+ anotherUsers {
386
+ ... on User {
387
+ age
388
+ }
389
+ }
390
+ }
391
+ `,
392
+ {
393
+ data: {
394
+ anotherUsers: [
395
+ {
396
+ age: 11
397
+ },
398
+ {
399
+ age: 22
400
+ }
401
+ ]
402
+ }
403
+ }
404
+ ),
405
+ createTest(
406
+ /* GraphQL */
407
+ `
408
+ query {
409
+ users {
410
+ ... on User {
411
+ age
412
+ }
413
+ }
414
+ }
415
+ `,
416
+ {
417
+ data: {
418
+ users: [
419
+ {
420
+ age: 11
421
+ },
422
+ {
423
+ age: 22
424
+ }
425
+ ]
426
+ }
427
+ }
428
+ ),
429
+ createTest(
430
+ /* GraphQL */
431
+ `
432
+ query {
433
+ anotherUsers {
434
+ ... on User {
435
+ age
436
+ id
437
+ name
438
+ username
439
+ }
440
+ id
441
+ name
442
+ }
443
+ }
444
+ `,
445
+ {
446
+ data: {
447
+ anotherUsers: [
448
+ {
449
+ age: 11,
450
+ id: "u1",
451
+ name: "u1-name",
452
+ username: "u1-username"
453
+ },
454
+ {
455
+ age: 22,
456
+ id: "u2",
457
+ name: "u2-name",
458
+ username: "u2-username"
459
+ }
460
+ ]
461
+ }
462
+ }
463
+ ),
464
+ createTest(
465
+ /* GraphQL */
466
+ `
467
+ query {
468
+ users {
469
+ ... on User {
470
+ age
471
+ id
472
+ name
473
+ username
474
+ }
475
+ id
476
+ name
477
+ }
478
+ }
479
+ `,
480
+ {
481
+ data: {
482
+ users: [
483
+ {
484
+ age: 11,
485
+ id: "u1",
486
+ name: "u1-name",
487
+ username: "u1-username"
488
+ },
489
+ {
490
+ age: 22,
491
+ id: "u2",
492
+ name: "u2-name",
493
+ username: "u2-username"
494
+ }
495
+ ]
496
+ }
497
+ }
498
+ ),
499
+ createTest(
500
+ /* GraphQL */
501
+ `
502
+ query {
503
+ users {
504
+ ... on User {
505
+ age
506
+ id
507
+ name
508
+ username
509
+ }
510
+ id
511
+ name
512
+ }
513
+ }
514
+ `,
515
+ {
516
+ data: {
517
+ users: [
518
+ {
519
+ age: 11,
520
+ id: "u1",
521
+ name: "u1-name",
522
+ username: "u1-username"
523
+ },
524
+ {
525
+ age: 22,
526
+ id: "u2",
527
+ name: "u2-name",
528
+ username: "u2-username"
529
+ }
530
+ ]
531
+ }
532
+ }
533
+ ),
534
+ createTest(
535
+ /* GraphQL */
536
+ `
537
+ query {
538
+ accounts {
539
+ name
540
+ }
541
+ }
542
+ `,
543
+ {
544
+ data: {
545
+ accounts: [
546
+ {
547
+ name: "Alice"
548
+ },
549
+ {
550
+ name: "Bob"
551
+ },
552
+ {
553
+ name: "Charlie"
554
+ }
555
+ ]
556
+ }
557
+ }
558
+ ),
559
+ createTest(
560
+ /* GraphQL */
561
+ `
562
+ query {
563
+ accounts {
564
+ ... on Admin {
565
+ name
566
+ }
567
+ }
568
+ }
569
+ `,
570
+ {
571
+ data: {
572
+ accounts: [
573
+ {
574
+ name: "Alice"
575
+ },
576
+ {
577
+ name: "Bob"
578
+ },
579
+ {}
580
+ ]
581
+ }
582
+ }
583
+ ),
584
+ createTest(
585
+ /* GraphQL */
586
+ `
587
+ query {
588
+ accounts {
589
+ name
590
+ # NOTE
591
+ # __typename is not available in the interfaceObject, needs to be resolved indirectly
592
+ __typename
593
+ }
594
+ }
595
+ `,
596
+ {
597
+ data: {
598
+ accounts: [
599
+ {
600
+ name: "Alice",
601
+ __typename: "Admin"
602
+ },
603
+ {
604
+ name: "Bob",
605
+ __typename: "Admin"
606
+ },
607
+ {
608
+ name: "Charlie",
609
+ __typename: "Regular"
610
+ }
611
+ ]
612
+ }
613
+ }
614
+ ),
615
+ createTest(
616
+ /* GraphQL */
617
+ `
618
+ query {
619
+ accounts {
620
+ ... on Admin {
621
+ __typename
622
+ }
623
+ }
624
+ }
625
+ `,
626
+ {
627
+ data: {
628
+ accounts: [
629
+ {
630
+ __typename: "Admin"
631
+ },
632
+ {
633
+ __typename: "Admin"
634
+ },
635
+ {}
636
+ ]
637
+ }
638
+ }
639
+ ),
640
+ createTest(
641
+ /* GraphQL */
642
+ `
643
+ query {
644
+ accounts {
645
+ id
646
+ isActive
647
+ }
648
+ }
649
+ `,
650
+ {
651
+ data: {
652
+ accounts: [
653
+ {
654
+ id: "u1",
655
+ isActive: false
656
+ },
657
+ {
658
+ id: "u2",
659
+ isActive: false
660
+ },
661
+ {
662
+ id: "u3",
663
+ isActive: false
664
+ }
665
+ ]
666
+ }
667
+ }
668
+ ),
669
+ createTest(
670
+ /* GraphQL */
671
+ `
672
+ query {
673
+ accounts {
674
+ # NOTE
675
+ # id is available in the interfaceObject and can be resolved as there's no type condition involved
676
+ id
677
+ ... on Admin {
678
+ isActive
679
+ }
680
+ }
681
+ }
682
+ `,
683
+ {
684
+ data: {
685
+ accounts: [
686
+ {
687
+ id: "u1",
688
+ isActive: true
689
+ },
690
+ {
691
+ id: "u2",
692
+ isActive: true
693
+ },
694
+ {
695
+ id: "u3"
696
+ }
697
+ ]
698
+ }
699
+ }
700
+ )
701
+ ];
702
+
703
+ var index = serve("simple-interface-object", [a, b, c], test);
704
+
705
+ export { index as default };