Recientemente implementé un esquema y algunos solucionadores para mi servidor Express. Los probé con éxito a través de /graphql y ahora me gustaría llamar a las consultas que implementé al acceder desde una API REST, así:

//[...]
//schema and root correctly implemented and working
app.use('/graphql', graphqlHTTP({
  schema: schema,
  rootValue: root,
  graphiql: true,
}));

//I start the server
app.listen(port, () => {
  console.log('We are live on ' + port);
});

//one of many GET handlers
app.get("/mdc/all/:param", function(req, res) {
    //call one of the (parametrized) queries here
    //respond with the JSON result
});

¿Cómo puedo llamar a las consultas que definí con GraphQL dentro de mis controladores GET? ¿Cómo les paso parámetros?

¡Gracias!

2
Masiar 16 oct. 2018 a las 12:27

2 respuestas

La mejor respuesta

Usé Apollo y realicé consultas directamente en /graphql a través de POST desde el front-end.

-5
Masiar 24 oct. 2018 a las 14:29

Básicamente, puede usar el método de publicación http para obtener los datos de una API GraphQL, pero aquí una muy buena solución usando node-fetch, para instalarlo:

npm install node-fetch --save

Y el código para usarlo es:

const fetch = require('node-fetch');

const accessToken = 'your_access_token_from_github';
const query = `
  query {
    repository(owner:"isaacs", name:"github") {
      issues(states:CLOSED) {
        totalCount
      }
    }
  }`;

fetch('https://api.github.com/graphql', {
  method: 'POST',
  body: JSON.stringify({query}),
  headers: {
    'Authorization': `Bearer ${accessToken}`,
  },
}).then(res => res.text())
  .then(body => console.log(body)) // {"data":{"repository":{"issues":{"totalCount":247}}}}
  .catch(error => console.error(error));

Esta solución se tomó de aquí

1
Efi Gordon 20 ene. 2019 a las 22:49