Изменить существующее пользовательское поле контактов crm.contact.userfield.update
Scope:
crmКто может выполнять метод: администратор
Метод crm.contact.userfield.update обновляет существующее пользовательское поле контактов.
Параметры метода
Обязательные параметры отмечены *
|
Название |
Описание |
|
id* |
Идентификатор пользовательского поля. Идентификатор можно получить с помощью методов |
|
fields* |
Объект формата:
где:
Список доступных полей описан ниже. Некорректное поле в В |
Параметр fields
|
Параметр |
Описание |
|
MANDATORY |
Является ли поле обязательным. Возможные значения:
|
|
SHOW_FILTER |
Показывать ли поле в фильтре. Возможные значения:
|
|
XML_ID |
Внешний код |
|
SETTINGS |
Дополнительные параметры поля. Для каждого типа поля ( Поле перезаписывает лишь переданные значения |
|
LIST |
Список возможных значений для пользовательского поля типа |
|
SORT |
Индекс сортировки. Обязательно больше нуля |
|
SHOW_IN_LIST |
Показывать ли пользовательское поле в списке. Данный параметр ни на что не влияет в рамках Возможные значения:
|
|
EDIT_IN_LIST |
Разрешать ли редактирование пользователем. Возможные значения:
|
|
IS_SEARCHABLE |
Участвуют ли значения поля в поиске. Данный параметр ни на что не влияет в рамках Возможные значения:
|
|
Подпись фильтра в списке. При передаче строки она устанавливается для каждого языка. Для языков, у которых явно не указано значение, будет записано Поле полностью перезаписывает предыдущее значение |
|
|
Заголовок в списке. При передаче строки она устанавливается для каждого языка. Для языков, у которых явно не указано значение, будет записано Поле полностью перезаписывает предыдущее значение |
|
|
Подпись в форме редактирования. При передаче строки она устанавливается для каждого языка. Для языков, у которых явно не указано значение, будет записано Поле полностью перезаписывает предыдущее значение |
|
|
Сообщение об ошибке. При передаче строки она устанавливается для каждого языка. Для языков, у которых явно не указано значение, будет записано Поле полностью перезаписывает предыдущее значение |
|
|
Помощь. При передаче строки она устанавливается для каждого языка. Для языков, у которых явно не указано значение, будет записано Поле полностью перезаписывает предыдущее значение |
Параметр SETTINGS
У каждого типа пользовательских полей существует свой набор дополнительных настроек. Данный метод поддерживает изменение лишь тех, что описаны ниже.
|
Название |
Описание |
|
DEFAULT_VALUE |
Значение по умолчанию |
|
ROWS |
Количество строк в поле ввода. Обязательно больше 0 и меньше 50. Если передавать значение <= 0, то выставится значение Если передавать значение >= 50, то выставиться значение |
|
Название |
Описание |
|
DEFAULT_VALUE |
Значение по умолчанию |
|
Название |
Описание |
|
DEFAULT_VALUE |
Значение по умолчанию |
|
PRECISION |
Точность числа. Обязательно больше или равно 0. Если передавать невалидное значение, выставится значение |
|
Название |
Описание |
|
DEFAULT_VALUE |
Значение по умолчанию, где При передаче значения выставится значение по правилу:
|
|
DISPLAY |
Внешний вид. Возможные значения:
|
|
Название |
Описание |
|
DEFAULT_VALUE |
Значение по умолчанию. Объект формата:
где
При передаче невалидного значения выставиться:
|
|
Название |
Описание |
|
DISPLAY |
Внешний вид. Возможные значения:
|
|
LIST_HEIGHT |
Высота списка. Обязано быть больше 0 |
|
Название |
Описание |
|
IBLOCK_TYPE_ID |
Идентификатор типа инфоблока |
|
IBLOCK_ID |
Идентификатор инфоблока |
|
DEFAULT_VALUE |
Значение по умолчанию |
|
DISPLAY |
Внешний вид. Возможные значения:
|
|
LIST_HEIGHT |
Высота списка. Обязательно больше 0 |
|
ACTIVE_FILTER |
Показывать ли элементы с включенным флагом активности. Возможные значения:
|
|
Название |
Описание |
|
ENTITY_TYPE |
Идентификатор типа справочника. Используйте |
Если не передать ни одну из следующих опций, то по умолчанию будет включена привязка к лидам (LEAD = Y)
|
Название |
Описание |
|
LEAD |
Включена ли привязка к Лидам. Возможные значения:
|
|
CONTACT |
Включена ли привязка к Контактам. Возможные значения:
|
|
COMPANY |
Включена ли привязка к Компаниям. Возможные значения:
|
|
DEAL |
Включена ли привязка к Сделкам. Возможные значения:
|
Тип uf_enum_element
|
Название |
Описание |
|
ID |
Идентификатор элемента списка. При передаче данного параметра будет изменен соответствующий элемент списка, иначе будет добавлен новый элемент списка. Идентификатор можно узнать с помощью метода |
|
DEL |
Флаг, необходимый для удаления элемента списка. Имеет смысл лишь при передаче Возможные значения: По умолчанию |
|
VALUE |
Значение элемента списка |
|
SORT |
Индекс сортировки. Обязательно больше или равно 0 |
|
DEF |
Является ли элемент списка значением по умолчанию. Возможные значения:
Для множественного поля допустимо несколько |
|
XML_ID |
Внешний код значения. Обязательно уникальный в рамках элементов списка пользовательского поля |
Примеры кода
Как использовать примеры в документации
Пример изменения пользовательского поля типа Строка
curl -X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{"id":536,"fields":{"MANDATORY":"N","SHOW_FILTER":"N","SETTINGS":{"DEFAULT_VALUE":"Привет, мир! Значение по умолчанию (изменено)","ROWS":10},"SORT":2000,"EDIT_IN_LIST":"N","LIST_FILTER_LABEL":"Привет, мир! Фильтр (изменено)","LIST_COLUMN_LABEL":{"en":"Hello, World! Column (changed)","ru":"Привет, мир! Колонка (изменено)","de":"Hallo, Welt! Spalte (geändert)"},"EDIT_FORM_LABEL":{"en":"Hello, World! Edit (changed)","ru":"Привет, мир! Редактировать (изменено)","de":"Hallo, Welt! Bearbeiten (geändert)"},"ERROR_MESSAGE":{"en":"Hello, World! Error (changed)","ru":"Привет, мир! Ошибка (изменено)","de":"Hallo, Welt! Fehler (geändert)"},"HELP_MESSAGE":{"en":"Hello, World! Help (changed)","ru":"Привет, мир! Помощь (изменено)","de":"Hallo, Welt! Hilfe (geändert)"}}}' \
https://**put_your_bitrix24_address**/rest/**put_your_user_id_here**/**put_your_webhook_here**/crm.contact.userfield.update
curl -X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{"id":536,"fields":{"MANDATORY":"N","SHOW_FILTER":"N","SETTINGS":{"DEFAULT_VALUE":"Привет, мир! Значение по умолчанию (изменено)","ROWS":10},"SORT":2000,"EDIT_IN_LIST":"N","LIST_FILTER_LABEL":"Привет, мир! Фильтр (изменено)","LIST_COLUMN_LABEL":{"en":"Hello, World! Column (changed)","ru":"Привет, мир! Колонка (изменено)","de":"Hallo, Welt! Spalte (geändert)"},"EDIT_FORM_LABEL":{"en":"Hello, World! Edit (changed)","ru":"Привет, мир! Редактировать (изменено)","de":"Hallo, Welt! Bearbeiten (geändert)"},"ERROR_MESSAGE":{"en":"Hello, World! Error (changed)","ru":"Привет, мир! Ошибка (изменено)","de":"Hallo, Welt! Fehler (geändert)"},"HELP_MESSAGE":{"en":"Hello, World! Help (changed)","ru":"Привет, мир! Помощь (изменено)","de":"Hallo, Welt! Hilfe (geändert)"}}, "auth":"**put_access_token_here**"}' \
https://**put_your_bitrix24_address**/rest/crm.contact.userfield.update
BX24.callMethod(
'crm.contact.userfield.update',
{
id: 536,
fields: {
MANDATORY: "N",
SHOW_FILTER: "N",
SETTINGS: {
DEFAULT_VALUE: "Привет, мир! Значение по умолчанию (изменено)",
ROWS: 10,
},
SORT: 2000,
EDIT_IN_LIST: "N",
LIST_FILTER_LABEL: "Привет, мир! Фильтр (изменено)",
LIST_COLUMN_LABEL: {
"en": "Hello, World! Column (changed)",
"ru": "Привет, мир! Колонка (изменено)",
"de": "Hallo, Welt! Spalte (geändert)"
},
EDIT_FORM_LABEL: {
"en": "Hello, World! Edit (changed)",
"ru": "Привет, мир! Редактировать (изменено)",
"de": "Hallo, Welt! Bearbeiten (geändert)"
},
ERROR_MESSAGE: {
"en": "Hello, World! Error (changed)",
"ru": "Привет, мир! Ошибка (изменено)",
"de": "Hallo, Welt! Fehler (geändert)"
},
HELP_MESSAGE: {
"en": "Hello, World! Help (changed)",
"ru": "Привет, мир! Помощь (изменено)",
"de": "Hallo, Welt! Hilfe (geändert)"
},
},
},
(result) => {
result.error()
? console.error(result.error())
: console.info(result.data())
;
},
);
require_once('crest.php');
$result = CRest::call(
'crm.contact.userfield.update',
[
'id' => 536,
'fields' => [
'MANDATORY' => "N",
'SHOW_FILTER' => "N",
'SETTINGS' => [
'DEFAULT_VALUE' => "Привет, мир! Значение по умолчанию (изменено)",
'ROWS' => 10,
],
'SORT' => 2000,
'EDIT_IN_LIST' => "N",
'LIST_FILTER_LABEL' => "Привет, мир! Фильтр (изменено)",
'LIST_COLUMN_LABEL' => [
'en' => "Hello, World! Column (changed)",
'ru' => "Привет, мир! Колонка (изменено)",
'de' => "Hallo, Welt! Spalte (geändert)"
],
'EDIT_FORM_LABEL' => [
'en' => "Hello, World! Edit (changed)",
'ru' => "Привет, мир! Редактировать (изменено)",
'de' => "Hallo, Welt! Bearbeiten (geändert)"
],
'ERROR_MESSAGE' => [
'en' => "Hello, World! Error (changed)",
'ru' => "Привет, мир! Ошибка (изменено)",
'de' => "Hallo, Welt! Fehler (geändert)"
],
'HELP_MESSAGE' => [
'en' => "Hello, World! Help (changed)",
'ru' => "Привет, мир! Помощь (изменено)",
'de' => "Hallo, Welt! Hilfe (geändert)"
],
]
]
);
echo '<PRE>';
print_r($result);
echo '</PRE>';
try {
$contactUserfieldItemId = 123; // Example ID
$userfieldFieldsToUpdate = [
'FIELD_NAME' => 'New Field Name',
'USER_TYPE_ID' => 'string',
'SORT' => '100',
'MULTIPLE' => 'N',
'MANDATORY' => 'N',
'SHOW_FILTER' => 'Y',
'SHOW_IN_LIST' => 'Y',
'EDIT_IN_LIST' => 'Y',
'IS_SEARCHABLE' => 'Y',
'EDIT_FORM_LABEL' => 'New Label',
'LIST_COLUMN_LABEL' => 'Column Label',
'LIST_FILTER_LABEL' => 'Filter Label',
'ERROR_MESSAGE' => 'Error Message',
'HELP_MESSAGE' => 'Help Message',
'LIST' => '',
'SETTINGS' => '',
];
$result = $serviceBuilder
->getCRMScope()
->contactUserfield()
->update($contactUserfieldItemId, $userfieldFieldsToUpdate);
if ($result->isSuccess()) {
print($result->getCoreResponse()->getResponseData()->getResult()[0]);
} else {
print("Update failed.");
}
} catch (Throwable $e) {
print("Error: " . $e->getMessage());
}
Пример изменения пользовательского поля типа Список
Текущие элементы списка:
[
{
"ID": "115",
"SORT": "100",
"VALUE": "Элемент списка #1",
"DEF": "Y",
"XML_ID": "XML_ID_1"
},
{
"ID": "116",
"SORT": "200",
"VALUE": "Элемент списка #2",
"DEF": "N",
"XML_ID": "XML_ID_2"
},
{
"ID": "117",
"SORT": "300",
"VALUE": "Элемент списка #3",
"DEF": "N",
"XML_ID": "XML_ID_3"
},
{
"ID": "118",
"SORT": "400",
"VALUE": "Элемент списка #4",
"DEF": "N",
"XML_ID": "XML_ID_4"
}
]
Изменить его следующим образом:
- удалить элементы списка с
ID = 115иID = 116 - изменить элемент списка с
ID = 117:VALUE: «Элемент списка #3» -> «Элемент списка #3 (изменено)»SORT: 300 -> 50
- добавить новый элемент списка «Элемент списка #5»
curl -X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{"fields":{"MANDATORY":"N","SHOW_FILTER":"Y","LIST":[{"ID":115,"DEL":"Y"},{"ID":116,"DEL":"Y"},{"ID":117,"VALUE":"Элемент списка #3 (изменено)","SORT":50},{"VALUE":"Элемент списка #5","XML_ID":"XML_ID_5","SORT":500}],"SETTINGS":{"DISPLAY":"DIALOG","LIST_HEIGHT":3},"SORT":1000}}' \
https://**put_your_bitrix24_address**/rest/**put_your_user_id_here**/**put_your_webhook_here**/crm.contact.userfield.update
curl -X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{"fields":{"MANDATORY":"N","SHOW_FILTER":"Y","LIST":[{"ID":115,"DEL":"Y"},{"ID":116,"DEL":"Y"},{"ID":117,"VALUE":"Элемент списка #3 (изменено)","SORT":50},{"VALUE":"Элемент списка #5","XML_ID":"XML_ID_5","SORT":500}],"SETTINGS":{"DISPLAY":"DIALOG","LIST_HEIGHT":3},"SORT":1000},"auth":"**put_access_token_here**"}' \
https://**put_your_bitrix24_address**/rest/crm.contact.userfield.update
BX24.callMethod(
'crm.contact.userfield.update',
{
fields: {
MANDATORY: "N",
SHOW_FILTER: "Y",
LIST: [
{
ID: 115,
DEL: "Y"
},
{
ID: 116,
DEL: "Y",
},
{
ID: 117,
VALUE: "Элемент списка #3 (изменено)",
SORT: 50,
},
{
VALUE: "Элемент списка #5",
XML_ID: "XML_ID_5",
SORT: 500,
},
],
SETTINGS: {
DISPLAY: "DIALOG",
LIST_HEIGHT: 3,
},
SORT: 1000,
},
},
(result) => {
result.error()
? console.error(result.error())
: console.info(result.data())
;
},
);
require_once('crest.php');
$result = CRest::call(
'crm.contact.userfield.update',
[
'fields' => [
'MANDATORY' => "N",
'SHOW_FILTER' => "Y",
'LIST' => [
[
'ID' => 115,
'DEL' => "Y"
],
[
'ID' => 116,
'DEL' => "Y",
],
[
'ID' => 117,
'VALUE' => "Элемент списка #3 (изменено)",
'SORT' => 50,
],
[
'VALUE' => "Элемент списка #5",
'XML_ID' => "XML_ID_5",
'SORT' => 500,
],
],
'SETTINGS' => [
'DISPLAY' => "DIALOG",
'LIST_HEIGHT' => 3,
],
'SORT' => 1000,
]
]
);
echo '<PRE>';
print_r($result);
echo '</PRE>';
Обработка ответа
HTTP-статус: 200
{
"result": true,
"time": {
"start": 1724419843.518672,
"finish": 1724419844.120328,
"duration": 0.6016559600830078,
"processing": 0.1907808780670166,
"date_start": "2024-08-23T15:30:43+02:00",
"date_finish": "2024-08-23T15:30:44+02:00",
"operating": 0
}
}
Возвращаемые данные
|
Название |
Описание |
|
result |
Корневой элемент ответа, содержит |
|
time |
Информация о времени выполнения запроса |
Обработка ошибок
HTTP-статус: 400
{
"error": "",
"error_description": "Access denied."
}
|
Название |
Описание |
|
error |
Строковый код ошибки. Может состоять из цифр, латинских букв и знака подчеркивания |
|
error_description |
Текстовое описание ошибки. Описание не предназначено для показа конечному пользователю в необработанном виде |
Возможные коды ошибок
|
Код |
Описание |
Значение |
|
|
|
Переданный |
|
|
|
Переданный |
|
|
|
Возникает в случаях, когда:
|
|
|
|
Пользовательского поля с переданным |
|
|
Элемент списка со значением XML_ID= |
Переданный |
Статусы и коды системных ошибок
HTTP-статус: 20x, 40x, 50x
Описанные ниже ошибки могут возникнуть при вызове любого метода
|
Статус |
Код |
Описание |
|
|
|
Возникла внутренняя ошибка сервера, обратитесь к администратору сервера или в техническую поддержку Битрикс24 |
|
|
|
Возникла внутренняя ошибка сервера, обратитесь к администратору сервера или в техническую поддержку Битрикс24 |
|
|
|
Превышен лимит на интенсивность запросов |
|
|
|
Текущий метод не разрешен для вызова с помощью batch |
|
|
|
Превышена максимальная длина параметров, переданных в метод batch |
|
|
|
Неверный access-токен или код вебхука |
|
|
|
Для вызовов методов требуется использовать протокол HTTPS |
|
|
|
REST API заблокирован из-за перегрузки. Это ручная индивидуальная блокировка, для снятия необходимо обращаться в техническую поддержку Битрикс24 |
|
|
|
REST API доступен только на коммерческих планах |
|
|
|
У пользователя, с чьим access-токеном или вебхуком был вызван метод, не хватает прав |
|
|
|
Манифест недоступен |
|
|
|
Запрос требует более высоких привилегий, чем предоставляет токен вебхука |
|
|
|
Предоставленный access-токен доступа истек |
|
|
|
Пользователь не имеет доступа к приложению. Это означает, что приложение установлено, но администратор портала разрешил доступ к этому приложению только конкретным пользователям |
|
|
|
Публичная часть сайта закрыта. Чтобы открыть публичную часть сайта на коробочной установке отключите опцию «Временное закрытие публичной части сайта». Путь к настройке: Рабочий стол > Настройки > Настройки продукта > Настройки модулей > Главный модуль > Временное закрытие публичной части сайта |
Продолжите изучение
- Создать пользовательское поле для контактов crm.contact.userfield.add
- Получить пользовательское поле контактов по Id crm.contact.userfield.get
- Получить список пользовательских полей контактов crm.contact.userfield.list
- Удалить пользовательское поле контактов crm.contact.userfield.delete