Los endpoints de las propiedades del CRM te permiten administrar propiedades personalizadas, así como ver los detalles de las propiedades predeterminadas de cualquier objeto.
type
y un conjunto de propiedades properties
. Cada tipo tiene un conjunto único de propiedades estándar, representado por un mapa de pares nombre-valor.
Encuentra más información sobre las propiedades predeterminadas para diferentes objetos:
type
y fieldType
son obligatorios. El valor type
determina el tipo de propiedad, es decir, indica si es una cadena de texto o un número. La propiedad fieldType
determina cómo aparecerá la propiedad en HubSpot o en un formulario, es decir, si aparecerá como un campo de texto sin formato, un menú desplegable o un selector de fechas.
En la siguiente tabla encontrarás información sobre los valores type
disponibles para las propiedades y los valores de fieldType
correspondientes.
type | Descripción | Valores válidos de fieldType |
---|---|---|
bool | Un campo que contiene opciones binarias (por ejemplo, Yes o No , True o False ). | booleancheckbox , calculation_equation |
enumeration | Una cadena que representa un conjunto de opciones que están separadas por un punto y coma. | booleancheckbox , checkbox , radio , select , calculation_equation |
date | Un valor que representa un día, mes y año específicos. Los valores deben estar en la zona horaria UTC y el formato puede ser una cadena en notación ISO 8601 o una marca de tiempo EPOCH en milisegundos (es decir, la media noche en la zona horaria UTC). | date |
datetime | Un valor que representa un día, mes, año y hora específicos del día. Los valores deben estar en la zona horaria UTC y el formato puede ser una cadena en notación ISO 8601 o una marca de tiempo EPOCH en milisegundos. | date |
string | Una cadena de texto sin formato, limitada a 65.536 caracteres. | file , text , textarea , calculation_equation , html , phonenumber |
number | Un valor numérico que contiene dígitos y, como máximo, un decimal. | number , calculation_equation |
object_coordinates | Un valor textual utilizado para hacer referencia a otros objetos de HubSpot y que se utiliza solo para propiedades internas. Las propiedades de este tipo no se pueden crear ni editar, y no son visibles en HubSpot. | text |
json | Un valor textual almacenado en formato JSON que se utiliza solo para propiedades internas. Las propiedades de este tipo no se pueden crear ni editar, y no son visibles en HubSpot. | text |
fieldType
incluyen:
Fieldtype | Descripción |
---|---|
booleancheckbox | El input que permitirá a los usuarios seleccionar “sí” o “no”. Cuando se usa en un formulario, se mostrará como una única casilla de comprobación. Descubre cómo agregar un valor a las propiedades de casilla de comprobación única. |
calculation_equation | Una ecuación personalizada que puede calcular valores basados en otros valores y asociaciones de las propiedades. Más información sobre cómo definir propiedades de cálculo. |
checkbox | Una lista de casillas de verificación que permitirán al usuario seleccionar varias opciones de un conjunto de opciones permitidas para la propiedad. Descubre cómo dar formato a los valores al actualizar propiedades con múltiples casillas de comprobación. |
date | Un valor de fecha, que se muestra como un selector de fechas. |
file | Permite subir un archivo en un registro o a través de un formulario. Almacena un ID de archivo. |
html | Una cadena, renderizada como HTML desinfectado, que permite el uso de un editor de texto enriquecido para la propiedad. |
number | Una cadena de numerales o números escritos en notación decimal o científica. |
phonenumber | Una cadena de texto sin formato que se muestra en forma de número de teléfono. |
radio | Input que permitirá a los usuarios seleccionar una opción de un conjunto de opciones permitidas para la propiedad. Si se utiliza en un formulario, se mostrará como un conjunto de botones de selección. |
select | Input en forma de desplegable que permiten a los usuarios seleccionar una opción de un conjunto de opciones permitidas para la propiedad. |
text | Una cadena de texto sin formato que se muestra como un input de texto de una sola línea. |
textarea | Una cadena de texto sin formato, que se muestra como un input de texto de varias líneas. |
POST
a /crm/v3/properties/{objectType}
. Incluye los siguientes campos obligatorios en el cuerpo de la solicitud:
groupName
: el grupo de propiedades en el que estará la propiedad.name
: el nombre interno de la propiedad (por ejemplo, favorite_food).label
: el nombre de la propiedad tal como aparece en HubSpot (por ejemplo, comida favorita).type
: el tipo de propiedad.fieldType
: el tipo de campo de la propiedad.hs_object_id
) que debe ser tratado como una cadena de texto. Estos ID solo son únicos dentro de ese tipo de objeto, por lo que puede haber un contacto y una empresa con el mismo ID. Para los contactos y las empresas, hay identificadores únicos adicionales, entre ellos, la dirección de correo electrónico de un contacto (email
) y el nombre de dominio de una empresa (domain
).
En algunos casos, puede que quieras crear tu propia propiedad de identificador único, de forma que no haya la posibilidad de introducir el mismo valor para varios registros. Puedes tener hasta diez propiedades de ID único por objeto. Para crear una propiedad que requiera valores únicos a través de la API:
POST
a /crm/v3/properties/{objectType}
.hasUniqueValue
, establece el valor como true
.abc
para la propiedad system_a_unique
, la URL de la solicitud sería: /crm/v3/objects/deals/abc?idProperty=system_a_unique
.
Luego puedes usar este valor de propiedad de identificador único para encontrar y actualizar registros específicos de la misma manera en que podrías usar hs_object_id
, email
(contactos) o domain
(empresas).
calculation_equation
y un tipo de valor number
, bool
, string
o enumeration
.
Puedes definir la fórmula para calcular la propiedad con el campo calculationFormula
.
calculationFormula
, puedes escribir una fórmula usando operadores aritméticos, operadores de comparación, operadores lógicos, sentencias condicionales y otras funciones.
'constant'
) o comillas dobles ("constant"
).1005
y 1.5589
son números constantes válidos.true
o false
.string
. Por ejemplo, string(var1)
se interpretará como el valor de la propiedad de cadena var1.var1
se interpretará como el valor de la propiedad numérica var1.bool
. Por ejemplo, el identificador bool(var1)
se interpretará como el valor de la propiedad booleana var1.If A ThEn B
es exactamente igual que if a then b
pero 'a'
no es lo mismo que 'A'
. Los espacios, las tabulaciones y las nuevas líneas se utilizan para la tokenización, pero se ignoran.Operador | Descripción | Ejemplos |
---|---|---|
+ | Agrega números o cadenas. | property1 + 100 |
- | Resta números. | property1 + 100 - property2 |
* | Multiplica números. | 10property1 = 10 * property1 |
/ | Dividir números. | property1 * (100 - property2/(50 - property3)) |
< | Comprueba si un valor es menor que otro, Y funciona con propiedades numéricas o constantes. | a < 100 |
> | Comprueba si un valor es mayor que otro, Y funciona con propiedades numéricas o constantes. | a > 50 |
<= | Comprueba si un valor es menor o igual que otro, Y funciona con propiedades numéricas o constantes. | a <= b |
>= | Comprueba si un valor es mayor o igual que otro, Y funciona con propiedades numéricas o constantes. | b>= c |
= | Comprueba si un valor es igual a otro, Y funciona tanto con números como con cadenas. | (a + b - 100c * 150.652) = 150-230b |
equals | Comprueba si un valor es igual a otro, Y funciona tanto con números como con cadenas. | a + b - 100.2c * 150 equals 150 - 230 |
!= | Comprueba si un valor no es igual a otro, Y funciona tanto con números como con cadenas. | string(property1) != 'test_string' |
or | Comprueba si cualquiera o los dos valores es verdadero. | a > b or b <= c |
and | Comprueba si ambos valores son verdaderos. | bool(a) and bool(c) |
not | Comprueba si ninguno de los valores es verdadero. | not (bool(a) and bool(c)) |
Función | Descripción | Ejemplos |
---|---|---|
max | Tendrá entre 2 y 100 números, y la respuesta será el número máximo de todas las entradas. | max(a, b, c, 100) o max(a, b) |
min | Tendrá entre 2 y 100 números, y la respuesta será el número mínimo de todas las entradas. | min(a, b, c, 100) o min(a, b) |
is_present | Evalúa si se puede evaluar una expresión | is_present(bool(a)) = true si la propiedad es booleana, pero is_present(bool(a)) = false si la propiedad está vacía o no es booleana. |
contains | Tiene dos cadenas y la respuesta será “true” si la primera entrada contiene la segunda. | contains('hello', 'ello') = true y contains('ello', 'hello') = false. |
concatenate | Se une a una lista de cadenas. La lista de entradas puede ir de 2 a 100. | concatenate('a', 'b', string(a), string(b)) |
number_to_string
: intenta convertir la expresión del número de entrada en una cadena.string_to_number
: intenta convertir la expresión de la cadena de entrada en un número."Number of cars: " + num_cars
no es una propiedad válida porque no puedes agregar una cadena con un número, pero "Number of cars: " + number_to_string(num_cars)
lo es.
if
, elseif
, endif
y else
.
Por ejemplo, una sentencia condicional podría parecerse a lo siguiente: if boolean_expression then statement [elseif expression then statement]* [else statement | endif]
donde los corchetes [a]
indican que “a” es opcional, a|b
indica que pueden ser “a” o “b”, y *
significa 0 o más. endif
se puede usar para terminar una sentencia condicional de manera anticipada para garantizar que el analizador sintáctico (parser) pueda identificar a qué if
pertenece el siguiente elseif
.
GET
a crm/v3/properties/{object}/{propertyName}
. Por ejemplo, para encontrar la propiedad favorite_food
, la URL de la solicitud sería /crm/v3/properties/contacts/favorite_food
GET
a /crm/v3/properties/{objectType}
.dataSensitivity
con el valor sensitive
. Encuentra más información sobre la gestión de datos sensibles mediante API (BETA, Enterprise solamente).PATCH
a crm/v3/objects/{objectType}/{recordId}
. En el cuerpo de tu solicitud, incluye las propiedades y sus valores en una matriz. Más información sobre la actualización de registros a través de las API de objetos.
2020-02-29
)2020-02-29T03:30:17.000Z
). La hora está en la zona horaria UTC, por lo que los valores siempre usarán el designador UTC “Z”.”1427997766000
se traduce al 02 de abril de 2015 a las 18:02:46 UTC o al 2 de abril de 2015 a las 2:02:46 p. m. EDT (horario de verano del este).date
y datetime
) que también afectan el formato de los valores:
date
almacena la fecha, no la hora. La propiedad date
muestra la fecha en la que están configuradas, independientemente de la configuración de zona horaria de la cuenta o del usuario. Para los valores de la propiedad date
, se recomienda utilizar el formato de fecha completa ISO 8601. Si utilizas el formato de marca de tiempo UNIX, debes utilizar una marca de tiempo EPOCH en milisegundos (es decir, el valor debe establecido en la medianoche de la zona UTC para la fecha). Por ejemplo, el 1 de mayo de 2015 se puede representar así en cualquiera de los dos formatos:
datetime
almacena tanto la fecha como la hora. Se aceptará cualquiera de estos formatos de marca de tiempo. En HubSpot, las propiedades datetime
se muestran con base en la zona horaria del usuario que ve el registro, por lo que el valor se convertirá a la zona horaria local del usuario.true
. Para que aparezca como No o sin marcar en HubSpot, el valor debe ser false
.DECISION_MAKER
para la propiedad hs_buying_role
. Para agregar más valores sin sustituir el valor existente, la solicitud debería ser así:id
del propietario del usuario, que puedes encontrar en la configuración de propiedades o a través de la API de propietarios. Por ejemplo, para asignar un usuario como propietario de un contacto, envía una solicitud PATCH
a crm/v3/objects/contacts/{contactId}
, con el cuerpo { "properties":{ "hubspot_owner_id": "41629779"}}
.
firstname
de un objeto de contacto, envía una solicitud PATCH
a /crm/v3/objects/contacts/{contactId}
con el cuerpo { "properties": { "firstname": ""}}
.