Activities

capoia

capoia posted a new question

apollo-module •

Error on cache reset (setToken) apolloClient.resetStore is not a function

Hi, I'm trying to use nuxt with apollo, and this error keeps showing up on my console, and I can't get apollo to update a data without updating the page.
I think it's related.
My fetch policy is already no-cache, and I even tried to create a plugin to update fetchPolicy, because I saw an issue that was the only way.
Screenshot_1.png
Screenshot_2.png
Screenshot_3.png

toddpadwick

toddpadwick posted a new question

apollo-module •

Cannot access apolloProvider within a Nuxt Store module

I am still learning and I am trying to set up an Apollo Graph QL query imported from a .gql file within a Vuex action. I have Nuxt Store set up in Module mode.

The documentation seems to suggest that I can access apolloProvider via this.app.apolloProvider.defaultClient. But this returns an 'undefined' error. I have tried looking in context and this.app for apollo instead but neither contain it.

My question is, how do I access the apollo object within a store namespaced module, and get this action to work as it should?

my code

store/index.js

import Vuex from 'vuex';
import product from './product';

const createStore = () => {
  return new Vuex.Store({
    modules: {
      product
    }
  });
};

export default createStore

store/product.js

import GET_PRODUCT from '~/apollo/queries/getProduct.gql';

export const state = () => ({
  product: {},
  loading:false,
  error:null
})

export const mutations = {
  setProduct: (state, payload) => {
    state.product = payload;
  },
  setLoading: (state, payload) => {
    state.loading = payload;
  }
}

export const actions = {
  getProduct: (context, payload) => {
    console.log(context);
    const apolloClient = this.app.apolloProvider.defaultClient; // This returns null
    apolloClient.query({
      query:GET_PRODUCT,
      variables:payload
    }).then(({data}) => {
      context.commit("setProduct", data);
    }).catch(err => {
      context.commit("setLoading", false);
      console.log(err);
    })
  }
}


export const getters = {
  product: state => {
    state.product
  },
  loading:state => {
    state.loading
  }
}

export default {
  state,
  actions,
  mutations,
  getters
}
kissu

kissu posted a new question

apollo-module •

How to access existing headers on a specific vuex call ?

I've configured my apollo with the following

import { HttpLink } from 'apollo-link-http'
import { setContext } from 'apollo-link-context'
import { from } from 'apollo-link'
import { InMemoryCache } from 'apollo-cache-inmemory'

export default ({ app, store, $config: { baseUrlGraphql } }) => {
  const headersConfig = setContext(() => ({
    credentials: 'same-origin',
    headers: {
      'x-company-id': 'xxx-yyy', // example language header
    },
  }))

  const httpLink = new HttpLink({ uri: baseUrlGraphql })

  const link = from([headersConfig, httpLink])
  const cache = new InMemoryCache()

  return {
    link,
    cache,
    defaultHttpLink: false,
  }
}

Now, I want to access the headers into a vuex action and add some headers to it (and only to that specific header)

await this.app.apolloProvider.defaultClient.query({
  query: myFancyQuery,
  context: {
    headers: {
      ...headers, // where can I found those ? 
      Authorization: this.app.$cookies.get('auth._token.local'),
    },
  },
})

Tried to inspect this.app.apolloProvider but it doesn't have my header…

kampfkuchen

kampfkuchen posted a new question

apollo-module •

Nuxt / Apollo - Set Authorization Header

I am trying to create a login functionality using nuxtjs with the nuxtjs apollo-module and nodejs in the backend using apollo-server. I would like to pass the token from the frontend (nuxtjs/apollo-client) to the backend (nodejs/apollo-server).


Signin Function

async signin () {
  const email = this.email
  const password = this.password
  try {
    const res = await this.$apollo.mutate({
      mutation: signIn,
      variables: {
        email,
        password
      }
    }).then(({ data }) => data && data.signIn)
    const token = res.token
    await this.$apolloHelpers.onLogin(token)
    this.$router.push('/')
  } catch (err) {
    // Error message
  }
}

nuxtjs.config

import Cookies from 'js-cookie'
const token = Cookies.get('apollo-token')

apollo: {  
  clientConfigs: {
    httpEndpoint: 'http://localhost:8000/graphql',
    httpLinkOptions: {
      credentials: 'include',
      headers: {
        'authorization': token ? token : '' // passing the token on this line fails it returns '' 
      }
    }
  }
},

