Entity History | Yext Hitchhikers Platform
Overview
Entity History displays the historical updates made to entities. The entity history can be accessed by navigating to Knowledge Graph > Configuration > Entity History in the Yext platform, or via the Logs API.
Below are the main differences between Entity History in the UI and via API:
UI | API | |
---|---|---|
Requires Developer App | No | Yes |
Includes Update Metadata (Event Type, Timestamp, Value (Rendered), etc.) | Yes | Yes |
Filterable | Yes (limited) | Yes |
Sortable by Timestamp | Yes | Yes |
View Previous Content for a Given Update | Yes | No |
Restore Field Values | Yes | No |
Returns Entity UID (Yext ID) | No | Yes |
Maximum Page Size (total records returned per request/page) | 100 | 1,000 |
See the
Events
and
Actors
sections for lists of the events and actors that can be displayed in Entity History.
Entity History UI
The Entity History page displays a table of past entity updates. By default, entity history is displayed by operation. You can toggle the table to view entity history by individual events.
Each row in the table corresponds to a single operation or event on a given entity.
View by Operation
These columns appear on the Operation view:
Column Name | Description |
---|---|
Time | The timestamp of the update. This column is sortable. |
Actor Type | The type of actor responsible for the event. See Actors for more information. |
Actor Details | Additional detail on the specific actor responsible for the event. See Actor Details for more information. |
Operation ID | Unique identifier for the operation responsible for the update (includes bulk updates). A single operation can contain multiple events. For example, if a user updates a field on an entity with three language profiles, this will appear in entity history as three separate rows (one for each language profile that was edited), but all three rows will have the same Operation ID. |
Entities | The number of entities the operation applied to. |
The table can be filtered by:
- Date
- Actor Type
Click on a given operation to view the operation details.
This will display additional information about the operation:
- Hero metrics: entities updated, created, and deleted; expanded actor details; fields updated
- A table of individual events in the operation
- Options to undo or reapply the operation (see Undo and Reapply Field Updates for more detail)
View by Event
These columns appear on the Event view:
Column Name | Description |
---|---|
Time | The timestamp of the update. This column is sortable. |
Entity | The entity that the event pertains to. This column displays a preview with an icon, name, and entity ID. |
Event Type | The type of update that took place. Event type descriptions can be found in the table below. |
Field | The field that was updated (if applicable). |
Actor Type | The type of actor responsible for the event. See Actors for more information. |
Actor Details | Additional detail on the specific actor responsible for the event. See Actor Details for more information. |
Language | The language profile that the update was made on. |
Operation ID | Unique identifier for the operation responsible for the update (includes bulk updates). A single operation can contain multiple events. For example, if a user updates a field on an entity with three language profiles, this will appear in entity history as three separate rows (one for each language profile that was edited), but all three rows will have the same Operation ID. |
Primary Profile | Optional - add this column by selecting it from the View dropdown menu. Displays a checkmark if the event took place on the entity’s primary profile. |
Profile ID | Optional - add this column by selecting it from the View dropdown menu. Displays the internal ID of the entity profile that the event took place on. Note that this is different from the Entity ID. |
The table can be filtered by:
- Entity
- Entity Type
- Actor Type
- Event Type
- Date
- Advanced: Operation ID, Field Content, Language, Field
Click on a given event to view the event details.
This will display additional information in a side panel about the event:
- Expanded information about the entity, event type, actor, language, and operation ID
- The previous and updated field values (for “field update” events). Toggle to view this as it appears in the UI or JSON.
Undo and Reapply Field Updates
In the Entity History UI, you can undo operations and events to restore field values on entities. You can also reapply the updates that were applied by a previous operation or event.
This applies only to Field Updated type events, and can only be done in the UI.
Undoing and reapplying updates is not supported for these cases:
- Any event type besides Field Updated (note that the
FIELD_UPDATED_INHERITED
event type is not supported for restoring field values) - Multiple changes on the same field for the same entity
- Newly created entities whose ID shows “Value Pending”
- Field values cannot be restored on the following fields:
- Country Code
- Coordinates (Display, Dropoff, Pickup, Routable, Walkable)
- Locale
- Any image fields
Operations can be undone or reapplied via the operation details page or by clicking the three-dot icon on a given operation.
Events can be undone or reapplied by clicking the three-dot icon on a given event.
See the Undo Changes to Entities guide for complete steps on restoring entity field values.
Entity History via API
Entity History can be accessed by querying the entityHistory
table in the POST query endpoint of the Logs API. Before doing this, you will need to configure an app in the Developer Console and set the Logs endpoint permissions to read-only.
To do this, follow the steps in the Create an App in the Developer Console guide.
For details on a sample request and payload, and a sample response, see the Logs API documentation.
Events
These are the types of events that can take place on entities, and how they appear in Entity History:
Event Type | Description |
---|---|
ENTITY_CREATED | The entity was created |
PROFILE_CREATED | A language profile was created for the entity |
FIELD_UPDATED | A field value was updated on the entity profile |
FIELD_UPDATED_INHERITED | The rendered value for a field was updated due to an update to the inherited field’s value. The raw value for the inheriting field was not updated. Updates that result in this event include: field value updates on an entity’s primary language profile carrying over to its alternate language profiles; source field value for an embedded field being updated |
PROFILE_HIERARCHY_UPDATED | The primary language profile on an entity was changed from one profile to another |
PROFILE_DELETED | A language profile was deleted |
ENTITY_DELETED | The entire entity was deleted |
Actors
An actor is the source responsible for an event in an entity’s history in Yext. In addition to the actor, Entity History includes actor details, which is further information about the exact source of the event. For example, an event could have happened due to a change made by a User (the actor), specifically via Entity Edit (the actor details).
An event in an entity’s history can be attributed to any of these actors:
- App
- Yext System
- Yext User
- Yext Account Team
- Connector
Most Yext System updates appear as a separate action triggered by a Yext User event. For example, if a user updates the Address field on an entity, the backend system would then need to geocode that new address. The update would then appear as two rows in Entity History (one with an actor of Yext User for the field edit in the UI, and one with an actor of Yext System for the geocoding).
Actor Details
An actor responsible for a particular event can be further specified by any of these actor details:
Actor Detail | Description |
---|---|
Entity Edit | Edits made to fields on an entity from the Entity Edit screen in the Yext UI |
Storm | Edits made directly in the Yext UI, outside of the Entity Edit screen |
Entity Upload | Edits made via the File Upload tool (under Knowledge Graph > Entities > Add Data > Entity Upload) |
API | Edits made via an API endpoint |
EnhancedLists | An edit made to an entity via Knowledge Graph > Menus (as opposed to on the entity itself) |
M4 | An edit made via Configuration as Code (the CLI or Admin Console), by pushing CaC resources that update an entity or modify a file in the admin console |
Employee [ID] on behalf of User [ID] (TemplateServer:applyTemplate) |
An internal tool used by Yext employees for applying entity templates on a client’s behalf |
SmartLabeler | The backend system that displays which saved filters an entity is part of |
GeocodeServer | The backend system that creates a geocode for an entity based on its address. You will see additional details about the creation of the geocode, similar to this format: (source user id: 12345678, details: PIN_YOUR_BUSINESS) (source user id: 1234, details: Geocode Validation Task) (source user id: 1234, details: Validated from TASKPROCESSING) |
TimezoneServer | The backend system that assigns a time zone to an entity based on its address and/or geocode |
ListingsProfileUpdaterMessageHandler | The backend system for monitoring a listing’s Google Place ID. If a new Google Place ID is found for a listing during the scanning process, Yext will update the entity in the Knowledge Graph that powers that listing with the new Place ID. |
match set change | The backend system that monitors the Facebook listing being synced to. This indicates when a new Facebook match is pulled in for a listing. |
profile pic fetch for partner 559 due to linkage change | Specific events related to the “match set change” actor details. If a new Facebook match is pulled in for a listing, the following fields may be updated on the corresponding entity in the Knowledge Graph: Facebook cover photo, Facebook page URL, Facebook profile photos. |
Bing (approved by [insert publisher name] ) |
A user approved a suggestion from some other publisher, coming from Bing |
EntityTypeUpdateHandler | The backend system that handles converting entity types. If an entity is changed from one type to another, this system will make the change from one type to another. |
EntityReferenceUpdater | The backend system that handles updates for entity references. If a user has a two-way entity relationship set up between Entity A and Entity B, and edits the Description field for Entity A, the same update will be made on Entity B by the EntityReferenceUpdater. |
PurgeReopenDateTask | The backend system for removing holiday hours from entities once they are in the past |
feedback | The backend system that pulls in publisher data for some fields. For example, if an entity in the Knowledge Graph does not have a profile picture specified, and it then syncs to a Facebook listing for the first time, this system will populate the profile picture on the entity with the profile picture on the Facebook listing. |
IsoRegionServer | The backend system that provides an ISO code for a given location |
Legacy Actor Details
You may see these actor details when reviewing past entity history, but they will not appear on new entity history events moving forward:
Actor Detail | Description |
---|---|
Feed Upload | Legacy name for Entity Upload, prior to 2018 |
Publisher Suggested Edits | Legacy version of publisher suggestions, prior to 2020 |
Limitations
Global
- Entity History is limited to the last three years (1,095 days). Events older than three years are deleted from the history.
- Newly created entities will appear in the Entity History UI with an undefined entity type and an ID of “Value Pending.” It may take up to one hour for these values to sync. Field updates cannot be restored for these entities until these values are resolved.
- It may take up to five minutes for new update logs to appear in Entity History.
UI
- The ability to export logs is not currently supported. Field Updated (Inherited) events cannot be restored.
- Field values cannot be restored on the following fields:
- Country Code
- Coordinates (Display, Dropoff, Pickup, Routable, Walkable)
- Locale
- Any image fields
API
- Field updates cannot be undone or reapplied.