• Pesan
  • Managed Agents
  • Admin
Search...
⌘K
CLI, SDK, dan pustaka
Ikhtisar
ant CLI
Mulai cepatOpsi autentikasiMenggunakan CLIScripting dan otomatisasi
SDK Klien
MiddlewarePythonTypeScriptC#GoJavaPHPRuby
Pustaka dan integrasi
Apple Foundation ModelsKompatibilitas OpenAI SDK
Log in
TypeScript
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...

Solutions

  • AI agents
  • Code modernization
  • Coding
  • Customer support
  • Education
  • Financial services
  • Government
  • Life sciences

Partners

  • Amazon Bedrock
  • Google Cloud's Vertex AI

Learn

  • Blog
  • Courses
  • Use cases
  • Connectors
  • Customer stories
  • Engineering at Anthropic
  • Events
  • Powered by Claude
  • Service partners
  • Startups program

Company

  • Anthropic
  • Careers
  • Economic Futures
  • Research
  • News
  • Responsible Scaling Policy
  • Security and compliance
  • Transparency

Learn

  • Blog
  • Courses
  • Use cases
  • Connectors
  • Customer stories
  • Engineering at Anthropic
  • Events
  • Powered by Claude
  • Service partners
  • Startups program

Help and security

  • Availability
  • Status
  • Support
  • Discord

Terms and policies

  • Privacy policy
  • Responsible disclosure policy
  • Terms of service: Commercial
  • Terms of service: Consumer
  • Usage policy
CLI, SDK, dan pustaka/SDK Klien

TypeScript SDK

Instal dan konfigurasikan Anthropic TypeScript SDK untuk Node.js, Deno, Bun, dan lingkungan browser

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.

Instalasi

npm install @anthropic-ai/sdk

Persyaratan

TypeScript >= 4.9 didukung.

Runtime berikut didukung:

  • Node.js 20 LTS atau versi yang lebih baru (non-EOL).
  • Deno v1.28.0 atau lebih tinggi.
  • Bun 1.0 atau lebih baru.
  • Cloudflare Workers.
  • Vercel Edge Runtime.
  • Jest 28 atau lebih tinggi dengan lingkungan "node" ("jsdom" tidak didukung saat ini).
  • Nitro v2.6 atau lebih tinggi.
  • Browser web: dinonaktifkan secara default untuk menghindari terungkapnya kredensial API rahasia Anda (lihat praktik terbaik kunci API). Aktifkan dukungan browser dengan secara eksplisit mengatur 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.

Penggunaan

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.

Tipe request dan response

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.

Menghitung token

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 }

Streaming response

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().

Helper streaming

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).

Helper alat

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);

Error alat

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.

Penggunaan alat

SDK ini menyediakan dukungan untuk "tool use" (penggunaan alat), juga dikenal sebagai function calling. Untuk detail lebih lanjut, lihat Penggunaan alat dengan Claude.

Helper MCP

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) });

Penanganan error MCP

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).

Message batches

SDK ini menyediakan dukungan untuk Message Batches API di bawah namespace client.messages.batches.

Membuat batch

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" }]
      }
    }
  ]
});

Mendapatkan hasil dari batch

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);
  }
}

Unggahan file

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.ReadStream
  • nilai kembalian dari helper toFile

Atur 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" })
});

Menangani error

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 statusTipe error
400BadRequestError
401AuthenticationError
403PermissionDeniedError
404NotFoundError
409ConflictError
422UnprocessableEntityError
429RateLimitError
>=500InternalServerError
N/AAPIConnectionError

Request ID

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_018EeWyXxfu5pfWkrYcMdjWG

Retry

Error 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 }
);

Timeout

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.

Request panjang

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.

Auto-pagination

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();
  // ...
}

Header default

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" } }
);

Penggunaan lanjutan

Mengakses data Response mentah (misalnya, header)

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);

Logging

Semua pesan log ditujukan hanya untuk debugging. Format dan konten pesan log dapat berubah antar rilis.

Level log

Level log dapat dikonfigurasi dengan dua cara:

  1. Melalui variabel lingkungan ANTHROPIC_LOG
  2. Menggunakan opsi klien logLevel (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 logging

Pada 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.

Logger kustom

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
});

Membuat request kustom/tidak terdokumentasi

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.

Endpoint tidak terdokumentasi

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" }
});

Parameter request tidak terdokumentasi

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.

Properti response tidak terdokumentasi

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.

Menyesuaikan klien fetch

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 });

Opsi 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`
  }
});

Mengonfigurasi proxy

Untuk memodifikasi perilaku proxy, Anda dapat menyediakan fetchOptions kustom yang menambahkan opsi proxy spesifik runtime ke request:

Fitur beta

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"]
});

Dukungan runtime

Integrasi platform

Untuk panduan pengaturan platform yang detail dengan contoh kode, lihat:

  • Amazon Bedrock
  • Amazon Bedrock (legacy)
  • Vertex AI
  • Microsoft Foundry
  • Claude Platform di AWS

TypeScript SDK mendukung platform berikut:

  • Bedrock: npm install @anthropic-ai/bedrock-sdk: Menyediakan klien AnthropicBedrockMantle, dan AnthropicBedrock untuk jalur bedrock-runtime
  • Vertex AI: npm install @anthropic-ai/vertex-sdk: Menyediakan klien AnthropicVertex
  • Foundry: npm install @anthropic-ai/foundry-sdk: Menyediakan klien AnthropicFoundry
  • Claude Platform di AWS: npm 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.

Semantic versioning

Paket ini secara umum mengikuti konvensi SemVer, meskipun perubahan tertentu yang tidak kompatibel ke belakang dapat dirilis sebagai versi minor:

  1. Perubahan yang hanya memengaruhi tipe statis, tanpa merusak perilaku runtime.
  2. Perubahan pada internal pustaka yang secara teknis publik tetapi tidak dimaksudkan atau didokumentasikan untuk penggunaan eksternal.
  3. Perubahan yang tidak diharapkan memengaruhi sebagian besar pengguna dalam praktiknya.

Kompatibilitas ke belakang ditangani dengan serius untuk memastikan Anda dapat mengandalkan pengalaman upgrade yang lancar.

Pertanyaan yang sering diajukan

Lihat repositori GitHub untuk FAQ, issue, dan dukungan komunitas.

Sumber daya tambahan

  • Repositori GitHub
  • Referensi API
  • Streaming Messages
  • Penggunaan alat dengan Claude

Was this page helpful?

  • Instalasi
  • Persyaratan
  • Penggunaan
  • Tipe request dan response
  • Menghitung token
  • Streaming response
  • Helper streaming
  • Helper alat
  • Error alat
  • Penggunaan alat
  • Helper MCP
  • Penanganan error MCP
  • Message batches
  • Membuat batch
  • Mendapatkan hasil dari batch
  • Unggahan file
  • Menangani error
  • Request ID
  • Retry
  • Timeout
  • Request panjang
  • Auto-pagination
  • Header default
  • Penggunaan lanjutan
  • Mengakses data Response mentah (misalnya, header)
  • Logging
  • Membuat request kustom/tidak terdokumentasi
  • Menyesuaikan klien fetch
  • Opsi fetch
  • Mengonfigurasi proxy
  • Fitur beta
  • Dukungan runtime
  • Integrasi platform
  • Semantic versioning
  • Pertanyaan yang sering diajukan
  • Sumber daya tambahan