Cookie in Browser DevTools


enter image description here



I am unable to pass the token to the authorization header. I also tried to do it using localStorage ('authorization': (process.client) ? localStorage.getItem('token') : ' '`) but this does not seem to be possible because of the server side rendering.

The token is saved in a cookie called 'apollo-token'. However the Authoriation header in the format 'Bearer token' is not set. According to the apollo-client documentation this should be set automatically (https://github.com/nuxt-community/apollo-module#authenticationtype-string-optional-default-bearer).


I would be very very thankful for any kind of help!

galaczi

galaczi posted a new question

apollo-module •

How to get batching?

I am wondering how would one go about using batching with Nuxt Apollo?

https://www.apollographql.com/blog/batching-client-graphql-queries-a685f5bcd41b/

jimmiejackson414

jimmiejackson414 posted a new question

apollo-module •

Latest version on npmjs.com is v4.0.1-rc.5?

Hi there, I am trying to install the latest version of this module, which I believe is 4.0.1-rc.18 from looking at the release log. The latest version I'm seeing on npm however is 4.0.1-rc.5. If this is intentional for some reason, then apologies for opening a ticket. Are there plans to update the version pushed to npm?

galaczi

galaczi resolved the question #c352

apollo-module •

Nuxt SSR mode - Client requested data is undefined
galaczi

galaczi posted a new question

apollo-module •

Nuxt SSR mode - Client requested data is undefined

I am using Nuxt in SSR mode and using smart queries. If I request a page from the server, the query works. If I navigate to a page via a nuxt-link, I get the error that data is undefined. At first I thought it is a CSP issue but it isn't. There is no warning in the console of the browser, and I can see the network response comes back from graphql as expected.

TypeError: _vm.doctor[0] is undefined render index.vue:25 VueJS 52 init vue-router.esm.js:2932 init vue-router.esm.js:2931 updateRoute vue-router.esm.js:2352 transitionTo vue-router.esm.js:2206 confirmTransition vue-router.esm.js:2340 step vue-router.esm.js:1944 step vue-router.esm.js:1951 runQueue vue-router.esm.js:1955 confirmTransition vue-router.esm.js:2335 step vue-router.esm.js:1944 step vue-router.esm.js:1948 iterator vue-router.esm.js:2322 resolveAsyncComponents vue-router.esm.js:2105 iterator vue-router.esm.js:2300 step vue-router.esm.js:1947 step vue-router.esm.js:1951 step vue-router.esm.js:1948 iterator vue-router.esm.js:2322 _callee6$ NuxtJS tryCatch runtime.js:63 invoke runtime.js:293 defineIteratorMethods runtime.js:118 asyncGeneratorStep Babel client.js:97

Sendoo

Sendoo posted a new question

apollo-module •

Logging requests?

Tell me a tool for logging / outputting requests?
So that you can see the request body, response, headers, etc.

manakuro

manakuro posted a new bug report

apollo-module •

bug Stop working in IE11

Version

v4.0.0-rc.5

Reproduction link

Nothing

Steps to reproduce

yarn dev

visit http://localhost:3000/ in IE11

What is expected ?

Working application without error in IE11

What is actually happening?

The error is logged in the console, in the nuxt/vendors/app.js file, only in IE11:

スクリーンショット 2020-12-13 13.28.35.png

It seems that the src folder is used for vue-cli-plugin-apollo/graphql-client instead of dist which is transpiled.

It occurred after this commit.
https://github.com/nuxt-community/apollo-module/commit/05fccfe6d6bbfe583bd720029276d81c615047b0#diff-5acbea5e90939d8ded320a17e74b9fe35c66ef8543384b023054c69570cf81f7R4

Transpiled code is here

/***/
"./node_modules/vue-cli-plugin-apollo/graphql-client/src/index.js":
/*!************************************************************************!*\
 !*** ./node_modules/vue-cli-plugin-apollo/graphql-client/src/index.js ***!
 \************************************************************************/
/*! exports provided: createApolloClient, restartWebsockets */
/***/
(function(module, __webpack_exports__, __webpack_require__) {

  "use strict";
  eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"createApolloClient\", function() { return createApolloClient; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"restartWebsockets\", function() { return restartWebsockets; });\n/* harmony import */ var apollo_client__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! apollo-client */ \"./node_modules/apollo-client/bundle.esm.js\");\n/* harmony import */ var apollo_link__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! apollo-link */ \"./node_modules/vue-cli-plugin-apollo/node_modules/apollo-link/lib/bundle.esm.js\");\n/* harmony import */ var apollo_upload_client__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! apollo-upload-client */ \"./node_modules/apollo-upload-client/lib/index.js\");\n/* harmony import */ var apollo_upload_client__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(apollo_upload_client__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var apollo_cache_inmemory__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! apollo-cache-inmemory */ \"./node_modules/apollo-cache-inmemory/lib/bundle.esm.js\");\n/* harmony import */ var subscriptions_transport_ws__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! subscriptions-transport-ws */ \"./node_modules/subscriptions-transport-ws/dist/client.js\");\n/* harmony import */ var subscriptions_transport_ws__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(subscriptions_transport_ws__WEBPACK_IMPORTED_MODULE_4__);\n/* harmony import */ var subscriptions_transport_ws_dist_message_types__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! subscriptions-transport-ws/dist/message-types */ \"./node_modules/subscriptions-transport-ws/dist/message-types.js\");\n/* harmony import */ var subscriptions_transport_ws_dist_message_types__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(subscriptions_transport_ws_dist_message_types__WEBPACK_IMPORTED_MODULE_5__);\n/* harmony import */ var apollo_link_ws__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! apollo-link-ws */ \"./node_modules/apollo-link-ws/lib/bundle.esm.js\");\n/* harmony import */ var apollo_utilities__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! apollo-utilities */ \"./node_modules/vue-cli-plugin-apollo/node_modules/apollo-utilities/lib/bundle.esm.js\");\n/* harmony import */ var apollo_link_persisted_queries__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! apollo-link-persisted-queries */ \"./node_modules/apollo-link-persisted-queries/lib/index.js\");\n/* harmony import */ var apollo_link_context__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! apollo-link-context */ \"./node_modules/apollo-link-context/lib/bundle.esm.js\");\n/* harmony import */ var apollo_link_state__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! apollo-link-state */ \"./node_modules/apollo-link-state/lib/index.js\");\n\n\n\n\n\n\n\n\n\n\n\n\n// Create the apollo client\nfunction createApolloClient ({\n  // Client ID if using multiple Clients\n  clientId = 'defaultClient',\n  // URL to the HTTP API\n  httpEndpoint,\n  // Url to the Websocket API\n  wsEndpoint = null,\n  // Token used in localstorage\n  tokenName = 'apollo-token',\n  // Enable this if you use Query persisting with Apollo Engine\n  persisting = false,\n  // Is currently Server-Side Rendering or not\n  ssr = false,\n  // Only use Websocket for all requests (including queries and mutations)\n  websocketsOnly = false,\n  // Custom starting link.\n  // If you want to replace the default HttpLink, set `defaultHttpLink` to false\n  link = null,\n  // Custom pre-auth links\n  // Useful if you want, for example, to set a custom middleware for refreshing an access token.\n  preAuthLinks = [],\n  // If true, add the default HttpLink.\n  // Disable it if you want to replace it with a terminating link using `link` option.\n  defaultHttpLink = true,\n  // Options for the default HttpLink\n  httpLinkOptions = {},\n  // Custom Apollo cache implementation (default is apollo-cache-inmemory)\n  cache = null,\n  // Options for the default cache\n  inMemoryCacheOptions = {},\n  // Additional Apollo client options\n  apollo = {},\n  // apollo-link-state options\n  clientState = null,\n  // Function returning Authorization header token\n  getAuth = defaultGetAuth,\n  // Local Schema\n  typeDefs = undefined,\n  // Local Resolvers\n  resolvers = undefined,\n  // Hook called when you should write local state in the cache\n  onCacheInit = undefined,\n}) {\n  let wsClient, authLink, stateLink\n  const disableHttp = websocketsOnly && !ssr && wsEndpoint\n\n  // Apollo cache\n  if (!cache) {\n    cache = new apollo_cache_inmemory__WEBPACK_IMPORTED_MODULE_3__[\"InMemoryCache\"](inMemoryCacheOptions)\n  }\n\n  if (!disableHttp) {\n    const httpLink = Object(apollo_upload_client__WEBPACK_IMPORTED_MODULE_2__[\"createUploadLink\"])({\n      uri: httpEndpoint,\n      ...httpLinkOptions,\n    })\n\n    if (!link) {\n      link = httpLink\n    } else if (defaultHttpLink) {\n      link = Object(apollo_link__WEBPACK_IMPORTED_MODULE_1__[\"from\"])([link, httpLink])\n    }\n\n    // HTTP Auth header injection\n    authLink = Object(apollo_link_context__WEBPACK_IMPORTED_MODULE_9__[\"setContext\"])(async (_, { headers }) => {\n      const Authorization = await getAuth(tokenName)\n      const authorizationHeader = Authorization ? { Authorization } : {}\n      return {\n        headers: {\n          ...headers,\n          ...authorizationHeader,\n        },\n      }\n    })\n\n    // Concat all the http link parts\n    link = authLink.concat(link)\n\n    if (preAuthLinks.length) {\n      link = Object(apollo_link__WEBPACK_IMPORTED_MODULE_1__[\"from\"])(preAuthLinks).concat(authLink)\n    }\n  }\n\n  // On the server, we don't want WebSockets and Upload links\n  if (!ssr) {\n    // If on the client, recover the injected state\n    if (typeof window !== 'undefined') {\n      // eslint-disable-next-line no-underscore-dangle\n      const state = window.__APOLLO_STATE__\n      if (state && state[clientId]) {\n        // Restore state\n        cache.restore(state[clientId])\n      }\n    }\n\n    if (!disableHttp) {\n      let persistingOpts = {}\n      if (typeof persisting === 'object' && persisting != null) {\n        persistingOpts = persisting\n        persisting = true\n      }\n      if (persisting === true) {\n        link = Object(apollo_link_persisted_queries__WEBPACK_IMPORTED_MODULE_8__[\"createPersistedQueryLink\"])(persistingOpts).concat(link)\n      }\n    }\n\n    // Web socket\n    if (wsEndpoint) {\n      wsClient = new subscriptions_transport_ws__WEBPACK_IMPORTED_MODULE_4__[\"SubscriptionClient\"](wsEndpoint, {\n        reconnect: true,\n        connectionParams: () => {\n          const Authorization = getAuth(tokenName)\n          return Authorization ? { Authorization, headers: { Authorization } } : {}\n        },\n      })\n\n      // Create the subscription websocket link\n      const wsLink = new apollo_link_ws__WEBPACK_IMPORTED_MODULE_6__[\"WebSocketLink\"](wsClient)\n\n      if (disableHttp) {\n        link = link ? link.concat(wsLink) : wsLink\n      } else {\n        link = Object(apollo_link__WEBPACK_IMPORTED_MODULE_1__[\"split\"])(\n          // split based on operation type\n          ({ query }) => {\n            const { kind, operation } = Object(apollo_utilities__WEBPACK_IMPORTED_MODULE_7__[\"getMainDefinition\"])(query)\n            return kind === 'OperationDefinition' &&\n              operation === 'subscription'\n          },\n          wsLink,\n          link,\n        )\n      }\n    }\n  }\n\n  if (clientState) {\n    console.warn('clientState is deprecated, see https://vue-cli-plugin-apollo.netlify.com/guide/client-state.html')\n    stateLink = Object(apollo_link_state__WEBPACK_IMPORTED_MODULE_10__[\"withClientState\"])({\n      cache,\n      ...clientState,\n    })\n    link = Object(apollo_link__WEBPACK_IMPORTED_MODULE_1__[\"from\"])([stateLink, link])\n  }\n\n  const apolloClient = new apollo_client__WEBPACK_IMPORTED_MODULE_0__[\"ApolloClient\"]({\n    link,\n    cache,\n    // Additional options\n    ...(ssr ? {\n      // Set this on the server to optimize queries when SSR\n      ssrMode: true,\n    } : {\n      // This will temporary disable query force-fetching\n      ssrForceFetchDelay: 100,\n      // Apollo devtools\n      connectToDevTools: \"development\" !== 'production',\n    }),\n    typeDefs,\n    resolvers,\n    ...apollo,\n  })\n\n  // Re-write the client state defaults on cache reset\n  if (stateLink) {\n    apolloClient.onResetStore(stateLink.writeDefaults)\n  }\n\n  if (onCacheInit) {\n    onCacheInit(cache)\n    apolloClient.onResetStore(() => onCacheInit(cache))\n  }\n\n  return {\n    apolloClient,\n    wsClient,\n    stateLink,\n  }\n}\n\nfunction restartWebsockets (wsClient) {\n  // Copy current operations\n  const operations = Object.assign({}, wsClient.operations)\n\n  // Close connection\n  wsClient.close(true)\n\n  // Open a new one\n  wsClient.connect()\n\n  // Push all current operations to the new connection\n  Object.keys(operations).forEach(id => {\n    wsClient.sendMessage(\n      id,\n      subscriptions_transport_ws_dist_message_types__WEBPACK_IMPORTED_MODULE_5___default.a.GQL_START,\n      operations[id].options,\n    )\n  })\n}\n\nfunction defaultGetAuth (tokenName) {\n  if (typeof window !== 'undefined') {\n    // get the authentication token from local storage if it exists\n    const token = window.localStorage.getItem(tokenName)\n    // return the headers to the context so httpLink can read them\n    return token ? `Bearer ${token}` : ''\n  }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///./node_modules/vue-cli-plugin-apollo/graphql-client/src/index.js?f7b4"],"names":[],"mappings":"AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAA4C;AACH;AACc;AACF;AACU;AACS;AAC1B;AACM;AACoB;AACxB;AACG;;AAEnD;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB;AACtB;AACA;AACA;AACA,2BAA2B;AAC3B;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD;AACA;;AAEA;AACA;AACA,gBAAgB,mEAAa;AAC7B;;AAEA;AACA,qBAAqB,6EAAgB;AACrC;AACA;AACA,KAAK;;AAEL;AACA;AACA,KAAK;AACL,aAAa,wDAAI;AACjB;;AAEA;AACA,eAAe,sEAAU,YAAY,UAAU;AAC/C;AACA,mDAAmD,gBAAgB;AACnE;AACA;AACA;AACA;AACA,SAAS;AACT;AACA,KAAK;;AAEL;AACA;;AAEA;AACA,aAAa,wDAAI;AACjB;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,8FAAwB;AACvC;AACA;;AAEA;AACA;AACA,qBAAqB,6EAAkB;AACvC;AACA;AACA;AACA,kCAAkC,0BAA0B,gBAAgB,EAAE;AAC9E,SAAS;AACT,OAAO;;AAEP;AACA,yBAAyB,4DAAa;;AAEtC;AACA;AACA,OAAO;AACP,eAAe,yDAAK;AACpB;AACA,YAAY,QAAQ;AACpB,mBAAmB,kBAAkB,GAAG,0EAAiB;AACzD;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,gBAAgB,0EAAe;AAC/B;AACA;AACA,KAAK;AACL,WAAW,wDAAI;AACf;;AAEA,2BAA2B,0DAAY;AACvC;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,yBAAyB,aAAoB;AAC7C,KAAK;AACL;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEO;AACP;AACA,qCAAqC;;AAErC;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,MAAM,oFAAY;AAClB;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA,6BAA6B,MAAM;AACnC;AACA","file":"./node_modules/vue-cli-plugin-apollo/graphql-client/src/index.js.js","sourcesContent":["import { ApolloClient } from 'apollo-client'\nimport { split, from } from 'apollo-link'\nimport { createUploadLink } from 'apollo-upload-client'\nimport { InMemoryCache } from 'apollo-cache-inmemory'\nimport { SubscriptionClient } from 'subscriptions-transport-ws'\nimport MessageTypes from 'subscriptions-transport-ws/dist/message-types'\nimport { WebSocketLink } from 'apollo-link-ws'\nimport { getMainDefinition } from 'apollo-utilities'\nimport { createPersistedQueryLink } from 'apollo-link-persisted-queries'\nimport { setContext } from 'apollo-link-context'\nimport { withClientState } from 'apollo-link-state'\n\n// Create the apollo client\nexport function createApolloClient ({\n  // Client ID if using multiple Clients\n  clientId = 'defaultClient',\n  // URL to the HTTP API\n  httpEndpoint,\n  // Url to the Websocket API\n  wsEndpoint = null,\n  // Token used in localstorage\n  tokenName = 'apollo-token',\n  // Enable this if you use Query persisting with Apollo Engine\n  persisting = false,\n  // Is currently Server-Side Rendering or not\n  ssr = false,\n  // Only use Websocket for all requests (including queries and mutations)\n  websocketsOnly = false,\n  // Custom starting link.\n  // If you want to replace the default HttpLink, set `defaultHttpLink` to false\n  link = null,\n  // Custom pre-auth links\n  // Useful if you want, for example, to set a custom middleware for refreshing an access token.\n  preAuthLinks = [],\n  // If true, add the default HttpLink.\n  // Disable it if you want to replace it with a terminating link using `link` option.\n  defaultHttpLink = true,\n  // Options for the default HttpLink\n  httpLinkOptions = {},\n  // Custom Apollo cache implementation (default is apollo-cache-inmemory)\n  cache = null,\n  // Options for the default cache\n  inMemoryCacheOptions = {},\n  // Additional Apollo client options\n  apollo = {},\n  // apollo-link-state options\n  clientState = null,\n  // Function returning Authorization header token\n  getAuth = defaultGetAuth,\n  // Local Schema\n  typeDefs = undefined,\n  // Local Resolvers\n  resolvers = undefined,\n  // Hook called when you should write local state in the cache\n  onCacheInit = undefined,\n}) {\n  let wsClient, authLink, stateLink\n  const disableHttp = websocketsOnly && !ssr && wsEndpoint\n\n  // Apollo cache\n  if (!cache) {\n    cache = new InMemoryCache(inMemoryCacheOptions)\n  }\n\n  if (!disableHttp) {\n    const httpLink = createUploadLink({\n      uri: httpEndpoint,\n      ...httpLinkOptions,\n    })\n\n    if (!link) {\n      link = httpLink\n    } else if (defaultHttpLink) {\n      link = from([link, httpLink])\n    }\n\n    // HTTP Auth header injection\n    authLink = setContext(async (_, { headers }) => {\n      const Authorization = await getAuth(tokenName)\n      const authorizationHeader = Authorization ? { Authorization } : {}\n      return {\n        headers: {\n          ...headers,\n          ...authorizationHeader,\n        },\n      }\n    })\n\n    // Concat all the http link parts\n    link = authLink.concat(link)\n\n    if (preAuthLinks.length) {\n      link = from(preAuthLinks).concat(authLink)\n    }\n  }\n\n  // On the server, we don't want WebSockets and Upload links\n  if (!ssr) {\n    // If on the client, recover the injected state\n    if (typeof window !== 'undefined') {\n      // eslint-disable-next-line no-underscore-dangle\n      const state = window.__APOLLO_STATE__\n      if (state && state[clientId]) {\n        // Restore state\n        cache.restore(state[clientId])\n      }\n    }\n\n    if (!disableHttp) {\n      let persistingOpts = {}\n      if (typeof persisting === 'object' && persisting != null) {\n        persistingOpts = persisting\n        persisting = true\n      }\n      if (persisting === true) {\n        link = createPersistedQueryLink(persistingOpts).concat(link)\n      }\n    }\n\n    // Web socket\n    if (wsEndpoint) {\n      wsClient = new SubscriptionClient(wsEndpoint, {\n        reconnect: true,\n        connectionParams: () => {\n          const Authorization = getAuth(tokenName)\n          return Authorization ? { Authorization, headers: { Authorization } } : {}\n        },\n      })\n\n      // Create the subscription websocket link\n      const wsLink = new WebSocketLink(wsClient)\n\n      if (disableHttp) {\n        link = link ? link.concat(wsLink) : wsLink\n      } else {\n        link = split(\n          // split based on operation type\n          ({ query }) => {\n            const { kind, operation } = getMainDefinition(query)\n            return kind === 'OperationDefinition' &&\n              operation === 'subscription'\n          },\n          wsLink,\n          link,\n        )\n      }\n    }\n  }\n\n  if (clientState) {\n    console.warn('clientState is deprecated, see https://vue-cli-plugin-apollo.netlify.com/guide/client-state.html')\n    stateLink = withClientState({\n      cache,\n      ...clientState,\n    })\n    link = from([stateLink, link])\n  }\n\n  const apolloClient = new ApolloClient({\n    link,\n    cache,\n    // Additional options\n    ...(ssr ? {\n      // Set this on the server to optimize queries when SSR\n      ssrMode: true,\n    } : {\n      // This will temporary disable query force-fetching\n      ssrForceFetchDelay: 100,\n      // Apollo devtools\n      connectToDevTools: process.env.NODE_ENV !== 'production',\n    }),\n    typeDefs,\n    resolvers,\n    ...apollo,\n  })\n\n  // Re-write the client state defaults on cache reset\n  if (stateLink) {\n    apolloClient.onResetStore(stateLink.writeDefaults)\n  }\n\n  if (onCacheInit) {\n    onCacheInit(cache)\n    apolloClient.onResetStore(() => onCacheInit(cache))\n  }\n\n  return {\n    apolloClient,\n    wsClient,\n    stateLink,\n  }\n}\n\nexport function restartWebsockets (wsClient) {\n  // Copy current operations\n  const operations = Object.assign({}, wsClient.operations)\n\n  // Close connection\n  wsClient.close(true)\n\n  // Open a new one\n  wsClient.connect()\n\n  // Push all current operations to the new connection\n  Object.keys(operations).forEach(id => {\n    wsClient.sendMessage(\n      id,\n      MessageTypes.GQL_START,\n      operations[id].options,\n    )\n  })\n}\n\nfunction defaultGetAuth (tokenName) {\n  if (typeof window !== 'undefined') {\n    // get the authentication token from local storage if it exists\n    const token = window.localStorage.getItem(tokenName)\n    // return the headers to the context so httpLink can read them\n    return token ? `Bearer ${token}` : ''\n  }\n}\n"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./node_modules/vue-cli-plugin-apollo/graphql-client/src/index.js\n");

  /***/
}),

And then, IE11 crushes down because const is still used there.

Jesus82

Jesus82 posted a new question

apollo-module •

Apollo query inside nuxt.config.js

Hi, I'm trying to make a smart request with this module in order to grab my routes for the nuxt-sitemaps-module in order to create my sitemap. I need to make this request from within nuxt.config.js I have tried this way with no luck (as app doesn't exist in this context). What would be the right way to do this?
Thanks in advance!

The relevant part of my nuxt.config.js

import gql from 'graphql-tag'

module.exports = {

sitemap: {
    path: '/sitemap.xml',
    hostname: 'https://example.com/',
    generate: true,
    cacheTime: 86400,
    trailingSlash: true,
    routes: async ({ app }) => {
        const myRoutes = ['/one-random-path/']
        let client = app.apolloProvider.defaultClient
        let myProductsQuery = gql`query {
              products {
                slug
              }
            }`
          let myBrandsQuery = gql`query {
              brands {
                slug
              }
            }`
          const myProducts = await client.query({ query: myProductsQuery })
          const myBrands = await client.query({ query: myBrandsQuery })

          return [myRoutes, ...myProducts, ...myBrands]
        }
    }
}
bencehusi

bencehusi posted a new question

apollo-module •

Prevent authentication conflicts with multiple clients

I have an app with connections to multiple back-end services, so I have clientA and clientB.

I am authenticating via clientA, since that is the service that provides this functionality. I want to make authenticated requests only to clientA.

I get a token from my clientA service and set it as described in the docs this.$apolloHelpers.onLogin(token, this.$apolloProvider.clients.clientA)

Note, that I am passing clientA as client in the second parameter.

What I expect is to have the authorization header present for requests made by clientA while clientB should not have any authorization.

However, what happens is that the token - that is valid obviously only for clientA - gets passed along with clientB requests too.

My question is: what can I do to prevent authorization to be sent along clientB requests?
That service uses token check too so my request fails due too malformed token - obviously.

Sandeeprao69

Sandeeprao69 posted a new question

apollo-module •

Handling Auth with Firebase

Hi,

I am new to graphql and apollo. I am trying to implement firebase auth with the apollo-module. As we know that firebase provides a token which expires in 1 hr so I am looking for a solution where I can refresh token after 1 hr.

batmanhit

batmanhit posted a new feature request

apollo-module •

idea Update the vue-cli-plugin-apollo version

What problem does this feature solve?

The new vue-cli-plugin-apollo version contains new updates in this release like preAuthLinks & promisified getAuth.

https://github.com/Akryum/vue-cli-plugin-apollo/releases/tag/v0.22.2

codiyer

codiyer posted a new question

apollo-module •

Can Apollo Client be upgraded to Apollo Client 3.0

Hi,
Can this module be used with Apollo Client 3.0? I can find that vue-apollo can be used with the latest apollo client, however I am not sure I this module can be used with the latest client. It would be great if someone can provide some example

xavism

xavism posted a new question

apollo-module •

WS closed when navigating between views

I need an open WS subscription through all the pages that use the same layout (this layout is only accessible if authenticated)
So I added a subscription in the layout's created lifecycle hook. But when I navigate to another view with the same layout, the stop message is automatically sent to the WebSocket to close the connection. Neither created nor destroyed is called so it should work.

What is wrong with this idea? Which is the most elegant way to achieve what I want?
A middleware that runs in all the pages of the layout and creates the connection should work, but it would be creating subscriptions and ending subscriptions all the time :'(

Screenshot 2020-10-29 at 20.41.00.png

ClaudiaGiv

ClaudiaGiv posted a new question

apollo-module •

Does apollo client support transactions?

I have a nuxtjs app that uses apollo module for graphql communication with FaunaDB.
I want to make multiple mutations in one transaction to FaunaDB. So I don't want to send a different request for every single mutation to FaunaDB, I want to make a single request that contains all the mutations. Is it possible?

ferry77

ferry77 posted a new question

apollo-module •

Apollo gql file cannot be resolved by nuxt storybook

The issue similar to this https://github.com/storybookjs/storybook/issues/9581
Do we have solution for nuxt?
Basically I am building nuxt with nuxt apollo and everything running well (no error on 'npm run dev')
After installing nuxt storybook (https://storybook.nuxtjs.org/setup) and run 'npm run storybook'
it comes error like

ERROR in ./pages/menus/index.vue?vue&type=script&lang=js& (./nodemodules/vue-docgen-loader/lib??ref--8!./nodemodules/babel-loader/lib??ref--0-0!./nodemodules/babel-loader/lib??ref--2-0!./nodemodules/@nuxt/components/dist/loader.js??ref--9-0!./node_modules/vue-loader/lib??vue-loader-options!./pages/menus/index.vue?vue&type=script&lang=js&)
Module not found: Error: Can't resolve '~/apollo/queries/fetchMenus' in '/Users/xxxx/nuxt-app/pages/menus'

How can I make Apollo gql to be resolvable by the storybook?

Thank you!

ferry77

ferry77 posted a new question

apollo-module •

Apollo gql file cannot be resolved by nuxt storybook

The issue similar to this https://github.com/storybookjs/storybook/issues/9581
Do we have solution for nuxt?
Basically I am building nuxt with nuxt apollo and everything running well (no error on 'npm run dev')
After installing nuxt storybook (https://storybook.nuxtjs.org/setup) and run 'npm run storybook'
it comes error like

ERROR in ./pages/menus/index.vue?vue&type=script&lang=js& (./nodemodules/vue-docgen-loader/lib??ref--8!./nodemodules/babel-loader/lib??ref--0-0!./nodemodules/babel-loader/lib??ref--2-0!./nodemodules/@nuxt/components/dist/loader.js??ref--9-0!./node_modules/vue-loader/lib??vue-loader-options!./pages/menus/index.vue?vue&type=script&lang=js&)
Module not found: Error: Can't resolve '~/apollo/queries/fetchMenus' in '/Users/xxxx/nuxt-app/pages/menus'

How can I make Apollo gql to be resolvable by the storybook?

Thank you!

SuddenlyRust

SuddenlyRust posted a new bug report

apollo-module •

bug Apollo composables not working

Version

v4.0.1-rc.4
@nuxtjs/[email protected]
@vue/[email protected]

Reproduction link

https://github.com/SuddenlyRust/nuxt-apollo-composables

Steps to reproduce

yarn dev

visit http://localhost:3000/

What is expected ?

Working application without error messages

What is actually happening?

ReferenceError: define is not defined is shown

bug.png

Additional Information

With @vue/[email protected] this error message is not shown.