Goals
Goal definitions are managed by the Sitecore.Marketing.Definitions.Goals.GoalDefinitionManager class.
Goals are specialized events. IGoalDefinition inherits IEventDefinition.
Accessing the GoalDefinitionManager
The GoalDefinitionManager is available from the Sitecore DI container. It is preferable to include a parameter of type DefinitionManagerBase<IGoalDefinition, GoalDefinitionRecord> in the constructor of your class and pull your class from the container, allowing the container to resolve the instance for you:
If you cannot use the container to construct your class, you can use the service locator. This class is also available in the Sitecore DI container:
Defining a goal
A goal is defined using types from the Sitecore.Marketing.Definitions.Goals.Model namespace.
Live events
The IsLiveEvent property is part of the base EventDefinition class and is used by Marketing Automation to determine if an event should be processed immediately rather than on session end. Read more about live event processing.
Saving a goal
Once you have defined a goal you may save it by calling the SaveAsync() method on the definition manager.
You can also optionally activate the goal during save by passing true to the second parameter of the SaveAsync() method:
Activating a goal
Goals must be activated before they are available for use outside of management. Goals can be activated when they’re saved by passing true to the activate (second) parameter of the SaveAsync() method:
Goals can also be activated without calling save, using the ActivateAsync() method:
The ActivateAsync() method takes the ID of the goal and does not require the goal definition model.
Deleting a goal
To delete a goal, use the Delete() method on the manager. Individual cultures cannot be deleted from the definition, only the entire definition. The culture provided to the method call should be either null (default value) or CultureInfo.InvariantCulture.
Retrieve a goal
A single goal can be retrieved by it’s ID using one of the Get() methods on the manager.
Retrieve a goal by its alias
You can also retrieve a goal by its alias:
Update an existing goal
To update an existing goal definition, retrieve the goal by ID, edit the goal
Retrieving all goals
The GetAll() method can be used to get all goals from the manager. As there may be a large number of definitions, this method supports paging. The return value is a single page of results.
To access the results, use the DataPage property of the result.
The result also includes properties to expose the total number of definitions and the current page index and page size.