0

以前は、次のスキーマを使用apollo-server-expressして GraphQL サーバーをセットアップしていました。

input IGetUser {
    email: String
    ID: String
    UserID: Int!
}
interface Entity {
    createdAt: String
    updatedAt: String
}
schema {
    query: Query
}
type Query {
    getUser(params:IGetUser): User!
}
type User implements Entity {
    UserID: Int!
    firstName: String!
    lastName: String
    email: String!
    ID: String
    ...
    confirmed: Boolean!
    createdAt: String!
    updatedAt: String!
}

基本的に、User型は私の MySQL データベースのテーブルを表します。サーバーは完全に機能しています。これが私のクエリです:

query GetUserQuery($UserID: Int!, $email: String, $ID: String) {
    getUser(params:{ email: $email, ID: $ID, UserID: $UserID }) {
        ...UserDetails
        ...EntityDetails
    }
}
fragment EntityDetails on Entity {
    createdAt
    updatedAt
}
fragment UserDetails on User {
    UserID
    firstName
    lastName
    email
    ID
    ...
    confirmed
}

UserタイプとUserDetailsフラグメントを短縮したことに注意してください。

クエリは Android Studio プロジェクトにあり、apollo-androidプラグインは Java オブジェクトを正しく生成します。私がしようとしているのは、ID 1 のユーザーをフェッチすることです。私の Java コードは次のようになります。

RestClient.getInstance(getApplicationContext())
    .getApolloClient(getString(R.string.urlGraphQLEndpoint))
    .query(
        GetUserQuery.builder()
            .userID(userID) // userID = 1 is a local variable
            .build()
    )
    .httpCachePolicy(HttpCachePolicy.NETWORK_ONLY)
    .enqueue(new ApolloCall.Callback<GetUserQuery.Data>() {
        @Override
        public void onFailure(@Nonnull ApolloException e) {
            Log.e(TAG, e.getMessage(), e);
        }

        @Override
        public void onResponse(@Nonnull Response<GetUserQuery.Data> response) {
            // Doesn't matter
        }
    })

このRestClientクラスは、インスタンスSingletonへのアクセスを提供する であり、リソース文字列はローカル GraphQL サーバーの IP アドレスとポートを指します: . Android アプリを実行しようとすると、次のエラー メッセージが表示されます。ApolloClienturlGraphQLEndpointhttp://10.0.2.2:3000/graphql

HTTP 400 Bad Request
com.apollographql.apollo.exception.ApolloHttpException: HTTP 400 Bad Request
    at com.apollographql.apollo.internal.interceptor.ApolloParseInterceptor.parse(ApolloParseInterceptor.java:105)
    at com.apollographql.apollo.internal.interceptor.ApolloParseInterceptor.access$100(ApolloParseInterceptor.java:28)
    at com.apollographql.apollo.internal.interceptor.ApolloParseInterceptor$1.onResponse(ApolloParseInterceptor.java:53)
    at com.apollographql.apollo.internal.interceptor.ApolloServerInterceptor$1$1.onResponse(ApolloServerInterceptor.java:93)
    at okhttp3.RealCall$AsyncCall.execute(RealCall.java:153)
    at okhttp3.internal.NamedRunnable.run(NamedRunnable.java:32)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1162)
    at java.util.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:636)
    at java.lang.Thread.run(Thread.java:764)

サーバー側では、次のコンソール ログを受け取ります。

GraphQLError: Variable "$UserID" of requiredtype "Int!" was not provided!
    at getVariableValues ...

まったく同じクエリapollo-androidを試すと、 GraphiQL を使用してクライアントが使用する必要があります。すべてが期待どおりに機能し、ID 1 のユーザーを受け取ります。私にとってはapollo-androidlib の内部エラーのようですが、私の Javaコードと私の GraphQL クエリは、Apolloを使用してコードを生成し、コードを消費するapollo-android例とあまり変わらないように見えます。

事前に感謝します。すべての助けに感謝します!

4

1 に答える 1