本文整理匯總了TypeScript中apollo-link.split函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript split函數的具體用法?TypeScript split怎麽用?TypeScript split使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了split函數的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: createClient
export function createClient(
// @ts-ignore - useful to pass in the store for `Authorization` headers, etc
store: Store
): ApolloClient<NormalizedCacheObject> {
// Create the cache first, which we'll share across Apollo tooling.
// This is an in-memory cache. Since we'll be calling `createClient` on
// universally, the cache will survive until the HTTP request is
// responded to (on the server) or for the whole of the user's visit (in
// the browser)
const cache = new InMemoryCache({ fragmentMatcher });
// Create a HTTP client (both server/client). It takes the GraphQL
// server from the `GRAPHQL` environment variable, which by default is
// set to an external playground at https://graphqlhub.com/graphql
const httpLink = new HttpLink({
credentials: "same-origin",
uri: GRAPHQL
});
// If we're in the browser, we'd have received initial state from the
// server. Restore it, so the client app can continue with the same data.
if (!SERVER) {
cache.restore((window as any).__APOLLO__);
}
// Return a new Apollo Client back, with the cache we've just created,
// and an array of 'links' (Apollo parlance for GraphQL middleware)
// to tell Apollo how to handle GraphQL requests
return new ApolloClient({
cache,
link: ApolloLink.from([
// General error handler, to log errors back to the console.
// Replace this in production with whatever makes sense in your
// environment. Remember you can use the global `SERVER` variable to
// determine whether you're running on the server, and record errors
// out to third-party services, etc
onError(({ graphQLErrors, networkError }) => {
if (graphQLErrors) {
graphQLErrors.map(({ message, locations, path }) =>
console.log(
`[GraphQL error]: Message: ${message}, Location: ${locations}, Path: ${path}`
)
);
}
if (networkError) {
console.log(`[Network error]: ${networkError}`);
}
}),
// Split on HTTP and WebSockets
WS_SUBSCRIPTIONS && !SERVER
? split(
({ query }) => {
const definition = getMainDefinition(query);
return (
definition.kind === "OperationDefinition" &&
definition.operation === "subscription"
);
},
// Use WebSockets for subscriptions
new WebSocketLink(
// Replace http(s) with `ws` for connecting via WebSockts
new SubscriptionClient(GRAPHQL.replace(/^https?/, "ws"), {
reconnect: true // <-- automatically redirect as needed
})
),
// ... fall-back to HTTP for everything else
httpLink
)
: httpLink // <-- just use HTTP on the server
]),
// On the server, enable SSR mode
ssrMode: SERVER
});
}
示例2: WebSocketLink
});
const wsLink = new WebSocketLink({
options: {
connectionParams: {
"X-JWT": getToken()
},
reconnect: true
},
uri: "ws://localhost:4000/subscription"
});
const combinedLinks = split(
({ query }) => {
const { kind, operation }: any = getMainDefinition(query);
return kind === "OperationDefinition" && operation === "subscription";
},
wsLink,
httpLink
);
const errorLink = onError(({ graphQLErrors, networkError }) => {
if (graphQLErrors) {
graphQLErrors.map(({ message }) => {
toast.error(`Unexpected error: ${message}`);
});
}
if (networkError) {
toast.error(`Network error: ${networkError}`);
}
});
示例3: WebSocketLink
// Create a WebSocket link:
const wsLink = new WebSocketLink({
uri: `${ssl ? 'wss' : 'ws'}://${host}/subscriptions`,
options: {
reconnect: true,
},
})
// using the ability to split links, you can send data to each link
// depending on what kind of operation is being sent
const link = split(
// split based on operation type
({query}) => {
const {kind, operation} = getMainDefinition(
query,
) as OperationDefinitionNode
return kind === 'OperationDefinition' && operation === 'subscription'
},
wsLink,
httpLink,
)
const cache = new InMemoryCache({
cacheRedirects: {
Query: {
device: (_, args) =>
toIdValue(
cache.config.dataIdFromObject({__typename: 'Device', id: args.id}),
),
},
},
示例4: setContext
})
const authLink = setContext((_, { headers }) => {
const auth = getAuthHeader()
return {
headers: {
...headers,
Authorization: auth,
},
}
})
const terminatingLink = split(
({ query }) => {
const { kind, operation } = getMainDefinition(query) as OperationDefinitionNode
return kind === 'OperationDefinition' && operation === 'subscription'
},
wsLink,
authLink.concat(httpLink),
)
const link = ApolloLink.from([terminatingLink])
const cache = new InMemoryCache()
export default new ApolloClient({
link,
cache,
})
示例5: createApolloClient
export function createApolloClient() {
const graphqlApiUrl = getGraphQLEndpoint(
process.env.REACT_APP_LOCAL_API ? 'graphqlApiUrlLocal' : 'graphqlApiUrl',
);
const httpLink = createHttpLink({ uri: graphqlApiUrl });
const authLink = setContext((_, { headers }) => {
return {
headers: {
...headers,
authorization: appInitializer.getBearerToken() || null,
},
};
});
const subscriptionsApiUrl = getGraphQLEndpoint(
process.env.REACT_APP_LOCAL_API
? 'subscriptionsApiUrlLocal'
: 'subscriptionsApiUrl',
);
const wsLink = new WebSocketLink({
uri: subscriptionsApiUrl,
options: {
reconnect: true,
},
});
const cache = new InMemoryCache();
const authHttpLink = authLink.concat(httpLink);
const errorLink = onError(
({ operation, response, graphQLErrors, networkError }) => {
if (process.env.REACT_APP_ENV !== 'production') {
if (graphQLErrors) {
graphQLErrors.map(({ message, locations, path }) =>
// tslint:disable-next-line
console.error(
`[GraphQL error]: Message: ${message}, Location: ${locations}, Path: ${path}`,
),
);
}
// tslint:disable-next-line
if (networkError) console.error(`[Network error]: ${networkError}`);
}
},
);
const link = split(
({ query }) => {
const { kind, operation } = getMainDefinition(query);
return kind === 'OperationDefinition' && operation === 'subscription';
},
wsLink,
authHttpLink,
);
const client = new ApolloClient({
link: ApolloLink.from([errorLink, link]),
cache,
connectToDevTools: true,
});
return client;
}