UploadThing Server
Server bindings for UploadThing.
createUploadthing
The helper function to create an UploadThing instance. MAKE SURE YOU IMPORT IT
FROM THE RIGHT PLACE. The export name ensures your file routes'
middleware functions are typed
correctly.
import { createUploadthing, type FileRouter } from "uploadthing/next";
const f = createUploadthing();
export const uploadRouter = {  };
// ...
f({  })
  .middleware(({ req }) => {
    //           ^? req: NextRequest
    return {}
  })
createRouteHandler
All adapters exports a createRouteHandler function that exposes your router to
the world. By default, you should only have to pass your router to this
function, although there are some extra configuration options available.
The names of the exported
createRouteHandleris different prior tov6.3.
import { createRouteHandler } from "uploadthing/next";
import { uploadRouter } from "~/server/uploadthing.ts";
export const { GET, POST } = createRouteHandler({
  router: uploadRouter,
  // config: { ... },
});
Config Parameters
You can configure the route handler either by passing a config object to the
createRouteHandler function, or by setting them as environment variables.
Environment variables follows the naming convention of UPLOADTHING_<NAME>
,where <NAME> is the name of the config option in constant case, e.g.
UPLOADTHING_LOG_LEVEL. If both are set, the config object takes precedence.
- Name
- callbackUrl
- Type
- Since 6.0
- Description
- The full, absolute URL to where your route handler is hosted. This is called via webhook after your file is uploaded. UploadThing attempts to automatically detect this value based on the request URL and headers. You can override this if the automatic detection fails. 
 - string
- Name
- token
- Type
- Default: env.UPLOADTHING_TOKENSince 7.0
- Description
- Your UploadThing token. You can find this on the UploadThing dashboard. 
 - string
- Name
- logLevel
- Type
- Default: InfoSince 7.0
- Description
- Enable more verbose logging. If using an older version of the SDK, levels might vary.
 - Error | Warning | Info | Debug | Trace
- Name
- logFormat
- Type
- Default: pretty in development, else jsonSince 7.1
- Description
- What format log entries should be in. Read more about the log formats here ↗. 
 - json | logFmt | structured | pretty
- Name
- isDev
- Type
- Default: env.NODE_ENV === 'development'Since 6.3
- Description
- Used to determine whether to run dev hook or not 
 - boolean
- Name
- fetch
- Type
- Default: globalThis.fetchSince 6.3
- Description
- Used to override the fetch implementation 
 - FetchEsque
- Name
- ingestUrl
- Type
- Since 7.0
- Description
- The URL of the UploadThing Ingest API. Will be decoded from the - tokenif not specified.- This option should only be set for self-hosted instances or for testing. 
 - string
UTApi
See UTApi
UTFile
A helper class to construct
File ↗ in environments
that don't support it natively.
Also accepts a customId property to set a custom identifier for the file to be
uploaded using UTApi.uploadFiles.
Constructor
- Name
- parts
- Type
- Required
- Description
- The parts of the file to be uploaded. 
 - BlobPart[]
- Name
- name
- Type
- Required
- Description
- The name of the file to be uploaded. 
 - string
- Name
- opts.type
- Type
- Since 6.4
- Description
- The type of the file to be uploaded. 
 - string
- Name
- opts.customId
- Type
- Since 6.4
- Description
- A custom identifier for the file to be uploaded using UTApi.uploadFiles. 
 - string
- Name
- opts.lastModified
- Type
- Since 6.4
- Description
- The last modified time of the file to be uploaded. 
 - number
Example
import { UTApi, UTFile } from "uploadthing/server";
const utapi = new UTApi();
const file = new UTFile(["foo"], "foo.txt", { customId: "foo" });
const response = await utapi.uploadFiles([file]);