Create a Custom Field for Contacts crm.contact.userfield.add
Scope:
crmWho can execute the method: administrator
The method crm.contact.userfield.add creates a new custom field for contacts.
Method Parameters
Required parameters are marked with *
|
Name |
Description |
|
fields* |
Object format:
where:
The list of available fields is described below. An incorrect field in |
Parameter fields
Required parameters are marked with *
|
Name |
Description |
|
USER_TYPE_ID* |
The data type of the custom field. Possible values:
|
|
FIELD_NAME* |
Field code. Unique. The system limit for the field code is 20 characters. The prefix Allowed characters: |
|
LABEL |
Default name of the custom field. The provided value will be set in the following fields: |
|
XML_ID |
External code |
|
Filter label in the list. When a string is provided, it will be set for all language identifiers. When a By default, the value passed in |
|
|
Header in the list. When a string is provided, it will be set for all language identifiers. When a By default, the value passed in |
|
|
Label in the edit form. When a string is provided, it will be set for all language identifiers. When a By default, the value passed in |
|
|
Error message. When a string is provided, it will be set for all language identifiers. When a By default, the value passed in |
|
|
Help. When a string is provided, it will be set for all language identifiers. When a By default, the value passed in |
|
|
MULTIPLE |
Is the field multiple. Possible values:
Fields of type By default |
|
MANDATORY |
Is the field mandatory. Possible values:
By default |
|
SHOW_FILTER |
Show the field in the filter. Possible values:
By default |
|
SETTINGS |
Additional field parameters. Each field type ( |
|
LIST |
List of possible values for the custom field of type By default |
|
SORT |
Sort index. Must be greater than zero. By default |
|
SHOW_IN_LIST |
Show the custom field in the list. This parameter has no effect within Possible values:
By default |
|
EDIT_IN_LIST |
Allow user editing. Possible values:
By default |
|
IS_SEARCHABLE |
Are the field values included in the search. This parameter has no effect within Possible values:
By default |
Parameter SETTINGS
Each type of custom field has its own set of additional settings. This method only supports those described below.
|
Name |
Description |
|
DEFAULT_VALUE |
Default value. By default |
|
ROWS |
Number of rows in the input field. Must be greater than 0. By default |
|
Name |
Description |
|
DEFAULT_VALUE |
Default value |
|
Name |
Description |
|
DEFAULT_VALUE |
Default value |
|
PRECISION |
Number precision. Must be greater than or equal to 0. By default |
|
Name |
Description |
|
DEFAULT_VALUE |
Default value, where Possible values:
By default |
|
DISPLAY |
Appearance. Possible values:
By default |
|
Name |
Description |
|
DEFAULT_VALUE |
Default value. Object format:
where:
Default value:
|
|
Name |
Description |
|
DISPLAY |
Appearance. Possible values:
By default |
|
LIST_HEIGHT |
Height of the list. Must be greater than 0. Available only when By default |
|
Name |
Description |
|
IBLOCK_TYPE_ID |
Identifier of the information block type. By default |
|
IBLOCK_ID |
Identifier of the information block. By default |
|
DEFAULT_VALUE |
Default value. By default |
|
DISPLAY |
Appearance. Possible values:
By default |
|
LIST_HEIGHT |
Height of the list. Must be greater than 0. By default |
|
ACTIVE_FILTER |
Show elements with the active flag enabled. Possible values:
By default |
|
Name |
Description |
|
ENTITY_TYPE |
Identifier of the directory type. Use By default |
If none of the following options are provided, the link to leads will be enabled by default (LEAD = Y).
|
Name |
Description |
|
LEAD |
Is the link to Leads enabled. Possible values:
By default |
|
CONTACT |
Is the link to Contacts enabled. Possible values:
By default |
|
COMPANY |
Is the link to Companies enabled. Possible values:
By default |
|
DEAL |
Is the link to Deals enabled. Possible values:
By default |
Type uf_enum_element
|
Name |
Description |
|
VALUE |
Value of the list element. List elements with an empty or missing |
|
SORT |
Sort index. Must be greater than or equal to 0. By default |
|
DEF |
Is the list element the default value. Possible values:
For a multiple field, multiple By default |
|
XML_ID |
External code of the value. Must be unique within the list elements of the custom field |
Code Examples
How to Use Examples in Documentation
Example of Creating a String Type Custom Field
curl -X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{"fields":{"LABEL":"Field \'Hello, World!\'","USER_TYPE_ID":"string","FIELD_NAME":"HELLO_WORLD","MULTIPLE":"Y","MANDATORY":"Y","SHOW_FILTER":"Y","SETTINGS":{"DEFAULT_VALUE":"Hello, World! Default value","ROWS":3},"SORT":1000,"EDIT_IN_LIST":"Y","LIST_FILTER_LABEL":"Hello, World! Filter","LIST_COLUMN_LABEL":{"en":"Hello, World! Column","de":"Hallo, Welt! Spalte"},"EDIT_FORM_LABEL":{"en":"Hello, World! Edit","de":"Hallo, Welt! Bearbeiten"},"ERROR_MESSAGE":{"en":"Hello, World! Error","de":"Hallo, Welt! Fehler"},"HELP_MESSAGE":{"en":"Hello, World! Help","de":"Hallo, Welt! Hilfe"}}}' \
https://**put_your_bitrix24_address**/rest/**put_your_user_id_here**/**put_your_webhook_here**/crm.contact.userfield.add
curl -X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{"fields":{"LABEL":"Field \'Hello, World!\'","USER_TYPE_ID":"string","FIELD_NAME":"HELLO_WORLD","MULTIPLE":"Y","MANDATORY":"Y","SHOW_FILTER":"Y","SETTINGS":{"DEFAULT_VALUE":"Hello, World! Default value","ROWS":3},"SORT":1000,"EDIT_IN_LIST":"Y","LIST_FILTER_LABEL":"Hello, World! Filter","LIST_COLUMN_LABEL":{"en":"Hello, World! Column","de":"Hallo, Welt! Spalte"},"EDIT_FORM_LABEL":{"en":"Hello, World! Edit","de":"Hallo, Welt! Bearbeiten"},"ERROR_MESSAGE":{"en":"Hello, World! Error","de":"Hallo, Welt! Fehler"},"HELP_MESSAGE":{"en":"Hello, World! Help","de":"Hallo, Welt! Hilfe"}},"auth":"**put_access_token_here**"}' \
https://**put_your_bitrix24_address**/rest/crm.contact.userfield.add
BX24.callMethod(
'crm.contact.userfield.add',
{
fields: {
LABEL: "Field \'Hello, World!\'",
USER_TYPE_ID: "string",
FIELD_NAME: "HELLO_WORLD",
MULTIPLE: "Y",
MANDATORY: "Y",
SHOW_FILTER: "Y",
SETTINGS: {
DEFAULT_VALUE: "Hello, World! Default value",
ROWS: 3,
},
SORT: 1000,
EDIT_IN_LIST: "Y",
LIST_FILTER_LABEL: "Hello, World! Filter",
LIST_COLUMN_LABEL: {
"en": "Hello, World! Column",
"de": "Hallo, Welt! Spalte"
},
EDIT_FORM_LABEL: {
"en": "Hello, World! Edit",
"de": "Hallo, Welt! Bearbeiten"
},
ERROR_MESSAGE: {
"en": "Hello, World! Error",
"de": "Hallo, Welt! Fehler"
},
HELP_MESSAGE: {
"en": "Hello, World! Help",
"de": "Hallo, Welt! Hilfe"
},
},
},
(result) => {
result.error()
? console.error(result.error())
: console.info(result.data())
;
},
);
require_once('crest.php');
$result = CRest::call(
'crm.contact.userfield.add',
[
'fields' => [
'LABEL' => "Field 'Hello, World!'",
'USER_TYPE_ID' => "string",
'FIELD_NAME' => "HELLO_WORLD",
'MULTIPLE' => "Y",
'MANDATORY' => "Y",
'SHOW_FILTER' => "Y",
'SETTINGS' => [
'DEFAULT_VALUE' => "Hello, World! Default value",
'ROWS' => 3,
],
'SORT' => 1000,
'EDIT_IN_LIST' => "Y",
'LIST_FILTER_LABEL' => "Hello, World! Filter",
'LIST_COLUMN_LABEL' => [
'en' => "Hello, World! Column",
'de' => "Hallo, Welt! Spalte"
],
'EDIT_FORM_LABEL' => [
'en' => "Hello, World! Edit",
'de' => "Hallo, Welt! Bearbeiten"
],
'ERROR_MESSAGE' => [
'en' => "Hello, World! Error",
'de' => "Hallo, Welt! Fehler"
],
'HELP_MESSAGE' => [
'en' => "Hello, World! Help",
'de' => "Hallo, Welt! Hilfe"
],
]
]
);
echo '<PRE>';
print_r($result);
echo '</PRE>';
try {
$userfieldItemFields = [
'FIELD_NAME' => 'UF_CRM_example',
'USER_TYPE_ID' => 'string',
'XML_ID' => 'xml_example',
'SORT' => '100',
'MULTIPLE' => 'N',
'MANDATORY' => 'Y',
'SHOW_FILTER' => 'Y',
'SHOW_IN_LIST' => 'Y',
'EDIT_IN_LIST' => 'Y',
'IS_SEARCHABLE' => 'Y',
'EDIT_FORM_LABEL' => 'Example Field',
'LIST_COLUMN_LABEL' => 'Example Column',
'LIST_FILTER_LABEL' => 'Example Filter',
'ERROR_MESSAGE' => 'Error occurred',
'HELP_MESSAGE' => 'Help message',
'LIST' => 'list_value',
'SETTINGS' => 'settings_value',
];
$result = $serviceBuilder
->getCRMScope()
->contactUserfield()
->add($userfieldItemFields);
print($result->getId());
} catch (Throwable $e) {
print('Error: ' . $e->getMessage());
}
Example of Creating a List Type Custom Field
curl -X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{"fields":{"LABEL":"Custom Field (list)","USER_TYPE_ID":"enumeration","FIELD_NAME":"ENUMERATION_EXAMPLE","MULTIPLE":"N","MANDATORY":"N","SHOW_FILTER":"Y","LIST":[{"VALUE":"List Item #1","DEF":"Y","XML_ID":"XML_ID_1","SORT":100},{"VALUE":"List Item #2","XML_ID":"XML_ID_2","SORT":200},{"VALUE":"List Item #3","XML_ID":"XML_ID_3","SORT":300},{"VALUE":"List Item #4","XML_ID":"XML_ID_4","SORT":400}],"SETTINGS":{"DISPLAY":"UI","LIST_HEIGHT":2},"SORT":2000}}' \
https://**put_your_bitrix24_address**/rest/**put_your_user_id_here**/**put_your_webhook_here**/crm.contact.userfield.add
curl -X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{"fields":{"LABEL":"Custom Field (list)","USER_TYPE_ID":"enumeration","FIELD_NAME":"ENUMERATION_EXAMPLE","MULTIPLE":"N","MANDATORY":"N","SHOW_FILTER":"Y","LIST":[{"VALUE":"List Item #1","DEF":"Y","XML_ID":"XML_ID_1","SORT":100},{"VALUE":"List Item #2","XML_ID":"XML_ID_2","SORT":200},{"VALUE":"List Item #3","XML_ID":"XML_ID_3","SORT":300},{"VALUE":"List Item #4","XML_ID":"XML_ID_4","SORT":400}],"SETTINGS":{"DISPLAY":"UI","LIST_HEIGHT":2},"SORT":2000},"auth":"**put_access_token_here**"}' \
https://**put_your_bitrix24_address**/rest/crm.contact.userfield.add
BX24.callMethod(
'crm.contact.userfield.add',
{
fields: {
LABEL: "Custom Field (list)",
USER_TYPE_ID: "enumeration",
FIELD_NAME: "ENUMERATION_EXAMPLE",
MULTIPLE: "N",
MANDATORY: "N",
SHOW_FILTER: "Y",
LIST: [
{
VALUE: "List Item #1",
DEF: "Y",
XML_ID: "XML_ID_1",
SORT: 100,
},
{
VALUE: "List Item #2",
XML_ID: "XML_ID_2",
SORT: 200,
},
{
VALUE: "List Item #3",
XML_ID: "XML_ID_3",
SORT: 300,
},
{
VALUE: "List Item #4",
XML_ID: "XML_ID_4",
SORT: 400,
},
],
SETTINGS: {
DISPLAY: "UI",
LIST_HEIGHT: 2,
},
SORT: 2000,
},
},
(result) => {
result.error()
? console.error(result.error())
: console.info(result.data())
;
},
);
require_once('crest.php');
$result = CRest::call(
'crm.contact.userfield.add',
[
'fields' => [
'LABEL' => "Custom Field (list)",
'USER_TYPE_ID' => "enumeration",
'FIELD_NAME' => "ENUMERATION_EXAMPLE",
'MULTIPLE' => "N",
'MANDATORY' => "N",
'SHOW_FILTER' => "Y",
'LIST' => [
[
'VALUE' => "List Item #1",
'DEF' => "Y",
'XML_ID' => "XML_ID_1",
'SORT' => 100,
],
[
'VALUE' => "List Item #2",
'XML_ID' => "XML_ID_2",
'SORT' => 200,
],
[
'VALUE' => "List Item #3",
'XML_ID' => "XML_ID_3",
'SORT' => 300,
],
[
'VALUE' => "List Item #4",
'XML_ID' => "XML_ID_4",
'SORT' => 400,
],
],
'SETTINGS' => [
'DISPLAY' => "UI",
'LIST_HEIGHT' => 2,
],
'SORT' => 2000,
]
]
);
echo '<PRE>';
print_r($result);
echo '</PRE>';
Response Handling
HTTP status: 200
{
"result": 399,
"time": {
"start": 1724239307.903115,
"finish": 1724239308.567422,
"duration": 0.6643068790435791,
"processing": 0.20090818405151367,
"date_start": "2024-08-21T13:21:47+02:00",
"date_finish": "2024-08-21T13:21:48+02:00",
"operating": 0
}
}
Returned Data
|
Name |
Description |
|
result |
Root element of the response, contains the identifier of the created custom field |
|
time |
Information about the request execution time |
Error Handling
HTTP status: 400
This method may return errors not immediately, but by collecting several and concatenating them into a string: \n.
{
"error": "",
"error_description": "The 'USER_TYPE_ID' field is not found."
}
|
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
|
Description |
Value |
|
|
The user does not have administrative rights |
|
|
Either an empty |
|
Field name is too long (more than 50 characters) |
The provided |
|
Field name contains invalid characters. Allowed are: |
The provided |
|
|
Either an empty |
|
Invalid user type specified |
The provided |
|
List item with XML_ID= |
The provided |
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 allowed to be called using batch |
|
|
|
The maximum length of parameters passed to the batch method has been exceeded |
|
|
|
Invalid access token or webhook code |
|
|
|
The methods must be called using the HTTPS protocol |
|
|
|
The REST API is blocked due to overload. This is a manual individual block, to remove it you need to contact Bitrix24 technical support |
|
|
|
The REST API is available only on commercial plans |
|
|
|
The user whose access token or webhook was used to call the method lacks 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 account administrator has allowed access to this application only for specific users |
|
|
|
The public part of the site is closed. To open the public part of the site on an on-premise installation, disable the option "Temporary closure of the public part of the site". Path to the setting: Desktop > Settings > Product Settings > Module Settings > Main Module > Temporary closure of the public part of the site |
Continue Learning
- Update Existing Custom Contact Field crm.contact.userfield.update
- Get Custom Contact Field by Id crm.contact.userfield.get
- Get a list of custom fields for contacts crm.contact.userfield.list
- Delete Custom Contact Field crm.contact.userfield.delete