Get a List of Blocks from the Repository landing.block.getrepository
If you are developing integrations for Bitrix24 using AI tools (Codex, Claude Code, Cursor), connect to the MCP server so that the assistant can utilize the official REST documentation.
Scope:
landingWho can execute the method: a user with access to the "Sites and Stores" section
The method landing.block.getrepository returns the available sections of the block repository or the data for a specific section.
Method Parameters
Required parameters are marked with *
|
Name |
Description |
|
section |
The code of the repository section, for example If the parameter is not provided, the method will return all available sections. In this case, the keys of the In addition to standard sections, the response may include sections from partner applications and system sections. To get the current section codes, call the method without If a section with the specified code is not found or an empty string is provided, the method will return |
|
scope |
An additional top-level parameter of the REST call that affects the type of site for which the repository is being collected. For site types The rules for selecting the value are described in detail in the article Working with Site Types and Scopes. If |
Code Examples
How to Use Examples in Documentation
curl -X POST \
-H "Content-Type: application/json" \
-d '{
"section": "text"
}' \
"https://**put.your-domain-here**/rest/**user_id**/**webhook_code**/landing.block.getrepository.json"
curl -X POST \
-H "Content-Type: application/json" \
-d '{
"section": "text",
"auth": "**put_access_token_here**"
}' \
"https://**put.your-domain-here**/rest/landing.block.getrepository.json"
try
{
const response = await $b24.callMethod(
'landing.block.getrepository',
{
section: 'text'
}
);
const result = response.getData().result;
console.info(result);
}
catch (error)
{
console.error(error);
}
try {
$response = $b24Service
->core
->call(
'landing.block.getrepository',
[
'section' => 'text',
]
);
$result = $response
->getResponseData()
->getResult();
echo 'Success: ' . var_export($result, true);
} catch (Throwable $e) {
error_log($e->getMessage());
echo 'Error getting repository blocks: ' . $e->getMessage();
}
BX24.callMethod(
'landing.block.getrepository',
{
section: 'text'
},
function(result)
{
if (result.error())
{
console.error(result.error());
}
else
{
console.info(result.data());
}
}
);
require_once('crest.php');
$result = CRest::call(
'landing.block.getrepository',
[
'section' => 'text',
]
);
if (isset($result['error']))
{
echo 'Error: ' . $result['error_description'];
}
else
{
echo '<pre>';
print_r($result['result']);
echo '</pre>';
}
Response Handling
HTTP Status: 200
Example Response for Request with Section Parameter
{
"result": {
"name": "Text",
"meta": {
"ai_text_placeholder": "text for website, family business, sale of flowers",
"ai_text_max_tokens": 150
},
"new": false,
"type": null,
"specialType": null,
"separator": false,
"app_code": false,
"items": {
"03.1.three_cols_big_with_text_and_titles": {
"id": null,
"name": "Text in 3 Columns Full Width on Color Background",
"namespace": "bitrix",
"new": false,
"version": null,
"type": [],
"section": [
"columns",
"text"
],
"system": false,
"description": "Three columns with headings and text",
"preview": "//example.bitrix24.com/bitrix/blocks/bitrix/03.1.three_cols_big_with_text_and_titles/preview.jpg",
"restricted": false,
"repo_id": false,
"app_code": false,
"only_for_license": "",
"requires_updates": false
},
"repo_405": {
"id": null,
"new": false,
"name": "Block 'Text + Image' with Button, Text on the Right, Image on the Left",
"description": null,
"namespace": "krayt.monotovar",
"type": [],
"section": [
"about",
"text",
"image"
],
"preview": "https://example.com/upload/iblock/5aa/5aabf5b9241876561d5db49c482dcd96.png",
"restricted": true,
"repo_id": "405",
"app_code": "krayt.monotovar",
"requires_updates": false
}
}
},
"time": {
"start": 1774521670,
"finish": 1774521670.823288,
"duration": 0.8232879638671875,
"processing": 0,
"date_start": "2026-03-26T13:41:10+02:00",
"date_finish": "2026-03-26T13:41:10+02:00",
"operating_reset_at": 1774522270,
"operating": 0
}
}
Example Response for Request without Section Parameter
{
"result": {
"favourite": {
"name": "Favorites",
"meta": [],
"new": false,
"type": null,
"specialType": null,
"separator": false,
"app_code": false,
"items": {}
},
"text": {
"name": "Text",
"meta": {
"ai_text_placeholder": "text for website, family business, sale of flowers",
"ai_text_max_tokens": 150
},
"new": false,
"type": null,
"specialType": null,
"separator": false,
"app_code": false,
"items": {
"03.1.three_cols_big_with_text_and_titles": {
"id": null,
"name": "Text in 3 Columns Full Width on Color Background",
"namespace": "bitrix",
"new": false,
"version": null,
"type": [],
"section": [
"columns",
"text"
],
"system": false,
"description": "Three columns with headings and text",
"preview": "//example.bitrix24.com/bitrix/blocks/bitrix/03.1.three_cols_big_with_text_and_titles/preview.jpg",
"restricted": false,
"repo_id": false,
"app_code": false,
"only_for_license": "",
"requires_updates": false
}
}
}
},
"time": {
"start": 1774521670,
"finish": 1774521670.823288,
"duration": 0.8232879638671875,
"processing": 0,
"date_start": "2026-03-26T13:41:10+02:00",
"date_finish": "2026-03-26T13:41:10+02:00",
"operating_reset_at": 1774522270,
"operating": 0
}
}
Returned Data
|
Name |
Description |
|
The result of the request. If If If |
|
|
time |
Information about the execution time of the request |
Section Object
|
Name |
Description |
|
name |
The name of the section |
|
Additional data for the section. For example, the section may return service fields for AI prompts |
|
|
new |
Indicates whether there are new blocks in the section |
|
Restriction of the section by site type, if specified. The value can be an array of types, a string, or |
|
|
Additional type of the section, if specified. If no additional type is specified, the method will return |
|
|
separator |
Indicates a service separator. Sections with this flag are needed for visually separating categories in the block editor. They do not contain blocks, so such sections can be skipped when traversing the response |
|
The application code if the section belongs to the partner catalog, otherwise |
|
|
items |
A set of blocks in the section, where the key is the block code and the value is the block object (detailed description). For favorite blocks, the key may contain the suffix |
Section Features:
lastcontains blocks that the user recently added in the editor. This section is filled only in edit mode. In a regular REST call, this section is usually not returned,favouritecontains favorite blocks and may be returned even with an emptyitems,- example of a separator:
separator_apps, - the composition of the section fields may vary. Sections from partner applications may lack
meta,type, andspecialType.
Block Object
|
Name |
Description |
|
Internal identifier of the block from the repository, if specified. For some blocks, the method will return |
|
|
name |
The name of the block |
|
namespace |
The namespace of the block |
|
new |
Indicates whether the block is new |
|
Minimum version of the product for which the block is designed, if specified. If no restriction is specified, the method will return |
|
|
type |
List of site types for which the block is available. An empty array means that no specific restriction by site type is set for the block. For rules on selecting the site type, refer to the article Working with Site Types and Scopes |
|
The code of the section or a list of section codes in which the block is displayed. Usually, an array of codes is returned in the response, for example |
|
|
system |
Indicates whether the block is a system block used internally by the platform — not intended for user addition to the page. Such blocks are not included in the method's response by default |
|
A brief description of the block. The field may be an empty string or |
|
|
preview |
The path or URL of the preview image. For standard blocks, a URL without specifying the protocol may be returned, such as |
|
restricted |
Indicates additional restrictions on the block |
|
Identifier of the partner block from the application repository or |
|
|
The application code to which the block belongs, or |
|
|
only_for_license |
The license code for which the block is available, if specified. If the field is filled, the value corresponds to the current license of the account. Blocks for other licenses do not appear in the response |
|
app_expired |
Indicates whether the subscription for the application to which the block belongs has expired. This field is present only for partner blocks with an expired subscription |
|
requires_updates |
Indicates whether a newer version of the product is required for the block to function correctly |
|
favorite |
Additional flag for favorite blocks |
|
favoriteMy |
Additional flag for favorite blocks indicating that the block is saved by the current user |
The composition of the block fields may vary for standard, partner, and favorite blocks. The method returns only those fields that are present for a specific block.
Error Handling
HTTP Status: 400
{
"error": "ACCESS_DENIED",
"error_description": "Insufficient permissions."
}
|
Name |
Description |
|
error |
String error code. It may consist of digits, Latin letters, and underscores |
|
error_description |
Textual description of the error. The description is not intended to be shown to the end user in its raw form |
Possible Error Codes
|
Code |
Description |
|
|
The user does not have access to the "Sites and Stores" section |
Statuses and System Error Codes
HTTP Status: 20x, 40x, 50x
The errors described below may occur when calling any method.
|
Status |
Code |
Description |
|
|
|
An internal server error has occurred. Please contact the server administrator or Bitrix24 technical support |
|
|
|
An internal server error has occurred. Please contact the server administrator or Bitrix24 technical support |
|
|
|
The request intensity limit has been exceeded |
|
|
|
The current method is not permitted for calls using batch |
|
|
|
The maximum length of parameters passed to the batch method has been exceeded |
|
|
|
Invalid access token or webhook code |
|
|
|
The HTTPS protocol is required for method calls |
|
|
|
The REST API is blocked due to overload. This is a manual individual block; please contact Bitrix24 technical support to lift it |
|
|
|
The REST API is only available on commercial plans |
|
|
|
The user associated with the access token or webhook used to call the method lacks the necessary permissions |
|
|
|
The manifest is not available |
|
|
|
The request requires higher privileges than those provided by the webhook token |
|
|
|
The provided access token has expired |
|
|
|
The user does not have access to the application. This means that the application is installed, but the portal administrator has restricted access to this application to specific users only |
|
|
|
The public part of the site is closed. To open the public part of the site on an on-premise installation, disable the "Temporary closure of the public part of the site" option. Path to the setting: Desktop > Settings > Product Settings > Module Settings > Main Module > Temporary closure of the public part of the site |
Continue Learning
- Get Block Content from Repository landing.block.getContentFromRepository
- Get the Manifest of the `landing.block.getmanifest` Method
- Get the Manifest File of the Block landing.block.getmanifestfile