Pustaka ini menyediakan akses yang mudah ke Anthropic REST API dari TypeScript atau JavaScript.
Untuk dokumentasi fitur API dengan contoh kode, lihat referensi API. Halaman ini membahas fitur dan konfigurasi SDK yang spesifik untuk TypeScript.
npm install @anthropic-ai/sdkTypeScript >= 4.9 didukung.
Runtime berikut didukung:
"node" ("jsdom" tidak didukung saat ini).dangerouslyAllowBrowser ke true.Perhatikan bahwa React Native tidak didukung saat ini.
Jika Anda tertarik dengan lingkungan runtime lainnya, buka atau berikan upvote pada issue di GitHub.
const client = new Anthropic({
apiKey: process.env["ANTHROPIC_API_KEY"] // This is the default and can be omitted
});
const message = await client.messages.create({
max_tokens: 1024,
messages: [{ role: "user", content: "Hello, Claude" }],
model: "claude-opus-4-8"
});
console.log(message.content);Untuk opsi autentikasi termasuk Workload Identity Federation, lihat Autentikasi.
Pustaka ini menyertakan definisi TypeScript untuk semua parameter request dan field response. Anda dapat mengimpor dan menggunakannya seperti berikut:
const client = new Anthropic({
apiKey: process.env["ANTHROPIC_API_KEY"] // This is the default and can be omitted
});
const params: Anthropic.MessageCreateParams = {
max_tokens: 1024,
messages: [{ role: "user", content: "Hello, Claude" }],
model: "claude-opus-4-8"
};
const message: Anthropic.Message = await client.messages.create(params);Dokumentasi untuk setiap metode, parameter request, dan field response tersedia dalam docstring dan akan muncul saat hover di sebagian besar editor modern.
Anda dapat melihat penggunaan persis untuk request tertentu melalui properti response usage, misalnya:
const message = await client.messages.create(/* ... */);
console.log(message.usage);
// { input_tokens: 25, output_tokens: 13 }SDK ini menyediakan dukungan untuk streaming response menggunakan Server Sent Events (SSE).
const client = new Anthropic();
const stream = await client.messages.create({
max_tokens: 1024,
messages: [{ role: "user", content: "Hello, Claude" }],
model: "claude-opus-4-8",
stream: true
});
for await (const messageStreamEvent of stream) {
console.log(messageStreamEvent.type);
}Jika Anda perlu membatalkan stream, Anda dapat menggunakan break dari loop atau memanggil stream.controller.abort().
Pustaka ini menyediakan beberapa kemudahan untuk streaming pesan, misalnya:
const anthropic = new Anthropic();
const stream = anthropic.messages
.stream({
model: "claude-opus-4-8",
max_tokens: 1024,
messages: [
{
role: "user",
content: "Say hello there!"
}
]
})
.on("text", (text) => {
console.log(text);
});
const message = await stream.finalMessage();
console.log(message);Streaming dengan client.messages.stream(...) menyediakan berbagai helper untuk kemudahan Anda termasuk event handler dan akumulasi.
Sebagai alternatif, Anda dapat menggunakan client.messages.create({ ..., stream: true }) yang hanya mengembalikan async iterable dari event dalam stream sehingga menggunakan lebih sedikit memori (tidak membangun objek pesan akhir untuk Anda).
SDK ini menyediakan helper untuk memudahkan pembuatan dan menjalankan alat di Messages API. Anda dapat menggunakan skema Zod atau JSON Schema untuk mendeskripsikan input ke sebuah alat. Anda kemudian dapat menjalankan alat-alat tersebut menggunakan metode client.beta.messages.toolRunner(). Metode ini akan menangani penerusan input yang dihasilkan oleh model yang dipilih ke alat yang tepat dan meneruskan hasilnya kembali ke model.
Untuk detail lebih lanjut tentang penggunaan alat, lihat Penggunaan alat dengan Claude.
import { betaZodTool } from "@anthropic-ai/sdk/helpers/beta/zod";
import { z } from "zod";
const anthropic = new Anthropic();
const weatherTool = betaZodTool({
name: "get_weather",
inputSchema: z.object({
location: z.string()
}),
description: "Get the current weather in a given location",
run: (input) => {
return `The weather in ${input.location} is foggy and 60°F`;
}
});
const finalMessage = await anthropic.beta.messages.toolRunner({
model: "claude-opus-4-8",
max_tokens: 1000,
messages: [{ role: "user", content: "What is the weather in San Francisco?" }],
tools: [weatherTool]
});
console.log(finalMessage.content);Untuk melaporkan error dari sebuah alat kembali ke model, lempar ToolError dari fungsi run. Tidak seperti Error biasa, ToolError menerima content block, memungkinkan Anda menyertakan gambar atau konten terstruktur lainnya dalam response error:
import { ToolError } from "@anthropic-ai/sdk/lib/tools/BetaRunnableTool";
const screenshotTool = betaZodTool({
name: "take_screenshot",
inputSchema: z.object({ url: z.string() }),
run: async (input) => {
if (!isValidUrl(input.url)) {
throw new ToolError(`Invalid URL: ${input.url}`);
}
const result = await takeScreenshot(input.url);
if (result.error) {
// Sertakan tangkapan layar error agar model dapat melihat apa yang salah
throw new ToolError([
{ type: "text", text: `Failed to load page: ${result.error}` },
{
type: "image",
source: { type: "base64", data: result.screenshot, media_type: "image/png" }
}
]);
}
return {
type: "image",
source: { type: "base64", data: result.screenshot, media_type: "image/png" }
};
}
});Jika Error biasa dilempar, pesannya akan dikonversi menjadi text content block.
SDK ini menyediakan dukungan untuk "tool use" (penggunaan alat), juga dikenal sebagai function calling. Untuk detail lebih lanjut, lihat Penggunaan alat dengan Claude.
SDK ini menyediakan helper untuk integrasi dengan server Model Context Protocol (MCP). Helper ini mengonversi tipe MCP ke tipe Claude API, mengurangi boilerplate saat bekerja dengan alat, prompt, dan resource MCP.
Claude API juga mendukung parameter mcp_servers yang memungkinkan Claude terhubung langsung ke server MCP jarak jauh. Gunakan mcp_servers ketika Anda memiliki server jarak jauh yang dapat diakses melalui URL dan hanya membutuhkan dukungan alat. Gunakan helper MCP ketika Anda membutuhkan server MCP lokal, prompt, resource, atau kontrol lebih atas koneksi MCP.
import {
mcpTools,
mcpMessages,
mcpResourceToContent,
mcpResourceToFile
} from "@anthropic-ai/sdk/helpers/beta/mcp";
import { Client } from "@modelcontextprotocol/sdk/client/index.js";
import { StdioClientTransport } from "@modelcontextprotocol/sdk/client/stdio.js";
const anthropic = new Anthropic();
// Hubungkan ke server MCP
const transport = new StdioClientTransport({ command: "mcp-server", args: [] });
const mcpClient = new Client({ name: "my-client", version: "1.0.0" });
await mcpClient.connect(transport);
// Gunakan prompt MCP
const { messages } = await mcpClient.getPrompt({ name: "my-prompt" });
const response = await anthropic.beta.messages.create({
model: "claude-opus-4-8",
max_tokens: 1024,
messages: mcpMessages(messages)
});
console.log(response.content);
// Gunakan alat MCP dengan toolRunner
const { tools } = await mcpClient.listTools();
const finalMessage = await anthropic.beta.messages.toolRunner({
model: "claude-opus-4-8",
max_tokens: 1024,
messages: [{ role: "user", content: "Use the available tools" }],
tools: mcpTools(tools, mcpClient)
});
console.log(finalMessage.content);
// Gunakan sumber daya MCP sebagai konten
const resource = await mcpClient.readResource({ uri: "file:///path/to/doc.txt" });
await anthropic.beta.messages.create({
model: "claude-opus-4-8",
max_tokens: 1024,
messages: [
{
role: "user",
content: [
mcpResourceToContent(resource),
{ type: "text", text: "Summarize this document" }
]
}
]
});
// Unggah sumber daya MCP sebagai file
const fileResource = await mcpClient.readResource({ uri: "file:///path/to/data.json" });
await anthropic.beta.files.upload({ file: mcpResourceToFile(fileResource) });Fungsi konversi melempar UnsupportedMCPValueError jika nilai MCP tidak didukung oleh Claude API (misalnya, tipe konten yang tidak didukung, tipe MIME yang tidak didukung, resource link non-http/https).
SDK ini menyediakan dukungan untuk Message Batches API di bawah namespace client.messages.batches.
Message Batches menerima array request, di mana setiap objek memiliki identifier custom_id, dan params request yang persis sama dengan Messages API standar:
const batch = await client.messages.batches.create({
requests: [
{
custom_id: "my-first-request",
params: {
model: "claude-opus-4-8",
max_tokens: 1024,
messages: [{ role: "user", content: "Hello, world" }]
}
},
{
custom_id: "my-second-request",
params: {
model: "claude-opus-4-8",
max_tokens: 1024,
messages: [{ role: "user", content: "Hi again, friend" }]
}
}
]
});Setelah Message Batch selesai diproses, ditandai dengan .processing_status === 'ended', Anda dapat mengakses hasilnya dengan .batches.results()
const results = await client.messages.batches.results(batch.id);
for await (const entry of results) {
if (entry.result.type === "succeeded") {
console.log(entry.result.message.content);
}
}Parameter request yang berkaitan dengan unggahan file dapat diteruskan dalam berbagai bentuk:
File (atau objek dengan struktur yang sama)Response dari fetch (atau objek dengan struktur yang sama)fs.ReadStreamtoFileAtur content-type secara eksplisit karena files API tidak akan menyimpulkannya untuk Anda:
import fs from "fs";
import Anthropic, { toFile } from "@anthropic-ai/sdk";
const client = new Anthropic();
// Jika Anda memiliki akses ke `fs` Node, gunakan `fs.createReadStream()`:
await client.beta.files.upload({
file: await toFile(fs.createReadStream("/path/to/file"), undefined, {
type: "application/json"
})
});
// Atau jika Anda memiliki API `File` web, Anda dapat meneruskan instance `File`:
await client.beta.files.upload({
file: new File(["my bytes"], "file.txt", { type: "text/plain" })
});
// Anda juga dapat meneruskan `Response` dari `fetch`:
await client.beta.files.upload({
file: await fetch("https://somesite/file")
});
// Atau `Buffer` / `Uint8Array`
await client.beta.files.upload({
file: await toFile(Buffer.from("my bytes"), "file", { type: "text/plain" })
});
await client.beta.files.upload({
file: await toFile(new Uint8Array([0, 1, 2]), "file", { type: "text/plain" })
});Ketika pustaka tidak dapat terhubung ke API,
atau jika API mengembalikan kode status non-sukses (yaitu, response 4xx atau 5xx),
subclass dari APIError akan dilempar:
const message = await client.messages
.create({
max_tokens: 1024,
messages: [{ role: "user", content: "Hello, Claude" }],
model: "claude-opus-4-8"
})
.catch(async (err) => {
if (err instanceof Anthropic.APIError) {
console.log(err.status); // 400
console.log(err.name); // BadRequestError
console.log(err.headers); // {server: 'nginx', ...}
} else {
throw err;
}
});Kode error adalah sebagai berikut:
| Kode status | Tipe error |
|---|---|
| 400 | BadRequestError |
| 401 | AuthenticationError |
| 403 | PermissionDeniedError |
| 404 | NotFoundError |
| 409 | ConflictError |
| 422 | UnprocessableEntityError |
| 429 | RateLimitError |
| >=500 | InternalServerError |
| N/A | APIConnectionError |
Untuk informasi lebih lanjut tentang debugging request, lihat Request ID.
Semua response objek dalam SDK menyediakan properti _request_id yang ditambahkan dari header response request-id sehingga Anda dapat dengan cepat mencatat request yang gagal dan melaporkannya kembali ke Anthropic.
const message = await client.messages.create({
max_tokens: 1024,
messages: [{ role: "user", content: "Hello, Claude" }],
model: "claude-opus-4-8"
});
console.log(message._request_id); // req_018EeWyXxfu5pfWkrYcMdjWGError tertentu akan secara otomatis dicoba ulang 2 kali secara default, dengan exponential backoff singkat. Error koneksi (misalnya, karena masalah konektivitas jaringan), 408 Request Timeout, 409 Conflict, 429 Rate Limit, dan error Internal >=500 semuanya dicoba ulang secara default.
Anda dapat menggunakan opsi maxRetries untuk mengonfigurasi atau menonaktifkan ini:
// Konfigurasikan default untuk semua permintaan:
const client = new Anthropic({
maxRetries: 0 // default is 2
});
// Atau, konfigurasikan per permintaan:
await client.messages.create(
{
max_tokens: 1024,
messages: [{ role: "user", content: "Hello, Claude" }],
model: "claude-opus-4-8"
},
{ maxRetries: 5 }
);Secara default, request akan timeout setelah 10 menit. Namun jika Anda telah menentukan nilai max_tokens yang besar dan
tidak menggunakan streaming, timeout default akan dihitung secara dinamis menggunakan rumus:
const minimum = 10 * 60;
const calculated = (60 * 60 * maxTokens) / 128_000;
return calculated < minimum ? minimum * 1000 : calculated * 1000;yang akan menghasilkan timeout hingga 60 menit, diskalakan oleh parameter max_tokens, kecuali ditimpa pada level request atau klien.
Anda dapat mengonfigurasi ini dengan opsi timeout:
// Konfigurasikan default untuk semua permintaan:
const client = new Anthropic({
timeout: 20 * 1000 // 20 seconds (default is 10 minutes)
});
// Timpa per permintaan:
await client.messages.create(
{
max_tokens: 1024,
messages: [{ role: "user", content: "Hello, Claude" }],
model: "claude-opus-4-8"
},
{ timeout: 5 * 1000 }
);Saat timeout, APIConnectionTimeoutError akan dilempar.
Perhatikan bahwa request yang mengalami timeout akan dicoba ulang dua kali secara default.
Pertimbangkan untuk menggunakan Messages API streaming untuk request yang berjalan lebih lama.
Hindari mengatur nilai max_tokens yang besar tanpa menggunakan streaming.
Beberapa jaringan mungkin memutus koneksi idle setelah periode waktu tertentu, yang
dapat menyebabkan request gagal atau timeout tanpa menerima response dari Anthropic.
SDK ini juga akan melempar error jika request non-streaming diperkirakan akan berlangsung lebih dari sekitar 10 menit.
Meneruskan stream: true atau menimpa opsi timeout pada level klien atau request akan menonaktifkan error ini.
"Latency" (latensi) request yang diperkirakan lebih lama dari timeout untuk request non-streaming akan menyebabkan klien memutus koneksi dan mencoba ulang tanpa menerima response.
Ketika didukung oleh implementasi fetch, SDK mengatur opsi TCP socket keep-alive untuk
mengurangi dampak timeout koneksi idle pada beberapa jaringan.
Ini dapat ditimpa dengan mengonfigurasi proxy kustom.
Metode list di Claude API menggunakan paginasi.
Anda dapat menggunakan sintaks for await ... of untuk melakukan iterasi melalui item di semua halaman:
async function fetchAllMessageBatches() {
const allMessageBatches = [];
// Secara otomatis mengambil lebih banyak halaman sesuai kebutuhan.
for await (const messageBatch of client.messages.batches.list({ limit: 20 })) {
allMessageBatches.push(messageBatch);
}
return allMessageBatches;
}Sebagai alternatif, Anda dapat meminta satu halaman pada satu waktu:
let page = await client.messages.batches.list({ limit: 20 });
for (const messageBatch of page.data) {
console.log(messageBatch);
}
// Metode praktis disediakan untuk paginasi manual:
while (page.hasNextPage()) {
page = await page.getNextPage();
// ...
}SDK secara otomatis mengirim header anthropic-version yang diatur ke 2023-06-01.
Jika perlu, Anda dapat menimpanya dengan mengatur header default pada basis per-request.
Perhatikan bahwa melakukan hal tersebut dapat menghasilkan tipe yang salah dan perilaku tak terduga atau tidak terdefinisi lainnya dalam SDK.
const client = new Anthropic();
const message = await client.messages.create(
{
max_tokens: 1024,
messages: [{ role: "user", content: "Hello, Claude" }],
model: "claude-opus-4-8"
},
{ headers: { "anthropic-version": "My-Custom-Value" } }
);Response "mentah" yang dikembalikan oleh fetch() dapat diakses melalui metode .asResponse() pada tipe APIPromise yang dikembalikan oleh semua metode.
Metode ini mengembalikan segera setelah header untuk response yang berhasil diterima dan tidak mengonsumsi body response, sehingga Anda bebas menulis logika parsing atau streaming kustom.
Anda juga dapat menggunakan metode .withResponse() untuk mendapatkan Response mentah bersama dengan data yang telah di-parse.
Tidak seperti .asResponse(), metode ini mengonsumsi body, mengembalikan setelah selesai di-parse.
const client = new Anthropic();
const response = await client.messages
.create({
max_tokens: 1024,
messages: [{ role: "user", content: "Hello, Claude" }],
model: "claude-opus-4-8"
})
.asResponse();
console.log(response.headers.get("X-My-Header"));
console.log(response.statusText); // access the underlying Response object
const { data: message, response: raw } = await client.messages
.create({
max_tokens: 1024,
messages: [{ role: "user", content: "Hello, Claude" }],
model: "claude-opus-4-8"
})
.withResponse();
console.log(raw.headers.get("X-My-Header"));
console.log(message.content);Semua pesan log ditujukan hanya untuk debugging. Format dan konten pesan log dapat berubah antar rilis.
Level log dapat dikonfigurasi dengan dua cara:
ANTHROPIC_LOGlogLevel (menimpa variabel lingkungan jika diatur)const client = new Anthropic({
logLevel: "debug" // Show all log messages
});Level log yang tersedia, dari yang paling verbose hingga paling sedikit:
'debug' - Tampilkan pesan debug, info, peringatan, dan error'info' - Tampilkan pesan info, peringatan, dan error'warn' - Tampilkan peringatan dan error (default)'error' - Tampilkan hanya error'off' - Nonaktifkan semua loggingPada level 'debug', semua request dan response HTTP dicatat, termasuk header dan body.
Beberapa header terkait autentikasi disensor, tetapi data sensitif dalam body request dan response
mungkin masih terlihat.
Secara default, pustaka ini mencatat log ke globalThis.console. Anda juga dapat menyediakan logger kustom.
Sebagian besar pustaka logging didukung, termasuk pino, winston, bunyan, consola, signale, dan @std/log. Jika logger Anda tidak berfungsi, buka issue.
Saat menyediakan logger kustom, opsi logLevel tetap mengontrol pesan mana yang dikeluarkan, pesan
di bawah level yang dikonfigurasi tidak akan dikirim ke logger Anda.
import pino from "pino";
const logger = pino();
const client = new Anthropic({
logger: logger.child({ name: "Anthropic" }),
logLevel: "debug" // Send all messages to pino, allowing it to filter
});Pustaka ini diberi tipe untuk akses yang mudah ke API yang terdokumentasi. Jika Anda perlu mengakses endpoint, parameter, atau properti response yang tidak terdokumentasi, pustaka ini tetap dapat digunakan.
Untuk membuat request ke endpoint yang tidak terdokumentasi, Anda dapat menggunakan client.get, client.post, dan HTTP verb lainnya.
Opsi pada klien, seperti retry, akan dihormati saat membuat request ini.
await client.post("/some/path", {
body: { some_prop: "foo" },
query: { some_query_arg: "bar" }
});Untuk membuat request menggunakan parameter yang tidak terdokumentasi, Anda dapat menggunakan // @ts-expect-error pada parameter
yang tidak terdokumentasi. Pustaka ini tidak memvalidasi saat runtime bahwa request cocok dengan tipenya, sehingga nilai tambahan apa pun yang Anda
kirim akan dikirim apa adanya.
client.messages.create({
// ...
// @ts-expect-error baz is not yet public
baz: "undocumented option"
});Untuk request dengan verb GET, parameter tambahan apa pun akan berada di query, semua request lainnya akan mengirim
parameter tambahan di body.
Jika Anda ingin secara eksplisit mengirim argumen tambahan, Anda dapat melakukannya dengan opsi request query, body, dan headers.
Untuk mengakses properti response yang tidak terdokumentasi, Anda dapat mengakses objek response dengan // @ts-expect-error pada
objek response, atau melakukan cast objek response ke tipe yang diperlukan. Seperti parameter request, SDK tidak
memvalidasi atau menghapus properti tambahan dari response dari API.
Secara default, pustaka ini mengharapkan fungsi fetch global telah didefinisikan.
Jika Anda ingin menggunakan fungsi fetch yang berbeda, Anda dapat melakukan polyfill pada global:
import fetch from "my-fetch";
globalThis.fetch = fetch;Atau meneruskannya ke klien:
import fetch from "my-fetch";
const client = new Anthropic({ fetch });Jika Anda ingin mengatur opsi fetch kustom tanpa menimpa fungsi fetch, Anda dapat menyediakan objek fetchOptions saat membuat klien atau membuat request. (Opsi spesifik request menimpa opsi klien.)
const client = new Anthropic({
fetchOptions: {
// Opsi `RequestInit`
}
});Untuk memodifikasi perilaku proxy, Anda dapat menyediakan fetchOptions kustom yang menambahkan opsi proxy
spesifik runtime ke request:
Fitur beta tersedia sebelum rilis umum untuk mendapatkan umpan balik awal dan menguji fungsionalitas baru. Anda dapat memeriksa ketersediaan semua kemampuan dan alat Claude di ikhtisar membangun dengan Claude.
Anda dapat mengakses sebagian besar fitur API beta melalui properti beta dari klien. Untuk mengaktifkan fitur beta tertentu, Anda perlu menambahkan header beta yang sesuai ke field betas saat membuat pesan.
Misalnya, untuk menggunakan Files API:
const client = new Anthropic();
const response = await client.beta.messages.create({
model: "claude-opus-4-8",
max_tokens: 1024,
messages: [
{
role: "user",
content: [
{ type: "text", text: "Please summarize this document for me." },
{
type: "document",
source: {
type: "file",
file_id: "file_abc123"
}
}
]
}
],
betas: ["files-api-2025-04-14"]
});Untuk panduan pengaturan platform yang detail dengan contoh kode, lihat:
TypeScript SDK mendukung platform berikut:
npm install @anthropic-ai/bedrock-sdk: Menyediakan klien AnthropicBedrockMantle, dan AnthropicBedrock untuk jalur bedrock-runtimenpm install @anthropic-ai/vertex-sdk: Menyediakan klien AnthropicVertexnpm install @anthropic-ai/foundry-sdk: Menyediakan klien AnthropicFoundrynpm install @anthropic-ai/aws-sdk: Menyediakan klien AnthropicAws. Teruskan workspaceId ke konstruktor atau atur variabel lingkungan ANTHROPIC_AWS_WORKSPACE_ID. Tersedia dalam beta.Gunakan AnthropicBedrockMantle untuk proyek baru; AnthropicBedrock tetap tersedia untuk aplikasi yang sudah ada yang menggunakan Bedrock InvokeModel API.
Paket ini secara umum mengikuti konvensi SemVer, meskipun perubahan tertentu yang tidak kompatibel ke belakang dapat dirilis sebagai versi minor:
Kompatibilitas ke belakang ditangani dengan serius untuk memastikan Anda dapat mengandalkan pengalaman upgrade yang lancar.
Lihat repositori GitHub untuk FAQ, issue, dan dukungan komunitas.
Was this page helpful?