Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Apollo Server 2.0 without Docs #1063

Merged
merged 174 commits into from
Jun 1, 2018
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
174 commits
Select commit Hold shift + click to select a range
bd80dd1
chore(deps): update dependency @adonisjs/bodyparser to v2.0.3
renovate-bot Apr 26, 2018
11aa855
docs: Fix typo in lambda package README (#999)
briandennis Apr 27, 2018
2750573
chore(deps): update dependency @types/aws-lambda to v8.10.3
renovate-bot Apr 27, 2018
1a0e27e
chore(deps): update dependency @types/node to v9.6.7
renovate-bot Apr 27, 2018
0fb310f
chore(deps): update dependency koa to v2.5.1
renovate-bot Apr 27, 2018
e5590e5
chore(deps): update dependency hapi to v17.4.0 (#1009)
renovate[bot] Apr 30, 2018
8915ef8
chore(deps): update dependency sinon to v5 (#1010)
renovate[bot] Apr 30, 2018
040737a
chore(deps): update dependency @types/node to v9.6.8
renovate-bot May 1, 2018
b7595b3
chore(deps): update dependency sinon to v5.0.2
renovate-bot May 1, 2018
adaad08
Temporarily remove version 2.
abernix May 3, 2018
f9d919c
chore(deps): update dependency sinon to v5.0.3
renovate-bot May 3, 2018
22d13f2
chore(deps): update dependency @types/node to v9.6.9
renovate-bot May 3, 2018
0e68e2e
errors: send stack in debug, codes, make ApolloErrors
evans Apr 18, 2018
a7a4e3d
started work on new apollo-server
Apr 3, 2018
f3bb826
move to updated API design
Apr 9, 2018
4ed7e5d
move to using express instead of micro
Apr 9, 2018
4c029b0
clean up and ui
Apr 11, 2018
e75fbf4
clean up of first pass and addition of koa
Apr 18, 2018
bdabe62
fix odd case in error handling
Apr 18, 2018
44a5412
use canary version
Apr 18, 2018
6d06a1c
allow passing engine: true and using env variables
Apr 18, 2018
b3b15e8
make graphiql root
Apr 18, 2018
de2d9dc
version bump with graphiql at root
Apr 18, 2018
35a5858
errors: change INTERNAL_ERROR to INTERNAL_SERVER_ERROR, matching http…
evans Apr 18, 2018
2bdc1fa
support all apollo-server-core options and setup build
Apr 23, 2018
59e68a2
how did a yarn lockfile get here?
Apr 23, 2018
cb09fef
Errors: latest codes and add exports to the apollo-server package
evans Apr 23, 2018
d88100a
errors: change formatError to internalFormatError and fix when user d…
evans Apr 23, 2018
4a06ca4
update from feedback
Apr 24, 2018
1fdef0c
apollo-server: npm compile uses cp to avoid breaking npm linked code
evans Apr 24, 2018
e207551
add error for passing app to nonvariant and added /graphiql callout
evans Apr 24, 2018
0992208
apollo-server: add prepublish command
evans Apr 24, 2018
93efedf
apollo-server: add health check endpoint (#992)
evans Apr 26, 2018
05fd515
default apollo-server offers graphiql at all endpoints if request not…
evans Apr 24, 2018
541476f
accept non application/json for simple get requests with ?query=
evans Apr 25, 2018
27c12d9
graphiql to a boolean and add graphqlPath to url on listen return
evans Apr 25, 2018
33e976f
apollo-server: add accepts and remove unused packages
evans Apr 25, 2018
1e3e23c
implemeted shared route for graphql ide and exection by checking requ…
evans Apr 25, 2018
1b672e5
fix default path to return /graphql rather than undefined
evans Apr 25, 2018
68a368b
shared graphql ide and execution for koa
evans Apr 25, 2018
0a77096
graphiql > gui and make content-type check only if necessary
evans Apr 25, 2018
80f96fc
apollo-server: cleared up comment on default application of middleware
evans Apr 27, 2018
21b68a8
apollo-server: comment how graphqlPath uses /graphql as default
evans Apr 27, 2018
086ac9f
apollo-server: use node's url module for path creation
evans Apr 27, 2018
a0191cc
apollo-server: factor out gui checking code
evans Apr 27, 2018
0cccdb9
root: add @types/graphql to package.json to fix cache-control compila…
evans Apr 27, 2018
720df52
apollo-server: export errors from variants
evans Apr 27, 2018
7b25a90
apollo-server: add message, location, and path to formatError
evans Apr 27, 2018
5eb23d8
apollo-server: collocation of graphql gui added to CHANGELOG
evans Apr 27, 2018
68dec79
clean up and move pieces around
May 1, 2018
a553365
cloudflare
May 1, 2018
ce7d72c
apollo-server-core: add mocks
evans May 1, 2018
1e78646
apollo-server-core: add changelog with mock
evans May 1, 2018
6b2e600
apollo-server-core: remove stack traces print and include response in…
evans May 1, 2018
52b6f76
apollo-server-core: Add changelog
evans May 1, 2018
8fdbfcd
apollo-server-core: remove unused function printStackTrace
evans May 1, 2018
cdf4c68
apollo-server-core: fix error printing and logging tests
evans May 1, 2018
6239aa9
apollo-server-core: remove merge artifact from changelog
evans May 1, 2018
16e8b17
fix header setting and error message for introspection
May 2, 2018
aaac1c8
initial full beta
May 2, 2018
f6eece6
apollo-server-core: move logging into separate file
evans May 2, 2018
2a51003
apollo-server-core: internalFormatError to formatApolloError
evans May 2, 2018
4645f20
apollo-server-core: apolloError places properties in root, so they ar…
evans May 2, 2018
a7772a0
apollo-server-core: wrap error thrown by context construction in apol…
evans May 2, 2018
e0332bb
apollo-server-core: added formatApolloError arguments to subscription…
evans May 3, 2018
75e661e
apollo-server-core: stronger typing on context in GraphQLServerOption…
evans May 3, 2018
5aeb36f
apollo-server-core: allow creation of context to be asynchronous
evans May 3, 2018
0fe53a6
apollo-server-core: capture context creation failure in GraphQL error
evans May 3, 2018
c4e3766
apollo-server-core: add check for null property in ApolloError
evans May 3, 2018
7dee300
apollo-server-express: fix tests to include error code
evans May 3, 2018
c83efac
apollo-server-integration-testsuite: fix tests for apollo-server 2
evans May 3, 2018
26c09e1
apollo-server-koa: add node types to koa
evans May 3, 2018
1f3103b
apollo-server-core: use getOwnPropertyNames to stay es5
evans May 4, 2018
26c3c07
build: remove node 4 tests
evans May 4, 2018
e18e231
chore(deps): update dependency @types/node to v9.6.11
renovate-bot May 4, 2018
e58db22
changelogs: added to root and apollo-server-core
evans May 4, 2018
95d23e7
chore(deps): update dependency @types/node to v9.6.12
renovate-bot May 5, 2018
1d6ca41
chore(deps): update dependency hexo-server to v0.3.2
renovate-bot May 5, 2018
5e3b642
chore(deps): update dependency sinon to v5.0.5
renovate-bot May 7, 2018
f6fc411
chore(deps): update dependency sinon to v5.0.6
renovate-bot May 7, 2018
98ec318
chore(deps): update dependency sinon to v5.0.7
renovate-bot May 8, 2018
2781cc8
apollo-server-core: remove unsued async from BaseServer's request fun…
evans May 8, 2018
ccb6eea
apollo-server-core: enrichError not exported and moved formatter chec…
evans May 8, 2018
8fe51be
apollo-server-core: add warning to options creation failure if debugD…
evans May 8, 2018
acae63c
apollo-server-core: remove Promise wrapping in async function return …
evans May 8, 2018
9099948
apollo-server-core: run http options allows query to be an array
evans May 8, 2018
b9858df
apollo-server-core: clarify context creation can be async in changelog
evans May 8, 2018
012f37a
engine -> engineProxy in listen, fix engineLauncherOptions, and unreq…
evans May 9, 2018
3fff064
chore(deps): update dependency @types/node to v9.6.14
renovate-bot May 9, 2018
7b78133
chore(deps): update dependency @types/sinon to v4.3.2
renovate-bot May 10, 2018
56955dc
apollo-server-core: remove extra Object assign, found by @justinanast…
evans May 11, 2018
1a34a0a
apollo-server: move registerServer call outside of disableHealthCheck…
evans May 11, 2018
e77a704
apollo-server: remove constructor modification and move extra options…
evans May 11, 2018
d08f862
apollo-server-express: add bodyParserConfig option to the listen meth…
evans May 11, 2018
6457b1a
chore(deps): update dependency @types/node to v9.6.15
renovate-bot May 11, 2018
70a09df
chore(deps): update dependency @types/sinon to v4.3.3
renovate-bot May 11, 2018
8072312
bump version of subscriptions-transport-ws for graphiql
baconz Apr 24, 2018
db47867
apollo-server-core: move subscriptions out of constructor into listen…
evans May 11, 2018
9fa4a8a
docs: add parameter movement from constructor to listen to changelog
evans May 11, 2018
98ca26a
apollo-server-hapi: initial implementation of apollo-server base class
evans May 11, 2018
6b80ac9
apollo-server-hapi: fix graphql gui request, bind server listen, and …
evans May 11, 2018
e10bf1d
apollo-server-hapi: update README to reflect Apollo-server 2 changes
evans May 11, 2018
ee6994b
apollo-server-hapi: remove subscriptions boolean from register option…
evans May 11, 2018
5d27900
apollo-server-core: feedback from #979 to improve readability and spe…
evans May 12, 2018
0e4848d
apollo-server: subscriptions options condensed to on option and ensur…
evans May 12, 2018
973b096
apollo-server-core: enableIntrospection -> introspection
evans May 12, 2018
8e1f354
apollo-server-core: type errors returned as ApolloErrors and add abil…
evans May 16, 2018
2267708
apollo-server-core: check for options as optional
evans May 16, 2018
8fd2c12
apollo-server-core: add test for errors
evans May 16, 2018
3c71f34
apollo-server-core: set error prototypes explicitly
evans May 20, 2018
1ffac8b
apollo-server-core: add instanceof error tests thanks to @JustinDSN
evans May 20, 2018
858216c
apollo-server-core: move environment checking into the constructor to…
evans May 20, 2018
a3daf7d
apollo-server-core: keep referrence to subscriptions server and clean…
evans May 20, 2018
3735221
apollo-server-core: add tests for ApolloServerBase basic functionality
evans May 20, 2018
aad7c39
build: update dependencies and remove extra node typings
evans May 20, 2018
c5687ae
apollo-server-core: await server stop and restore node env in test
evans May 20, 2018
6ab3a62
apollo-server-core: add changelog for error prototyping fixes
evans May 20, 2018
5749c0a
apollo-server-core: test for starting up engine
evans May 21, 2018
138a0b5
build: readd @types/node and type configuration for tsconfig
evans May 21, 2018
04006e4
build: skipLibraryChecks when compiling
evans May 21, 2018
072aef4
tsconfig: remove typeRoots from tsconfig and automatic retreival of n…
evans May 21, 2018
84e7633
package.json: remove node and graphql types from root and unnecessary…
evans May 21, 2018
4f00977
apollo-server-core: fix typings on operation ast check for null ast
evans May 21, 2018
aea7c4e
apollo-server-core: fix test after update typings to node 10
evans May 21, 2018
23f5b76
apollo-server-core: ApolloError extends Error and implements GraphQLE…
evans May 21, 2018
b568677
apollo-server-azure-functions: add @types/node
evans May 21, 2018
2e9d468
apollo-server-core: add comment about ApolloError construction
evans May 21, 2018
361b661
lerna: add hoist option
evans May 21, 2018
582698c
package.json: update @types/graphql
evans May 21, 2018
d935e51
apollo-server-core: update graphql-tools
evans May 22, 2018
ae3fc36
Update all apollo-server-core dependencies
glasser May 17, 2018
40d8879
apollo-server-core: runHttpQuery accepts options function with arguments
evans May 22, 2018
ee7c99b
tests: fix unhandled rejection log in test runner
evans May 22, 2018
c9eaae6
Merge pull request #1074 from apollographql/server-2.0/testing
evans May 22, 2018
57328e2
apollo-server-core: move http options under own key in listenOptions
evans May 22, 2018
dccb482
Merge pull request #1080 from apollographql/server-2.0/http-option
evans May 22, 2018
f04b76f
apollo-server-hapi: add options parameter to create a server (#1082)
evans May 22, 2018
712a562
package.json: beta.2 for apollo-server, beta.1 for core/express, beta…
evans May 22, 2018
69be8c8
apollo-server-hapi: add cors option to registerServer (#1085)
evans May 23, 2018
1f78463
apollo-server: move health check into variant's registerServer call
evans May 23, 2018
06a4bcb
apollo-server: add cors options to listen function
evans May 23, 2018
45d3614
Merge pull request #1086 from apollographql/server-2.0/healthcheck-in…
evans May 23, 2018
6b94408
apollo-server: remove registerServer config from listen (#1090)
evans May 24, 2018
3acb7c7
apollo-server: tests constructor and basic queries
evans May 24, 2018
f1fa8ad
apollo-server-express: tests constructor, registerServer options, and…
evans May 24, 2018
cc5f81f
tests: add apollo-server{,-express} tests to main test runner
evans May 24, 2018
9342658
apollo-server-express: remove circular devDependeny on apollo-server …
evans May 24, 2018
5b98a07
apollo-server-express: move import of apollo-server in tests to a req…
evans May 24, 2018
b4bad69
Merge pull request #1095 from apollographql/server-2.0/testing
evans May 24, 2018
43d545f
apollo-server-core: add request object to runHttpQuery for access to …
evans May 24, 2018
8b6b016
Be consistent about where GraphQL queries are parsed
glasser May 17, 2018
220d2ed
apollo-server-core: move query presence check to after formatParams
evans May 24, 2018
8c92c1a
integration-testsuite: add error on AST passed to server as query
evans May 24, 2018
f118ed4
apollo-server-core: add note about mutation on GET request ad-hoc error
evans May 24, 2018
1c46a32
apollo-server-core: add changelog entry for removing AST over the wire
evans May 24, 2018
447bb18
Merge pull request #1097 from apollographql/server-2.0/consistent-que…
evans May 24, 2018
5412885
apollo-server 2: uploads as schema enhancement fulfilled in registerS…
evans May 29, 2018
da31690
runQuery accepts Request object that variants create (#1108)
evans May 30, 2018
5bb652a
hapi: add new server instantiation to the readme
evans May 30, 2018
4609ee9
core: evaluate context per request and differ error until caught in r…
evans May 30, 2018
9e07cb3
core: add test around throwing Authentication error inside of context…
evans May 30, 2018
7d17f1f
core: made name non-eunumerable in ApolloError and removed extra code…
evans May 30, 2018
7cad97e
core: add tests error handling in resolvers with production env
evans May 30, 2018
c5ba902
express: add fallback for file uploads middleware if not enabled
evans May 31, 2018
63d0f72
core: error resurfacing for merged schemas that hide errors in a Comb…
evans May 31, 2018
38c8713
Merge pull request #1113 from apollographql/server-2.0/context-fix
evans May 31, 2018
2acf565
Added an option to support additional extensions
sebas5384 Apr 3, 2018
7444904
Update for [email protected] API
glasser May 17, 2018
6618965
Rename ApolloServer.request to graphQLServerOptionsForRequest
glasser May 30, 2018
5e1b49b
basic apollo-engine-reporting integration
glasser May 31, 2018
ec7394d
apollo-server,core,hapi,express: bump package to newest beta
evans Jun 1, 2018
4405405
hapi,express: fix graphql playground subscriptitionPath argument for …
evans Jun 1, 2018
1a305eb
Merge pull request #1105 from apollographql/glasser/extensions-0.1.0
glasser Jun 1, 2018
db3316c
Merge branch 'version-2' into refactor-2.0
evans Jun 1, 2018
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 0 additions & 6 deletions .circleci/config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -36,10 +36,6 @@ jobs:
# Platform tests, each with the same tests but different platform or version.
# The docker tag represents the Node.js version and the full list is available
# at https://hub.docker.com/r/circleci/node/.
Node.js 4:
docker: [ { image: 'circleci/node:4' } ]
<<: *common_test_steps

Node.js 6:
docker: [ { image: 'circleci/node:6' } ]
<<: *common_test_steps
Expand Down Expand Up @@ -79,8 +75,6 @@ workflows:
version: 2
Build and Test:
jobs:
- Node.js 4:
<<: *ignore_doc_branches
- Node.js 6:
<<: *ignore_doc_branches
- Node.js 8:
Expand Down
3 changes: 3 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,9 @@ All of the packages in the `apollo-server` repo are released with the same versi

### vNEXT

* Upgrade `subscription-transport-ws` to 0.9.9 for Graphiql
* Remove tests and guaranteed support for Node 4 [PR #1024](https://github.com/apollographql/apollo-server/pull/1024)

### v1.3.6

* Recognize requests with Apollo Persisted Queries and return `PersistedQueryNotSupported` to the client instead of a confusing error. [PR #982](https://github.com/apollographql/apollo-server/pull/982)
Expand Down
3 changes: 2 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -235,7 +235,8 @@ store.put('query testquery{ testString }');
graphqlOptions = {
schema: Schema,
formatParams(params) {
params['query'] = store.get(params.operationName);
params['parsedQuery'] = store.get(params.operationName);
delete params['queryString']; // Or throw if this is provided.
return params;
},
};
Expand Down
1 change: 0 additions & 1 deletion docs/_config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@ subtitle: Apollo Server
description: A guide to using Apollo Server.
versions:
- '1'
- '2'
sidebar_categories:
null:
- index
Expand Down
4 changes: 2 additions & 2 deletions docs/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -13,8 +13,8 @@
"hexo-renderer-ejs": "0.3.1",
"hexo-renderer-less": "0.2.0",
"hexo-renderer-marked": "0.3.2",
"hexo-server": "0.3.1",
"meteor-theme-hexo": "1.0.9"
"hexo-server": "0.3.2",
"meteor-theme-hexo": "1.0.13"
},
"scripts": {
"start": "npm run build && chexo apollo-hexo-config -- server",
Expand Down
118 changes: 86 additions & 32 deletions docs/source/api/apollo-server.md
Original file line number Diff line number Diff line change
Expand Up @@ -3,27 +3,71 @@ title: "API Reference: apollo-server"
sidebar_title: apollo-server
---

This API reference documents the exports from the `apollo-server`, and `apollo-server/{variant}` packages (e.g. `apollo-server/express`). Both the root module and the module sub-paths export the same functionality.
This API reference documents the exports from the `apollo-server`.

## `ApolloServer`

The core of an Apollo Server implementation. For a complete example, see the [Building a server](../essentials/server.html) section within "Essentials".
The core of an Apollo Server implementation. For an example, see the [Building a server](../essentials/server.html) section within "Essentials".

### `constructor(options)`: <`ApolloServer`>

#### Parameters

* `options`: <`Object`>
* `typeDefs`: <`String` inside [`gql`](#gql) tag> _(required)_

This is a string representation of your GraphQL Schema Definition Language (SDL).
* `typeDefs`: <`String` inside [`gql`](#gql) tag> _(required)_

String representation of GraphQL schema in the Schema Definition Language (SDL).

* `resolvers`: <`Object`> _(required)_

Type: `Object`
A map of resolvers for the types defined in `typeDefs`. The key should be the type name and the value should be a `Function` to be executed for that type.

* `context`: <`Object`> | <`Function`>

An object or function called with the current request that creates the context shared across all resolvers

```js
new ApolloServer({
typeDefs,
resolvers,
context: ({ req }) => ({
authScope: getScope(req.headers.authorization)
}),
});
```

* `mocks`: <`Object`> | <`Boolean`>

A boolean enabling the default mocks or object that contains definitions

* `schemaDirectives`: <`Object`>

Contains definition of schema directives used in the `typeDefs`

* `introspection`: <`Boolean`>

Enables and disables schema introspection

* `debug`: <`Boolean`>

Enables and disables development mode helpers. Defaults to `true`

* `validationRules`: <`Object`>

Schema validation rules

This should be a map of resolvers for the types defined in `typeDefs`. The key should be the type name and the value should be a `Function` to be executed for that type.
* `tracing`, `cacheControl`: <`Boolean`>

Add tracing or cacheControl meta data to the GraphQL response

* `formatError`, `formatResponse`, `formatParams`: <`Function`>

Functions to format the errors and response returned from the server, as well as the parameters to graphql execution(`runQuery`)

* `schema`: <`Object`>

An executable GraphQL schema that will override the `typeDefs` and `resolvers` provided

#### Returns

Expand All @@ -35,24 +79,35 @@ The core of an Apollo Server implementation. For a complete example, see the [B

* `options`: <`Object`>

Most parameters which are supported by Node.js' [`net.Server.listen`](https://nodejs.org/api/net.html#net_server_listen_options_callback) method are supported, including:
* `http`: <`Object`>

All parameters which are supported by Node.js' [`net.Server.listen`](https://nodejs.org/api/net.html#net_server_listen_options_callback) method are supported, including:

* `port`: <`String`> | <`Number`>
* `path`: <`String`>
* `backlog`: <`Number`>
* `exclusive`: <`Boolean`>

or

* `handler`: <`Object`>
* `backlog`: <`Number`>

* `port`: <`String`> | <`Number`>
* `path`: <`String`>
* `backlog`: <`Number`>
* `exclusive`: <`Boolean`>
Engine launcher options

// Engine launcher options
`engineLauncherOptions?: EngineLauncherOptions;`
* `engineLauncherOptions` : [<`Object`>](https://www.apollographql.com/docs/engine/setup-node.html#api-engine.listen)
* `engineProxy`: [<`Object`>](https://www.apollographql.com/docs/engine/proxy-config.html)

// WebSocket options
`keepAlive?: number;`
`onConnect?: (
connectionParams: Object,
websocket: WebSocket,
context: ConnectionContext,
) => any;
onDisconnect?: (websocket: WebSocket, context: ConnectionContext) => any;`
WebSocket options

* `subscriptions`: <`Object`> | <`String`> | false

String defining the path for subscriptions or an Object to customize the subscriptions server. Set to false to disable subscriptions

* `path`: <`String`>
* `keepAlive`: <`Number`>
* `onConnect`: <`Function`>
* `onDisconnect`: <`Function`>

#### Returns

Expand All @@ -65,29 +120,28 @@ The `registerServer` method is from `apollo-server-express`. Middleware registra
### Parameters

* `options`: <`Object`>

* `app`: <`HttpServer`> _(required)_

Pass the handle to your nexpress server here.
Pass the handle to your nexpress server here.

* `server`: <`ApolloServer`> _(required)_

Pass the instance of Apollo Server
Pass the instance of Apollo Server

* `path` : <`String`>

Specify a custom path. It defaults to `/graphql` if no path is specified.
Specify a custom path. It defaults to `/graphql` if no path is specified.

* `cors`: <`Object`>

Pass the cors options.


Pass the cors options.

## `gql`

The `gql` is a [template literal tag](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Template_literals#Tagged_templates). Template literals were introduced in recent versions of ECMAScript to provide embedded expressions (i.e. `` `A string with interpolated ${variables}` ``) and template literal tags exist to provide additional functionality for what would otherwise be a normal template literal.
The `gql` is a [template literal tag](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Template_literals#Tagged_templates). Template literals were introduced in recent versions of ECMAScript to provide embedded expressions (i.e. `` `A string with interpolated ${variables}` ``) and template literal tags exist to provide additional functionality for what would otherwise be a normal template literal.

In the case of GraphQL, the `gql` tag is used to surround GraphQL operation and schema language (which are represented as `String`s), and makes it easier to differentiate from ordinary strings. This is particularly useful when performing static analysis on GraphQL language (e.g. to enable syntax highlighting, code generation, etc.) and avoids need for tools to "guess" if a string contains GraphQL language.
In the case of GraphQL, the `gql` tag is used to surround GraphQL operation and schema language (which are represented as `String`s), and makes it easier to differentiate from ordinary strings. This is particularly useful when performing static analysis on GraphQL language (e.g. to enable syntax highlighting, code generation, etc.) and avoids need for tools to "guess" if a string contains GraphQL language.

### Usage

Expand All @@ -97,7 +151,7 @@ Import the `gql` template literal tag into the current context from the `apollo-
const { gql } = require('apollo-server');
```

Then, place GraphQL schema definitions (SDL), queries or other operations into the `gql` template literal tag. Keep in mind that template literals use the grave accent (`` ` ``) and not normal quotation marks (e.g. not `"` or `'`):
Then, place GraphQL schema definitions (SDL), queries or other operations into the `gql` template literal tag. Keep in mind that template literals use the grave accent (`` ` ``) and not normal quotation marks (e.g. not `"` or `'`):

```js
const typeDefs = gql`
Expand All @@ -120,7 +174,7 @@ The `makeExecutableSchema` method is re-exported from apollo-server as a conveni
* `allowUndefinedInResolve` = false
* `resolverValidationOptions` = {}
* `directiveResolvers` = null
* `schemaDirectives` = null
* `schemaDirectives` = null
* `parseOptions` = {}
* `inheritResolversFromInterfaces` = false

Expand All @@ -135,6 +189,7 @@ If preserveResolvers is set to true, existing resolve functions will not be over
### Parameters

* `options`: <`Object`>

* `schema`: <`GraphQLSchema`> _(required)_

Pass an executable schema (`GraphQLSchema`) to be mocked.
Expand All @@ -157,7 +212,6 @@ If preserveResolvers is set to true, existing resolve functions will not be over

### Usage


```js
const { addMockFunctionsToSchema } = require('apollo-server');

Expand Down
10 changes: 4 additions & 6 deletions docs/source/essentials/data.md
Original file line number Diff line number Diff line change
Expand Up @@ -95,21 +95,19 @@ Every resolver function is called according to the nesting of the query. To unde

The context is how you access your shared connections and fetchers in resolvers to get data.

The `context` is the third argument passed to every resolver. It is useful for passing things that any resolver may need, like [authentication scope](), database connections([mongo](), [postgres](), etc), and custom fetch functions. Additionally, if you're using [dataloaders to batch requests](../best-practices/performance.html#Batching-data-lookups) across resolvers, you can attach them to the `context` as well.
The `context` is the third argument passed to every resolver. It is useful for passing things that any resolver may need, like [authentication scope](https://dev-blog.apollodata.com/authorization-in-graphql-452b1c402a9), database connections, and custom fetch functions. Additionally, if you're using [dataloaders to batch requests](../best-practices/performance.html#Batching-data-lookups) across resolvers, you can attach them to the `context` as well.

As a best practice, `context` should be the same for all resolvers, no matter the particular query or mutation, and resolvers should never modify it. This ensures consistency across resolvers, and helps increase development velocity.

To provide a `context` to your resolvers, add a `context` object to the Apollo Server constructor. This constructor gets called with every request, so you can set the context based off the details of the request (like HTTP headers).

For specific examples, follow the [backend]() instructions.

```
const server = new ApolloServer(req => ({
const server = new ApolloServer({
typeDefs,
resolvers,
context: {
context: ({ req }) => ({
authScope: getScope(req.headers.authorization)
}
})
}));

// resolver
Expand Down
42 changes: 0 additions & 42 deletions docs/source/features/creating-directives.md
Original file line number Diff line number Diff line change
Expand Up @@ -614,45 +614,3 @@ As its name suggests, the `SchemaDirectiveVisitor` abstraction is specifically d
While directive syntax can also appear in GraphQL queries sent from the client, implementing query directives would require runtime transformation of query documents. We have deliberately restricted this implementation to transformations that take place when you call the `makeExecutableSchema` function&mdash;that is, at schema construction time.

We believe confining this logic to your schema is more sustainable than burdening your clients with it, though you can probably imagine a similar sort of abstraction for implementing query directives. If that possibility becomes a desire that becomes a need for you, let us know, and we may consider supporting query directives in a future version of these tools.

## What about `directiveResolvers`?

Before `SchemaDirectiveVisitor` was implemented, the `makeExecutableSchema` function took a `directiveResolvers` option that could be used for implementing certain kinds of `@directive`s on fields that have resolver functions.

The new abstraction is more general, since it can visit any kind of schema syntax, and do much more than just wrap resolver functions. However, the old `directiveResolvers` API has been [left in place](directive-resolvers.html) for backwards compatibility, though it is now implemented in terms of `SchemaDirectiveVisitor`:

```typescript
function attachDirectiveResolvers(
schema: GraphQLSchema,
directiveResolvers: IDirectiveResolvers<any, any>,
) {
const schemaDirectives = Object.create(null);

Object.keys(directiveResolvers).forEach(directiveName => {
schemaDirectives[directiveName] = class extends SchemaDirectiveVisitor {
public visitFieldDefinition(field: GraphQLField<any, any>) {
const resolver = directiveResolvers[directiveName];
const originalResolver = field.resolve || defaultFieldResolver;
const directiveArgs = this.args;
field.resolve = (...args: any[]) => {
const [source, /* original args */, context, info] = args;
return resolver(
async () => originalResolver.apply(field, args),
source,
directiveArgs,
context,
info,
);
};
}
};
});

SchemaDirectiveVisitor.visitSchemaDirectives(
schema,
schemaDirectives,
);
}
```

Existing code that uses `directiveResolvers` should probably consider migrating to `SchemaDirectiveVisitor` if feasible, though we have no immediate plans to deprecate `directiveResolvers`.
2 changes: 1 addition & 1 deletion docs/source/features/mocking.md
Original file line number Diff line number Diff line change
Expand Up @@ -170,4 +170,4 @@ server.listen().then(({ url }) => {

## API

Under the hood, Apollo Sever uses a library for building GraphQL servers, called `graphql-tools`. The mocking functionality is provided by the function [`addMockFunctionsToSchema`](../api/graphql-tools#addMockFunctionsToSchema). The `mocks` object is passed directly to the function and `preserveResolvers` is always true. [`MockList`](../api/graphql-tools#MockList) is exported directly from the `graphql-tools` library.
Under the hood, Apollo Sever uses a library for building GraphQL servers, called `graphql-tools`. The mocking functionality is provided by the function [`addMockFunctionsToSchema`](../api/graphql-tools.html#addMockFunctionsToSchema). The `mocks` object is passed directly to the function and `preserveResolvers` is always true. [`MockList`](../api/graphql-tools.html#MockList) is exported directly from the `graphql-tools` library.
4 changes: 2 additions & 2 deletions docs/source/features/schema-delegation.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ The `graphql-tools` package provides several related tools for managing schema d

* [Remote schemas](./remote-schemas.html) - turning a remote GraphQL endpoint into a local schema
* [Schema transforms](./schema-transforms.html) - modifying existing schemas to make delegation easier
* [Schema stitching](./schema-stitching) - merging multiple schemas into one
* [Schema stitching](./schema-stitching.html) - merging multiple schemas into one

Delegation is performed by one function, `delegateToSchema`, called from within a resolver function of the parent schema. The `delegateToSchema` function sends the query subtree received by the parent resolver to a subschema that knows how to execute it, then returns the result as if the parent resolver had executed the query.

Expand Down Expand Up @@ -158,4 +158,4 @@ Delegation preserves aliases that are passed from the parent query. However that

## API

Under the hood, Apollo server uses the `graphql-tools` library, which includes [`delegateToSchema`](../api/graphql-tools#delegateToSchema) by default.
Under the hood, Apollo server uses the `graphql-tools` library, which includes [`delegateToSchema`](../api/graphql-tools.html#delegateToSchema) by default.
2 changes: 1 addition & 1 deletion docs/source/features/schema-stitching.md
Original file line number Diff line number Diff line change
Expand Up @@ -232,7 +232,7 @@ const mergedSchema = mergeSchemas({

<h2 id="using-with-transforms">Using with Transforms</h2>

Often, when creating a GraphQL gateway that combines multiple existing schemas, we might want to modify one of the schemas. The most common tasks include renaming some of the types, and filtering the root fields. By using [transforms](./schema-transforms) with schema stitching, we can easily tweak the subschemas before merging them together.
Often, when creating a GraphQL gateway that combines multiple existing schemas, we might want to modify one of the schemas. The most common tasks include renaming some of the types, and filtering the root fields. By using [transforms](./schema-transforms.html) with schema stitching, we can easily tweak the subschemas before merging them together.

Before, when we were simply merging schemas without first transforming them, we would typically delegate directly to one of the merged schemas. Once we add transforms to the mix, there are times when we want to delegate to fields of the new, transformed schemas, and other times when we want to delegate to the original, untransformed schemas.

Expand Down
2 changes: 1 addition & 1 deletion docs/source/getting-started.md
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ In this step, we'll use your terminal (e.g. Terminal, iTerm, PowerShell) to crea

npm init --yes

> We use `npm`, the default package manager which ships with Node.js. Other package managers, such as [Yarn](//yarnpkg.com), offer similar functionality, but will not be covered in this guide.
> We use `npm`, the default package manager which ships with Node.js. Other package managers, such as [Yarn](http://yarnpkg.com), offer similar functionality, but will not be covered in this guide.

If the above steps all completed successfully, there should be a new `package.json` file in the directory. You can verify this by running `ls` (list files).

Expand Down
4 changes: 2 additions & 2 deletions docs/source/migration-two-dot.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ The Apollo Server 2.0 beta dramatically simplifies the API for building a GraphQ

While it's possible to migrate an existing server to the 2.0 beta without any changes, we recommend changing to new patterns we're suggesting in order to take advantage of all the latest Apollo Server features, reduce the boilerplate, and enable future flexibility. To learn how to migrate to the 2.0 beta from version 1.0, please read the following guide.

> **Note:** In the beta of Apollo Server 2.0 only Express is supported. Additional middleware variants will be implemented in the official 2.0 release.
> **Note:** In the beta of Apollo Server 2.0 only Express and Hapi are supported. Additional middleware integrations will be implemented in the official 2.0 release.

### Recommending the `gql` tag

Expand Down Expand Up @@ -127,7 +127,7 @@ server.listen().then(({ url }) => {

If you are simply focused on running a production-ready GraphQL server quickly, Apollo Server 2.0 ships with a built-in server and starting your own server (e.g. Express, Koa, etc.) is no longer necessary.

For these cases, it's possible to remove the existing `apollo-server-{variant}` package and add the new `apollo-server` beta. If using Express, this can be done by running:
For these cases, it's possible to remove the existing `apollo-server-{integrations}` package and add the new `apollo-server` beta. If using Express, this can be done by running:

npm uninstall --save apollo-server-express

Expand Down
Loading