
Product
Introducing Socket Firewall Enterprise: Flexible, Configurable Protection for Modern Package Ecosystems
Socket Firewall Enterprise is now available with flexible deployment, configurable policies, and expanded language support.
@strapi/client
Advanced tools
The official client library to easily interface with Strapi from your JavaScript/TypeScript project
Connect your JavaScript/TypeScript apps to a flexible and fully customizable Strapi backend with ease.
CMS Repository - Website - SDK Roadmap
Before you begin, ensure you have the following:
http://localhost:1337/api.Install the client as a dependency in your project:
NPM
npm install @strapi/client
Yarn
yarn add @strapi/client
pnpm
pnpm add @strapi/client
To interact with your Strapi backend, initialize the client with your Strapi API base URL:
import { strapi } from '@strapi/client';
const client = strapi({ baseURL: 'http://localhost:1337/api' });
Alternatively, use a <script> tag in a browser environment:
<script src="https://cdn.jsdelivr.net/npm/@strapi/client"></script>
<script>
  const client = strapi.strapi({ baseURL: 'http://localhost:1337/api' });
</script>
The client library supports multiple authentication strategies for accessing authenticated content in your Strapi backend.
If your Strapi instance uses API tokens, configure the client like this:
const client = strapi({
  // Endpoint configuration
  baseURL: 'http://localhost:1337/api',
  // Auth configuration
  auth: 'your-api-token-here',
});
You can configure custom headers to be included with every request made by the client:
const client = strapi({
  baseURL: 'http://localhost:1337/api',
  auth: 'your-api-token-here',
  headers: {
    'X-Custom-Header': 'value',
    'Accept-Language': 'en-US',
  },
});
Custom headers specified in the client configuration are applied to all requests
Example: Using Custom Headers
// Initialize client with custom headers
const client = strapi({
  baseURL: 'http://localhost:1337/api',
  headers: {
    'X-Request-ID': '12345',
    'Accept-Language': 'en-US',
  },
});
// Headers will be included in all requests
const articles = await client.collection('articles').find();
The Strapi client library instance provides key properties and utility methods for content and API interaction:
baseURL: base URL of your Strapi backend.fetch(): perform generic requests to the Strapi Content API using fetch-like syntax.collection(): get a manager instance for handling collection-type resources.single(): get a manager instance for handling single-type resources.files: access the files manager instance for handling common files operations..collection(resource, [options])The .collection() method provides a manager for working with collection-type resources,
which can have multiple entries.
resource: string - plural name of your collection type, as defined in the Strapi model[options]: object - additional options to pass to the collection type manager
[path]: string - optional root path override for the manager's queriesfind(queryParams?): fetch multiple entries.findOne(documentID, queryParams?): fetch a single entry by its ID.create(data, queryParams?): create a new entry.update(documentID, data, queryParams?): update an existing entry.delete(documentID, queryParams?): remove an entry.const articles = client.collection('articles');
// Fetch all english articles sorted by title
const allArticles = await articles.find({
  locale: 'en',
  sort: 'title',
});
// Fetch a single article
const singleArticle = await articles.findOne('article-document-id');
// Create a new article
const newArticle = await articles.create({ title: 'New Article', content: '...' });
// Update an existing article
const updatedArticle = await articles.update('article-document-id', { title: 'Updated Title' });
// Delete an article
await articles.delete('article-id');
You can also customize the root path for requests by providing a value for the path option:
const articles = client.collection('articles', { path: '/my-custom-path' });
.single(resource, [options])The .single() method provides a manager for working with single-type resources, which have only one entry.
resource: string - singular name of your single type, as defined in the Strapi model[options]: object - additional options to pass to the single type manager
[path]: string - optional root path override for the manager's queriesfind(queryParams?): fetch the document.update(data, queryParams?): update the document.delete(queryParams?): remove the document.const homepage = client.single('homepage');
// Fetch the default version of the homepage
const defaultHomepage = await homepage.find();
// Fetch the spanish version of the homepage
const spanishHomepage = await homepage.find({ locale: 'es' });
// Update the homepage draft content
const updatedHomepage = await homepage.update(
  { title: 'Updated Homepage Title' },
  { status: 'draft' }
);
// Delete the homepage content
await homepage.delete();
You can also customize the root path for requests by providing a value for the path option:
const homepage = client.single('homepage', { path: '/my-custom-path' });
.filesThe files property provides access to the Strapi Media Library through the Upload plugin. It allows you to retrieve files metadata without directly interacting with the REST API manually.
find(params?: FileQueryParams): Promise<FileListResponse> - Retrieves a list of file metadata based on optional query parametersfindOne(fileId: number): Promise<FileResponse> - Retrieves the metadata for a single file by its IDupdate(fileId: number, fileInfo: FileUpdateData): Promise<FileResponse> - Updates metadata for an existing filedelete(fileId: number): Promise<void> - Deletes a file by its IDFinding all files
// Initialize the client
const client = strapi({
  baseURL: 'http://localhost:1337/api',
  auth: 'your-api-token',
});
// Find all file metadata
const allFiles = await client.files.find();
console.log(allFiles);
// Find file metadata with filtering and sorting
const imageFiles = await client.files.find({
  filters: {
    mime: { $contains: 'image' }, // Only get image files
    name: { $contains: 'avatar' }, // Only get files with 'avatar' in the name
  },
  sort: ['name:asc'], // Sort by name in ascending order
});
Finding a Single File
// Initialize the client
const client = strapi({
  baseURL: 'http://localhost:1337/api',
  auth: 'your-api-token',
});
// Find file metadata by ID
const file = await client.files.findOne(1);
console.log(file.name); // The file name
console.log(file.url); // The file URL
console.log(file.mime); // The file MIME type
Updating File Metadata
// Initialize the client
const client = strapi({
  baseURL: 'http://localhost:1337/api',
  auth: 'your-api-token',
});
// Update file metadata
const updatedFile = await client.files.update(1, {
  name: 'New file name',
  alternativeText: 'Descriptive alt text for accessibility',
  caption: 'A caption for the file',
});
console.log(updatedFile.name); // Updated file name
console.log(updatedFile.alternativeText); // Updated alt text
Deleting a File
// Initialize the client
const client = strapi({
  baseURL: 'http://localhost:1337/api',
  auth: 'your-api-token',
});
// Delete a file by ID
const deletedFile = await client.files.delete(1);
console.log('File deleted successfully');
console.log('Deleted file ID:', deletedFile.id);
console.log('Deleted file name:', deletedFile.name);
This section provides guidance on enabling and managing debug logs for the SDK, powered by debug.
In Node.js bundles (cjs, esm), debugging capabilities are always available to use.
You can turn on or off debug logs using the DEBUG environment variable:
# Enable logs for all namespaces
DEBUG=*
# Enable logs for a specific namespace
DEBUG=strapi:http
# Turn off logs
unset DEBUG
For browser environments, debug capabilities are intentionally turned off to optimize the bundle size.
The debug tool allows you to control logs using wildcard patterns (*):
*: enable all logs.strapi:module: enable logs for a specific module.strapi:module1,sdk:module2: enable logs for multiple modules.strapi:*: match all namespaces under strapi.strapi:*,-strapi:module2: enable all logs except those from strapi:module2.Below is a list of available namespaces to use:
| Namespace | Description | 
|---|---|
| strapi:core | Logs SDK initialization, configuration validation, and HTTP client setup. | 
| strapi:validators:config | Logs details related to SDK configuration validation. | 
| strapi:validators:url | Logs URL validation processes. | 
| strapi:http | Logs HTTP client setup, request processing, and response/error handling. | 
| strapi:auth:factory | Logs the registration and creation of authentication providers. | 
| strapi:auth:manager | Logs authentication lifecycle management. | 
| strapi:auth:provider:api-token | Logs operations related to API token authentication. | 
| strapi:ct:collection | Logs interactions with collection-type content managers. | 
| strapi:ct:single | Logs interactions with single-type content managers. | 
| strapi:utils:url-helper | Logs URL helper utility operations (e.g., appending query parameters or formatting URLs). | 
| strapi:files | Logs interactions with the files manager. | 
This repository includes demo projects located in the /demo directory to help you get started with using the client. The actual Strapi app is located in the .strapi-app directory.
.strapi-app: the main Strapi app used for the demo projects.demo/node-typescript: a Node.js project using TypeScript.demo/node-javascript: a Node.js project using JavaScript.demo/next-server-components: a Next.js project using TypeScript and server components.demo/react-vite: a React project using Vite and TypeScriptThe repository supports running demo-related commands directly using the format pnpm demo <command>.
To display the entire list of available commands, use pnpm demo help
pnpm demo setup
A complete setup command that installs dependencies, sets up the environment,
builds the projects, and seeds the database with initial data for the demo app.
It is a one-stop command for preparing everything.
pnpm demo setup
pnpm demo app:start
Starts the Strapi demo app in development mode. This is useful for testing and making changes to the Strapi backend.
pnpm demo app:start
pnpm demo app:seed
Seeds the Strapi app with sample data. Use this when you want to populate your Strapi app with default content.
pnpm demo app:seed
pnpm demo app:seed:clean
Cleans the existing database and re-seeds the Strapi demo app.
This is helpful if you want to reset the demo data to its initial state.
pnpm demo app:seed:clean
pnpm demo build
Builds the main Strapi app and all demo projects.
Use this to prepare the projects for use, ensuring all components are compiled and ready.
pnpm demo build
pnpm demo install
Installs dependencies for the main Strapi app and all demo applications.
This command ensures that all required packages are downloaded and ready to go.
pnpm demo install
pnpm demo app:env:setup
Sets up the .env file for the main Strapi app by copying the example .env.example file if no .env file exists.
This ensures the environment is configured appropriately.
pnpm demo app:env:setup
New projects added to the /demo directory are automatically picked up by the demo scripts.
Thus, no explicit configuration updates are required for these commands to work with new demo directories.
Note: if a project needs to be built to be used, add a build script
to its package.json so that the demo scripts automatically run it.
We plan to expand the demo projects to include:
FAQs
The official client library to easily interface with Strapi from your JavaScript/TypeScript project
The npm package @strapi/client receives a total of 6,789 weekly downloads. As such, @strapi/client popularity was classified as popular.
We found that @strapi/client demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 8 open source maintainers collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Product
Socket Firewall Enterprise is now available with flexible deployment, configurable policies, and expanded language support.

Security News
Open source dashboard CNAPulse tracks CVE Numbering Authorities’ publishing activity, highlighting trends and transparency across the CVE ecosystem.

Product
Detect malware, unsafe data flows, and license issues in GitHub Actions with Socket’s new workflow scanning support.