🚀 DAY 5 OF LAUNCH WEEK: Introducing Socket Firewall Enterprise.Learn more
Socket
Book a DemoInstallSign in
Socket

@strapi/client

Package Overview
Dependencies
Maintainers
8
Versions
10
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@strapi/client

The official client library to easily interface with Strapi from your JavaScript/TypeScript project

latest
Source
npmnpm
Version
1.5.0
Version published
Weekly downloads
8.4K
-12.2%
Maintainers
8
Weekly downloads
 
Created
Source

Strapi logo Strapi logo

Manage Your Strapi Content From Anywhere 🚀

Connect your JavaScript/TypeScript apps to a flexible and fully customizable Strapi backend with ease.

CMS Repository - Website - SDK Roadmap


NPM Version NPM downloads Tests Strapi on Discord


📖 Table of contents

🛠 Getting started

Pre-Requisites

Before you begin, ensure you have the following:

  • A Strapi backend up and running: quick start guide.
  • The API URL of your Strapi instance: for example, http://localhost:1337/api.
  • A recent version of Node.js installed.

Installation

Install the client as a dependency in your project:

NPM

npm install @strapi/client

Yarn

yarn add @strapi/client

pnpm

pnpm add @strapi/client

⚙️ Creating and configuring the client Instance

Basic configuration

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>

Authentication

The client library supports multiple authentication strategies for accessing authenticated content in your Strapi backend.

API-Token authentication

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

Custom Headers

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

📚 API Reference

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.

📁 Resource Managers

.collection(resource, [options])

The .collection() method provides a manager for working with collection-type resources, which can have multiple entries.

Params

  • 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 queries

Available Methods:

  • find(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.

Examples:

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.

Params

  • 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 queries

Available Methods:

  • find(queryParams?): fetch the document.
  • update(data, queryParams?): update the document.
  • delete(queryParams?): remove the document.

Examples:

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

.files

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

Methods

  • find(params?: FileQueryParams): Promise<FileListResponse> - Retrieves a list of file metadata based on optional query parameters
  • findOne(fileId: number): Promise<FileResponse> - Retrieves the metadata for a single file by its ID
  • update(fileId: number, fileInfo: FileUpdateData): Promise<FileResponse> - Updates metadata for an existing file
  • delete(fileId: number): Promise<void> - Deletes a file by its ID

Examples

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

🐛 Debug

This section provides guidance on enabling and managing debug logs for the SDK, powered by debug.

Node.js Debugging

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

Browser Debugging

For browser environments, debug capabilities are intentionally turned off to optimize the bundle size.

Usage Overview

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.

Namespaces

Below is a list of available namespaces to use:

NamespaceDescription
strapi:coreLogs SDK initialization, configuration validation, and HTTP client setup.
strapi:validators:configLogs details related to SDK configuration validation.
strapi:validators:urlLogs URL validation processes.
strapi:httpLogs HTTP client setup, request processing, and response/error handling.
strapi:auth:factoryLogs the registration and creation of authentication providers.
strapi:auth:managerLogs authentication lifecycle management.
strapi:auth:provider:api-tokenLogs operations related to API token authentication.
strapi:ct:collectionLogs interactions with collection-type content managers.
strapi:ct:singleLogs interactions with single-type content managers.
strapi:utils:url-helperLogs URL helper utility operations (e.g., appending query parameters or formatting URLs).
strapi:filesLogs interactions with the files manager.

🚀 Demo Projects

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.

Demo Structure

  • .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 TypeScript

Using Demo Commands

The 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

Comprehensive Setup:

  • 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
    

Development:

  • 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
    

Database Seeding:

  • 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
    

Build and Install:

  • 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
    

Environment Setup:

  • 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
    

Adding New Projects

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.

Future Plans

We plan to expand the demo projects to include:

  • A basic HTML project
  • A Vue.js project (with or without server components)
  • A Svelte project

Keywords

strapi

FAQs

Package last updated on 18 Aug 2025

Did you know?

Socket

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.

Install

Related posts