
Security News
Oracle Drags Its Feet in the JavaScript Trademark Dispute
Oracle seeks to dismiss fraud claims in the JavaScript trademark dispute, delaying the case and avoiding questions about its right to the name.
@as-integrations/hapi
Advanced tools
An Apollo Server integration for use with Hapi.
This is a simple package that easily allows you to connect your own Hapi server implementation to an Apollo Server instance.
npm install @as-integrations/hapi @apollo/server graphql @hapi/hapi
Setup Hapi & Apollo Server like you usually would and then connect the two by using the hapiApollo
plugin:
import { Server } from '@hapi/hapi';
import { ApolloServer, BaseContext } from "@apollo/server";
import hapiApollo from "@as-integrations/hapi";
// ...
// create the apollo server instance and start it
const apolloServer = new ApolloServer<BaseContext>({
typeDefs,
resolvers,
});
await apolloServer.start();
// create the hapi server
const hapi = new Server({
host: 'localhost',
port: 5000
});
// ...
// register the plugin with the hapi server and provide the apollo instance in plugin config
await hapi.register({
plugin: hapiApollo,
options: {
apolloServer,
path: '/graphql'
}
});
await hapi.start();
Note: You must call and await apollo.start()
before using the integration.
If you are using ES5 or are otherwise using require() to use this module, you may need reference the default export like so:
const hapiApollo = require("@as-integrations/hapi").default;
Apollo Server v4 has moved context setup outside of the ApolloServer
constructor.
Define you're own context function and pass it in to the context
option for the plugin.
For example:
await hapi.register({
plugin: hapiPlugin,
options: {
context: async ({ request }) => ({
token: request.headers.token
}),
apolloServer
}
});
Additional configuration for Hapi routes that are created by this module can be passed via getRoute (get / options routes) or postRoute (post route). Both support options, rules, and vhost configuration.
For example, to add a max upload size to the post route:
await hapi.register({
plugin: hapiPlugin,
options: {
context: async ({ request }) => ({
token: request.headers.token
}),
apolloServer,
postRoute: {
options: {
payload: {
maxBytes: 1024
}
}
}
}
});
FAQs
An Apollo Server integration for use with Hapi
We found that @as-integrations/hapi demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 3 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Oracle seeks to dismiss fraud claims in the JavaScript trademark dispute, delaying the case and avoiding questions about its right to the name.
Security News
The Linux Foundation is warning open source developers that compliance with global sanctions is mandatory, highlighting legal risks and restrictions on contributions.
Security News
Maven Central now validates Sigstore signatures, making it easier for developers to verify the provenance of Java packages.