UNPKG

@apollo/server

Version:
104 lines 5.53 kB
"use strict"; var __importDefault = (this && this.__importDefault) || function (mod) { return (mod && mod.__esModule) ? mod : { "default": mod }; }; Object.defineProperty(exports, "__esModule", { value: true }); exports.ApolloServerPluginSchemaReporting = ApolloServerPluginSchemaReporting; const os_1 = __importDefault(require("os")); const internalPlugin_js_1 = require("../../internalPlugin.js"); const uuid_1 = require("uuid"); const graphql_1 = require("graphql"); const schemaReporter_js_1 = require("./schemaReporter.js"); const schemaIsSubgraph_js_1 = require("../schemaIsSubgraph.js"); const packageVersion_js_1 = require("../../generated/packageVersion.js"); const computeCoreSchemaHash_js_1 = require("../../utils/computeCoreSchemaHash.js"); function ApolloServerPluginSchemaReporting({ initialDelayMaxMs, overrideReportedSchema, endpointUrl, fetcher, } = Object.create(null)) { const bootId = (0, uuid_1.v4)(); return (0, internalPlugin_js_1.internalPlugin)({ __internal_plugin_id__: 'SchemaReporting', __is_disabled_plugin__: false, async serverWillStart({ apollo, schema, logger }) { const { key, graphRef } = apollo; if (!key) { throw Error('To use ApolloServerPluginSchemaReporting, you must provide an Apollo API ' + 'key, via the APOLLO_KEY environment variable or via `new ApolloServer({apollo: {key})`'); } if (!graphRef) { throw Error('To use ApolloServerPluginSchemaReporting, you must provide your graph ref (eg, ' + "'my-graph-id@my-graph-variant'). Try setting the APOLLO_GRAPH_REF environment " + 'variable or passing `new ApolloServer({apollo: {graphRef}})`.'); } if (overrideReportedSchema) { try { const validationErrors = (0, graphql_1.validateSchema)((0, graphql_1.buildSchema)(overrideReportedSchema, { noLocation: true })); if (validationErrors.length) { throw new Error(validationErrors.map((error) => error.message).join('\n')); } } catch (err) { throw new Error('The schema provided to overrideReportedSchema failed to parse or ' + `validate: ${err.message}`); } } if ((0, schemaIsSubgraph_js_1.schemaIsSubgraph)(schema)) { throw Error([ 'Schema reporting is not yet compatible with Apollo Federation subgraphs.', "If you're interested in using schema reporting with subgraphs,", 'please contact Apollo support. To set up managed federation, see', 'https://go.apollo.dev/s/managed-federation', ].join(' ')); } if (endpointUrl !== undefined) { logger.info(`Apollo schema reporting: schema reporting URL override: ${endpointUrl}`); } const baseSchemaReport = { bootId, graphRef, platform: process.env.APOLLO_SERVER_PLATFORM || 'local', runtimeVersion: `node ${process.version}`, userVersion: process.env.APOLLO_SERVER_USER_VERSION, serverId: process.env.APOLLO_SERVER_ID || process.env.HOSTNAME || os_1.default.hostname(), libraryVersion: `@apollo/server@${packageVersion_js_1.packageVersion}`, }; let currentSchemaReporter; return { schemaDidLoadOrUpdate({ apiSchema, coreSupergraphSdl }) { if (overrideReportedSchema !== undefined) { if (currentSchemaReporter) { return; } else { logger.info('Apollo schema reporting: schema to report has been overridden'); } } const coreSchema = overrideReportedSchema ?? coreSupergraphSdl ?? (0, graphql_1.printSchema)(apiSchema); const coreSchemaHash = (0, computeCoreSchemaHash_js_1.computeCoreSchemaHash)(coreSchema); const schemaReport = { ...baseSchemaReport, coreSchemaHash, }; currentSchemaReporter?.stop(); currentSchemaReporter = new schemaReporter_js_1.SchemaReporter({ schemaReport, coreSchema, apiKey: key, endpointUrl, logger, initialReportingDelayInMs: Math.floor(Math.random() * (initialDelayMaxMs ?? 10_000)), fallbackReportingDelayInMs: 20_000, fetcher, }); currentSchemaReporter.start(); logger.info('Apollo schema reporting: reporting a new schema to Studio! See your graph at ' + `https://studio.apollographql.com/graph/${encodeURI(graphRef)}/ with server info ${JSON.stringify(schemaReport)}`); }, async serverWillStop() { currentSchemaReporter?.stop(); }, }; }, }); } //# sourceMappingURL=index.js.map