@modrinth/api-client
v0.5.0
Published
An API client for Modrinth's API for use in nuxt, tauri and plain node/browser environments.
Readme
@modrinth/api-client
Platform-agnostic TypeScript client for Modrinth's API across Node.js, browsers, Nuxt, and Tauri.
⚠️ We use this internally to power modrinth.com, Modrinth App, and Modrinth Hosting frontends. It may break without any notice, but you are welcome to use it.
Installation
pnpm add @modrinth/api-clientTauri apps also need the optional peer dependency:
pnpm add @modrinth/api-client @tauri-apps/plugin-httpUsage
Generic Node.js or Browser Client
import { AuthFeature, GenericModrinthClient, type Labrinth } from '@modrinth/api-client'
const client = new GenericModrinthClient({
userAgent: 'my-app/1.0.0',
features: [new AuthFeature({ token: process.env.MODRINTH_TOKEN })],
})
const project: Labrinth.Projects.v2.Project = await client.labrinth.projects_v2.get('sodium')
const members = await client.labrinth.projects_v3.getMembers(project.id)You can still make direct requests through the same platform layer:
const project = await client.request<Labrinth.Projects.v2.Project>('/project/sodium', {
api: 'labrinth',
version: 2,
})Nuxt
import { AuthFeature, CircuitBreakerFeature, NuxtCircuitBreakerStorage, NuxtModrinthClient } from '@modrinth/api-client'
export const useModrinthClient = async () => {
const config = useRuntimeConfig()
return new NuxtModrinthClient({
userAgent: 'my-nuxt-app/1.0.0',
rateLimitKey: import.meta.server ? config.rateLimitKey : undefined,
features: [
new AuthFeature({
token: process.env.MODRINTH_TOKEN,
}),
new CircuitBreakerFeature({
storage: new NuxtCircuitBreakerStorage(),
}),
],
})
}Tauri
import { getVersion } from '@tauri-apps/api/app'
import { AuthFeature, TauriModrinthClient } from '@modrinth/api-client'
const client = new TauriModrinthClient({
userAgent: async () => `modrinth/theseus/${await getVersion()} ([email protected])`,
features: [new AuthFeature({ token: process.env.MODRINTH_TOKEN })],
})
const project = await client.labrinth.projects_v2.get('sodium')API Modules
Modules are available as nested properties on the client:
client.labrinth.projects_v2
client.labrinth.projects_v3
client.labrinth.versions_v3Types are exported from the package root:
import type { Labrinth } from '@modrinth/api-client'
const project: Labrinth.Projects.v3.Project = await client.labrinth.projects_v3.get('sodium')Modrinth Hosting API Modules
- These modules are internal to Modrinth and are only supported inside the Modrinth Hosting panel in Modrinth App and on modrinth.com. They should not be expected to work in third-party clients today. We are discussing how to safely expose access to your own server through these APIs in the future.
Base URLs
By default, the client uses Modrinth production services:
labrinthBaseUrl:https://api.modrinth.com
Override them for staging or custom deployments:
const client = new GenericModrinthClient({
userAgent: 'my-app/1.0.0',
labrinthBaseUrl: 'https://staging-api.modrinth.com',
})External APIs can be targeted per request by passing a full URL as api and disabling auth:
await client.request('/endpoint', {
api: 'https://example.com',
version: 1,
skipAuth: true,
})Features
Features wrap requests before they reach the platform implementation:
import { AuthFeature, CircuitBreakerFeature, RetryFeature } from '@modrinth/api-client'
const client = new GenericModrinthClient({
features: [new AuthFeature({ token: async () => process.env.MODRINTH_TOKEN }), new RetryFeature({ maxAttempts: 3, backoffStrategy: 'exponential' }), new CircuitBreakerFeature({ maxFailures: 3, resetTimeout: 30_000 })],
})Built-in features include authentication, node auth, retries, circuit breaking, panel version headers, and verbose logging.
Uploads
Upload endpoints return an UploadHandle<T> with progress and cancellation support:
const upload = client.kyros.files_v0.uploadFile(path, file)
upload.onProgress(({ progress }) => {
console.log(Math.round(progress * 100))
})
await upload.promiseUploads use XMLHttpRequest for progress tracking and are only available in browser-capable contexts. NuxtModrinthClient.upload() throws during SSR.
Third-Party API Typings
- This package also includes some third-party API modules and typings used by Modrinth internals. They are not part of the stable public API surface and should be used at your own risk.
Development
pnpm --filter @modrinth/api-client build
pnpm --filter @modrinth/api-client lint
# or pnpm prepr:frontend:lib in turborepo root.When adding a module, add it to src/modules/index.ts so it is included in the typed client structure.
License
Licensed under LGPL-3.0. See LICENSE.
