Как обновить заголовки apolloProvider?
Пожалуйста, проверьте репозиторий приложения nativescript-vue:
https://github.com/kaanguru/vue-apollo-login
Я не могу объяснить как следует, поэтому, пожалуйста, проверьте приложение. Я не знаю, как обновить заголовки appolloClient.
В репозитории приложений есть свои комментарии и директивы. Его легко установить и увидеть самому.
Текущая структура кода:
Почтовый запрос отправляет идентификатор пользователя и пароль для аутентификации и получает токен на странице входа.
Apollo необходимо поместить токен jwt в заголовок авторизации.
Main.js: запустить клиент apollo, если есть запуск JWT с заголовками
Перейти к логину, если нет JWT
Перейти к списку птиц, если есть JWT
Вход: получить jwt с сервера и записать его в локальное хранилище
- Go to birds list (does not show data because apollo initilised in main js)
import ApolloClient from 'apollo-boost'
import VueApollo from 'vue-apollo'
Vue.use(VueApollo)
const apolloClient = new ApolloClient({
uri: 'http://sebapi.com/graphql',
// HEADERS WORK FINE IF TOKEN WAS IN MAIN
// headers: {
// authorization: `Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpZCI6MSwiaWF0IjoxNTg2MzU2NzM2LCJleHAiOjE1ODg5NDg3MzZ9.wpyhPTWuqxrDgezDXJqIOaAIaocpM8Ehd3BhQUWKK5Q`,
// }
})
const apolloProvider = new VueApollo({
defaultClient: apolloClient,
})
LOGIN.VUE
.then(
(response) => {
const result = response.content.toJSON();
console.log("Result from Server: ", result);
const token = result.jwt;
// HOW TO ADD HEADERS TO APOLLOCLIENT this.$apollo.provider.defaultClient
// this.$apollo.provider.defaultClient({
// request: (operation) => {
// operation.setContext({
// headers: {
// authorization: `Bearer ${result.jwt}` ,
// },
// });
// },
// });
},
Спасибо за Ваш интерес.
ПРИМЕЧАНИЕ. Прокомментируйте, чтобы получить более подробную информацию. Бэкэнд sebapi.com - это сервер strapi graphql.
Похожие документы: