From 21e00444e513a2bc84d95f3e1a0f9fa6bcfd9589 Mon Sep 17 00:00:00 2001 From: Adam Zionts Date: Thu, 14 May 2020 00:58:44 -0700 Subject: [PATCH 1/5] Update references of `ENGINE_API_KEY` in .mdx --- docs/source/tutorial/client.mdx | 7 ++++--- graph-manager-docs/source/getting-started.mdx | 4 ++-- .../source/managed-federation/advanced-topics.mdx | 2 +- .../source/managed-federation/setup.mdx | 2 +- graph-manager-docs/source/operation-registry.mdx | 14 +++++++------- graph-manager-docs/source/schema-registry.mdx | 4 ++-- graph-manager-docs/source/schema-validation.mdx | 2 +- graph-manager-docs/source/setup-analytics.mdx | 2 +- 8 files changed, 19 insertions(+), 18 deletions(-) diff --git a/docs/source/tutorial/client.mdx b/docs/source/tutorial/client.mdx index db4173e2b..83d533c11 100644 --- a/docs/source/tutorial/client.mdx +++ b/docs/source/tutorial/client.mdx @@ -31,18 +31,19 @@ Now, our dependencies are installed. Here are the packages we will be using to b While Apollo VSCode is not required to successfully complete the tutorial, setting it up unlocks a lot of helpful features such as autocomplete for operations, jump to fragment definitions, and more. First, make a copy of the `.env.example` file located in `client/` and call it `.env`. Add your Graph Manager API key that you already created in step #4 to the file: +> Note: You may need to upgrade your plugin version, which relies on the former `ENGINE_API_KEY` environment variable ```bash:title=.env -ENGINE_API_KEY=service:: +APOLLO_KEY=service:: ``` The entry should basically look something like this: ```bash:title=.env -ENGINE_API_KEY=service:my-service-439:E4VSTiXeFWaSSBgFWXOiSA +APOLLO_KEY=service:my-service-439:E4VSTiXeFWaSSBgFWXOiSA ``` -Our key is now stored under the environment variable `ENGINE_API_KEY`. Apollo VSCode uses this API key to pull down your schema from the registry. +Our key is now stored under the environment variable `APOLLO_KEY`. Apollo VSCode uses this API key to pull down your schema from the registry. Next, create an Apollo config file called `apollo.config.js`. This config file is how you configure both the Apollo VSCode extension and CLI. Paste the snippet below into the file: diff --git a/graph-manager-docs/source/getting-started.mdx b/graph-manager-docs/source/getting-started.mdx index 2fec3f70e..df46617d1 100644 --- a/graph-manager-docs/source/getting-started.mdx +++ b/graph-manager-docs/source/getting-started.mdx @@ -47,13 +47,13 @@ In Graph Manager, each **graph** corresponds to the entirety of a GraphQL schema 3. Add the `.env` file to your project's `.gitignore` file. -4. Obtain a personal API key from Graph Manager and set it as the value of `ENGINE_API_KEY` in your `.env` file: +4. Obtain a personal API key from Graph Manager and set it as the value of `APOLLO_KEY` (previously `ENGINE_API_KEY`) in your `.env` file: ```python:title=.env # Don't worry, the author invalidated this API key before sharing it 😉 - ENGINE_API_KEY=user:gh.StephenBarlow:Rc6D_7mLxY74okHRCL2HMg + APOLLO_KEY=user:gh.StephenBarlow:Rc6D_7mLxY74okHRCL2HMg ``` 4. Add an `apollo.config.js` file to your project's root directory if there isn't one yet. Unlike `.env`, you _do_ add this file to version control. diff --git a/graph-manager-docs/source/managed-federation/advanced-topics.mdx b/graph-manager-docs/source/managed-federation/advanced-topics.mdx index 1235e7899..17041c0d1 100644 --- a/graph-manager-docs/source/managed-federation/advanced-topics.mdx +++ b/graph-manager-docs/source/managed-federation/advanced-topics.mdx @@ -198,7 +198,7 @@ With this atomic strategy, the query planner resolves all outstanding requests t Like any distributed architecture, you should make sure that your federated graph has proper observability, monitoring, and automation to ensure reliability and performance of both your gateway and the federated services underneath it. Serving your GraphQL API from a distributed architecture has many benefits, like productivity, isolation, and being able to match the right services with the right runtimes. Operating a distributed system also has more complexity and points of failure than operating a monolith, and with that complexity comes a need to heighten observability into the state of your system and control over its coordination. -Apollo Server has support for reporting federated [tracing](/performance/) information from the gateway. In order to support the gateway with detailed timing and error information, federated services expose their own tracing information per-fetch in their extensions, which are consumed by the gateway and merged together in order to be emitted to the Apollo metrics ingress. To enable this functionality, make sure the `ENGINE_API_KEY` is set in the environment for your gateway server and ensure that all federated services and the gateway are running `apollo-server` version `2.7.0` or greater. Also, ensure that federated services do not have the `ENGINE_API_KEY` environment variable set. +Apollo Server has support for reporting federated [tracing](/performance/) information from the gateway. In order to support the gateway with detailed timing and error information, federated services expose their own tracing information per-fetch in their extensions, which are consumed by the gateway and merged together in order to be emitted to the Apollo metrics ingress. To enable this functionality, make sure the `APOLLO_KEY` is set in the environment for your gateway server and ensure that all federated services and the gateway are running `apollo-server` version `2.7.0` or greater. Also, ensure that federated services do not have the `APOLLO_KEY` environment variable (`ENGINE_API_KEY` in `apollo-server` versions pre 2.13.0) set. Traces will be reported in the shape of the query plan, with each unique fetch to a federated service reporting timing and error data. diff --git a/graph-manager-docs/source/managed-federation/setup.mdx b/graph-manager-docs/source/managed-federation/setup.mdx index 918787d7b..abe1c7d89 100644 --- a/graph-manager-docs/source/managed-federation/setup.mdx +++ b/graph-manager-docs/source/managed-federation/setup.mdx @@ -98,7 +98,7 @@ const gateway = new ApolloGateway(); Like your implementing services, your gateway uses an API key to identify itself to Graph Manager. Obtain a **graph API key** from your graph's Settings page in the [Graph Manager UI](https://engine.apollographql.com/). -Provide your API key to your gateway by setting it as the value of the `ENGINE_API_KEY` environment variable in your gateway's environment. Apollo Server will automatically read this environment variable on startup. +Provide your API key to your gateway by setting it as the value of the `APOLLO_KEY` environment variable (`ENGINE_API_KEY` in `apollo-server` pre-2.13.0) in your gateway's environment. Apollo Server will automatically read this environment variable on startup. Note that if you specify the API key in a `.env` file, the gateway does _not_ automatically read this file. Use a library such as [`dotenv`](https://www.npmjs.com/package/dotenv). diff --git a/graph-manager-docs/source/operation-registry.mdx b/graph-manager-docs/source/operation-registry.mdx index 8c402284c..8ca416f6b 100644 --- a/graph-manager-docs/source/operation-registry.mdx +++ b/graph-manager-docs/source/operation-registry.mdx @@ -64,11 +64,11 @@ npm install apollo --save-dev First, make sure Apollo Server is running and that introspection is enabled (it is often disabled in production). -Next, using the following command as a reference, replace the `` with the Apollo Graph Manager API key from the appropriate service and specify the correct server endpoint with the `--endpoint` flag: +Next, using the following command as a reference, replace the `` with the Apollo Graph Manager API key from the appropriate service and specify the correct server endpoint with the `--endpoint` flag: ``` npx apollo service:push \ - --key \ + --key \ --endpoint https://server/graphql ``` @@ -101,7 +101,7 @@ To register operations, use the following command as a reference, taking care to ``` npx apollo client:push \ - --key \ + --key \ --clientName \ --clientVersion \ --includes="src/**/*.{ts,js,graphql}" @@ -232,10 +232,10 @@ const server = new ApolloServer({ If the server was already configured to use Apollo Graph Manager, no additional changes are necessary, but it's important to make sure that the server is configured to use the same service as the operations were registered with in step 3. -If the server was not previously configured with Apollo Graph Manager, be sure to start the server with the `ENGINE_API_KEY` variable set to the appropriate API key. For example: +If the server was not previously configured with Apollo Graph Manager, be sure to start the server with the `APOLLO_KEY` variable set to the appropriate API key. For example: ``` -ENGINE_API_KEY= npm start +APOLLO_KEY= npm start ``` Alternatively, the API key can be specified with the `engine` parameter on the Apollo Server constructor options: @@ -243,7 +243,7 @@ Alternatively, the API key can be specified with the `engine` parameter on the A ```js const server = new ApolloServer({ // ... - engine: '', // highlight-line + engine: '', // highlight-line // ... }); ``` @@ -290,7 +290,7 @@ const server = new ApolloServer({ typeDefs, resolvers, subscriptions: false, - engine: '', + engine: '', plugins: [ require('apollo-server-plugin-operation-registry')({ // De-structure the object to get the HTTP `headers` and the GraphQL diff --git a/graph-manager-docs/source/schema-registry.mdx b/graph-manager-docs/source/schema-registry.mdx index 6b9cdd049..1f812721f 100644 --- a/graph-manager-docs/source/schema-registry.mdx +++ b/graph-manager-docs/source/schema-registry.mdx @@ -105,7 +105,7 @@ If you omit the `--variant` flag, the `apollo service:push` command always pushe ### Associating metrics with a variant -You can configure Apollo Server to associate the metrics it sends to Graph Manager with a particular variant. To do so, set the `ENGINE_SCHEMA_TAG` environment variable to the appropriate variant before initializing Apollo Server. +You can configure Apollo Server to associate the metrics it sends to Graph Manager with a particular variant. To do so, set the `APOLLO_GRAPH_VARIANT` environment variable (`ENGINE_SCHEMA_TAG` in `apollo-server` pre-2.13.0 ) to the appropriate variant before initializing Apollo Server. Alternatively, you can include the `graphVariant` (`schemaTag` in `apollo-server` pre-2.13.0) option in your call to the `ApolloServer` constructor, like so: @@ -113,7 +113,7 @@ Alternatively, you can include the `graphVariant` (`schemaTag` in `apollo-server const server = new ApolloServer({ ... engine: { - apiKey: "", + apiKey: "", graphVariant: "beta" // highlight-line } }); diff --git a/graph-manager-docs/source/schema-validation.mdx b/graph-manager-docs/source/schema-validation.mdx index aa5080ea4..dbb6b69da 100644 --- a/graph-manager-docs/source/schema-validation.mdx +++ b/graph-manager-docs/source/schema-validation.mdx @@ -112,7 +112,7 @@ jobs: # commands against it. - run: sleep 5 - # This command authenticates using the `ENGINE_API_KEY` environment + # This command authenticates using the `APOLLO_KEY` environment # variable. Specify your GraphQL endpoint's URL in your Apollo config. - run: npx apollo service:check --variant=staging ``` diff --git a/graph-manager-docs/source/setup-analytics.mdx b/graph-manager-docs/source/setup-analytics.mdx index a57477136..6c47c0c43 100644 --- a/graph-manager-docs/source/setup-analytics.mdx +++ b/graph-manager-docs/source/setup-analytics.mdx @@ -23,7 +23,7 @@ Apollo Server has built-in support for pushing traces to Graph Manager. To set i -After you obtain a graph API key, assign it to the `ENGINE_API_KEY` environment variable in your production server's environment. +After you obtain a graph API key, assign it to the `APOLLO_KEY` environment variable (`ENGINE_API_KEY` in `apollo-server` pre-2.13.0) in your production server's environment. >Consult your production environment's documentation to learn how to set its environment variables. From 5978b36c414079818873c9f824858031c2492740 Mon Sep 17 00:00:00 2001 From: Adam Zionts Date: Thu, 14 May 2020 01:00:17 -0700 Subject: [PATCH 2/5] Update ENGINE_API_KEY references in .md --- docs/source/devtools/editor-plugins.md | 2 +- docs/source/tutorial/production.md | 3 ++- graph-manager-docs/source/github-integration.md | 2 +- 3 files changed, 4 insertions(+), 3 deletions(-) diff --git a/docs/source/devtools/editor-plugins.md b/docs/source/devtools/editor-plugins.md index c8924c3a8..7eda492d2 100644 --- a/docs/source/devtools/editor-plugins.md +++ b/docs/source/devtools/editor-plugins.md @@ -50,7 +50,7 @@ To authenticate with Graph Manager to pull down the schema, create a file next t After the key is found, add the following line to the `.env` file: ```bash -ENGINE_API_KEY= +APOLLO_KEY= ``` After this is done, VS Code can be reloaded and the Apollo integration will connect to Graph Manager to provide autocomplete, validation, and more. diff --git a/docs/source/tutorial/production.md b/docs/source/tutorial/production.md index be112a836..cd85643b7 100644 --- a/docs/source/tutorial/production.md +++ b/docs/source/tutorial/production.md @@ -21,6 +21,7 @@ First, we need an Apollo Graph Manager API key. Navigate to [Apollo Graph Manage Let's save our key as an environment variable. It's important to make sure we don't check our Graph Manager API key into version control. Go ahead and make a copy of the `.env.example` file located in `server/` and call it `.env`. Delete the content of the newly created file and add your Graph Manager API key that you copied from the previous step to the file: + ``` APOLLO_KEY=user:: ``` @@ -38,7 +39,7 @@ Create `apollo.config.js` with the following configuration: ```js{3} module.exports = { service: { - name: 'my-graph-name' // the name of your graph in Apollo Graph Manager + name: 'my-graph-name' // the identifier for your graph in Apollo Graph Manager } }; ``` diff --git a/graph-manager-docs/source/github-integration.md b/graph-manager-docs/source/github-integration.md index 14b49d330..3c11f3a98 100644 --- a/graph-manager-docs/source/github-integration.md +++ b/graph-manager-docs/source/github-integration.md @@ -41,7 +41,7 @@ jobs: # commands against it - run: sleep 5 - # This will authenticate using the `ENGINE_API_KEY` environment + # This will authenticate using the `APOLLO_KEY` environment # variable. If the GraphQL server is available elsewhere than # http://localhost:4000/graphql, set it with `--endpoint=`. - run: apollo service:check From 76c6a79ae0fce1dffeca8195f3d37163bfb3e778 Mon Sep 17 00:00:00 2001 From: Adam Zionts Date: Thu, 14 May 2020 01:00:50 -0700 Subject: [PATCH 3/5] Fix extra whitespace --- graph-manager-docs/source/schema-registry.mdx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/graph-manager-docs/source/schema-registry.mdx b/graph-manager-docs/source/schema-registry.mdx index 1f812721f..10db5da18 100644 --- a/graph-manager-docs/source/schema-registry.mdx +++ b/graph-manager-docs/source/schema-registry.mdx @@ -105,7 +105,7 @@ If you omit the `--variant` flag, the `apollo service:push` command always pushe ### Associating metrics with a variant -You can configure Apollo Server to associate the metrics it sends to Graph Manager with a particular variant. To do so, set the `APOLLO_GRAPH_VARIANT` environment variable (`ENGINE_SCHEMA_TAG` in `apollo-server` pre-2.13.0 ) to the appropriate variant before initializing Apollo Server. +You can configure Apollo Server to associate the metrics it sends to Graph Manager with a particular variant. To do so, set the `APOLLO_GRAPH_VARIANT` environment variable (`ENGINE_SCHEMA_TAG` in `apollo-server` pre-2.13.0) to the appropriate variant before initializing Apollo Server. Alternatively, you can include the `graphVariant` (`schemaTag` in `apollo-server` pre-2.13.0) option in your call to the `ApolloServer` constructor, like so: From b6fa297b98a6ee7144eb3476292c1ba252591507 Mon Sep 17 00:00:00 2001 From: Adam Zionts Date: Thu, 14 May 2020 01:25:05 -0700 Subject: [PATCH 4/5] Further update production.md to remove config --- docs/source/tutorial/production.md | 17 +++-------------- 1 file changed, 3 insertions(+), 14 deletions(-) diff --git a/docs/source/tutorial/production.md b/docs/source/tutorial/production.md index cd85643b7..a863fea06 100644 --- a/docs/source/tutorial/production.md +++ b/docs/source/tutorial/production.md @@ -21,7 +21,6 @@ First, we need an Apollo Graph Manager API key. Navigate to [Apollo Graph Manage Let's save our key as an environment variable. It's important to make sure we don't check our Graph Manager API key into version control. Go ahead and make a copy of the `.env.example` file located in `server/` and call it `.env`. Delete the content of the newly created file and add your Graph Manager API key that you copied from the previous step to the file: - ``` APOLLO_KEY=user:: ``` @@ -32,24 +31,14 @@ The entry should basically look like this: APOLLO_KEY=user:xz.5r134305-88p1-4840-12c1-88rc0xcxe179:E4VSTiXeFWaSSBgFWXOiSA ``` -Our key is now stored under the environment variable `APOLLO_KEY`. We now have to create a file called `apollo.config.js`. Apollo projects are configured using an `apollo.config.js` file at the root of your project. Many Apollo tools leverage your Apollo config, reducing the net amount of configuration you need to do in your project in the end. - -Create `apollo.config.js` with the following configuration: - -```js{3} -module.exports = { - service: { - name: 'my-graph-name' // the identifier for your graph in Apollo Graph Manager - } -}; -``` +Our key is now stored under the environment variable `APOLLO_KEY`. ### Check and publish with the Apollo CLI It's time to publish our schema to Graph Manager! First, start your server in one terminal window by running `npm start`. In another terminal window, run: ```bash -npx apollo service:push --endpoint=http://localhost:4000 +npx apollo service:push --endpoint=http://localhost:4000 --graph=my-graph ``` > npx is a tool bundled with npm for easily running packages that are not installed globally. @@ -59,7 +48,7 @@ This command publishes your schema to the Apollo registry. Once your schema is u For subsequent publishes, we may first want to check for any breaking changes in our new schema against the old version. In a terminal window, run: ```bash -npx apollo service:check --endpoint=http://localhost:4000 +npx apollo service:check --endpoint=http://localhost:4000 --graph=my-graph ``` ### What are the benefits of Graph Manager? From f9712136ed0300787afad1d2604f65e7d45900b9 Mon Sep 17 00:00:00 2001 From: Adam Zionts Date: Thu, 14 May 2020 12:22:37 -0700 Subject: [PATCH 5/5] Apply suggestions from code review --- docs/source/tutorial/production.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/docs/source/tutorial/production.md b/docs/source/tutorial/production.md index a863fea06..c34562365 100644 --- a/docs/source/tutorial/production.md +++ b/docs/source/tutorial/production.md @@ -35,10 +35,10 @@ Our key is now stored under the environment variable `APOLLO_KEY`. ### Check and publish with the Apollo CLI -It's time to publish our schema to Graph Manager! First, start your server in one terminal window by running `npm start`. In another terminal window, run: +It's time to publish our schema to Graph Manager! First, start your server in one terminal window by running `npm start`. In another terminal window, run the following command, substituting the name of your graph where indicated: ```bash -npx apollo service:push --endpoint=http://localhost:4000 --graph=my-graph +npx apollo service:push --endpoint=http://localhost:4000 --graph=name-of-graph ``` > npx is a tool bundled with npm for easily running packages that are not installed globally.