You can use aliases by iterating over nodes and map them to a field name like nodeX
:
{
node1: node(id: "MDEwOlJlcG9zaXRvcnkxMDQ4MzQ4") {
... on Repository {
...Repo
}
}
node2: node(id: "MDEwOlJlcG9zaXRvcnkyMzE5NDk4") {
... on Repository {
...Repo
}
}
node3: node(id: "MDEwOlJlcG9zaXRvcnkyMzI1Mjk4") {
... on Repository {
...Repo
}
}
}
fragment Repo on Repository {
name
}
output:
{
"data": {
"node1": {
"name": "DROP5.0"
},
"node2": {
"name": "subsurface"
},
"node3": {
"name": "linux"
}
}
}
For the cursor value you just need to map the field name to both the node id and the cursor value:
{
node1: node(id: "MDEwOlJlcG9zaXRvcnkyMzE5NDk4") {
... on Repository {
name
stargazers(first: 1, after:"Y3Vyc29yOnYyOpIAzR1p") {
pageInfo {
endCursor
}
edges {
starredAt
}
}
}
}
node2: node(id: "MDEwOlJlcG9zaXRvcnkxMDQ4MzQ4") {
... on Repository {
name
stargazers(first: 1, after: null) {
pageInfo {
endCursor
}
edges {
starredAt
}
}
}
}
node3: node(id: "MDEwOlJlcG9zaXRvcnkyMzI1Mjk4") {
... on Repository {
name
stargazers(first: 1, after:"Y3Vyc29yOnYyOpIAzQzi") {
pageInfo {
endCursor
}
edges {
starredAt
}
}
}
}
}
In this case your input map would look like:
input = {
"node1": {
"id": "MDEwOlJlcG9zaXRvcnkyMzE5NDk4",
"cursor": "Y3Vyc29yOnYyOpIAzR1p"
},
"node2": {
"id": "MDEwOlJlcG9zaXRvcnkxMDQ4MzQ4",
"cursor": null
},
"node3": {
"id": "MDEwOlJlcG9zaXRvcnkyMzI1Mjk4",
"cursor": "Y3Vyc29yOnYyOpIAzQzi"
}
}
With variables:
query ($id1: ID!, $cursor1: String, $id2: ID!, $cursor2: String, $id3: ID!, $cursor3: String) {
node1: node(id: $id1) {
... on Repository {
name
stargazers(first: 1, after: $cursor1) {
pageInfo {
endCursor
}
edges {
starredAt
}
}
}
}
node2: node(id: $id2) {
... on Repository {
name
stargazers(first: 1, after: $cursor2) {
pageInfo {
endCursor
}
edges {
starredAt
}
}
}
}
node3: node(id: $id3) {
... on Repository {
name
stargazers(first: 1, after: $cursor3) {
pageInfo {
endCursor
}
edges {
starredAt
}
}
}
}
}
variables :
{
"id1": "MDEwOlJlcG9zaXRvcnkyMzE5NDk4",
"cursor1": "Y3Vyc29yOnYyOpIAzR1p",
"id2": "MDEwOlJlcG9zaXRvcnkxMDQ4MzQ4",
"cursor2": null,
"id3": "MDEwOlJlcG9zaXRvcnkyMzI1Mjk4",
"cursor3": "Y3Vyc29yOnYyOpIAzQzi"
}