Add Address crm.address.add
Scope:
crmWho can execute the method: any user
This method adds a new address for a requisite or lead. For the user, this address appears as the address of a contact, company, or lead.
Multiple addresses of different types can be created, linked to a single requisite.
Method Parameters
Required parameters are marked with *
|
Name |
Description |
|
fields* |
A set of fields — an object of the form |
Parameter fields
Required parameters are marked with *
|
Name |
Description |
|
TYPE_ID* |
Identifier of the address type. Enumeration element "Address Type". Elements of the enumeration "Address Type" can be obtained using the method crm.enum.addresstype |
|
ENTITY_TYPE_ID* |
Identifier of the parent object's type. Identifiers of object types can be obtained using the method crm.enum.ownertype. Addresses can only be linked to Requisites (and requisites are linked to companies or contacts) or Leads. For backward compatibility, the ability to link Addresses with Contacts or Companies is retained. However, this linkage is only possible on some older accounts where the old address handling mode was specifically enabled by technical support. |
|
ENTITY_ID* |
|
|
ADDRESS_1 |
Street, house, building, structure |
|
ADDRESS_2 |
Apartment / office |
|
CITY |
City |
|
POSTAL_CODE |
Postal code |
|
REGION |
District |
|
PROVINCE |
State |
|
COUNTRY |
Country |
|
COUNTRY_CODE |
Country code. Not used, retained for backward compatibility. An empty string can be specified as a value. |
|
LOC_ADDR_ID |
Identifier of the location address. This field contains the identifier of the address object in the If the identifier of the If at least one string field is specified, only the specified fields will be saved in the CRM address, and their values will overwrite the corresponding values in the location address object. The same behavior will occur when updating the address. |
Code Examples
How to Use Examples in Documentation
curl -X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{"fields":{"TYPE_ID":1,"ENTITY_TYPE_ID":8,"ENTITY_ID":1,"ADDRESS_1":"4 Peace Avenue","ADDRESS_2":"Drama Theater","CITY":"City","POSTAL_CODE":"000000","REGION":"Urban District","PROVINCE":"Region","COUNTRY":"USA"}}' \
https://**put_your_bitrix24_address**/rest/**put_your_user_id_here**/**put_your_webhook_here**/crm.address.add
curl -X POST \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d '{"fields":{"TYPE_ID":1,"ENTITY_TYPE_ID":8,"ENTITY_ID":1,"ADDRESS_1":"4 Peace Avenue","ADDRESS_2":"Drama Theater","CITY":"City","POSTAL_CODE":"000000","REGION":"Urban District","PROVINCE":"Region","COUNTRY":"USA"},"auth":"**put_access_token_here**"}' \
https://**put_your_bitrix24_address**/rest/crm.address.add
try
{
const response = await $b24.callMethod(
"crm.address.add",
{
fields:
{
"TYPE_ID": 1, // Address type, see crm.enum.addresstype
"ENTITY_TYPE_ID": 8, // Object type (requisite or lead)
"ENTITY_ID": 1, // Identifier of the requisite
"ADDRESS_1": "4 Peace Avenue",
"ADDRESS_2": "Drama Theater",
"CITY": "City",
"POSTAL_CODE": "00000",
"REGION": "Urban District",
"PROVINCE": "Region",
"COUNTRY": "USA",
}
}
);
const result = response.getData().result;
if(result.error())
console.error(result.error());
}
catch(error)
{
console.error(error);
}
try {
$response = $b24Service
->core
->call(
'crm.address.add',
[
'fields' => [
'TYPE_ID' => 1,
'ENTITY_TYPE_ID' => 8,
'ENTITY_ID' => 1,
'ADDRESS_1' => '4 Peace Avenue',
'ADDRESS_2' => 'Drama Theater',
'CITY' => 'City',
'POSTAL_CODE' => '00000',
'REGION' => 'Urban District',
'PROVINCE' => 'Region',
'COUNTRY' => 'USA',
],
]
);
$result = $response
->getResponseData()
->getResult();
} catch (Throwable $e) {
error_log($e->getMessage());
echo 'Error adding address: ' . $e->getMessage();
}
BX24.callMethod(
"crm.address.add",
{
fields:
{
"TYPE_ID": 1, // Address type, see crm.enum.addresstype
"ENTITY_TYPE_ID": 8, // Object type (requisite or lead)
"ENTITY_ID": 1, // Identifier of the requisite
"ADDRESS_1": "4 Peace Avenue",
"ADDRESS_2": "Drama Theater",
"CITY": "City",
"POSTAL_CODE": "00000",
"REGION": "Urban District",
"PROVINCE": "Region",
"COUNTRY": "USA",
}
},
function(result)
{
if(result.error())
console.error(result.error());
}
);
require_once('crest.php');
$result = CRest::call(
'crm.address.add',
[
'fields' => [
'TYPE_ID' => 1,
'ENTITY_TYPE_ID' => 8,
'ENTITY_ID' => 1,
'ADDRESS_1' => '4 Peace Avenue',
'ADDRESS_2' => 'Drama Theater',
'CITY' => 'City',
'POSTAL_CODE' => '00000',
'REGION' => 'Urban District',
'PROVINCE' => 'Region',
'COUNTRY' => 'USA',
]
]
);
echo '<PRE>';
print_r($result);
echo '</PRE>';
Response Handling
HTTP status: 200
{
"result": true,
"time": {
"start": 1712922620.724857,
"finish": 1712922623.393783,
"duration": 2.6689260005950928,
"processing": 2.210068941116333,
"date_start": "2024-04-12T14:50:20+02:00",
"date_finish": "2024-04-12T14:50:23+02:00"
}
}
Returned Data
|
Name |
Description |
|
result |
Result of adding the address:
|
|
time |
Information about the request execution time |
Error Handling
HTTP status: 40x, 50x
{
"error": "",
"error_description": "ENTITY_ID is not defined or invalid."
}
|
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 |
|
|
Address type identifier is not specified or has an invalid value |
|
|
Parent object type identifier is not specified or has an invalid value. |
|
|
Parent object identifier is not specified or has an invalid value |
|
|
An address of this type already exists for the specified parent object |
|
|
Insufficient access permissions to add the address |
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 Address for crm.address.update
- Get a List of Addresses by Filter crm.address.list
- Delete address crm.address.delete
- Get Description of Address Fields crm.address.fields
- Add a Company with Details via Web Form
- Add a contact with details via a web form
- Add a deal and company with requisites