2017-06-18 17 views
0

私はApolloライブラリの古いバージョンで6ヶ月以上完璧に動作していたApolloコードをたくさん持っています。私はそれをApolloライブラリの最新バージョンで動作するように更新しようとしています。アポロ構成エラー?

現在graphIQLで実行したときに、私のクエリは正常に実行されますが、私自身のフロントエンドのコードから実行したとき、私はエラーを取得:

Unhandled (in react-apollo) Error: Network error: Network request failed with status 200 - "OK"

ここでスタックトレースを示すスクリーンショットです:

enter image description here

Apolloに接続するための初期設定で設定エラーがありますか?

クライアントのセットアップ

import {GET_USERINFOFORIMS_QUERY} from '/imports/api/query-library'; 
import { gql, ApolloClient, createNetworkInterface, ApolloProvider, graphql, createBatchingNetworkInterface, addTypename } from 'react-apollo'; 
import { SubscriptionClient, addGraphQLSubscriptions } from 'subscriptions-transport-ws'; 

const subscriptionClient = new SubscriptionClient(`ws://localhost:5000/`, { 
    reconnect: true 
}); 

// Create a normal network interface: 
const networkInterface = createNetworkInterface({ 
    uri: 'http://localhost:3000', 
    opts: { 
     credentials: 'same-origin', 
    }, 
    transportBatching: true, 
    batchInterval: 10 

}); 
// Extend the network interface with the WebSocket 
const networkInterfaceWithSubscriptions = addGraphQLSubscriptions(
    networkInterface, 
    subscriptionClient 
); 

const ApolloClientWithSubscribeEnabled = new ApolloClient({ 
    networkInterface: networkInterfaceWithSubscriptions, 
    queryTransformer: addTypename, 
    dataIdFromObject: (result) => { 
     if (result.id && result.__typename) { // eslint-disable-line no-underscore-dangle 
      return result.__typename + result.id; // eslint-disable-line no-underscore-dangle 
     } 
     return null; 
    }, 
    shouldBatch: true, 
    initialState: window.__APOLLO_STATE__, // eslint-disable-line no-underscore-dangle 
    ssrForceFetchDelay: 100 
}); 

クライアント側のQUERY

Serverセットアップ

import { subscriptionManager, pubsub } from '/imports/api/subscriptions-server'; 
import schema from '/imports/api/schema'; 
import cors from 'cors'; 

//SET UP APOLLO QUERY AND MUTATIONS 
import express from 'express'; 
import bodyParser from 'body-parser'; 
import { graphqlExpress, graphiqlExpress } from 'graphql-server-express'; 
const GRAPHQL_PORT = 3010; 
var graphQLServer = express().use('*', cors()); 
graphQLServer.use('/graphql', bodyParser.json(), graphqlExpress(request => ({ 
    schema: schema 
}))); 
graphQLServer.use('/graphiql', graphiqlExpress({ 
    endpointURL: '/graphql', 
})); 
graphQLServer.listen(GRAPHQL_PORT); 


console.log(
    `GraphQL Server is now running on http://localhost:${GRAPHQL_PORT}/graphql` 
); 
console.log(
    `GraphIQL available on http://localhost:${GRAPHQL_PORT}/graphiql` 
); 
//END OF SET UP APOLLO QUERIES AND MUTATIONS 

//SET UP APOLLO PUBSUB 
// WebSocket server for subscriptions 
import { createServer } from 'http'; 
import { execute, subscribe } from 'graphql'; 
import { SubscriptionServer } from 'subscriptions-transport-ws'; 
const SUBSCRIPTION_PORT = 5000; 
// Create WebSocket listener server 
const websocketServer = createServer((request, response) => { 
    response.writeHead(404); 
    response.end(); 
}); 
// Bind it to port and start listening 
websocketServer.listen(SUBSCRIPTION_PORT,() => console.log(
    `Websocket Server is now running on http://localhost:${SUBSCRIPTION_PORT}` 
)); 
const subscriptionsServer = new SubscriptionServer(
    { 
     execute, 
     subscribe, 
     schema, 
    }, 
    { 
     server: websocketServer 
    } 
); 
//END OF SET UP APOLLO PUBSUB 

...と、ここでは、クライアント上の私のセットアップコードであります

getUserInfoForCurrentUser() { 
    const userIsLoggedIn = Meteor.userId() ? true : false; 
    if ((userIsLoggedIn) && (this.originatingUser == null)){ 
     const localThis = this; 
     const userID = Meteor.userId(); 
     this.client.query({ 
      query: GET_USERINFOFORIMS_QUERY, 
      variables: {userID: userID}, 
     }).then((result) => { 
      localThis.originatingUser = result.data.getUserData[0]; 
     }); 
    } 
} 

前述のように、クエリはgraphIQLから正常に実行されます。

私のコードでApolloに接続するとエラーが発生しますか?

ご意見ありがとうございました。クライアント上の

答えて

0

この編集は、それを修正しているようだ:

//import ApolloClient, { createBatchingNetworkInterface, addTypename } from 'apollo-client'; 
// import {addGraphQLSubscriptions} from '/imports/api/subscriptions-client'; 

import {GET_USERINFOFORIMS_QUERY} from '/imports/api/query-library'; 

import { ApolloClient, createNetworkInterface } from 'react-apollo'; 
const networkInterface = createNetworkInterface({ 
    uri: 'http://localhost:3010/graphql' 
}); 
const ApolloClientWithSubscribeEnabled = new ApolloClient({ 
    networkInterface: networkInterface 
}); 
関連する問題