Get a List of Custom Fields for Companies crm.company.userfield.list
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:
crmWho can execute the method: a user with read access permission for companies
The method crm.company.userfield.list returns a list of custom fields for companies based on the filter.
Method Parameters
|
Name |
Description |
|
filter |
Object format:
All conditions for individual fields are combined using |
|
order |
Object format:
Available fields for sorting:
By default:
|
Available Fields for Filtering
|
Name |
Description |
|
ID |
Identifier of the custom field |
|
FIELD_NAME |
Code of the custom field |
|
USER_TYPE_ID |
Type of the custom field. Possible values:
|
|
XML_ID |
External code |
|
SORT |
Sorting index |
|
MULTIPLE |
Is the custom field multiple.
|
|
MANDATORY |
Is the custom field mandatory. Possible values:
|
|
SHOW_FILTER |
Show in the list filter. Possible values:
|
|
SHOW_IN_LIST |
Whether to show in the list. Possible values:
|
|
EDIT_IN_LIST |
Allow user editing? Possible values:
|
|
IS_SEARCHABLE |
Whether the field values participate in search. Possible values:
|
|
LANG |
Language identifier. When filtering by this parameter, a set of fields with values in the provided language will be returned:
|
Code Examples
How to Use Examples in Documentation
Get a list of custom fields that:
- are multiple,
- are mandatory,
- have custom field labels in German. By filtering with the
LANGparameter, we will additionally receive field names in the response.
curl -X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{"filter":{"MULTIPLE":"Y","MANDATORY":"Y","LANG":"de"},"order":{"USER_TYPE_ID":"ASC","SORT":"ASC"}}' \
https://**put_your_bitrix24_address**/rest/**put_your_user_id_here**/**put_your_webhook_here**/crm.company.userfield.list
curl -X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{"filter":{"MULTIPLE":"Y","MANDATORY":"Y","LANG":"de"},"order":{"USER_TYPE_ID":"ASC","SORT":"ASC"},"auth":"**put_access_token_here**"}' \
https://**put_your_bitrix24_address**/rest/crm.company.userfield.list
// This snippet is an ES module: top-level await requires type="module" or a bundler.
// $b24 is an already-initialized SDK instance (see the SDK "Get started" guide).
import { Text } from '@bitrix24/b24jssdk'
import type { B24Frame } from '@bitrix24/b24jssdk'
declare const $b24: B24Frame
// Shape of each userfield object returned in result[]
type CrmCompanyUserfieldListItem = {
ID: string
ENTITY_ID: string
FIELD_NAME: string
USER_TYPE_ID: string
XML_ID: string | null
SORT: string
MULTIPLE: string
MANDATORY: string
EDIT_FORM_LABEL: string
LIST_COLUMN_LABEL: string
}
try {
// crm.company.userfield.list returns a single page (max 50 records). For the whole result set
// use a list helper: $b24.actions.v2.callList.make() returns every record as one
// array, $b24.actions.v2.fetchList.make() yields them in chunks (async generator).
// NOTE: the list helpers do not accept `order` (it is excluded from their params, so
// passing it is a TS error) — keep this call.make + `start` variant when sort matters.
const response = await $b24.actions.v2.call.make<CrmCompanyUserfieldListItem[]>({
method: 'crm.company.userfield.list',
params: {
filter: {
MULTIPLE: 'Y',
MANDATORY: 'Y',
LANG: 'de',
},
order: {
USER_TYPE_ID: 'ASC',
SORT: 'ASC',
},
start: 0,
},
requestId: Text.getUuidRfc4122()
})
// The payload is available only on a successful response
if (!response.isSuccess) {
console.error(response.getErrorMessages().join('; '))
} else {
const result = response.getData()!.result
console.info('Userfields on this page:', result.length, result)
}
} catch (error) {
// Thrown on transport or SDK failures (AjaxError, SdkError, etc.)
console.error(error)
}
<!-- Load the SDK (UMD build); it is exposed as the global B24Js -->
<script src="https://unpkg.com/@bitrix24/b24jssdk@1/dist/umd/index.min.js"></script>
<script>
async function listCompanyUserfields() {
try {
// Initialize the SDK inside a Bitrix24 frame
const $b24 = await B24Js.initializeB24Frame()
// crm.company.userfield.list returns a single page (max 50 records). For the whole result set
// use a list helper: $b24.actions.v2.callList.make() returns every record as one
// array, $b24.actions.v2.fetchList.make() yields them in chunks (async generator).
// NOTE: the list helpers do not accept `order` (it is excluded from their params, so
// passing it is a TS error) — keep this call.make + `start` variant when sort matters.
const response = await $b24.actions.v2.call.make({
method: 'crm.company.userfield.list',
params: {
filter: {
MULTIPLE: 'Y',
MANDATORY: 'Y',
LANG: 'de',
},
order: {
USER_TYPE_ID: 'ASC',
SORT: 'ASC',
},
start: 0,
},
requestId: B24Js.Text.getUuidRfc4122()
})
// The payload is available only on a successful response
if (!response.isSuccess) {
console.error(response.getErrorMessages().join('; '))
return
}
const result = response.getData().result
console.info('Userfields on this page:', result.length, result)
} catch (error) {
// Thrown on transport or SDK failures (AjaxError, SdkError, etc.)
console.error(error)
}
}
document.addEventListener('DOMContentLoaded', listCompanyUserfields)
</script>
try {
$response = $b24Service
->core
->call(
'crm.company.userfield.list',
[
'filter' => [
'MULTIPLE' => 'Y',
'MANDATORY' => 'Y',
'LANG' => 'de',
],
'order' => [
'USER_TYPE_ID' => 'ASC',
'SORT' => 'ASC',
],
]
);
$result = $response
->getResponseData()
->getResult();
if ($result->error()) {
echo 'Error: ' . $result->error();
} else {
echo 'Data: ' . print_r($result->data(), true);
}
} catch (Throwable $e) {
error_log($e->getMessage());
echo 'Error fetching company user fields: ' . $e->getMessage();
}
Example
from b24pysdk.client import BaseClient
from b24pysdk.errors import BitrixAPIError, BitrixSDKException
client: BaseClient
try:
bitrix_response = client.crm.company.userfield.list(
filter={
"MULTIPLE": "Y",
"MANDATORY": "Y",
"LANG": "de",
},
order={
"USER_TYPE_ID": "ASC",
"SORT": "ASC",
},
).response
result = bitrix_response.result
print(result)
except BitrixAPIError as error:
print(
"Bitrix API Error",
f"error: {error.error}",
f"error_description: {error.error_description}",
sep="\n",
)
except BitrixSDKException as error:
print(f"Bitrix SDK Error: {error.message}")
except Exception as error:
print(f"Unexpected error: {error}")
Example as_list
from b24pysdk.client import BaseClient
from b24pysdk.errors import BitrixAPIError, BitrixSDKException
client: BaseClient
try:
bitrix_response = client.crm.company.userfield.list(
filter={
"MULTIPLE": "Y",
"MANDATORY": "Y",
"LANG": "de",
},
order={"ID": "ASC"},
).as_list().response
result = bitrix_response.result
for item in result:
print(item)
except BitrixAPIError as error:
print(
"Bitrix API Error",
f"error: {error.error}",
f"error_description: {error.error_description}",
sep="\n",
)
except BitrixSDKException as error:
print(f"Bitrix SDK Error: {error.message}")
except Exception as error:
print(f"Unexpected error: {error}")
Example as_list_fast
from b24pysdk.client import BaseClient
from b24pysdk.errors import BitrixAPIError, BitrixSDKException
client: BaseClient
try:
bitrix_response = client.crm.company.userfield.list(
filter={
"MULTIPLE": "Y",
"MANDATORY": "Y",
"LANG": "de",
},
order={"ID": "DESC"},
).as_list_fast(descending=True).response
result = bitrix_response.result
for item in result:
print(item)
except BitrixAPIError as error:
print(
"Bitrix API Error",
f"error: {error.error}",
f"error_description: {error.error_description}",
sep="\n",
)
except BitrixSDKException as error:
print(f"Bitrix SDK Error: {error.message}")
except Exception as error:
print(f"Unexpected error: {error}")
BX24.callMethod(
'crm.company.userfield.list',
{
filter: {
MULTIPLE: "Y",
MANDATORY: "Y",
LANG: "de",
},
order: {
USER_TYPE_ID: "ASC",
SORT: "ASC",
},
},
(result) => {
result.error()
? console.error(result.error())
: console.info(result.data())
;
},
);
require_once('crest.php');
$result = CRest::call(
'crm.company.userfield.list',
[
'filter' => [
'MULTIPLE' => "Y",
'MANDATORY' => "N",
'LANG' => "de",
],
'order' => [
'USER_TYPE_ID' => "ASC",
'SORT' => "ASC",
]
]
);
echo '<PRE>';
print_r($result);
echo '</PRE>';
Response Handling
HTTP status: 200
{
"result": [
{
"ID": "5815",
"ENTITY_ID": "CRM_COMPANY",
"FIELD_NAME": "UF_CRM_1713790573",
"USER_TYPE_ID": "crm_status",
"XML_ID": null,
"SORT": "100",
"MULTIPLE": "Y",
"MANDATORY": "N",
"SHOW_FILTER": "I",
"SHOW_IN_LIST": "Y",
"EDIT_IN_LIST": "Y",
"IS_SEARCHABLE": "N",
"SETTINGS": {
"ENTITY_TYPE": "INDUSTRY"
},
"EDIT_FORM_LABEL": "Directory",
"LIST_COLUMN_LABEL": "Directory",
"LIST_FILTER_LABEL": "Directory",
"ERROR_MESSAGE": null,
"HELP_MESSAGE": null
},
{
"ID": "6799",
"ENTITY_ID": "CRM_COMPANY",
"FIELD_NAME": "UF_CRM_1724077760",
"USER_TYPE_ID": "enumeration",
"XML_ID": null,
"SORT": "150",
"MULTIPLE": "Y",
"MANDATORY": "N",
"SHOW_FILTER": "E",
"SHOW_IN_LIST": "Y",
"EDIT_IN_LIST": "Y",
"IS_SEARCHABLE": "N",
"SETTINGS": {
"DISPLAY": "LIST",
"LIST_HEIGHT": 1,
"CAPTION_NO_VALUE": "",
"SHOW_NO_VALUE": "Y"
},
"EDIT_FORM_LABEL": "Radio",
"LIST_COLUMN_LABEL": "Radio",
"LIST_FILTER_LABEL": "Radio",
"ERROR_MESSAGE": null,
"HELP_MESSAGE": null,
"LIST": [
{
"ID": "3157",
"SORT": "10",
"VALUE": "Kids Radio",
"DEF": "N",
"XML_ID": "79b4c576f96e65eb40f390e45c0dc802"
},
{
"ID": "3159",
"SORT": "20",
"VALUE": "Chanson Radio",
"DEF": "N",
"XML_ID": "d3ffd89a825f218f5efd79dffd38fbbf"
},
{
"ID": "3161",
"SORT": "30",
"VALUE": "Love Radio",
"DEF": "N",
"XML_ID": "dff769fa19d7d7ce8d0677341d221161"
},
{
"ID": "3163",
"SORT": "40",
"VALUE": "Monte Carlo Radio",
"DEF": "N",
"XML_ID": "1f22e5c818ce336a42bd0ec94eb69b9e"
},
{
"ID": "3181",
"SORT": "130",
"VALUE": "DFM Yuryev-Polsky",
"DEF": "N",
"XML_ID": "fc1c5e6b4a9fd20b4749240b8dbac41a"
}
]
},
{
"ID": "6791",
"ENTITY_ID": "CRM_COMPANY",
"FIELD_NAME": "UF_CRM_1722578010",
"USER_TYPE_ID": "file",
"XML_ID": null,
"SORT": "150",
"MULTIPLE": "Y",
"MANDATORY": "N",
"SHOW_FILTER": "E",
"SHOW_IN_LIST": "Y",
"EDIT_IN_LIST": "Y",
"IS_SEARCHABLE": "N",
"SETTINGS": {
"SIZE": 20,
"LIST_WIDTH": 0,
"LIST_HEIGHT": 0,
"MAX_SHOW_SIZE": 0,
"MAX_ALLOWED_SIZE": 0,
"EXTENSIONS": [],
"TARGET_BLANK": "Y"
},
"EDIT_FORM_LABEL": "KP (files)",
"LIST_COLUMN_LABEL": "KP (files)",
"LIST_FILTER_LABEL": "KP (files)",
"ERROR_MESSAGE": null,
"HELP_MESSAGE": null
},
{
"ID": "5567",
"ENTITY_ID": "CRM_COMPANY",
"FIELD_NAME": "UF_CRM_1709565075",
"USER_TYPE_ID": "resourcebooking",
"XML_ID": null,
"SORT": "1",
"MULTIPLE": "Y",
"MANDATORY": "N",
"SHOW_FILTER": "N",
"SHOW_IN_LIST": "Y",
"EDIT_IN_LIST": "Y",
"IS_SEARCHABLE": "N",
"SETTINGS": {
"USE_USERS": "N",
"USE_RESOURCES": "Y",
"RESOURCES": {
"resource": {
"XML_ID": "resource",
"NAME": "resource",
"SECTIONS": [
{
"ID": "7",
"CAL_TYPE": "resource",
"NAME": "Museum Hall"
},
{
"ID": "49",
"CAL_TYPE": "resource",
"NAME": "resource 1"
},
{
"ID": "51",
"CAL_TYPE": "resource",
"NAME": "resource 2"
},
{
"ID": "53",
"CAL_TYPE": "resource",
"NAME": "1"
},
{
"ID": "57",
"CAL_TYPE": "resource",
"NAME": "Resource"
},
{
"ID": "59",
"CAL_TYPE": "resource",
"NAME": "Resource 2"
}
]
}
},
"SELECTED_RESOURCES": [
{
"type": "resource",
"id": "7",
"title": "Museum Hall"
}
],
"SELECTED_USERS": [],
"FULL_DAY": "N",
"ALLOW_OVERBOOKING": "Y",
"USE_SERVICES": "N",
"SERVICE_LIST": [
{
"name": "",
"duration": "60"
}
],
"RESOURCE_LIMIT": -1,
"TIMEZONE": "Europe/Berlin",
"USE_USER_TIMEZONE": "N"
},
"EDIT_FORM_LABEL": "BOOK MEETING",
"LIST_COLUMN_LABEL": "BOOK MEETING",
"LIST_FILTER_LABEL": "BOOK MEETING",
"ERROR_MESSAGE": null,
"HELP_MESSAGE": null
},
{
"ID": "6997",
"ENTITY_ID": "CRM_COMPANY",
"FIELD_NAME": "UF_CRM_HELLO_WORLD",
"USER_TYPE_ID": "string",
"XML_ID": null,
"SORT": "2000",
"MULTIPLE": "Y",
"MANDATORY": "N",
"SHOW_FILTER": "N",
"SHOW_IN_LIST": "Y",
"EDIT_IN_LIST": "N",
"IS_SEARCHABLE": "N",
"SETTINGS": {
"SIZE": 20,
"ROWS": 10,
"REGEXP": "",
"MIN_LENGTH": 0,
"MAX_LENGTH": 0,
"DEFAULT_VALUE": "Hello, world! Default value (changed)"
},
"EDIT_FORM_LABEL": "Hello, world! Edit (changed)",
"LIST_COLUMN_LABEL": "Hello, world! Column (changed)",
"LIST_FILTER_LABEL": "Hello, world! Filter (changed)",
"ERROR_MESSAGE": "Hello, world! Error (changed)",
"HELP_MESSAGE": "Hello, world! Help (changed)"
}
],
"total": 5,
"time": {
"start": 1753793143.219832,
"finish": 1753793143.529472,
"duration": 0.30964016914367676,
"processing": 0.06361007690429688,
"date_start": "2025-07-29T15:45:43+03:00",
"date_finish": "2025-07-29T15:45:43+03:00",
"operating_reset_at": 1753793743,
"operating": 0
}
}
Returned Data
|
Name |
Description |
|
result |
Root element of the response, contains a list of custom fields. The structure of an individual custom field depends on its type. The fields |
|
total |
Number of found custom fields |
|
time |
Information about the request execution time |
Error Handling
HTTP status: 400
{
"error": "",
"error_description": "Parameter 'filter' must be array."
}
|
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 |
Value |
|
|
Parameter 'order' must be array |
The provided |
|
|
Parameter 'filter' must be array |
The provided |