• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

TypeScript fastify.FastifyInstance类代码示例

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

本文整理汇总了TypeScript中fastify.FastifyInstance的典型用法代码示例。如果您正苦于以下问题:TypeScript FastifyInstance类的具体用法?TypeScript FastifyInstance怎么用?TypeScript FastifyInstance使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。



在下文中一共展示了FastifyInstance类的5个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的TypeScript代码示例。

示例1: describe

describe('apollo-server-fastify', () => {
  let server: ApolloServer;
  let httpServer: http.Server;
  let app: FastifyInstance;

  testApolloServer(
    async options => {
      server = new ApolloServer(options);
      app = fastify();
      app.register(server.createHandler());
      await app.listen(port);
      return createServerInfo(server, app.server);
    },
    async () => {
      if (server) await server.stop();
      if (app) await new Promise(resolve => app.close(() => resolve()));
      if (httpServer && httpServer.listening) await httpServer.close();
    },
  );
});
开发者ID:apollostack,项目名称:apollo-server,代码行数:20,代码来源:ApolloServer.test.ts


示例2: async

    return async (
      app: FastifyInstance<Server, IncomingMessage, OutgoingMessage>,
    ) => {
      await promiseWillStart;

      if (!disableHealthCheck) {
        app.get('/.well-known/apollo/server-health', async (req, res) => {
          // Response follows https://tools.ietf.org/html/draft-inadarei-api-health-check-01
          res.type('application/health+json');

          if (onHealthCheck) {
            try {
              await onHealthCheck(req);
              res.send(stringifyHealthCheck({ status: 'pass' }));
            } catch (e) {
              res.status(503).send(stringifyHealthCheck({ status: 'fail' }));
            }
          } else {
            res.send(stringifyHealthCheck({ status: 'pass' }));
          }
        });
      }

      app.register(
        async instance => {
          instance.register(require('fastify-accepts'));

          if (cors === true) {
            instance.register(require('fastify-cors'));
          } else if (cors !== false) {
            instance.register(require('fastify-cors'), cors);
          }

          instance.setNotFoundHandler((_request, reply) => {
            reply.code(405);
            reply.header('allow', 'GET, POST');
            reply.send();
          });

          const beforeHandlers = [
            (
              req: FastifyRequest<IncomingMessage>,
              reply: FastifyReply<OutgoingMessage>,
              done: () => void,
            ) => {
              // Note: if you enable playground in production and expect to be able to see your
              // schema, you'll need to manually specify `introspection: true` in the
              // ApolloServer constructor; by default, the introspection query is only
              // enabled in dev.
              if (this.playgroundOptions && req.req.method === 'GET') {
                // perform more expensive content-type check only if necessary
                const accept = (req as any).accepts() as Accepts;
                const types = accept.types() as string[];
                const prefersHTML =
                  types.find(
                    (x: string) =>
                      x === 'text/html' || x === 'application/json',
                  ) === 'text/html';

                if (prefersHTML) {
                  const playgroundRenderPageOptions: PlaygroundRenderPageOptions = {
                    endpoint: this.graphqlPath,
                    subscriptionEndpoint: this.subscriptionsPath,
                    ...this.playgroundOptions,
                  };
                  reply.type('text/html');
                  const playground = renderPlaygroundPage(
                    playgroundRenderPageOptions,
                  );
                  reply.send(playground);
                  return;
                }
              }
              done();
            },
          ];

          if (typeof processFileUploads === 'function' && this.uploadsConfig) {
            instance.addContentTypeParser(
              'multipart',
              (
                request: IncomingMessage,
                done: (err: Error | null, body?: any) => void,
              ) => {
                (request as any)[kMultipart] = true;
                done(null);
              },
            );
            beforeHandlers.push(fileUploadMiddleware(this.uploadsConfig, this));
          }

          instance.route({
            method: ['GET', 'POST'],
            url: '/',
            beforeHandler: beforeHandlers,
            handler: await graphqlFastify(this.graphQLServerOptions.bind(this)),
          });
        },
        {
          prefix: this.graphqlPath,
//.........这里部分代码省略.........
开发者ID:apollostack,项目名称:apollo-server,代码行数:101,代码来源:ApolloServer.ts


示例3: createServerInfo

 async options => {
   server = new ApolloServer(options);
   app = fastify();
   app.register(server.createHandler());
   await app.listen(port);
   return createServerInfo(server, app.server);
 },
开发者ID:apollostack,项目名称:apollo-server,代码行数:7,代码来源:ApolloServer.test.ts


示例4: createServer

  async function createServer(
    serverOptions: Config,
    options: Partial<ServerRegistration> = {},
  ) {
    server = new ApolloServer(serverOptions);
    app = fastify();

    app.register(server.createHandler(options));
    await app.listen(port);

    return createServerInfo(server, app.server);
  }
开发者ID:apollostack,项目名称:apollo-server,代码行数:12,代码来源:ApolloServer.test.ts


示例5:

 if (app) await new Promise(resolve => app.close(() => resolve()));
开发者ID:apollostack,项目名称:apollo-server,代码行数:1,代码来源:ApolloServer.test.ts



注:本文中的fastify.FastifyInstance类示例由纯净天空整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
TypeScript fastify.FastifyReply类代码示例发布时间:2022-05-25
下一篇:
TypeScript fastbitset.add函数代码示例发布时间:2022-05-25
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap