Skip to content

rintoj/hypergraph-server

Repository files navigation

Hypergraph Server

With the help of this package you can spin off a service to serve a REST or GraphQL endpoint

Install

Using npm:

npm install @hgraph/server

Using yarn:

yarn add @hgraph/server

Usage

Setup a service

mkdir my-service
cd my-service
yarn init -y

Setup src/index.ts

import 'reflect-metadata'

import { initializeGraphqlServer } from 'hypergraph-graphql'
import { bootstrapServer, createMiddleware } from '@hgraph/server'
import { createSchema } from './schema'

async function run() {
  await bootstrapServer({
    port: 4000,
    apiRoot: '/api',
    controllers: [`${__dirname}/**/*-controller.ts`],
  })
}

void run()

Add controller

import { Controller, Get } from '@hgraph/server'

@Controller('/user')
export class UserController {
  @Get('/me')
  async findCurrentUser() {
    return { user: null } // your logic
  }
}

Start the service

npx ts-node src/index.ts

This will expose a GET url http://localhost:4000/api/user/me

[2023-06-29T16:43:35.723] [INFO ] [TSED] - Injector created... +3ms
[2023-06-29T16:43:35.723] [INFO ] [TSED] - Build providers +0ms
[2023-06-29T16:43:35.734] [INFO ] [TSED] - Settings and injector loaded... +11ms
[2023-06-29T16:43:35.736] [INFO ] [TSED] - Load routes +2ms
[2023-06-29T16:43:35.736] [INFO ] [TSED] - Routes mounted... +0ms
[2023-06-29T16:43:35.737] [INFO ] [TSED] -
┌───────────────┬──────────────┬──────────────────────────────────┐
│ Method        │ Endpoint     │ Class method                     │
│───────────────│──────────────│──────────────────────────────────│
│ GET           │ /api/user/me │ UserController.findCurrentUser() │
└───────────────┴──────────────┴──────────────────────────────────┘
[2023-06-29T16:43:35.738] [INFO ] [TSED] - Listen server on http://0.0.0.0:4001
[2023-06-29T16:43:35.738] [INFO ] [TSED] - Started in 18 ms +2ms

Adding GraphQL

Create src/schema.ts

import { createGraphqlSchema, referenceResolver } from 'hypergraph-graphql'

export async function createSchema() {
  return await createGraphqlSchema({
    resolvers: [`${__dirname}/**/*-resolver.ts`],
    referenceResolvers: {
      // User: referenceResolver(UserRepository),
    },
    authChecker: () => true,
  })
}

Modify src/index.ts

async function run() {
  const schema = await createSchema()
  const router = initializeGraphqlServer({ schema })
  await bootstrapServer({
    port: 4000,
    apiRoot: '/api',
    controllers: [`${__dirname}/**/*-controller.ts`],
    middlewares: [createMiddleware(router)],
  })
}

Create a user schema by adding src/schema/user/user-schema.ts

import { Field, ObjectType } from 'type-graphql'
import { Repository } from 'hypergraph-storage'

@ObjectType()
export class User {
  @Field()
  id!: string

  @Field()
  name?: string
}

Add resolver src/resolver/user/user-resolver.ts

import { Query, Resolver } from 'type-graphql'
import { User } from '../../schema/user/user'

@Resolver()
export class UserResolver {
  @Query(() => User, { nullable: true })
  me() {
    return null
  }
}

Now start the service. This will expose a new endpoint http://localhost:4000/graphql

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Packages

No packages published