oRPC is currently pre-stable, please report any issues on our Discord or GitHub 🚧
oRPC
background

Integrations

Integrating oRPC with your existing stacks, environments, and frameworks.

Integrate oRPC with various stacks, environments, and frameworks effortlessly. oRPC is designed with the Fetch API in mind, making it compatible with any modern environment or framework.

It uses the highly performant Hono RegExpRouter under the hood, ensuring low-latency routing. Whether you're targeting serverless, edge environments, or traditional backends, oRPC is optimized for all scenarios.

Quick Example

import {  } from '@orpc/server/fetch'
import {  } from '@orpc/openapi/fetch'
import {  } from 'examples/server'
import {  } from '@orpc/zod'
 
const  = new (, {
  : [
    new (),
  ],
})
 
const  = new ()
 
export async function (: Request) {
  const  = new (.)
 
  if (..('/api')) {
     const { ,  } = await .(, {
       : '/api'
     })
 
     if () {
       return 
     }
  }
 
  if (..('/rpc')) {
    const { ,  } = await .(, {
      : '/rpc'
    })
 
    if () {
      return 
    }
  }
 
  return new ('Not found', { : 404 })
}

Node.js

import {  } from 'node:http'
import {  } from '@orpc/server/node'
import {  } from '@orpc/openapi/node'
import {  } from 'examples/server'
import {  } from '@orpc/zod'
 
const  = new (, {
  : [
    new (),
  ],
})
const  = new ()
 
const  = (async (, ) => {
  if (.?.('/api')) {
    const {  } = await .(, , {
      : '/api',
      : {},
    })
 
    if () {
      return
    }
  }
 
  if (.?.('/rpc')) {
    const {  } = await .(, , {
      : '/rpc',
      : {},
    })
 
    if () {
      return
    }
  }
  
  . = 404
  .('Not found')
})
 
.(3000, () => {
  .('Server is available at http://localhost:3000')
})

Express.js

import  from 'express'
import {  } from '@orpc/server/node'
import {  } from '@orpc/openapi/node'
import {  } from 'examples/server'
import {  } from '@orpc/zod'
 
const  = ()
 
const  = new (, {
  : [
    new (),
  ],
})
 
.('/api/*', async (, , ) => {
  const {  } = await .(, , {
    : '/api',
    : {},
  })
 
  if () {
    return
  }
 
  ()
})
 
const  = new ()
 
.('/rpc/*', async (, , ) => {
  const {  } = await .(, , {
    : '/rpc',
    : {},
  })
 
  if () {
    return
  }
 
  ()
})
 
.(3000, () => {
  .('Server is available at http://localhost:3000')
})

Hono

import {  } from 'hono'
import { ,  } from '@orpc/server/hono'
import {  } from '@orpc/openapi/hono'
import {  } from 'examples/server'
import {  } from '@orpc/zod'
 
 
const  = new ()
 
const  = new (, {
  : [
    new (),
  ],
})
 
.('/api/*', (, {
  : '/api',
  : async () => {
    return {}
  }
}))
 
const  = new ()
 
.('/rpc/*', (, {
  : '/rpc',
  : async () => {
    return {}
  }
}))
 
export default 

Next.js

app/api/[...orpc]/route.ts
import {  } from '@orpc/openapi/next'
import {  } from '@orpc/server/next'
import {  } from 'examples/server'
import {  } from '@orpc/zod'
 
const  = new (, {
  : [
    new (),
  ],
})
 
export const { , , , ,  } = (, {
  : '/api',
  : async () => {
    return {}
  },
})
app/rpc/[...orpc]/route.ts
import { ,  } from '@orpc/server/next'
import {  } from 'examples/server'
 
const  = new ()
 
export const { , , , ,  } = (, {
  : '/rpc',
  : async () => {
    return {}
  },
})

Cloudflare Workers

import {  } from '@orpc/server/fetch'
import {  } from '@orpc/openapi/fetch'
import {  } from 'examples/server'
import {  } from '@orpc/zod'
 
const  = new (, {
  : [
    new (),
  ],
})
 
const  = new ()
 
export default {
  async (: Request) {
    const  = new (.)
 
    if (..('/api')) {
      const { ,  } = await .(, {
        : '/api'
      })
 
      if () {
        return 
      }
    }
 
    if (..('/rpc')) {
      const { ,  } = await .(, {
        : '/rpc'
      })
 
      if () {
        return 
      }
    }
 
    return new ('Not found', { : 404 })
  },
}

Other Environments and Frameworks

oRPC works in any modern environment that supports the creating server with Fetch API.

On this page