apollo-android не предоставляет переменные в запросе

Я использовал 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 Project и apollo-android Плагин генерирует объекты Java правильно. Я пытаюсь выбрать пользователя с идентификатором 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 который обеспечивает доступ к ApolloClient Экземпляр и строка ресурса urlGraphQLEndpoint указывает на IP-адрес и порт моего локального сервера GraphQL: http://10.0.2.2:3000/graphql, Когда я пытаюсь запустить свое приложение для Android, я получаю следующее сообщение об ошибке:

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 все работает, как я ожидаю, и я получаю пользователя с идентификатором 1. Это кажется внутренней ошибкой apollo-android lib для меня, но потому что мой Java-код и мой запрос GraphQL не сильно отличаются от apollo-android пример Генерация кода с использованием Apollo и использования кода Я действительно не знаю, где моя ошибка.

Заранее спасибо, я ценю любую помощь!

1 ответ

Решение

Я обнаружил ошибку... Как вы можете видеть в моем запросе, я использую заглавные буквы в начале некоторых из моих переменных. apollo-android чувствителен к регистру, как и должно быть, но он игнорирует заглавные буквы в начале переменных и преобразует их в маленькие буквы. С помощью прокси-сервера Postman я смог проверить сетевые запросы моего приложения и увидел, что переменные все еще были маленькими буквами.

Другие вопросы по тегам